1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759 |
- using Aitex.Core.Common.DeviceData;
- using Aitex.Core.RT.IOCore;
- using Aitex.Core.RT.Log;
- using Aitex.Core.UI.View.Common;
- using MECF.Framework.Common.CommonData;
- using MECF.Framework.Common.DataCenter;
- using MECF.Framework.Common.Equipment;
- using MECF.Framework.Common.OperationCenter;
- using Microsoft.VisualBasic;
- using Newtonsoft.Json;
- using Newtonsoft.Json.Linq;
- using Prism.Commands;
- using Prism.Mvvm;
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.IO;
- using System.Linq;
- using System.Reflection;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Data;
- using System.Windows.Input;
- using System.Windows.Media;
- using System.Xml;
- using Venus_Core;
- using Venus_Core.Attributes;
- using Venus_MainPages.PMs;
- using Venus_MainPages.Unity;
- using Venus_MainPages.Views;
- using Venus_Themes.UserControls;
- using WPF.Themes.UserControls;
- using MessageBox = System.Windows.MessageBox;
- using RecipeStep = Venus_Core.RecipeStep;
- namespace Venus_MainPages.ViewModels
- {
- internal class NewRecipeViewModel : BindableBase
- {
- #region 私有字段
- public string ModuleName = "PMA";
- private string m_CurrentRecipeName;
- private UiRecipeManager m_uiRecipeManager = new UiRecipeManager();
- private NewRecipeView recipeView;
- private TreeView treeViewRcpList;
- private Recipe m_currentRecipe;
- private string m_recipeType;
- private bool firstLoad = true;
- private WrapPanel headWrapPanel;
- private int copyIndex = -1;
- private List<string> EPDCfgList = new List<string>();
- private EPDType currentEPDType = EPDType.None;
- private JetChamber currentChamber;
- private bool isInstalledEPD;
- private bool m_IsFrozen;
- private bool m_PMAIsInstalled;
- private bool m_PMBIsInstalled;
- private bool m_PMCIsInstalled;
- private bool m_PMDIsInstalled;
- private readonly List<string> moduleList = new List<string>();
- TreeViewFileItem selectedItem;
- private string typeFolder = "";
- private bool m_HeadExpand = true;
- private Grid leftGrid;
- private Grid rightGrid;
- private readonly int controlHeight = 24;
- private readonly string tolerancePath = "_Tolerance_EAP";
- private readonly string eapPath = "_EAP";
- #endregion
- #region 属性
- public bool HeadExpand
- {
- get { return m_HeadExpand; }
- set { SetProperty(ref m_HeadExpand, value); }
- }
- public string CurrentRecipeName
- {
- get { return m_CurrentRecipeName; }
- set { SetProperty(ref m_CurrentRecipeName, value); }
- }
- public Recipe CurrentRecipe
- {
- get { return m_currentRecipe; }
- set
- {
- m_currentRecipe = value;
- RecipeType = m_currentRecipe?.Header?.Type.ToString();
- }
- }
- public string RecipeType
- {
- get { return m_recipeType; }
- set { SetProperty(ref m_recipeType, value); }
- }
- public bool IsFrozen
- {
- get { return m_IsFrozen; }
- set { SetProperty(ref m_IsFrozen, value); }
- }
- public bool PMAIsInstalled
- {
- get { return m_PMAIsInstalled; }
- set { SetProperty(ref m_PMAIsInstalled, value); }
- }
- public bool PMBIsInstalled
- {
- get { return m_PMBIsInstalled; }
- set { SetProperty(ref m_PMBIsInstalled, value); }
- }
- public bool PMCIsInstalled
- {
- get { return m_PMCIsInstalled; }
- set { SetProperty(ref m_PMCIsInstalled, value); }
- }
- public bool PMDIsInstalled
- {
- get { return m_PMDIsInstalled; }
- set { SetProperty(ref m_PMDIsInstalled, value); }
- }
- #endregion
- #region 命令
- private DelegateCommand<Object> _MouseRightButtonDownCommand;
- public DelegateCommand<Object> MouseRightButtonDownCommand =>
- _MouseRightButtonDownCommand ?? (_MouseRightButtonDownCommand = new DelegateCommand<Object>(OnMouseRightButtonDown));
- private DelegateCommand<Object> _LoadedCommand;
- public DelegateCommand<Object> LoadedCommand =>
- _LoadedCommand ?? (_LoadedCommand = new DelegateCommand<Object>(OnLoaded));
- private DelegateCommand _SaveRecipeCommand;
- public DelegateCommand SaveRecipeCommand =>
- _SaveRecipeCommand ?? (_SaveRecipeCommand = new DelegateCommand(OnSaveRecipe));
- private DelegateCommand<object> _SaveToRecipeCommand;
- public DelegateCommand<object> SaveToRecipeCommand =>
- _SaveToRecipeCommand ?? (_SaveToRecipeCommand = new DelegateCommand<object>(OnSaveToRecipe));
- private DelegateCommand _AddStepCommand;
- public DelegateCommand AddStepCommand =>
- _AddStepCommand ?? (_AddStepCommand = new DelegateCommand(OnAddStep));
- private DelegateCommand _DeleteStepCommand;
- public DelegateCommand DeleteStepCommand =>
- _DeleteStepCommand ?? (_DeleteStepCommand = new DelegateCommand(OnDeleteStep));
- private DelegateCommand _RefreshCommand;
- public DelegateCommand RefreshCommand =>
- _RefreshCommand ?? (_RefreshCommand = new DelegateCommand(OnRefresh));
- private DelegateCommand _ExpandCommand;
- public DelegateCommand ExpandCommand =>
- _ExpandCommand ?? (_ExpandCommand = new DelegateCommand(OnExpand));
- private DelegateCommand _UnloadCommand;
- public DelegateCommand UnloadCommand =>
- _UnloadCommand ?? (_UnloadCommand = new DelegateCommand(OnUnload));
- private DelegateCommand _ClearRecipeCommand;
- public DelegateCommand ClearRecipeCommand =>
- _ClearRecipeCommand ?? (_ClearRecipeCommand = new DelegateCommand(OnClearRecipe));
- private DelegateCommand<Object> _MouseLeftButtonDownCommand;
- public DelegateCommand<Object> MouseLeftButtonDownCommand =>
- _MouseLeftButtonDownCommand ?? (_MouseLeftButtonDownCommand = new DelegateCommand<Object>(OnMouseLeftButtonDown));
- #endregion
- #region 命令方法
- private void OnAddStep()
- {
- if (CurrentRecipe != null && IsFrozen == false)
- {
- var index = rightGrid.ColumnDefinitions.Count;
- RecipeStep recipeStep;
- if (copyIndex == -1)
- {
- recipeStep = new RecipeStep();
- recipeStep.StepNo = index + 1;
- recipeStep.LstUnit = RecipeUnity.GetAllUnits(currentChamber, CurrentRecipe.Header.Type);
- CurrentRecipe.Steps.Add(recipeStep);
- }
- else
- {
- var t = JsonConvert.SerializeObject(CurrentRecipe);
- recipeStep = Recipe.Load(t).Steps[copyIndex - 1];
- recipeStep.StepNo = index + 1;
- CurrentRecipe.Steps.Add(recipeStep);
- }
- ColumnDefinition col1 = new ColumnDefinition();
- col1.Width = GridLength.Auto;
- rightGrid.ColumnDefinitions.Insert(index, col1);
- RecipeStepToGridColumn(recipeStep, rightGrid, index);
- }
- }
- private void OnDeleteStep()
- {
- if (CurrentRecipe != null && IsFrozen == false)
- {
- OnDeleteStep(CurrentRecipe.Steps.Count - 1);
- }
- }
- private void OnSaveRecipe()
- {
- if (WPFMessageBox.ShowQuestion($"Save recipe file?", "") == MessageBoxResult.Yes)
- {
- var inLP1UseRecipe = QueryDataClient.Instance.Service.GetData($"Scheduler.LP1.InUsingRecipe");
- var inLP2UseRecipe = QueryDataClient.Instance.Service.GetData($"Scheduler.LP2.InUsingRecipe");
- var inLP3UseRecipe = QueryDataClient.Instance.Service.GetData($"Scheduler.LP3.InUsingRecipe");
- if (inLP1UseRecipe != null)
- {
- if ((inLP1UseRecipe as List<string>).Contains($"{ModuleName}.{CurrentRecipe.Header.Type}.{CurrentRecipeName}"))
- {
- WPFMessageBox.ShowError($"{CurrentRecipeName} Recipe is LP1 In Use,can not edit");
- return;
- }
- }
- if (inLP2UseRecipe != null)
- {
- if ((inLP2UseRecipe as List<string>).Contains($"{ModuleName}.{CurrentRecipe.Header.Type}.{CurrentRecipeName}"))
- {
- WPFMessageBox.ShowError($"{CurrentRecipeName} Recipe is LP2 In Use,can not edit");
- return;
- }
- }
- if (inLP3UseRecipe != null)
- {
- if ((inLP3UseRecipe as List<string>).Contains($"{ModuleName}.{CurrentRecipe.Header.Type}.{CurrentRecipeName}"))
- {
- WPFMessageBox.ShowError($"{CurrentRecipeName} Recipe is LP3 In Use,can not edit");
- return;
- }
- }
- CurrentRecipe.Header.EditTime = DateTime.Now.ToString();
- CurrentRecipe.Header.LastModifiedBy = GlobalUser.Instance.User.Name;
- //SaveRecipe(CurrentRecipeName, RecipeUnity.RecipeToString(CurrentRecipe));
- var newrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, typeFolder, CurrentRecipeName + ".rcp");
- FileInfo fi = new FileInfo(newrecipePath);
- var di = fi.Directory;
- if (!di.Exists)
- {
- di.Create();
- }
- //File.WriteAllText(newrecipePath, RecipeUnity.RecipeToString(CurrentRecipe),Encoding.UTF8);
- string recipeContent = RecipeUnity.RecipeToString(CurrentRecipe);
- SaveRecipe(CurrentRecipe.Header.Name, CurrentRecipe.Header.Type.ToString(), recipeContent);
- //LoadHeadWrapPanel(headWrapPanel, CurrentRecipe);
- SaveEAPRecipe(recipeContent, CurrentRecipeName);
- }
- }
- private void OnSaveToRecipe(object obj)
- {
- if (CurrentRecipe == null)
- {
- return;
- }
- string moduleName = "";
- switch (obj.ToString())
- {
- case "0":
- moduleName = "PMA";
- break;
- case "1":
- moduleName = "PMB";
- break;
- case "2":
- moduleName = "PMC";
- break;
- case "3":
- moduleName = "PMD";
- break;
- case "4":
- moduleName = "ALL";
- break;
- }
- if (moduleName == "")
- {
- return;
- }
- if (moduleName == "ALL")
- {
- var newName = Interaction.InputBox(" ", $"Save Recipe To All", CurrentRecipeName, -1, -1);
- OnSaveRecipe();
- foreach (var x in moduleList)
- {
- if (newName != "")
- {
- var targetChamber = (JetChamber)Enum.Parse(typeof(JetChamber), QueryDataClient.Instance.Service.GetConfig($"{x}.ChamberType").ToString());
- if (currentChamber != targetChamber || x == ModuleName)
- {
- continue;
- }
- var newRecipe = CurrentRecipe;
- newRecipe.Header.Name = newName;
- newRecipe.Header.CreateTime = DateTime.Now.ToString();
- var newrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", x, typeFolder, newName + ".rcp");
- FileInfo fi = new FileInfo(newrecipePath);
- var di = fi.Directory;
- if (!di.Exists)
- {
- di.Create();
- }
- //File.WriteAllText(newrecipePath, RecipeUnity.RecipeToString(newRecipe));
- if (m_uiRecipeManager.SaveAsRecipeWithType(x, CurrentRecipe.Header.Type.ToString(), newName, RecipeUnity.RecipeToString(newRecipe)))
- {
- UpdateRecipeFileList();
- }
- UpdateRecipeFileList();
- }
- }
- }
- else
- {
- var targetChamber = (JetChamber)Enum.Parse(typeof(JetChamber), QueryDataClient.Instance.Service.GetConfig($"{moduleName}.ChamberType").ToString());
- if (currentChamber != targetChamber)
- {
- WPFMessageBox.ShowError($"Recipe can not from {currentChamber.ToString()} copy to {targetChamber.ToString()}");
- return;
- }
- var newName = Interaction.InputBox(" ", $"Save Recipe To {moduleName}", CurrentRecipeName, -1, -1);
- if (newName != "")
- {
- OnSaveRecipe();
- var newRecipe = CurrentRecipe;
- newRecipe.Header.Name = newName;
- newRecipe.Header.CreateTime = DateTime.Now.ToString();
- var newrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", moduleName, typeFolder, newName + ".rcp");
- FileInfo fi = new FileInfo(newrecipePath);
- var di = fi.Directory;
- if (!di.Exists)
- {
- di.Create();
- }
- //File.WriteAllText(newrecipePath, RecipeUnity.RecipeToString(newRecipe));
- if (m_uiRecipeManager.SaveAsRecipeWithType(moduleName, CurrentRecipe.Header.Type.ToString(), newName, RecipeUnity.RecipeToString(newRecipe)))
- {
- UpdateRecipeFileList();
- }
- //if (SaveAsRecipeWithType(newName, CurrentRecipe.Header.Type.ToString(), RecipeUnity.RecipeToString(newRecipe)))
- //{
- //}
- }
- }
- }
- private async void OnLoaded(Object myrecipeView)
- {
- if (firstLoad == true)
- {
- currentChamber = (JetChamber)Enum.Parse(typeof(JetChamber), QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.ChamberType").ToString());
- if (currentChamber != JetChamber.Kepler2200A && currentChamber != JetChamber.Kepler2200B)
- {
- isInstalledEPD = bool.Parse(QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.EPD.IsEnabled").ToString());
- }
- firstLoad = false;
- recipeView = myrecipeView as NewRecipeView;
- treeViewRcpList = recipeView.treeViewRcpList;
- headWrapPanel = recipeView.headWrapPanel;
- //bodyStackPanel = recipeView.bodyStackPanel;
- leftGrid = recipeView.leftGrid;
- rightGrid = recipeView.rightGrid;
- UpdateRecipeFileList();
- treeViewRcpList.SelectedItemChanged += TreeViewRcpList_SelectedItemChanged;
- string allModules = QueryDataClient.Instance.Service.GetConfig($"System.InstalledModules").ToString();
- if (allModules.Contains("PMA"))
- {
- PMAIsInstalled = true;
- moduleList.Add("PMA");
- }
- if (allModules.Contains("PMB"))
- {
- PMBIsInstalled = true;
- moduleList.Add("PMB");
- }
- if (allModules.Contains("PMC"))
- {
- PMCIsInstalled = true;
- moduleList.Add("PMC");
- }
- if (allModules.Contains("PMD"))
- {
- PMDIsInstalled = true;
- moduleList.Add("PMD");
- }
- }
- if (isInstalledEPD)
- {
- for (int i = 0; i < 5; i++)
- {
- InvokeClient.Instance.Service.DoOperation($"{ModuleName}.EndPoint.SearchCfg");
- await Task.Delay(200);
- currentEPDType = (EPDType)System.Convert.ToInt32(QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.EPD.EPDType"));
- if (currentEPDType == EPDType.Socket)
- {
- EPDCfgList = (List<string>)QueryDataClient.Instance.Service.GetData($"{ModuleName}.EPDCfgList");
- }
- if (EPDCfgList != null)
- {
- EPDCfgList.Add("");
- break;
- }
- }
- }
- UpdateRecipeFileList();
- }
- private void TreeViewRcpList_SelectedItemChanged(object sender, RoutedPropertyChangedEventArgs<object> e)
- {
- //rightGrid.Visibility = Visibility.Visible;
- selectedItem = e.NewValue as TreeViewFileItem;
- if (selectedItem == null)
- return;
- try
- {
- string[] info = selectedItem.FileName.Split('\\');
- //string path;
- string xmlRecipeData = "";
- if (info.Length == 1)
- {
- CurrentRecipeName = info[0];
- typeFolder = "";
- string path = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, $"{CurrentRecipeName}.rcp");
- xmlRecipeData = m_uiRecipeManager.LoadRecipeByPath(path);
- }
- else if (info.Length == 2)
- {
- string type = info[0];
- typeFolder = type;
- CurrentRecipeName = info[1];
- string path = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, type, $"{CurrentRecipeName}.rcp");
- xmlRecipeData = m_uiRecipeManager.LoadRecipeByPath(path);
- }
- else
- {
- return;
- }
- if (xmlRecipeData == "")
- {
- treeViewRcpList.Items.Remove(selectedItem);
- return;
- }
- CurrentRecipe = Recipe.Load(xmlRecipeData);
- if (CurrentRecipe.Header.ChamberType != currentChamber)
- {
- WPFMessageBox.ShowError($"Can not Open {CurrentRecipe.Header.ChamberType} Recipe in {currentChamber} Chamber,please delete it.");
- return;
- }
- LoadHeadWrapPanel(headWrapPanel, CurrentRecipe);
- LoadRecipe(CurrentRecipe);
- }
- catch (Exception ex)
- {
- WPFMessageBox.ShowError(ex.ToString());
- //MessageBox.Show(string.Format(Application.Current.Resources["GlobalLableTitleRecipeEditor"].ToString(), ex.Message), Application.Current.Resources["GlobalLableTitleRecipeEditor"].ToString(), MessageBoxButton.OK, MessageBoxImage.Error);
- }
- e.Handled = true;
- }
- public bool SaveRecipe(string recipeName, string type, string recipeContent)
- {
- return m_uiRecipeManager.SaveRecipeWithType(ModuleName, type, recipeName, recipeContent);
- }
- private void OnMouseRightButtonDown(Object treeView)
- {
- //treeViewRcpList = treeView as TreeView;
- treeViewRcpList.ContextMenu = new ContextMenu() { Background = new SolidColorBrush(Colors.AliceBlue) };
- MenuItem menuItem = new MenuItem();
- menuItem = new MenuItem();
- menuItem.Tag = "\\";
- menuItem.Click += new RoutedEventHandler(menuItem_MouseClick_CreateRecipe);
- menuItem.Header = "New Recipe";
- treeViewRcpList.ContextMenu.Items.Add(menuItem);
- menuItem = new MenuItem();
- menuItem.Tag = "\\";
- menuItem.Click += new RoutedEventHandler(menuItem_MouseClick_DeleteRecipe);
- menuItem.Header = "Delete Recipe";
- treeViewRcpList.ContextMenu.Items.Add(menuItem);
- menuItem = new MenuItem();
- menuItem.Tag = "\\";
- menuItem.Click += new RoutedEventHandler(menuItem_MouseClick_SaveAsRecipe);
- menuItem.Header = "Save As Recipe";
- treeViewRcpList.ContextMenu.Items.Add(menuItem);
- menuItem = new MenuItem();
- menuItem.Tag = "\\";
- menuItem.Click += new RoutedEventHandler(menuItem_MouseClick_RenameRecipe);
- menuItem.Header = "Rename";
- treeViewRcpList.ContextMenu.Items.Add(menuItem);
- treeViewRcpList.ContextMenu.Visibility = Visibility.Visible;
- }
- private void OnMouseLeftButtonDown(Object treeView)
- {
- //treeViewRcpList = treeView as TreeView;
- }
- private void menuItem_MouseClick_CreateRecipe(object sender, RoutedEventArgs e)
- {
- //MenuItem mit = sender as MenuItem;
- //string folderName = mit.Tag as string;
- PerformCreateRecipe();
- }
- private void PerformCreateRecipe()
- {
- try
- {
- bool hasHV = false;
- if (currentChamber == JetChamber.VenusSE || currentChamber == JetChamber.VenusDE)
- {
- hasHV = true;
- }
- RecipeNameInputDlg dlg = new RecipeNameInputDlg("Input Recipe Name", hasHV)
- {
- Owner = Application.Current.MainWindow
- };
- if (dlg.ShowDialog() == true)
- {
- var recipeName = dlg.InputText;
- //var recipeName = folderName + dlg.InputText;
- //var recipeName = folderName + "\\" + dlg.InputText;
- if (!RecipeNameIsOk(recipeName))
- {
- return;
- }
- RecipeType type = (RecipeType)Enum.Parse(typeof(RecipeType), dlg.SelectedType);
- //typeFolder=type.ToString();
- string newRecipe = RecipeUnity.CreateRecipe(currentChamber, type, dlg.InputText, GlobalUser.Instance.User.Name);
- if (SaveAsRecipeWithType(recipeName, type.ToString(), newRecipe))
- {
- UpdateRecipeFileList();
- }
- //SaveEAPRecipe(newRecipe,recipeName);
- }
- }
- catch (Exception ex)
- {
- LOG.WriteExeption(ex);
- WPFMessageBox.ShowError(ex.ToString());
- //MessageBox.Show(string.Format(Application.Current.Resources["GlobalLableMsgRecipeCreateException"].ToString(), ex.Message), Application.Current.Resources["GlobalLableTitleRecipeEditor"].ToString(), MessageBoxButton.OK, MessageBoxImage.Error);
- }
- }
- private void menuItem_MouseClick_DeleteRecipe(object sender, RoutedEventArgs e)
- {
- //if (CurrentRecipe == null)
- //{
- // return;
- //}
- if (WPFMessageBox.ShowQuestion($"Delete {typeFolder}Recipe {CurrentRecipeName}?", "删除后无法恢复!!!") == MessageBoxResult.Yes)
- {
- //MenuItem mit = sender as MenuItem;
- //string recipename = mit.Header.ToString();
- string path = typeFolder == "" ? CurrentRecipeName : $"{typeFolder}\\{CurrentRecipeName}";
- m_uiRecipeManager.DeleteRecipe(ModuleName, path);
- DeleteEAPRecipe();
- DeleteToleranceRecipe();
- //PerformCreateRecipe(folderName);
- //treeViewRcpList.Items.Remove(selectedItem);
- UpdateRecipeFileList();
- }
- }
- private void menuItem_MouseClick_SaveAsRecipe(object sender, RoutedEventArgs e)
- {
- if (CurrentRecipe == null)
- {
- return;
- }
- var newName = Interaction.InputBox(" ", "Save As Recipe", CurrentRecipeName, -1, -1);
- if (!RecipeNameIsOk(newName))
- {
- return;
- }
- //newName = newName.Trim();
- if (newName != CurrentRecipeName && newName != "")
- {
- var newRecipe = CurrentRecipe;
- if (WPFMessageBox.ShowQuestion($"Save recipe file {newName} ?", "") == MessageBoxResult.Yes)
- {
- //MessageBox.Show($"Save as recipe {newName} ?", "Save As Recipe", MessageBoxButton.OKCancel, MessageBoxImage.Warning);
- newRecipe.Header.Name = newName;
- newRecipe.Header.CreateTime = DateTime.Now.ToString();
- //var newrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, typeFolder, newName + ".rcp");
- //File.WriteAllText(newrecipePath, RecipeUnity.RecipeToString(newRecipe));
- if (SaveAsRecipeWithType(newName, CurrentRecipe.Header.Type.ToString(), RecipeUnity.RecipeToString(newRecipe)))
- {
- UpdateRecipeFileList();
- CurrentRecipeName = newName;
- //LoadHeadWrapPanel(headWrapPanel, CurrentRecipe);
- LoadRecipe(CurrentRecipe);
- }
- }
- }
- else if (newName == CurrentRecipeName || newName == "")
- {
- WPFMessageBox.Show("Please input right recipename", MessageBoxButton.OK);
- }
- }
- private void menuItem_MouseClick_RenameRecipe(object sender, RoutedEventArgs e)
- {
- if (CurrentRecipe == null)
- {
- return;
- }
- var newName = Interaction.InputBox(" ", "Rename Recipe", CurrentRecipeName, -1, -1);
- //newName = newName.Trim();
- if (!RecipeNameIsOk(newName))
- {
- return;
- }
- if (newName != CurrentRecipeName && newName != "")
- {
- var newRecipe = CurrentRecipe;
- if (WPFMessageBox.ShowQuestion($"Save recipe file {newName} ?", "") == MessageBoxResult.Yes)
- {
- newRecipe.Header.Name = newName;
- newRecipe.Header.CreateTime = DateTime.Now.ToString();
- var oldrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, typeFolder, CurrentRecipeName + ".rcp");
- var newrecipePath = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, typeFolder, newName + ".rcp");
- File.Delete(oldrecipePath);
- File.WriteAllText(newrecipePath, RecipeUnity.RecipeToString(newRecipe));
- UpdateRecipeFileList();
- }
- }
- else if (newName == CurrentRecipeName || newName == "")
- {
- WPFMessageBox.Show("Please input right recipename", MessageBoxButton.OK);
- }
- }
- public bool SaveAsRecipeWithType(string recipeName, string type, string recipeContent)
- {
- return m_uiRecipeManager.SaveAsRecipeWithType(ModuleName, type, recipeName, recipeContent);
- }
- public string GetXmlRecipeList()
- {
- return m_uiRecipeManager.GetXmlRecipeList(ModuleName, true) ?? "";
- }
- void CreateTreeViewItems(XmlElement curElementNode, ItemsControl itemsControl)
- {
- foreach (XmlElement ele in curElementNode.ChildNodes)
- {
- if (ele.Name == "File")
- {
- string fileName = ele.Attributes["Name"].Value;
- fileName = fileName.Substring(fileName.LastIndexOf('\\') + 1);
- TreeViewFileItem item = new TreeViewFileItem(ele.Attributes["Name"].Value);
- item.Tag = ele.Attributes["Name"].Value;
- if (!item.Tag.ToString().Contains("\\"))
- {
- continue;
- }
- itemsControl.Items.Add(item);
- }
- else if (ele.Name == "Folder")
- {
- string folderName = ele.Attributes["Name"].Value;
- folderName = folderName.Substring(folderName.LastIndexOf('\\') + 1);
- if (folderName == Venus_Core.RecipeType.Process.ToString() || folderName == Venus_Core.RecipeType.Clean.ToString() || folderName == Venus_Core.RecipeType.Chuck.ToString() || folderName == Venus_Core.RecipeType.DeChuck.ToString())
- {
- TreeViewFolderItem item = new TreeViewFolderItem(folderName);
- item.Tag = ele.Attributes["Name"].Value;
- CreateTreeViewItems(ele, item);
- item.IsExpanded = false;
- itemsControl.Items.Add(item);
- }
- }
- }
- }
- private IEnumerable<string> GetFilesNames(string path)
- {
- if (Directory.Exists(path))
- {
- return Directory.GetFiles(path, "*.rcp")?
- .Select(Path.GetFileNameWithoutExtension);
- }
- else
- {
- return new List<string>();
- }
- }
- private void LoadHeadWrapPanel(WrapPanel HeadWrapPanel, Recipe recipe)
- {
- HeadWrapPanel.Children.Clear();
- Type type = recipe.Header.GetType();
- foreach (var propertyInfo in type.GetProperties())
- {
- TextBlock textBlock = new TextBlock();
- textBlock.FontSize = 16;
- textBlock.Margin = new Thickness(0, 20, 0, 0);
- textBlock.Width = 200;
- switch (propertyInfo.Name)
- {
- case "ChuckRecipe":
- if (currentChamber != JetChamber.VenusSE && currentChamber != JetChamber.VenusDE)
- {
- continue;
- }
- textBlock.Text = "Chuck:";
- break;
- case "DechuckRecipe":
- if (currentChamber != JetChamber.VenusSE && currentChamber != JetChamber.VenusDE)
- {
- continue;
- }
- textBlock.Text = "DeChuck:";
- break;
- case "WallTemperature":
- if (currentChamber != JetChamber.VenusSE && currentChamber != JetChamber.VenusDE)
- {
- continue;
- }
- break;
- case "BiasRFHoldTime":
- if (currentChamber != JetChamber.VenusSE && currentChamber != JetChamber.VenusDE && currentChamber != JetChamber.Kepler2300)
- {
- continue;
- }
- break;
- default:
- object[] NameAttrs = propertyInfo.GetCustomAttributes(typeof(CustomName), true);
- string name;
- if (NameAttrs.Length > 0)
- {
- name = (NameAttrs[0] as CustomName).Name;
- }
- else
- {
- name = propertyInfo.Name;
- }
- textBlock.Text = name + ":";
- break;
- }
- textBlock.Margin = new Thickness(15, 0, 0, 0);
- textBlock.VerticalAlignment = VerticalAlignment.Center;
- HeadWrapPanel.Children.Add(textBlock);
- Binding binding = new Binding()
- {
- Source = recipe.Header, // 数据源
- Path = new PropertyPath(propertyInfo.Name), // 需绑定的数据源属性名
- Mode = BindingMode.TwoWay, // 绑定模式
- UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged, //触发器
- };
- var propertyTypeName = propertyInfo.PropertyType.Name;
- var propertyInfoName = propertyInfo.Name;
- Control control = new Control();
- switch (propertyInfoName)
- {
- //case "ChamberType":
- // control = new ComboBox();
- // control.IsEnabled = false;
- // //control.Height = 23;
- // control.SetBinding(ComboBox.SelectedItemProperty, binding);
- // control.Style = (Style)recipeView.FindResource("customeComboBoxStyle");
- // ItemsControlHelper.SetEnumValuesToItemsSource(control, true);
- // break;
- //case "Type":
- // ComboBox cb = new ComboBox();
- // cb.Style = (Style)recipeView.FindResource("customeComboBoxStyle");
- // cb.IsEnabled = false;
- // cb.SelectionChanged += ChangeUI;
- // control = cb;
- // //control.Height = 23;
- // ItemsControlHelper.SetEnumValuesToItemsSource(control, true);
- // control.SetBinding(ComboBox.SelectedItemProperty, binding);
- // break;
- case "ChuckRecipe":
- StringBuilder stringBuilder = new StringBuilder();
- control = new ComboBox()
- {
- ItemsSource = GetFilesNames(Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", $"{ModuleName}\\Chuck"))
- };
- //control.Height = 23;
- control.MinWidth = 100;
- control.MaxWidth = 300;
- control.SetBinding(ComboBox.SelectedItemProperty, binding);
- control.PreviewMouseLeftButtonDown += ChuckControl_PreviewMouseLeftButtonDown;
- break;
- case "DechuckRecipe":
- //if (currentChamber != JetChamber.Venus)
- //{
- // continue;
- //}
- //string[] dechucklist = new string[] { "" };
- //ArrayList dearrayList = new ArrayList(dechucklist.ToList());
- //IEnumerable<string> delist = GetFilesNames(Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName)).ToList().Where(item => item.ToLower().Contains("dechuck"));
- //foreach (var i in delist)
- //{
- // dearrayList.Add(i);
- //}
- //dechucklist = (string[])dearrayList.ToArray(typeof(string));
- //StringBuilder destringBuilder = new StringBuilder();
- //for (int i = 0; i < dechucklist.Length; i++)
- //{
- // destringBuilder.Append(dechucklist[i] + "\t");
- //}
- control = new ComboBox()
- {
- ItemsSource = GetFilesNames(Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", $"{ModuleName}\\DeChuck"))
- };
- //control.Height = 23;
- control.MinWidth = 100;
- control.MaxWidth = 300;
- control.SetBinding(ComboBox.SelectedItemProperty, binding);
- control.PreviewMouseLeftButtonDown += DechuckControl_PreviewMouseLeftButtonDown;
- break;
- case "IsShowTolerance":
- control = new CheckBox();
- control.SetBinding(CheckBox.IsCheckedProperty, binding);
- control.Style = null;
- control.VerticalAlignment = VerticalAlignment.Center;
- (control as CheckBox).Checked += RecipeViewModel_Checked;
- (control as CheckBox).Unchecked += RecipeViewModel_Checked;
- break;
- default:
- control = new TextBox();
- control.Margin = new Thickness(1, 0, 0, 0);
- control.BorderThickness = new Thickness(0, 0, 0, 1);
- control.BorderBrush = Brushes.White;
- control.FontSize = 15;
- control.Foreground = Brushes.Green;
- control.Background = Brushes.Transparent;
- control.VerticalAlignment = VerticalAlignment.Center;
- control.MinWidth = 15;
- control.SetBinding(TextBox.TextProperty, binding);
- object[] objAttrs = propertyInfo.GetCustomAttributes(typeof(IsOnlyReadAttribute), true);
- if (objAttrs.Length > 0)
- {
- (control as TextBox).IsReadOnly = true;
- }
- break;
- }
- control.Margin = new Thickness(20, 3, 0, 7);
- control.Width = 250;
- HeadWrapPanel.Children.Add(control);
- }
- }
- private void RecipeViewModel_Checked(object sender, RoutedEventArgs e)
- {
- LoadRecipe(CurrentRecipe, false);
- }
- private void ChuckControl_PreviewMouseLeftButtonDown(object sender, MouseButtonEventArgs e)
- {
- var items = GetFilesNames(Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", $"{ModuleName}\\Chuck")).ToList();
- items.Add("");
- (sender as ComboBox).ItemsSource = items;
- }
- private void DechuckControl_PreviewMouseLeftButtonDown(object sender, MouseButtonEventArgs e)
- {
- var items = GetFilesNames(Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", $"{ModuleName}\\DeChuck")).ToList();
- items.Add("");
- (sender as ComboBox).ItemsSource = items;
- }
- private void ChangeUI(object sender, SelectionChangedEventArgs e)
- {
- var t = sender as ComboBox;
- if (t.SelectedValue.ToString() != "Process")
- {
- headWrapPanel.Children[8].Visibility = Visibility.Collapsed;
- headWrapPanel.Children[9].Visibility = Visibility.Collapsed;
- headWrapPanel.Children[10].Visibility = Visibility.Collapsed;
- headWrapPanel.Children[11].Visibility = Visibility.Collapsed;
- }
- else
- {
- headWrapPanel.Children[8].Visibility = Visibility.Visible;
- headWrapPanel.Children[9].Visibility = Visibility.Visible;
- headWrapPanel.Children[10].Visibility = Visibility.Visible;
- headWrapPanel.Children[11].Visibility = Visibility.Visible;
- }
- }
- private void MenuItemLeftInsert_Click(object sender, RoutedEventArgs e)
- {
- var t = ((sender as MenuItem).Parent as ContextMenu).PlacementTarget as TextBox;
- int insertIndex = Convert.ToInt32(t.Text) - 1;
- RecipeStep recipeStep;
- if (copyIndex == -1)
- {
- recipeStep = new RecipeStep();
- recipeStep.LstUnit = RecipeUnity.GetAllUnits(currentChamber, CurrentRecipe.Header.Type);
- CurrentRecipe.Steps.Insert(insertIndex, recipeStep);
- }
- else
- {
- var t1 = JsonConvert.SerializeObject(CurrentRecipe);
- recipeStep = Recipe.Load(t1).Steps[copyIndex - 1];
- CurrentRecipe.Steps.Insert(insertIndex, recipeStep);
- }
- for (int i = 0; i < CurrentRecipe.Steps.Count; i++)
- {
- CurrentRecipe.Steps[i].StepNo = i + 1;
- }
- ColumnDefinition col1 = new ColumnDefinition();
- col1.Width = GridLength.Auto;
- rightGrid.ColumnDefinitions.Add(col1);
- for (int i = 0; i < rightGrid.Children.Count; i++)
- {
- if (Grid.GetColumn(rightGrid.Children[i]) >= insertIndex)
- {
- Grid.SetColumn(rightGrid.Children[i], Grid.GetColumn(rightGrid.Children[i]) + 1);
- }
- }
- RecipeStepToGridColumn(recipeStep, rightGrid, insertIndex);
- }
- private void MenuItemRightInsert_Click(object sender, RoutedEventArgs e)
- {
- var t = ((sender as MenuItem).Parent as ContextMenu).PlacementTarget as TextBox;
- int insertIndex = Convert.ToInt32(t.Text);
- RecipeStep recipeStep;
- if (copyIndex == -1)
- {
- recipeStep = new RecipeStep();
- recipeStep.LstUnit = RecipeUnity.GetAllUnits(currentChamber, CurrentRecipe.Header.Type);
- CurrentRecipe.Steps.Insert(insertIndex, recipeStep);
- }
- else
- {
- var t1 = JsonConvert.SerializeObject(CurrentRecipe);
- recipeStep = Recipe.Load(t1).Steps[copyIndex - 1];
- CurrentRecipe.Steps.Insert(insertIndex, recipeStep);
- }
- for (int i = 0; i < CurrentRecipe.Steps.Count; i++)
- {
- CurrentRecipe.Steps[i].StepNo = i + 1;
- }
- ColumnDefinition col1 = new ColumnDefinition();
- col1.Width = GridLength.Auto;
- rightGrid.ColumnDefinitions.Add(col1);
- for (int i = 0; i < rightGrid.Children.Count; i++)
- {
- if (Grid.GetColumn(rightGrid.Children[i]) >= insertIndex)
- {
- Grid.SetColumn(rightGrid.Children[i], Grid.GetColumn(rightGrid.Children[i]) + 1);
- }
- }
- RecipeStepToGridColumn(recipeStep, rightGrid, insertIndex);
- }
- private void MenuItemDelete_Click(object sender, RoutedEventArgs e)
- {
- var t = ((sender as MenuItem).Parent as ContextMenu).PlacementTarget as TextBox;
- int deleteIndex = Convert.ToInt32(t.Text) - 1;
- CurrentRecipe.Steps.RemoveAt(deleteIndex);
- for (int i = 0; i < CurrentRecipe.Steps.Count; i++)
- {
- CurrentRecipe.Steps[i].StepNo = i + 1;
- }
- RemoveColumnFromGrid(rightGrid, deleteIndex);
- rightGrid.ColumnDefinitions.RemoveAt(deleteIndex);
- for (int i = 0; i < rightGrid.Children.Count; i++)
- {
- if (Grid.GetColumn(rightGrid.Children[i]) >= deleteIndex)
- {
- Grid.SetColumn(rightGrid.Children[i], Grid.GetColumn(rightGrid.Children[i]) - 1);
- }
- }
- }
- private void MenuItemCopy_Click(object sender, RoutedEventArgs e)
- {
- var t = ((sender as MenuItem).Parent as ContextMenu).PlacementTarget as TextBox;
- copyIndex = Convert.ToInt32(t.Text);
- }
- #endregion
- #region 私有方法
- private void RecipeStepToGridColumn(RecipeStep recipeStep, Grid grid, int columnIndex)
- {
- Type recipeType = recipeStep.GetType();
- int rowIndex = 0;
- foreach (PropertyInfo propertyInfo in recipeType.GetProperties())
- {
- string propertyInfoName = propertyInfo.Name;
- string propertyTypeName = propertyInfo.PropertyType.Name;
- if (propertyInfoName != "LstUnit")
- {
- if ((propertyInfoName == "EPDConfig" || propertyInfoName == "MinEndPointTime" || propertyInfoName == "MaxEndPointTime" || propertyInfoName == "OverEtchPercent") && isInstalledEPD == false)
- {
- continue;
- }
- if (columnIndex == 0)
- {
- RowDefinition row1 = new RowDefinition();
- row1.Height = new GridLength(controlHeight);
- grid.RowDefinitions.Add(row1);
- }
- Binding binding = new Binding()
- {
- Source = recipeStep, // 数据源
- Path = new PropertyPath(propertyInfoName), // 需绑定的数据源属性名
- Mode = BindingMode.TwoWay, // 绑定模式
- UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged //触发器
- };
- switch (propertyTypeName)
- {
- case "Int32":
- case "String":
- case "Single":
- case "Double":
- if (propertyInfoName == "EPDConfig")
- {
- if (currentEPDType == EPDType.Socket)
- {
- ComboBox EPDcomboBox = new ComboBox();
- EPDcomboBox.Style = (Style)recipeView.FindResource("customeComboBoxStyle");
- EPDcomboBox.Background = new SolidColorBrush(Colors.Black);
- EPDcomboBox.SetBinding(ComboBox.SelectedItemProperty, binding);
- EPDcomboBox.ItemsSource = EPDCfgList;
- grid.Children.Add(EPDcomboBox);
- Grid.SetRow(EPDcomboBox, rowIndex);
- Grid.SetColumn(EPDcomboBox, columnIndex);
- }
- else if (currentEPDType == EPDType.WCF)
- {
- Button EPDButton = new Button();
- EPDButton.Content = "EndPoint";
- EPDButton.Cursor = Cursors.Hand;
- EPDButton.Tag = $"{CurrentRecipeName}.{(columnIndex).ToString()}";
- EPDButton.Style = null;
- EPDButton.Click += EPDButton_Click;
- grid.Children.Add(EPDButton);
- Grid.SetRow(EPDButton, rowIndex);
- Grid.SetColumn(EPDButton, columnIndex);
- }
- break;
- }
- TextBox textBox = new TextBox();
- textBox.HorizontalContentAlignment = HorizontalAlignment.Center;
- textBox.VerticalContentAlignment = VerticalAlignment.Center;
- textBox.SetBinding(TextBox.TextProperty, binding);
- grid.Children.Add(textBox);
- Grid.SetRow(textBox, rowIndex);
- Grid.SetColumn(textBox, columnIndex);
- object[] objAttrs = propertyInfo.GetCustomAttributes(typeof(IsOnlyReadAttribute), true);
- if (objAttrs.Length > 0)
- {
- textBox.IsReadOnly = true;
- ContextMenu contextmenu = new ContextMenu();
- textBox.ContextMenu = contextmenu;
- MenuItem menuItemDelete = new MenuItem();
- menuItemDelete.Header = "Delete";
- menuItemDelete.Click += MenuItemDelete_Click;
- MenuItem menuItemLeftInsert = new MenuItem();
- menuItemLeftInsert.Header = "Left Insert";
- menuItemLeftInsert.Click += MenuItemLeftInsert_Click;
- MenuItem menuItemRightInsert = new MenuItem();
- menuItemRightInsert.Header = "Right Insert";
- menuItemRightInsert.Click += MenuItemRightInsert_Click;
- MenuItem menuItemCopy = new MenuItem();
- menuItemCopy.Tag = textBox.Text;
- menuItemCopy.Header = "Copy";
- menuItemCopy.Click += MenuItemCopy_Click;
- contextmenu.Items.Add(menuItemCopy);
- contextmenu.Items.Add(menuItemDelete);
- contextmenu.Items.Add(menuItemLeftInsert);
- contextmenu.Items.Add(menuItemRightInsert);
- }
- break;
- case "Boolean":
- CheckBox checkBox = new CheckBox();
- checkBox.SetBinding(CheckBox.IsCheckedProperty, binding);
- grid.Children.Add(checkBox);
- Grid.SetRow(checkBox, rowIndex);
- Grid.SetColumn(checkBox, columnIndex);
- break;
- default:
- ComboBox comboBox = new ComboBox();
- comboBox.Style = (Style)recipeView.FindResource("customeComboBoxStyle");
- comboBox.Background = new SolidColorBrush(Colors.Black);
- comboBox.SetBinding(ComboBox.SelectedItemProperty, binding);
- ItemsControlHelper.SetEnumValuesToItemsSource(comboBox, true);
- grid.Children.Add(comboBox);
- Grid.SetRow(comboBox, rowIndex);
- Grid.SetColumn(comboBox, columnIndex);
- break;
- }
- rowIndex++;
- }
- }
- int unitIndex = 0;
- foreach (var x in recipeStep.LstUnit.ToList())
- {
- Type unitType = x.GetType();
- Binding checkbinding = null;
- foreach (PropertyInfo propertyInfo in unitType.GetProperties())
- {
- object[] IgnoreAttrs = propertyInfo.GetCustomAttributes(typeof(IsCanConfigIgnore), true);
- bool IsEnableRecipeExtension = Convert.ToBoolean(QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.IsEnableRecipeExtension"));
- if (IgnoreAttrs.Length > 0 && IsEnableRecipeExtension == false)
- {
- break;
- }
- object[] toleranceAttrs = propertyInfo.GetCustomAttributes(typeof(IsTolerance), true);
- if (toleranceAttrs.Length > 0 && CurrentRecipe.Header.IsShowTolerance == false)
- {
- continue;
- }
- if (propertyInfo.Name == "UnitName")
- {
- continue;
- }
- if (columnIndex == 0)
- {
- RowDefinition row1 = new RowDefinition();
- row1.Height = new GridLength(controlHeight);
- grid.RowDefinitions.Add(row1);
- }
- Binding binding = new Binding()
- {
- Source = recipeStep.LstUnit[unitIndex], // 数据源
- //Path = new PropertyPath($"LstUnit[{k}]." + propertyInfo.Name), // 需绑定的数据源属性名
- Path = new PropertyPath(propertyInfo.Name), // 需绑定的数据源属性名
- Mode = BindingMode.TwoWay, // 绑定模式
- UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged //触发器
- };
- var item = propertyInfo.PropertyType.Name;
- switch (item)
- {
- case "Int32":
- case "String":
- case "Single":
- case "Double":
- TextBox textBox = new TextBox();
- textBox.HorizontalContentAlignment = HorizontalAlignment.Center;
- textBox.VerticalContentAlignment = VerticalAlignment.Center;
- if (checkbinding == null)
- {
- textBox.IsEnabled = true;
- }
- else
- {
- textBox.SetBinding(TextBox.IsEnabledProperty, checkbinding);
- }
- textBox.SetBinding(TextBox.TextProperty, binding);
- grid.Children.Add(textBox);
- Grid.SetRow(textBox, rowIndex);
- Grid.SetColumn(textBox, columnIndex);
- object[] objAttrs = propertyInfo.GetCustomAttributes(typeof(IsOnlyReadAttribute), true);
- if (objAttrs.Length > 0)
- {
- textBox.IsReadOnly = true;
- }
- break;
- case "Boolean":
- CheckBox checkBox = new CheckBox();
- if (checkbinding == null)
- {
- checkbinding = new Binding
- {
- Source = checkBox, // 数据源
- Path = new PropertyPath("IsChecked"), // 需绑定的数据源属性名
- Mode = BindingMode.TwoWay, // 绑定模式
- UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged //触发器
- };
- }
- checkBox.SetBinding(CheckBox.IsCheckedProperty, binding);
- grid.Children.Add(checkBox);
- Grid.SetRow(checkBox, rowIndex);
- Grid.SetColumn(checkBox, columnIndex);
- break;
- default:
- //if (checkbinding != null)
- //{
- // break;
- //}
- ComboBox comboBox = new ComboBox();
- comboBox.BorderBrush = Brushes.Gray;
- comboBox.Style = (Style)recipeView.FindResource("customeComboBoxStyle");
- if (checkbinding == null)
- {
- comboBox.IsEnabled = true;
- }
- else
- {
- comboBox.SetBinding(TextBox.IsEnabledProperty, checkbinding);
- }
- comboBox.Background = Brushes.White;
- string path = propertyInfo.Name;
- comboBox.SetBinding(ComboBox.SelectedItemProperty, binding);
- ItemsControlHelper.SetEnumValuesToItemsSource(comboBox, true);
- grid.Children.Add(comboBox);
- Grid.SetRow(comboBox, rowIndex);
- Grid.SetColumn(comboBox, columnIndex);
- break;
- }
- rowIndex++;
- }
- unitIndex++;
- }
- }
- private void RecipeStepToGridColumnOnlyTitle(RecipeStep recipeStep, Grid grid)
- {
- Type recipeType = recipeStep.GetType();
- int i = 0;
- ColumnDefinition col1 = new ColumnDefinition();
- grid.ColumnDefinitions.Add(col1);
- foreach (PropertyInfo propertyInfo in recipeType.GetProperties())
- {
- string propertyInfoName = propertyInfo.Name;
- string propertyTypeName = propertyInfo.PropertyType.Name;
- if (propertyInfoName != "LstUnit")
- {
- if ((propertyInfoName == "EPDConfig" || propertyInfoName == "MinEndPointTime" || propertyInfoName == "MaxEndPointTime" || propertyInfoName == "OverEtchPercent") && isInstalledEPD == false)
- {
- continue;
- }
- RowDefinition row1 = new RowDefinition();
- row1.Height = new GridLength(controlHeight);
- grid.RowDefinitions.Add(row1);
- Border border = new Border();
- TextBlock textBlock = new TextBlock();
- textBlock.Padding = new Thickness(5, 3, 0, 0);
- border.Child = textBlock;
- border.BorderBrush = Brushes.Silver;
- border.BorderThickness = new Thickness(1);
- //textBlock.IsReadOnly = true;
- object[] NameAttrs = propertyInfo.GetCustomAttributes(typeof(CustomName), true);
- string name;
- if (NameAttrs.Length > 0)
- {
- name = (NameAttrs[0] as CustomName).Name;
- }
- else
- {
- name = propertyInfo.Name;
- }
- textBlock.Text = name;
- //textBlock.FontSize = 15;
- grid.Children.Add(border);
- border.Background = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FAFAFA"));
- Grid.SetRow(border, i);
- Grid.SetColumn(border, 0);
- i++;
- }
- }
- foreach (var x in recipeStep.LstUnit.ToList())
- {
- Type unitType = x.GetType();
- bool isUnitFirstRow = true;
- foreach (PropertyInfo propertyInfo in unitType.GetProperties())
- {
- object[] IgnoreAttrs = propertyInfo.GetCustomAttributes(typeof(IsCanConfigIgnore), true);
- bool IsEnableRecipeExtension = Convert.ToBoolean(QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.IsEnableRecipeExtension"));
- if (IgnoreAttrs.Length > 0 && IsEnableRecipeExtension == false)
- {
- break;
- }
- object[] toleranceAttrs = propertyInfo.GetCustomAttributes(typeof(IsTolerance), true);
- if (toleranceAttrs.Length > 0 && CurrentRecipe.Header.IsShowTolerance == false)
- {
- continue;
- }
- if (propertyInfo.Name == "UnitName")
- {
- continue;
- }
- //if (propertyInfo.Name.Contains("Gas"))
- //{
- // if (!(bool)QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.MfcGas1.Enable"))
- // {
- // continue;
- // }
- //}
- RowDefinition row1 = new RowDefinition();
- row1.Height = new GridLength(controlHeight);
- grid.RowDefinitions.Add(row1);
- Border border = new Border();
- TextBlock textBlock = new TextBlock();
- //textBlock.Padding = new Thickness(0, 3, 0, 0);
- border.Child = textBlock;
- border.BorderBrush = Brushes.Silver;
- border.BorderThickness = new Thickness(1);
- if (isUnitFirstRow)
- {
- textBlock.FontWeight = FontWeights.Bold;
- textBlock.FontSize = 15;
- isUnitFirstRow = false;
- textBlock.Padding = new Thickness(5, 2, 5, 0);
- }
- else
- {
- textBlock.Padding = new Thickness(5, 3, 5, 0);
- }
- switch (propertyInfo.Name)
- {
- case "Gas1":
- var data1 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas1");
- textBlock.Text = $"{propertyInfo.Name}({data1.DisplayName},{data1.Scale})";
- break;
- case "Gas2":
- var data2 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas2");
- textBlock.Text = $"{propertyInfo.Name}({data2.DisplayName},{data2.Scale})";
- break;
- case "Gas3":
- var data3 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas3");
- textBlock.Text = $"{propertyInfo.Name}({data3.DisplayName},{data3.Scale})";
- break;
- case "Gas4":
- var data4 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas4");
- textBlock.Text = $"{propertyInfo.Name}({data4.DisplayName},{data4.Scale})";
- break;
- case "Gas5":
- var data5 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas5");
- textBlock.Text = $"{propertyInfo.Name}({data5.DisplayName},{data5.Scale})";
- break;
- case "Gas6":
- var data6 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas6");
- textBlock.Text = $"{propertyInfo.Name}({data6.DisplayName},{data6.Scale})";
- break;
- case "Gas7":
- var data7 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas7");
- textBlock.Text = $"{propertyInfo.Name}({data7.DisplayName},{data7.Scale})";
- break;
- case "Gas8":
- var data8 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas8");
- textBlock.Text = $"{propertyInfo.Name}({data8.DisplayName},{data8.Scale})";
- break;
- case "Gas9":
- var data9 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas9");
- textBlock.Text = $"{propertyInfo.Name}({data9.DisplayName},{data9.Scale})";
- break;
- case "Gas10":
- var data10 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas10");
- textBlock.Text = $"{propertyInfo.Name}({data10.DisplayName},{data10.Scale})";
- break;
- case "Gas11":
- var data11 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas11");
- textBlock.Text = $"{propertyInfo.Name}({data11.DisplayName},{data11.Scale})";
- break;
- case "Gas12":
- var data12 = (AITMfcData)QueryDataClient.Instance.Service.GetData($"{ModuleName}.MfcGas12");
- textBlock.Text = $"{propertyInfo.Name}({data12.DisplayName},{data12.Scale})";
- break;
- default:
- object[] NameAttrs = propertyInfo.GetCustomAttributes(typeof(CustomName), true);
- string name;
- if (NameAttrs.Length > 0)
- {
- name = (NameAttrs[0] as CustomName).Name;
- }
- else
- {
- name = propertyInfo.Name;
- }
- textBlock.Text = name;
- break;
- }
- grid.Children.Add(border);
- border.Background = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FAFAFA"));
- Grid.SetRow(border, i);
- Grid.SetColumn(border, 0);
- i++;
- }
- }
- }
- private void EPDButton_Click(object sender, RoutedEventArgs e)
- {
- Button button = sender as Button;
- string para = button.Tag.ToString();
- int stepno = Convert.ToInt32(para.Split('.')[1]) - 1;
- var endpointconfigitem = new MECF.Framework.Common.CommonData.EndPointConfigItem();
- if (CurrentRecipe.Steps[stepno].EPDConfig != null && CurrentRecipe.Steps[stepno].EPDConfig.Length > 20)
- {
- endpointconfigitem.SetValue(CurrentRecipe.Steps[stepno].EPDConfig);
- }
- (new EndPointDlg(para, endpointconfigitem, CurrentRecipe)).ShowDialog();
- }
- private void UpdateRecipeFileList()
- {
- XmlDocument doc = new XmlDocument();
- doc.LoadXml(GetXmlRecipeList());
- treeViewRcpList.Items.Clear();
- CreateTreeViewItems(doc.DocumentElement, this.treeViewRcpList);
- ExpandAllItems(this.treeViewRcpList);
- }
- private void LoadRecipe(Recipe recipe, bool isSaveRecipe = true)
- {
- copyIndex = -1;
- OnClearRecipe();
- CurrentRecipe = recipe;
- RecipeStepToGridColumnOnlyTitle(recipe.Steps[0], leftGrid);
- for (int i = 0; i < recipe.Steps.Count; i++)
- {
- ColumnDefinition col1 = new ColumnDefinition();
- col1.Width = GridLength.Auto;
- rightGrid.ColumnDefinitions.Insert(i, col1);
- RecipeStepToGridColumn(recipe.Steps[i], rightGrid, i);
- }
- string recipeContent = RecipeUnity.RecipeToString(CurrentRecipe);
- if (isSaveRecipe)
- {
- SaveEAPRecipe(recipeContent, CurrentRecipeName);
- }
- }
- private void OnDeleteStep(int index)
- {
- if (CurrentRecipe != null && CurrentRecipe.Steps.Count > 1)
- {
- RemoveColumnFromGrid(rightGrid, index);
- rightGrid.ColumnDefinitions.RemoveAt(index);
- CurrentRecipe.Steps.RemoveAt(index);
- }
- }
- /// <summary>
- /// 删除Grid某列数据
- /// </summary>
- /// <param name="grid"></param>
- /// <param name="column"></param>
- public void RemoveColumnFromGrid(Grid grid, int column)
- {
- List<UIElement> listControl = new List<UIElement>();
- for (int i = 0; i < grid.Children.Count; i++)
- {
- var child = grid.Children[i];
- if (Grid.GetColumn(child) == column)
- {
- listControl.Add(child);
- }
- }
- listControl.ForEach(x =>
- {
- grid.Children.Remove(x);
- });
- }
- private void OnRefresh()
- {
- if (CurrentRecipeName != "")
- {
- string path = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, typeFolder, $"{CurrentRecipeName}.rcp");
- string xmlRecipeData = m_uiRecipeManager.LoadRecipeByPath(path);
- CurrentRecipe = Recipe.Load(xmlRecipeData);
- LoadHeadWrapPanel(headWrapPanel, CurrentRecipe);
- LoadRecipe(CurrentRecipe);
- }
- }
- private void OnExpand()
- {
- HeadExpand = !HeadExpand;
- if (HeadExpand)
- {
- recipeView.expandGrid.Width = 300;
- }
- else
- {
- recipeView.expandGrid.Width = 30;
- }
- }
- private void OnUnload()
- {
- //if (CurrentRecipeName == null || CurrentRecipeName == "")
- //{
- // return;
- //}
- //if (WPFMessageBox.ShowQuestion($"Is Save Recipe {CurrentRecipeName}", "", false) == MessageBoxResult.Yes)
- //{
- // OnSaveRecipe();
- //}
- }
- private void OnClearRecipe()
- {
- for (int i = 0; i < rightGrid.ColumnDefinitions.Count; i++)
- {
- rightGrid.ColumnDefinitions[i].Width = new GridLength(75);
- }
- leftGrid.Children.Clear();
- rightGrid.Children.Clear();
- leftGrid.ColumnDefinitions.Clear();
- rightGrid.ColumnDefinitions.Clear();
- rightGrid.RowDefinitions.Clear();
- leftGrid.RowDefinitions.Clear();
- GC.Collect(); // This should pick up the control removed at a previous MouseDown
- GC.WaitForPendingFinalizers(); // Doesn't help either
- //rightGrid.Visibility = Visibility.Visible;
- }
- private void ExpandAllItems(ItemsControl control)
- {
- if (control == null)
- {
- return;
- }
- foreach (Object item in control.Items)
- {
- System.Windows.Controls.TreeViewItem treeItem = control.ItemContainerGenerator.ContainerFromItem(item) as TreeViewItem;
- if (treeItem == null || !treeItem.HasItems)
- {
- continue;
- }
- treeItem.IsExpanded = true;
- ExpandAllItems(treeItem as ItemsControl);
- }
- }
- private bool RecipeNameIsOk(string recipeName)
- {
- if (recipeName.Contains(' '))
- {
- WPFMessageBox.ShowError("Recipe Name 包含空格,不符合规格");
- return false;
- }
- if (recipeName.Length > 25)
- {
- WPFMessageBox.ShowError("Recipe Name 大于25个字符,不符合规格");
- return false;
- }
- return true;
- }
- private void SaveEAPRecipe(string recipeContent, string recipeName)
- {
- if (currentChamber == JetChamber.Kepler2200A || currentChamber == JetChamber.Kepler2200B)
- {
- var newrecipePath2 = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, $"{typeFolder}{eapPath}", recipeName + ".rcp");
- var currentRecipe = Recipe.Load(recipeContent);
- FileInfo fi2 = new FileInfo(newrecipePath2);
- var di2 = fi2.Directory;
- if (!di2.Exists)
- {
- di2.Create();
- }
- var newContent = Recipe.ShowEAPRecipe(recipeContent, currentRecipe.Steps);
- File.WriteAllText(newrecipePath2, newContent, Encoding.UTF8);
- var newrecipePath3 = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, $"{typeFolder}{tolerancePath}", recipeName + ".rcp");
- FileInfo fi3 = new FileInfo(newrecipePath3);
- var di3 = fi3.Directory;
- if (!di3.Exists)
- {
- di3.Create();
- }
- var newContent3 = Recipe.ShowToleranceRecipe(recipeContent, currentRecipe.Steps);
- File.WriteAllText(newrecipePath3, newContent3, Encoding.UTF8);
- }
- }
- private bool DeleteEAPRecipe()
- {
- var path = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, $"{typeFolder}{eapPath}", CurrentRecipeName + ".rcp");
- if (File.Exists(path))
- {
- File.Delete(path);
- }
- var path2 = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "Recipes", ModuleName, $"{typeFolder}{tolerancePath}", CurrentRecipeName + ".rcp");
- if (File.Exists(path))
- {
- File.Delete(path2);
- }
- return true;
- }
- private bool DeleteToleranceRecipe()
- {
- return true;
- }
- #endregion
- }
- }
|