123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935 |
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Linq;
- using System.Windows;
- using System.Windows.Controls;
- using System.Xml;
- using Caliburn.Micro;
- using Caliburn.Micro.Core;
- using OpenSEMI.ClientBase;
- using RecipeEditorLib.DGExtension.CustomColumn;
- using RecipeEditorLib.RecipeModel.Params;
- using MECF.Framework.Common.RecipeCenter;
- using VirgoUI.Client.Dialog;
- using MECF.Framework.Common.Equipment;
- using OpenSEMI.ClientBase.Command;
- using System.Windows.Input;
- using System.Windows.Media;
- using MECF.Framework.Common.DataCenter;
- using VirgoUI.Client.Models.Operate;
- namespace VirgoUI.Client.Models.Recipe.Sequence
- {
- public class SequenceViewModel : BaseModel
- {
- private int MenuPermission;
- public ObservableCollection<FileNode> Files { get; set; }
- private EfemType _efemType = EfemType.FutureEfem;
- private bool _enableThickness = true;
- public Visibility ThicknessVisibility
- {
- get { return (_efemType == EfemType.JetEfem && _enableThickness) ? Visibility.Visible : Visibility.Collapsed; }
- }
- protected override void OnInitialize()
- {
- base.OnInitialize();
- this.CurrentSequence = new SequenceData();
- this.Columns = this.columnBuilder.Build();
- this.editMode = EditMode.None;
- this.IsSavedDesc = true;
- List<string> names = this.provider.GetSequences();
- this.Files = new ObservableCollection<FileNode>(RecipeSequenceTreeBuilder.GetFiles(names));
- this.CurrentFileNode = this.Files[0];
-
- this.SelectDefault(this.CurrentFileNode);
- }
- protected override void OnActivate()
- {
- MenuPermission = ClientApp.Instance.GetPermission("Sequence");
- _efemType = (int)QueryDataClient.Instance.Service.GetConfig("EFEM.EfemType") == 1 ? EfemType.FutureEfem : EfemType.JetEfem;
- _enableThickness = (bool)QueryDataClient.Instance.Service.GetConfig("System.WaferThickness.EnableThickness");
- NotifyOfPropertyChange(nameof(ThicknessVisibility));
- base.OnActivate();
- }
- protected override void OnDeactivate(bool close)
- {
- base.OnDeactivate(close);
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- this.SaveSequence();
- }
- }
- protected override void OnViewLoaded(object view)
- {
- base.OnViewLoaded(view);
- SequenceColumnBuilder.ApplyTemplate((UserControl)view, this.Columns);
- SequenceView u = (SequenceView)view;
- this.Columns.Apply((c) =>
- {
- c.Header = c;
- u.dgCustom.Columns.Add(c);
- });
- u.dgCustom.ItemsSource = CurrentSequence.Steps;
- this.UpdateView();
- }
- #region Sequence selection
- public void TreeSelectChanged(FileNode file)
- {
- if (file.IsFile)
- {
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- {
- this.Save(this.CurrentSequence);
- }
- }
- this.LoadData(file.FullPath);
- }
- else
- {
- this.ClearData();
- this.editMode = EditMode.None;
- }
- this.UpdateView();
- this.CurrentFileNode = file;
- }
- private TreeViewItem GetParentObjectEx<TreeViewItem>(DependencyObject obj) where TreeViewItem : FrameworkElement
- {
- DependencyObject parent = VisualTreeHelper.GetParent(obj);
- while (parent != null)
- {
- if (parent is TreeViewItem)
- {
- return (TreeViewItem)parent;
- }
- parent = VisualTreeHelper.GetParent(parent);
- }
- return null;
- }
- public void TreeRightMouseDown(MouseButtonEventArgs e)
- {
- var item = GetParentObjectEx<TreeViewItem>(e.OriginalSource as DependencyObject) as TreeViewItem;
- if (item != null)
- {
- item.Focus();
- }
- }
- #endregion
- private ICommand _NotImplementCommand;
- public ICommand NotImplementCommand
- {
- get
- {
- if (this._NotImplementCommand == null)
- this._NotImplementCommand = new BaseCommand(() => this.NotImplement());
- return this._NotImplementCommand;
- }
- }
- public void NotImplement()
- {
- MessageBox.Show("Not Implement");
- }
- #region Sequence operation
- private ICommand _NewFolderCommand;
- public ICommand NewFolderCommand
- {
- get
- {
- if (this._NewFolderCommand == null)
- this._NewFolderCommand = new BaseCommand(() => this.NewFolder());
- return this._NewFolderCommand;
- }
- }
- public void NewFolder()
- {
- if (!this.CurrentFileNode.IsFile)
- {
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("Input Folder Name");
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- string fullpath = (this.CurrentFileNode.FullPath == "" ? dialog.DialogResult : this.CurrentFileNode.FullPath + "\\" + dialog.DialogResult);
- if (this.provider.CreateSequenceFolder(fullpath))
- {
- FileNode folder = new FileNode();
- folder.Name = dialog.DialogResult;
- folder.FullPath = fullpath;
- folder.Parent = this.CurrentFileNode;
- this.CurrentFileNode.Files.Add(folder);
- }
- else
- MessageBox.Show("Create folder failed!");
- }
- }
- private ICommand _NewFolderInParentCommand;
- public ICommand NewFolderInParentCommand
- {
- get
- {
- if (this._NewFolderInParentCommand == null)
- this._NewFolderInParentCommand = new BaseCommand(() => this.NewFolderInParent());
- return this._NewFolderInParentCommand;
- }
- }
- public void NewFolderInParent()
- {
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("Input Folder Name");
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- string fullpath = dialog.DialogResult;
- if (this.provider.CreateSequenceFolder(fullpath))
- {
- FileNode folder = new FileNode();
- folder.Name = dialog.DialogResult;
- folder.FullPath = fullpath;
- folder.Parent = this.Files[0];
- this.Files[0].Files.Add(folder);
- }
- else
- MessageBox.Show("Create folder failed!");
- }
- private ICommand _NewSequenceInParentCommand;
- public ICommand NewSequenceInParentCommand
- {
- get
- {
- if (this._NewSequenceInParentCommand == null)
- this._NewSequenceInParentCommand = new BaseCommand(() => this.NewSequenceInParent());
- return this._NewSequenceInParentCommand;
- }
- }
- public void NewSequenceInParent()
- {
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("Input New Sequence Name");
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if ((bool)bret)
- {
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- {
- this.CurrentSequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- this.CurrentSequence.ReviseTime = DateTime.Now;
- this.Save(this.CurrentSequence);
- }
- }
- else
- {
- string fullpath = dialog.DialogResult;
- if (this.IsExist(fullpath))
- {
- MessageBox.Show("Sequence already existed!");
- }
- else
- {
- SequenceData sequence = new SequenceData();
- sequence.Name = fullpath;
- sequence.Creator = BaseApp.Instance.UserContext.LoginName;
- sequence.CreateTime = DateTime.Now;
- sequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- sequence.ReviseTime = DateTime.Now;
- sequence.Description = string.Empty;
- if (this.Save(sequence))
- {
- this.CurrentSequence.Name = sequence.Name;
- this.CurrentSequence.Creator = sequence.Creator;
- this.CurrentSequence.CreateTime = sequence.CreateTime;
- this.CurrentSequence.Revisor = sequence.Revisor;
- this.CurrentSequence.ReviseTime = sequence.ReviseTime;
- this.CurrentSequence.Description = sequence.Description;
- this.CurrentSequence.IsThick = sequence.IsThick;
- this.CurrentSequence.Steps.Clear();
- CurrentSequence.IsChanged = false;
- FileNode file = new FileNode();
- file.Name = dialog.DialogResult;
- file.FullPath = this.CurrentSequence.Name;
- file.IsFile = true;
- file.Parent = this.Files[0];
- this.Files[0].Files.Insert(this.findInsertPosition(this.Files[0].Files), file);
- this.editMode = EditMode.Normal;
- this.UpdateView();
- }
- }
- }
- }
- }
- public int findInsertPosition(ObservableCollection<FileNode> files)
- {
- int pos = -1;
- if (files.Count == 0)
- pos = 0;
- else
- {
- bool foundfolder = false;
- for (var index = 0; index < files.Count; index++)
- {
- if (!files[index].IsFile)
- {
- foundfolder = true;
- pos = index;
- break;
- }
- }
- if (!foundfolder)
- pos = files.Count;
- }
- return pos;
- }
- private ICommand _SaveAsCommand;
- public ICommand SaveAsCommand
- {
- get
- {
- if (this._SaveAsCommand == null)
- this._SaveAsCommand = new BaseCommand(() => this.SaveAsSequence());
- return this._SaveAsCommand;
- }
- }
- public void SaveAsSequence()
- {
- if (this.CurrentFileNode.IsFile)
- {
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("SaveAs Sequence");
- WindowManager wm = new WindowManager();
- dialog.FileName = this.CurrentFileNode.Name;
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- string fullpath = (this.CurrentFileNode.Parent.FullPath == "" ? dialog.DialogResult : this.CurrentFileNode.Parent.FullPath + "\\" + dialog.DialogResult);
- if (this.IsExist(fullpath))
- {
- MessageBox.Show("Sequence already existed!");
- }
- else
- {
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- {
- this.Save(this.CurrentSequence);
- }
- }
- this.CurrentSequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- this.CurrentSequence.ReviseTime = DateTime.Now;
- string tempname = this.CurrentSequence.Name;
- this.CurrentSequence.Name = fullpath;
- if (this.provider.SaveAs(fullpath, this.CurrentSequence))
- {
- FileNode node = new FileNode();
- node.Parent = this.CurrentFileNode.Parent;
- node.Name = dialog.DialogResult;
- node.FullPath = fullpath;
- node.IsFile = true;
- this.CurrentFileNode.Parent.Files.Add(node);
- }
- else
- {
- this.CurrentSequence.Name = tempname;
- MessageBox.Show("SaveAs failed!");
- }
- }
- }
- }
- private ICommand _DeleteFolderCommand;
- public ICommand DeleteFolderCommand
- {
- get
- {
- if (this._DeleteFolderCommand == null)
- this._DeleteFolderCommand = new BaseCommand(() => this.DeleteFolder());
- return this._DeleteFolderCommand;
- }
- }
- public void DeleteFolder()
- {
- if (!this.CurrentFileNode.IsFile && this.CurrentFileNode.FullPath != "")
- {
- if (DialogBox.Confirm("Do you want to delete this folder? this operation will delete all files in this folder."))
- {
- if (this.provider.DeleteSequenceFolder(this.CurrentFileNode.FullPath))
- {
- this.CurrentFileNode.Parent.Files.Remove(this.CurrentFileNode);
- }
- else
- DialogBox.ShowInfo("Delete folder failed!");
- }
- }
- }
- private ICommand _NewSequenceCommand;
- public ICommand NewSequenceCommand
- {
- get
- {
- if (this._NewSequenceCommand == null)
- this._NewSequenceCommand = new BaseCommand(() => this.NewSequence());
- return this._NewSequenceCommand;
- }
- }
- public void NewSequence()
- {
- if (MenuPermission != 3) return;
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("Input New Sequence Name");
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if ((bool)bret)
- {
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- {
- this.CurrentSequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- this.CurrentSequence.ReviseTime = DateTime.Now;
- this.Save(this.CurrentSequence);
- }
- }
- else
- {
- string fullpath = "";
- if (this.CurrentFileNode.IsFile)
- fullpath = (this.CurrentFileNode.Parent.FullPath == "" ? dialog.DialogResult : this.CurrentFileNode.Parent.FullPath + "\\" + dialog.DialogResult);
- else
- fullpath = (this.CurrentFileNode.FullPath == "" ? dialog.DialogResult : this.CurrentFileNode.FullPath + "\\" + dialog.DialogResult);
- if (this.IsExist(fullpath))
- {
- MessageBox.Show("Sequence already existed!");
- }
- else
- {
- SequenceData sequence = new SequenceData();
- sequence.Name = fullpath;
- sequence.Creator = BaseApp.Instance.UserContext.LoginName;
- sequence.CreateTime = DateTime.Now;
- sequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- sequence.ReviseTime = DateTime.Now;
- sequence.Description = string.Empty;
- if (this.Save(sequence))
- {
- this.CurrentSequence.Name = sequence.Name;
- this.CurrentSequence.Creator = sequence.Creator;
- this.CurrentSequence.CreateTime = sequence.CreateTime;
- this.CurrentSequence.Revisor = sequence.Revisor;
- this.CurrentSequence.ReviseTime = sequence.ReviseTime;
- this.CurrentSequence.Description = sequence.Description;
- this.CurrentSequence.Steps.Clear();
- FileNode file = new FileNode();
- file.Name = dialog.DialogResult;
- file.FullPath = this.CurrentSequence.Name;
- file.IsFile = true;
- file.Parent = this.CurrentFileNode.IsFile ? this.CurrentFileNode.Parent : this.CurrentFileNode;
- if (this.CurrentFileNode.IsFile)
- this.CurrentFileNode.Parent.Files.Insert(this.findInsertPosition(this.CurrentFileNode.Parent.Files), file);
- else
- this.CurrentFileNode.Files.Insert(this.findInsertPosition(this.CurrentFileNode.Files), file);
- this.editMode = EditMode.Normal;
- this.UpdateView();
- }
- }
- }
- }
- }
- private ICommand _RenameCommand;
- public ICommand RenameCommand
- {
- get
- {
- if (this._RenameCommand == null)
- this._RenameCommand = new BaseCommand(() => this.RenameSequence());
- return this._RenameCommand;
- }
- }
- public void RenameSequence()
- {
- if (MenuPermission != 3) return;
- if (this.CurrentFileNode.IsFile)
- {
- InputFileNameDialogViewModel dialog = new InputFileNameDialogViewModel("Rename Sequence");
- WindowManager wm = new WindowManager();
- dialog.FileName = this.CurrentFileNode.Name;
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- string fullpath = this.CurrentFileNode.Parent.FullPath == "" ? dialog.DialogResult : this.CurrentFileNode.Parent.FullPath + "\\" + dialog.DialogResult;
- if (this.IsExist(fullpath))
- {
- MessageBox.Show("Sequence already existed!");
- }
- else
- {
- if (this.IsChanged)
- {
- if (MessageBox.Show("This sequence is changed,do you want to save it?", "", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
- {
- this.Save(this.CurrentSequence);
- }
- }
- this.CurrentSequence.Revisor = BaseApp.Instance.UserContext.LoginName;
- this.CurrentSequence.ReviseTime = DateTime.Now;
- if (this.provider.Rename(this.CurrentSequence.Name, fullpath))
- {
- this.CurrentFileNode.Name = dialog.DialogResult;
- this.CurrentFileNode.FullPath = fullpath;
- this.CurrentSequence.Name = fullpath;
- }
- else
- MessageBox.Show("Rename failed!");
- }
- }
- }
- public void SaveSequence()
- {
- if (this.IsChanged)
- {
- this.Save(this.CurrentSequence);
- }
- }
- private ICommand _DeleteCommand;
- public ICommand DeleteSequenceCommand
- {
- get
- {
- if (this._DeleteCommand == null)
- this._DeleteCommand = new BaseCommand(() => this.DeleteSequence());
- return this._DeleteCommand;
- }
- }
- public void DeleteSequence()
- {
- if (MenuPermission != 3) return;
- if (this.CurrentFileNode.IsFile)
- {
- if (DialogBox.Confirm("Do you want to delete this sequence?"))
- {
- if (this.provider.Delete(this.CurrentSequence.Name))
- {
- this.CurrentFileNode.Parent.Files.Remove(this.CurrentFileNode);
- }
- }
- }
- }
- public void ReloadSequence()
- {
- if (MenuPermission != 3) return;
- if (this.editMode == EditMode.Normal || this.editMode == EditMode.Edit)
- {
- this.LoadData(this.CurrentSequence.Name);
- this.UpdateView();
- }
- }
- private bool Save(SequenceData seq)
- {
- if (MenuPermission != 3) return false;
- bool result = false;
- if (string.IsNullOrEmpty(seq.Name))
- {
- MessageBox.Show("Sequence name can't be empty");
- return false;
- }
- string ruleCheckMessage = null;
- if (!ValidateSequenceRules(seq, ref ruleCheckMessage))
- {
- MessageBox.Show(string.Format($"{seq.Name} rules check failed, don't allow to save: {ruleCheckMessage}"));
- return false;
- }
- seq.Revisor = BaseApp.Instance.UserContext.LoginName;
- seq.ReviseTime = DateTime.Now;
- result = this.provider.Save(seq);
- if (result)
- {
- foreach (ObservableCollection<Param> parameters in seq.Steps)
- {
- parameters.Apply(param => param.IsSaved = true);
- }
- this.editMode = EditMode.Normal;
- this.IsSavedDesc = true;
- this.CurrentSequence.IsChanged = false;
- this.NotifyOfPropertyChange("IsSavedDesc");
- this.UpdateView();
- }
- else
- MessageBox.Show("Save failed!");
- return result;
- }
- private bool IsExist(string sequencename)
- {
- bool existed = false;
- FileNode filenode = this.CurrentFileNode.IsFile ? this.CurrentFileNode.Parent : this.CurrentFileNode;
- for (var index = 0; index < filenode.Files.Count; index++)
- {
- if (filenode.Files[index].FullPath.ToLower() == sequencename.ToLower())
- {
- existed = true;
- break;
- }
- }
- return existed;
- }
- private bool ValidateSequenceRules(SequenceData currentSequence, ref string ruleCheckMessage)
- {
- return true;
- }
- #endregion
- #region Steps operation
- public void AddStep()
- {
- if (MenuPermission != 3) return;
- this.CurrentSequence.Steps.Add(CurrentSequence.CreateStep(this.Columns));
- if (this.editMode != EditMode.New && this.editMode != EditMode.ReName)
- this.editMode = EditMode.Edit;
- int index = 1;
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- (parameters[0] as StepParam).Value = index.ToString();
- index++;
- }
- this.UpdateView();
- }
- public void AppendStep()
- {
- if (MenuPermission != 3) return;
- int index = -1;
- bool found = false;
- for (var i = 0; i < this.CurrentSequence.Steps.Count; i++)
- {
- if (this.CurrentSequence.Steps[i][0] is StepParam && ((StepParam)this.CurrentSequence.Steps[i][0]).Checked)
- {
- index = i;
- found = true;
- break;
- }
- }
- if (found)
- {
- if (this.editMode != EditMode.New && this.editMode != EditMode.ReName)
- this.editMode = EditMode.Edit;
- this.CurrentSequence.Steps.Insert(index, this.CurrentSequence.CreateStep(this.Columns));
- index = 1;
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- (parameters[0] as StepParam).Value = index.ToString();
- index++;
- }
- }
- }
- private ObservableCollection<ObservableCollection<Param>> copySteps = new ObservableCollection<ObservableCollection<Param>>();
- public void CopyStep()
- {
- if (MenuPermission != 3) return;
- this.copySteps.Clear();
- for (var i = 0; i < this.CurrentSequence.Steps.Count; i++)
- {
- if (this.CurrentSequence.Steps[i][0] is StepParam && ((StepParam)this.CurrentSequence.Steps[i][0]).Checked)
- {
- this.copySteps.Add(this.CurrentSequence.CloneStep(this.Columns, this.CurrentSequence.Steps[i]));
- }
- }
- }
- public void PasteStep()
- {
- if (MenuPermission != 3) return;
- if (this.copySteps.Count > 0)
- {
- if (this.editMode != EditMode.New && this.editMode != EditMode.ReName)
- this.editMode = EditMode.Edit;
- for (var i = 0; i < this.CurrentSequence.Steps.Count; i++)
- {
- if (this.CurrentSequence.Steps[i][0] is StepParam && ((StepParam)this.CurrentSequence.Steps[i][0]).Checked)
- {
- for (var copyindex = 0; copyindex < this.copySteps.Count; copyindex++)
- {
- this.CurrentSequence.Steps.Insert(i, this.CurrentSequence.CloneStep(this.Columns, this.copySteps[copyindex]));
- i++;
- }
- break;
- }
- }
- int index = 1;
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- (parameters[0] as StepParam).Value = index.ToString();
- index++;
- }
- this.UpdateView();
- }
- }
- public void DeleteStep()
- {
- if (MenuPermission != 3) return;
- if (this.editMode != EditMode.New && this.editMode != EditMode.ReName)
- this.editMode = EditMode.Edit;
- List<ObservableCollection<Param>> steps = this.CurrentSequence.Steps.ToList();
- for (var i = 0; i < steps.Count; i++)
- {
- if (steps[i][0] is StepParam && ((StepParam)steps[i][0]).Checked)
- {
- this.CurrentSequence.Steps.Remove(steps[i]);
- }
- }
- int index = 1;
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- (parameters[0] as StepParam).Value = index.ToString();
- index++;
- }
- }
- public void SelectRecipe(PathFileParam param)
- {
- RecipeSequenceSelectDialogViewModel dialog = new RecipeSequenceSelectDialogViewModel();
- dialog.DisplayName = "Select Recipe";
- ObservableCollection<Param> parameters = param.Parent;
- PositionParam posParam = null;
- for (var index = 0; index < parameters.Count; index++)
- {
- if (parameters[index] is PositionParam)
- {
- posParam = parameters[index] as PositionParam;
- break;
- }
- }
- string module = ModuleName.System.ToString();
- List<string> lstFiles;
-
- if (Enum.TryParse<ModuleName>(posParam.Value, out ModuleName mod))
- module = posParam.Value;
- if (string.IsNullOrEmpty(param.Path))
- {
- lstFiles = RecipeClient.Instance.Service.GetRecipesByPath($"{module}", false).ToList();
- }
- else
- {
- lstFiles = RecipeClient.Instance.Service.GetRecipesByPath($"{param.Path}", false).ToList();
- }
- dialog.Files = new ObservableCollection<FileNode>(RecipeSequenceTreeBuilder.GetFiles(lstFiles));
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if ((bool)bret)
- {
- param.Value = dialog.DialogResult;
- param.IsSaved = false;
- }
- }
- #endregion
- private void SelectDefault(FileNode node)
- {
- if (!node.IsFile)
- {
- if (node.Files.Count > 0)
- {
- foreach (FileNode file in node.Files)
- {
- if (file.IsFile)
- {
- this.TreeSelectChanged(file);
- break;
- }
- }
- }
- }
- }
- private void LoadData(string newSeqName)
- {
- SequenceData Sequence = this.provider.GetSequenceByName(this.Columns, newSeqName);
- this.CurrentSequence.Name = Sequence.Name;
- this.CurrentSequence.Creator = Sequence.Creator;
- this.CurrentSequence.CreateTime = Sequence.CreateTime;
- this.CurrentSequence.Revisor = Sequence.Revisor;
- this.CurrentSequence.ReviseTime = Sequence.ReviseTime;
- this.CurrentSequence.Description = Sequence.Description;
- this.CurrentSequence.IsThick = Sequence.IsThick;
- this.CurrentSequence.IsChanged = false;
- this.CurrentSequence.Steps.Clear();
- Sequence.Steps.ToList().ForEach(step =>
- this.CurrentSequence.Steps.Add(step));
- int index = 1;
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- (parameters[0] as StepParam).Value = index.ToString();
- index++;
- }
- this.IsSavedDesc = true;
- this.NotifyOfPropertyChange("IsSavedDesc");
- this.editMode = EditMode.Normal;
- }
- private void ClearData()
- {
- this.editMode = EditMode.None;
- this.CurrentSequence.Steps.Clear();
- this.CurrentSequence.Name = string.Empty;
- this.CurrentSequence.Description = string.Empty;
- this.CurrentSequence.IsChanged = false;
- this.IsSavedDesc = true;
-
- this.NotifyOfPropertyChange("IsSavedGroup");
- this.NotifyOfPropertyChange("IsSavedDesc");
- }
- public void UpdateView()
- {
- this.EnableSequenceName = false;
- this.NotifyOfPropertyChange("EnableSequenceName");
- this.EnableNew = true;
- this.EnableReName = true;
- this.EnableCopy = true;
- this.EnableDelete = true;
- this.EnableSave = true;
- this.EnableStep = true;
- this.NotifyOfPropertyChange("EnableNew");
- this.NotifyOfPropertyChange("EnableReName");
- this.NotifyOfPropertyChange("EnableCopy");
- this.NotifyOfPropertyChange("EnableDelete");
- this.NotifyOfPropertyChange("EnableSave");
- this.NotifyOfPropertyChange("EnableStep");
- if (this.editMode == EditMode.None)
- {
- this.EnableNew = true;
- this.EnableReName = false;
- this.EnableCopy = false;
- this.EnableDelete = false;
- this.EnableStep = false;
- this.EnableSave = false;
- this.NotifyOfPropertyChange("EnableNew");
- this.NotifyOfPropertyChange("EnableReName");
- this.NotifyOfPropertyChange("EnableCopy");
- this.NotifyOfPropertyChange("EnableDelete");
- this.NotifyOfPropertyChange("EnableSave");
- this.NotifyOfPropertyChange("EnableStep");
- }
- }
- private bool IsChanged
- {
- get
- {
- bool changed = false;
- if (!this.IsSavedDesc || this.editMode == EditMode.Edit || CurrentSequence.IsChanged)
- {
- changed = true;
- }
- else
- {
- foreach (ObservableCollection<Param> parameters in this.CurrentSequence.Steps)
- {
- if (parameters.Where(param => param.IsSaved == false).Count() > 0)
- {
- changed = true;
- break;
- }
- }
- }
- return changed;
- }
- }
- public bool EnableNew { get; set; }
- public bool EnableReName { get; set; }
- public bool EnableCopy { get; set; }
- public bool EnableDelete { get; set; }
- public bool EnableSave { get; set; }
- public bool EnableStep { get; set; }
- public bool IsSavedDesc { get; set; }
- public FileNode CurrentFileNode { get; private set; }
- public SequenceData CurrentSequence { get; private set; }
- public ObservableCollection<ColumnBase> Columns { get; set; }
- public bool EnableSequenceName { get; set; }
- private string selectedSequenceName = string.Empty;
- private string SequenceNameBeforeRename = string.Empty;
- private string lastSequenceName = string.Empty;
- private SequenceColumnBuilder columnBuilder = new SequenceColumnBuilder();
- private EditMode editMode;
- private SequenceDataProvider provider = new SequenceDataProvider();
- }
- }
|