1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049 |
- using Aitex.Core.RT.Log;
- using Caliburn.Micro;
- using FurnaceUI.Client.Dialog;
- using FurnaceUI.Views.Editors;
- using MECF.Framework.Common.CommonData;
- using MECF.Framework.Common.DataCenter;
- using MECF.Framework.UI.Client.CenterViews.Editors;
- using MECF.Framework.UI.Client.CenterViews.Editors.Recipe;
- using MECF.Framework.UI.Client.CenterViews.Editors.Sequence;
- using MECF.Framework.UI.Client.ClientBase;
- using OpenSEMI.ClientBase;
- using RecipeEditorLib.RecipeModel.Params;
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Linq;
- using System.Text.RegularExpressions;
- using System.Windows;
- using System.Windows.Controls;
- using System.Xml;
- namespace FurnaceUI.Views.Recipes
- {
- public class TwoStepDataItem : CompareItem
- {
- public string AStepNumber { get; set; }
- private string _aStepName;
- public string AStepName
- {
- get => _aStepName;
- set
- {
- _aStepName = value;
- InvokePropertyChanged("AStepName");
- }
- }
- public string BStepNumber { get; set; }
- public string BStepName { get; set; }
- }
- public class TwoParamDataItem : CompareItem
- {
- private string _paramName;
- public string ParamName
- {
- get => _paramName;
- set
- {
- _paramName = value;
- InvokePropertyChanged("_paramName");
- }
- }
- private string _aParamValue;
- public string AParamValue
- {
- get => _aParamValue;
- set
- {
- _aParamValue = value;
- InvokePropertyChanged("AParamValue");
- }
- }
- private string _bParamValue;
- public string BParamValue
- {
- get => _bParamValue;
- set
- {
- _bParamValue = value;
- InvokePropertyChanged("BParamValue");
- }
- }
- }
- public class TableDataItem : CompareItem
- {
- public string TableIndex { get; set; }
- public string TableName { get; set; }
- public string EndStatus { get; set; }
- }
- public class TwoTableDataItem : CompareItem
- {
- public int Index { get; set; }
- public string ATableName { get; set; }
- public string BTableName { get; set; }
- }
- public class RecipesCompareTwoViewModel : ModuleUiViewModelBase
- {
- private string _module = "PM1";
- public ObservableCollection<ProcessTypeFileItem> ProcessTypeFileList { get; set; }
- public ObservableCollection<string> ChamberType { get; set; }
- public ObservableCollection<string> RecipeProcessType { get; set; }
- public int ChamberTypeIndexSelection { get; set; }
- public int _processTypeIndexSelection;
- public int ProcessTypeIndexSelection
- {
- get { return _processTypeIndexSelection; }
- set { _processTypeIndexSelection = value; NotifyOfPropertyChange("ProcessTypeIndexSelection"); }
- }
- public string CurrentChamberType
- {
- get
- {
- return ChamberType[ChamberTypeIndexSelection];
- }
- }
- public string SelectedRecipeType { get; set; }
- private string _currentProcessType;
- public string CurrentProcessType
- {
- get
- {
- if (ProcessTypeIndexSelection < 0)
- ProcessTypeIndexSelection = 0;
- if (ProcessTypeFileList.Count == 0)
- return "Process";
- return ProcessTypeFileList[ProcessTypeIndexSelection].ProcessType;
- }
- set { _currentProcessType = CurrentProcessType; NotifyOfPropertyChange("CurrentProcessType"); }
- }
- public ObservableCollection<TwoStepDataItem> StepList { get; set; } = new ObservableCollection<TwoStepDataItem>();
- public ObservableCollection<TwoParamDataItem> ParamList { get; set; } = new ObservableCollection<TwoParamDataItem>();
- //-------------------------A Properties
- public ObservableCollection<StepDataItem> StepListA { get; set; }
- public ObservableCollection<ParamDataItem> ParamListA { get; set; }
- public ObservableCollection<LineDataItem> WholeListA { get; set; }
- public string RecipeA { get; set; }
- private XmlDocument _domA = new XmlDocument();
- private string _pathPrefixA;
- private Dictionary<string, ObservableCollection<ParamDataItem>> _mapStepParamA = new Dictionary<string, ObservableCollection<ParamDataItem>>();
- private Dictionary<TableDataItem, Dictionary<string, ObservableCollection<ParamDataItem>>> _mapTableStepParamA = new Dictionary<TableDataItem, Dictionary<string, ObservableCollection<ParamDataItem>>>();
- private Dictionary<string, LineDataItem> _mapLineTextA = new Dictionary<string, LineDataItem>();
- private List<string> BackInnerXmlTextA = new List<string>();
- private bool _isChangedA { get; set; }
- public bool EnableButtonRemoveA
- {
- get { return !string.IsNullOrEmpty(RecipeA); }
- }
- public bool EnableButtonUndoA
- {
- get { return false; }
- }
- public bool EnableButtonSaveA
- {
- get { return false; }
- }
- private Visibility _paramVisibility;
- public Visibility ParamVisibility
- {
- get => _paramVisibility;
- set
- {
- _paramVisibility = value;
- NotifyOfPropertyChange(nameof(ParamVisibility));
- }
- }
- private TwoStepDataItem _stepSelection;
- public TwoStepDataItem StepSelection
- {
- get
- {
- return _stepSelection;
- }
- set
- {
- if (!BtnTableIsEnabled)
- {
- SyncStepSelection(value);
- }
- else
- {
- SyncTableStepSelection(value);
- }
- SyncShowDiffParams(_isShowDiffParams);
- _stepSelection = value;
- ParamSelection = null;
- NotifyOfPropertyChange(nameof(StepSelection));
- }
- }
- private TwoParamDataItem _paramSelection;
- public TwoParamDataItem ParamSelection
- {
- get
- {
- return _paramSelection;
- }
- set
- {
- _paramSelection = value;
- if (value == null)
- {
- ParamVisibility = Visibility.Hidden;
- }
- else
- {
- ParamVisibility = Visibility.Visible;
- }
- NotifyOfPropertyChange(nameof(ParamSelection));
- }
- }
- //private ParamDataItem _paramSelectionA;
- //public ParamDataItem ParamSelectionA
- //{
- // get
- // {
- // return _paramSelectionA;
- // }
- // set
- // {
- // SyncParamSelection(value, false);
- // _paramSelectionA = value;
- // }
- //}
- private LineDataItem _lineSelectionA;
- public LineDataItem LineSelectionA
- {
- get
- {
- return _lineSelectionA;
- }
- set
- {
- SyncLineSelection(value, false);
- _lineSelectionA = value;
- }
- }
- //-------------------------B Properties-------------------------------------------------------------
- public ObservableCollection<StepDataItem> StepListB { get; set; }
- public ObservableCollection<ParamDataItem> ParamListB { get; set; }
- public ObservableCollection<LineDataItem> WholeListB { get; set; }
- public string RecipeB { get; set; }
- private XmlDocument _domB = new XmlDocument();
- private string _pathPrefixB;
- private Dictionary<string, ObservableCollection<ParamDataItem>> _mapStepParamB = new Dictionary<string, ObservableCollection<ParamDataItem>>();
- private Dictionary<TableDataItem, Dictionary<string, ObservableCollection<ParamDataItem>>> _mapTableStepParamB = new Dictionary<TableDataItem, Dictionary<string, ObservableCollection<ParamDataItem>>>();
- private Dictionary<string, LineDataItem> _mapLineTextB = new Dictionary<string, LineDataItem>();
- private List<string> BackInnerXmlTextB = new List<string>();
- private string BaseTextB = "";
- private bool _isChangedB { get; set; }
- public bool EnableButtonRemoveB
- {
- get { return !string.IsNullOrEmpty(RecipeB); }
- }
- public bool EnableButtonUndoB
- {
- get { return false; }
- }
- public bool EnableButtonSaveB
- {
- get { return false; }
- }
- private ParamDataItem _paramSelectionB;
- public ParamDataItem ParamSelectionB
- {
- get
- {
- return _paramSelectionB;
- }
- set
- {
- SyncParamSelection(value, true);
- _paramSelectionB = value;
- }
- }
- private LineDataItem _lineSelectionB;
- public LineDataItem LineSelectionB
- {
- get
- {
- return _lineSelectionB;
- }
- set
- {
- SyncLineSelection(value, true);
- _lineSelectionB = value;
- }
- }
- private bool _isCurrentSelected = true;
- public bool IsCurrentSelected
- {
- get => _isCurrentSelected;
- set
- {
- _isCurrentSelected = value;
- NotifyOfPropertyChange(nameof(IsCurrentSelected));
- NotifyOfPropertyChange(nameof(ChkboxString));
- }
- }
- public string ChkboxString
- {
- get
- {
- if (_isCurrentSelected)
- {
- return "Current";
- }
- else
- {
- return "History";
- }
- }
- }
- private bool _btnTableIsEnabled = false;
- public bool BtnTableIsEnabled
- {
- get => _btnTableIsEnabled;
- set
- {
- _btnTableIsEnabled = value;
- NotifyOfPropertyChange(nameof(BtnTableIsEnabled));
- }
- }
- private TwoTableDataItem _selectedTwoTableData;
- public TwoTableDataItem SelectedTwoTableData
- {
- get => _selectedTwoTableData;
- set
- {
- _selectedTwoTableData = value;
- NotifyOfPropertyChange(nameof(SelectedTwoTableData));
- }
- }
- Dictionary<int, ObservableCollection<StepDataItem>> tableStepListA = new Dictionary<int, ObservableCollection<StepDataItem>>();
- Dictionary<int, ObservableCollection<StepDataItem>> tableStepListB = new Dictionary<int, ObservableCollection<StepDataItem>>();
- /// <summary>
- /// IsVisibilityEdit
- /// </summary>
- public bool IsVisibilityEdit
- {
- get { return _isVisibilityEdit; }
- set
- {
- _isVisibilityEdit = value;
- NotifyOfPropertyChange(nameof(IsVisibilityEdit));
- }
- }
- private bool _isVisibilityEdit = true;
- public string TimeA
- {
- get { return _timeA; }
- set
- {
- _timeA = value;
- NotifyOfPropertyChange("TimeA");
- }
- }
- private string _timeA = string.Empty;
- public string TimeB
- {
- get { return _timeB; }
- set
- {
- _timeB = value;
- NotifyOfPropertyChange("TimeB");
- }
- }
- private string _timeB = string.Empty;
- public int SelectTableIndex { get; set; } = 1;
- public RecipesCompareTwoViewModel()
- {
- StepListA = new ObservableCollection<StepDataItem>();
- ParamListA = new ObservableCollection<ParamDataItem>();
- WholeListA = new ObservableCollection<LineDataItem>();
- StepListB = new ObservableCollection<StepDataItem>();
- ParamListB = new ObservableCollection<ParamDataItem>();
- WholeListB = new ObservableCollection<LineDataItem>();
- }
- public RecipesCompareTwoViewModel(ShowRecipeHistory showRecipeHistoryA, ShowRecipeHistory showRecipeHistoryB)
- {
- IsVisibilityEdit = false;
- StepListA = new ObservableCollection<StepDataItem>();
- ParamListA = new ObservableCollection<ParamDataItem>();
- WholeListA = new ObservableCollection<LineDataItem>();
- StepListB = new ObservableCollection<StepDataItem>();
- ParamListB = new ObservableCollection<ParamDataItem>();
- WholeListB = new ObservableCollection<LineDataItem>();
- if (showRecipeHistoryA != null && showRecipeHistoryB != null)
- {
- var recipeType = showRecipeHistoryA.Recipe_Type;
- if (!string.IsNullOrEmpty(recipeType))
- {
- if (recipeType.EndsWith("sub") || recipeType.EndsWith("alarm") || recipeType.EndsWith("abort") || recipeType.EndsWith("idle") || recipeType.EndsWith("reset"))
- {
- BtnTableIsEnabled = true;
- }
- else
- {
- BtnTableIsEnabled = false;
- }
- }
- TimeA = showRecipeHistoryA.LastRevisionTime.ToString("yyyy-MM-dd HH:mm:ss");
- TimeB = showRecipeHistoryB.LastRevisionTime.ToString("yyyy-MM-dd HH:mm:ss");
- RecipeA = showRecipeHistoryA.Recipe_Path;
- RecipeB = showRecipeHistoryB.Recipe_Path;
- if (!BtnTableIsEnabled)
- {
- LoadData(showRecipeHistoryA.Recipe_Path, showRecipeHistoryA.recipe_Content, true, true);
- LoadData(showRecipeHistoryB.Recipe_Path, showRecipeHistoryB.recipe_Content, false, true);
- Recompare();
- GetStepList();
- }
- else
- {
- LoadTableData(showRecipeHistoryA.Recipe_Path, showRecipeHistoryA.recipe_Content, true, true);
- LoadTableData(showRecipeHistoryB.Recipe_Path, showRecipeHistoryB.recipe_Content, false, true);
- RecompareTableByName();
- GetTableStepList(true);
- GetTableStepList(false);
- }
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- }
- protected override void OnInitialize()
- {
- base.OnInitialize();
- var chamberType = QueryDataClient.Instance.Service.GetConfig("System.Recipe.SupportedChamberType");
- if (chamberType == null)
- {
- ChamberType = new ObservableCollection<string>() { "Default" };
- }
- else
- {
- ChamberType = new ObservableCollection<string>(((string)(chamberType)).Split(','));
- }
- ChamberTypeIndexSelection = 0;
- //Etch:Process,Clean,Chuck,Dechuck;CVD:Process,Clean;
- //var processType = QueryDataClient.Instance.Service.GetConfig("System.Recipe.SupportedProcessType");
- //if (processType == null)
- //{
- // RecipeProcessType = new ObservableCollection<string>() { "Process" };
- //}
- //else
- //{
- // RecipeProcessType = new ObservableCollection<string>(((string)processType).Split(','));
- //}
- RecipeProcessType = new ObservableCollection<string>();
- var processType = QueryDataClient.Instance.Service.GetConfig("System.CompareRecipeType");
- if (processType != null)
- {
- var sss = ((string)processType).Split(';');
- foreach (var item in sss)
- {
- RecipeProcessType.Add(item);
- }
- }
- ProcessTypeFileList = new ObservableCollection<ProcessTypeFileItem>();
- UpdateProcessTypeFileList();
- }
- protected override void OnActivate()
- {
- base.OnActivate();
- }
- protected override void OnDeactivate(bool close)
- {
- base.OnDeactivate(close);
- }
- protected override void OnViewLoaded(object view)
- {
- base.OnViewLoaded(view);
- if (((RecipesCompareTwoView)view).CboRecipeType.Items.Count > 0)
- {
- ((RecipesCompareTwoView)view).CboRecipeType.SelectedIndex = 0;
- }
- }
- public void SelectChangedRecipeType(SelectionChangedEventArgs eventArgs)
- {
- string recipeType = null;
- recipeType = eventArgs.AddedItems[0].ToString();
- if (recipeType == "sub" || recipeType == "alarm" || recipeType == "abort" || recipeType == "idle" || recipeType == "reset")
- {
- BtnTableIsEnabled = true;
- }
- else
- {
- BtnTableIsEnabled = false;
- }
- }
- public void UpdateProcessTypeFileList()
- {
- ProcessTypeFileList.Clear();
- for (int i = 0; i < RecipeProcessType.Count; i++)
- {
- var type = new ProcessTypeFileItem();
- type.ProcessType = RecipeProcessType[i];
- var prefix = $"{ChamberType[ChamberTypeIndexSelection]}\\{RecipeProcessType[i]}";
- ProcessTypeFileList.Add(type);
- }
- while (ProcessTypeFileList.Count > RecipeProcessType.Count)
- {
- ProcessTypeFileList.RemoveAt(0);
- }
- }
- public void SelectA()
- {
- SelectRecipe(true);
- }
- public void SelectB()
- {
- SelectRecipe(false);
- //if (IsCurrentSelected)
- //{
- // SelectBCurrent();
- //}
- //else
- //{
- // SelectBHistory();
- //}
- }
- public void SelectBHistory()
- {
- // SelectRecipe(false);
- try
- {
- RecipeCompareSelectDialogViewModel dialog = new RecipeCompareSelectDialogViewModel();
- dialog.DisplayName = "Select Recipe";
- SystemName = _module;
- dialog.IsSelectedA = false;
- var recipeProvider = new RecipeProvider();
- dialog.Chambers.Clear();
- recipeProvider.RestoreRecipeFolderList().ForEach(x => dialog.Chambers.Add(x));
- string[] recipeProcessType = null;
- if (string.IsNullOrEmpty(SelectedRecipeType))
- {
- var processType = QueryDataClient.Instance.Service.GetConfig("System.Recipe.SupportedProcessType");
- if (processType == null)
- {
- processType = "Process";
- }
- var ProcessTypeFileList = new ObservableCollection<ProcessTypeFileItem>();
- recipeProcessType = ((string)processType).Split(',');
- }
- else
- {
- recipeProcessType = new string[] { SelectedRecipeType };
- }
- string[] partsType1 = new string[] { };
- string[] partsType2 = new string[] { };
- for (int i = 0; i < recipeProcessType.Length; i++)
- {
- var type = new ProcessTypeFileItem();
- type.ProcessType = recipeProcessType[i];
- var prefix = $"Furnace\\{recipeProcessType[i]}";
- var recipes = recipeProvider.GetXmlRecipeList(prefix, false);
- string[] parts = Regex.Split(recipes, "<");
- if (i == 0)
- {
- partsType1 = parts;
- }
- else if (i == 1)
- {
- partsType2 = parts;
- }
- string recipeChamber;
- recipeChamber = "<" + parts[1];
- foreach (string part in parts)
- {
- if (part.Contains($".{SystemName}"))
- {
- string temp = part.Replace($".{SystemName}", string.Empty);
- recipeChamber += "<" + temp;
- }
- }
- if (parts.Length > 2)
- {
- recipeChamber += "<" + parts[parts.Length - 1];
- }
- type.FileListByProcessType = RecipeSequenceTreeBuilder.BuildFileNode(prefix, "", false, recipeChamber)[0].Files;
- ProcessTypeFileList.Add(type);
- }
- dialog.ProcessTypeFileList = ProcessTypeFileList;
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- _module = dialog.SelectedChamber;
- string suffix = $".{_module}";
- string dialogResult = dialog.DialogResult;
- bool isFullPath = false;
- if (dialogResult.Contains(".rcp"))
- isFullPath = true;
- string recipeName = dialogResult;
- RecipeB = recipeName;
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- if (string.IsNullOrEmpty(RecipeB))
- {
- string[] recipe2 = RecipeB.Split('\\'); string r2 = recipe2[0];
- }
- LoadData(recipeName, false, false, isFullPath);
- Recompare();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- catch (Exception ex)
- {
- throw;
- }
- }
- public void SelectBCurrent()
- {
- try
- {
- RecipeCompareSelectDialogViewModel dialog = new RecipeCompareSelectDialogViewModel();
- dialog.DisplayName = "Select Recipe";
- SystemName = _module;
- var recipeProvider = new RecipeProvider();
- var processType = QueryDataClient.Instance.Service.GetConfig("System.Recipe.SupportedProcessType");
- if (processType == null)
- {
- processType = "Process";
- }
- var ProcessTypeFileList = new ObservableCollection<ProcessTypeFileItem>();
- string[] recipeProcessType = ((string)processType).Split(',');
- string[] partsType1 = new string[] { };
- string[] partsType2 = new string[] { };
- for (int i = 0; i < recipeProcessType.Length; i++)
- {
- var type = new ProcessTypeFileItem();
- type.ProcessType = recipeProcessType[i];
- var prefix = $"Furnace\\{recipeProcessType[i]}";
- type.FileListByProcessType = RecipeSequenceTreeBuilder.GetFileNodeParameterList(prefix);
- ProcessTypeFileList.Add(type);
- }
- dialog.ProcessTypeFileList = ProcessTypeFileList;
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- _module = dialog.SelectedChamber;
- string suffix = $".{_module}";
- string dialogResult = dialog.DialogResult;
- bool isFullPath = false;
- if (dialogResult.Contains(".rcp"))
- isFullPath = true;
- string recipeName = dialogResult;
- RecipeB = recipeName;
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- if (!string.IsNullOrEmpty(RecipeA) && !string.IsNullOrEmpty(RecipeB))
- {
- string[] recipe1 = RecipeA.Split('\\'); string r1 = recipe1[0];
- string[] recipe2 = RecipeB.Split('\\'); string r2 = recipe2[0];
- if (r1 != r2)
- {
- if (MessageBoxResult.Yes != MessageBox.Show($"腔体类型不一致! \n 是否继续比较 ?", "", MessageBoxButton.YesNo, MessageBoxImage.Information))
- {
- RemoveSelectB();
- return;
- }
- }
- }
- LoadData(recipeName, false, true, isFullPath);
- Recompare();
- GetStepList();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- catch (Exception ex)
- {
- LOG.Error(ex.Message);
- }
- }
- private void SelectRecipe(bool isSelectA)
- {
- if (!BtnTableIsEnabled)
- {
- NoTableRecipe(isSelectA);
- }
- else
- {
- TableRecipe(isSelectA);
- }
- }
- private void NoTableRecipe(bool isSelectA)
- {
- try
- {
- RecipeCompareSelectDialogViewModel dialog = new RecipeCompareSelectDialogViewModel();
- dialog.DisplayName = "Select Recipe";
- SystemName = _module;
- var recipeProvider = new RecipeProvider();
- string[] recipeProcessType = null;
- var ProcessTypeFileList = new ObservableCollection<ProcessTypeFileItem>();
- if (string.IsNullOrEmpty(SelectedRecipeType))
- {
- var processType = QueryDataClient.Instance.Service.GetConfig("System.Recipe.SupportedProcessType");
- if (processType == null)
- {
- processType = "Process";
- }
- recipeProcessType = ((string)processType).Split(',');
- }
- else
- {
- recipeProcessType = new string[] { SelectedRecipeType };
- }
- string[] partsType1 = new string[] { };
- string[] partsType2 = new string[] { };
- for (int i = 0; i < recipeProcessType.Length; i++)
- {
- var type = new ProcessTypeFileItem();
- type.ProcessType = recipeProcessType[i];
- var prefix = $"Furnace\\{recipeProcessType[i]}";
- var recipes = recipeProvider.GetXmlRecipeList(prefix, false);
- type.FileListByProcessType = RecipeSequenceTreeBuilder.GetFileNodeParameterList(prefix);
- ProcessTypeFileList.Add(type);
- }
- dialog.ProcessTypeFileList = ProcessTypeFileList;
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- _module = dialog.SelectedChamber;
- string suffix = $".{_module}";
- string dialogResult = dialog.DialogResult;
- bool isFullPath = false;
- if (dialogResult.Contains(".rcp"))
- isFullPath = true;
- string recipeName = dialogResult;
- if (isSelectA)
- {
- RecipeA = recipeName;
- NotifyOfPropertyChange(nameof(RecipeA));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveA));
- }
- else
- {
- RecipeB = recipeName;
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- }
- if (!string.IsNullOrEmpty(RecipeA) && !string.IsNullOrEmpty(RecipeB))
- {
- string[] recipe1 = RecipeA.Split('\\'); string r1 = recipe1[0];
- string[] recipe2 = RecipeB.Split('\\'); string r2 = recipe2[0];
- if (r1 != r2)
- {
- if (MessageBoxResult.Yes != MessageBox.Show($"腔体类型不一致! \n 是否继续比较 ?", "", MessageBoxButton.YesNo, MessageBoxImage.Information))
- {
- RemoveSelectB();
- return;
- }
- }
- }
- LoadData(recipeName, isSelectA, true, isFullPath);
- Recompare();
- GetStepList();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- catch (Exception ex)
- {
- throw;
- }
- }
- private void TableRecipe(bool isSelectA)
- {
- try
- {
- RecipeCompareSelectDialogViewModel dialog = new RecipeCompareSelectDialogViewModel();
- dialog.DisplayName = "Select Recipe";
- SystemName = _module;
- var recipeProvider = new RecipeProvider();
- string recipeProcessType = null;
- var ProcessTypeFileList = new ObservableCollection<ProcessTypeFileItem>();
- if (string.IsNullOrEmpty(SelectedRecipeType))
- {
- //弹出告警消息
- return;
- }
- else
- {
- recipeProcessType = SelectedRecipeType;
- }
- string[] partsType1 = new string[] { };
- string[] partsType2 = new string[] { };
- var type = new ProcessTypeFileItem();
- type.ProcessType = recipeProcessType;
- var prefix = $"Furnace\\{recipeProcessType}";
- var recipes = recipeProvider.GetXmlRecipeList(prefix, false);
- type.FileListByProcessType = RecipeSequenceTreeBuilder.GetFileNodeParameterList(prefix);
- ProcessTypeFileList.Add(type);
- dialog.ProcessTypeFileList = ProcessTypeFileList;
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(dialog);
- if (!(bool)bret)
- return;
- _module = dialog.SelectedChamber;
- string suffix = $".{_module}";
- string dialogResult = dialog.DialogResult;
- bool isFullPath = false;
- if (dialogResult.Contains(".rcp"))
- isFullPath = true;
- string recipeName = dialogResult;
- if (isSelectA)
- {
- RecipeA = recipeName;
- NotifyOfPropertyChange(nameof(RecipeA));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveA));
- }
- else
- {
- RecipeB = recipeName;
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- }
- if (!string.IsNullOrEmpty(RecipeA) && !string.IsNullOrEmpty(RecipeB))
- {
- string[] recipe1 = RecipeA.Split('\\'); string r1 = recipe1[0];
- string[] recipe2 = RecipeB.Split('\\'); string r2 = recipe2[0];
- if (r1 != r2)
- {
- if (MessageBoxResult.Yes != MessageBox.Show($"腔体类型不一致! \n 是否继续比较 ?", "", MessageBoxButton.YesNo, MessageBoxImage.Information))
- {
- RemoveSelectB();
- return;
- }
- }
- }
- LoadTableData(recipeName, isSelectA, true, isFullPath);
- RecompareTableByName();
- GetTableStepList(isSelectA);
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- catch (Exception ex)
- {
- throw;
- }
- }
- public void GetStepList()
- {
- StepList.Clear();
- if (StepListA == null || StepListA.Count == 0)
- {
- if (StepListB == null || StepListB.Count == 0)
- { return; }
- else
- {
- foreach (var item in StepListB)
- {
- var tempStep = new TwoStepDataItem();
- tempStep.BStepNumber = item.StepNumber;
- tempStep.BStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- StepList.Add(tempStep);
- }
- }
- }
- else
- {
- if (StepListB == null || StepListB.Count == 0)
- {
- foreach (var item in StepListA)
- {
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- StepList.Add(tempStep);
- }
- }
- else
- {
- int bIndex = 0;
- int oldIndex = 0;
- foreach (var item in StepListA)
- {
- var tempB = StepListB.FirstOrDefault(x => x.StepName == item.StepName);
- if (tempB != null)
- {
- bIndex = StepListB.IndexOf(tempB);
- if (bIndex != 0 && bIndex != oldIndex + 1)
- {
- for (int i = oldIndex + 1; i < bIndex; i++)
- {
- var bStep = new TwoStepDataItem();
- bStep.AStepNumber = "";
- bStep.AStepName = "";
- bStep.BStepNumber = StepListB[i].StepNumber;
- bStep.BStepName = StepListB[i].StepName;
- bStep.IsDiff = false;
- StepList.Add(bStep);
- }
- }
- if (oldIndex > bIndex)
- {
- var tempStepA = new TwoStepDataItem();
- tempStepA.AStepNumber = item.StepNumber;
- tempStepA.AStepName = item.StepName;
- tempStepA.IsDiff = false;
- StepList.Add(tempStepA);
- continue;
- }
- else
- {
- oldIndex = bIndex;
- }
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.BStepNumber = tempB.StepNumber;
- tempStep.BStepName = tempB.StepName;
- tempStep.IsDiff = tempB.IsDiff;
- StepList.Add(tempStep);
- }
- else
- {
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- tempStep.BStepNumber = "";
- tempStep.BStepName = "";
- StepList.Add(tempStep);
- }
- }
- if (bIndex + 1 < StepListB.Count)
- {
- for (int i = bIndex + 1; i < StepListB.Count; i++)
- {
- var bStep = new TwoStepDataItem();
- bStep.AStepNumber = "";
- bStep.AStepName = "";
- bStep.BStepNumber = StepListB[i].StepNumber;
- bStep.BStepName = StepListB[i].StepName;
- bStep.IsDiff = StepListB[i].IsDiff;
- StepList.Add(bStep);
- }
- }
- }
- }
- }
- public void GetTableStepList(bool isSelectA, int tableInex = 1)
- {
- StepList.Clear();
- TwoTableDataItem tempTable = new TwoTableDataItem();
- tempTable.Index = tableInex;
- var tableA = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == tableInex.ToString());
- if (tableA != null)
- {
- tempTable.ATableName = tableA.TableName;
- }
- var tableB = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == tableInex.ToString());
- if (tableB != null)
- {
- tempTable.BTableName = tableB.TableName;
- }
- if (isSelectA)
- {
- StepListA.Clear();
- if (tableStepListA.Keys.Contains(tableInex))
- {
- (tableStepListA[tableInex].OrderBy(x => int.Parse(x.StepNumber))).ToList().ForEach(x => StepListA.Add(x));
- }
- NotifyOfPropertyChange(nameof(StepListA));
- }
- else
- {
- StepListB.Clear();
- if (tableStepListB.Keys.Contains(tableInex))
- {
- (tableStepListB[tableInex].OrderBy(x => int.Parse(x.StepNumber))).ToList().ForEach(x => StepListB.Add(x));
- }
- NotifyOfPropertyChange(nameof(StepListB));
- }
- if (StepListA == null || StepListA.Count == 0)
- {
- if (StepListB == null || StepListB.Count == 0)
- { return; }
- else
- {
- foreach (var item in StepListB)
- {
- var tempStep = new TwoStepDataItem();
- tempStep.BStepNumber = item.StepNumber;
- tempStep.BStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- StepList.Add(tempStep);
- }
- }
- }
- else
- {
- if (StepListB == null || StepListB.Count == 0)
- {
- foreach (var item in StepListA)
- {
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- StepList.Add(tempStep);
- }
- }
- else
- {
- int bIndex = 0;
- int oldIndex = -1;
- foreach (var item in StepListA)
- {
- var tempB = StepListB.FirstOrDefault(x => x.StepName == item.StepName);
- if (tempB != null)
- {
- bIndex = StepListB.IndexOf(tempB);
- if (bIndex != 0 && bIndex != oldIndex + 1)
- {
- for (int i = oldIndex + 1; i < bIndex; i++)
- {
- var bStep = new TwoStepDataItem();
- bStep.AStepNumber = "";
- bStep.AStepName = "";
- bStep.BStepNumber = StepListB[i].StepNumber;
- bStep.BStepName = StepListB[i].StepName;
- bStep.IsDiff = false;
- StepList.Add(bStep);
- }
- }
- if (oldIndex > bIndex)
- {
- var tempStepA = new TwoStepDataItem();
- tempStepA.AStepNumber = item.StepNumber;
- tempStepA.AStepName = item.StepName;
- tempStepA.IsDiff = false;
- StepList.Add(tempStepA);
- continue;
- }
- else
- {
- oldIndex = bIndex;
- }
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.BStepNumber = tempB.StepNumber;
- tempStep.BStepName = tempB.StepName;
- tempStep.IsDiff = tempB.IsDiff;
- StepList.Add(tempStep);
- }
- else
- {
- var tempStep = new TwoStepDataItem();
- tempStep.AStepNumber = item.StepNumber;
- tempStep.AStepName = item.StepName;
- tempStep.IsDiff = item.IsDiff;
- tempStep.BStepNumber = "";
- tempStep.BStepName = "";
- StepList.Add(tempStep);
- }
- }
- if (bIndex + 1 < StepListB.Count)
- {
- for (int i = bIndex + 1; i < StepListB.Count; i++)
- {
- var bStep = new TwoStepDataItem();
- bStep.AStepNumber = "";
- bStep.AStepName = "";
- bStep.BStepNumber = StepListB[i].StepNumber;
- bStep.BStepName = StepListB[i].StepName;
- bStep.IsDiff = StepListB[i].IsDiff;
- StepList.Add(bStep);
- }
- }
- }
- }
- SelectedTwoTableData = tempTable;
- }
- public void LoadData(string selectedRecipePath, bool isSelectA, bool isCurrent, bool isFullPath)
- {
- var array = selectedRecipePath.Split(new char[] { '\\' });
- string recipeName = array[array.Length - 1];
- XmlDocument doc = isSelectA ? _domA : _domB;
- string prefixPath = (isSelectA ? RecipeA : RecipeB).Replace(recipeName, "");
- var _recipeProvider = new RecipeProvider();
- string recipeContent;
- if (isSelectA)
- {
- recipeContent = isFullPath ? _recipeProvider.LoadRecipeByFullPath(selectedRecipePath) : _recipeProvider.LoadRecipe(prefixPath, recipeName, false);
- }
- else
- {
- if (isCurrent)
- {
- recipeContent = _recipeProvider.LoadRecipe(prefixPath, recipeName);
- }
- else
- {
- recipeContent = _recipeProvider.LoadRestoreRecipe(prefixPath, recipeName);
- }
- }
- if (string.IsNullOrEmpty(recipeContent))
- {
- MessageBox.Show($"{prefixPath}\\{recipeName} is empty, please confirm the file is valid.");
- return;
- }
- if (isSelectA)
- {
- BackInnerXmlTextA.Clear();
- if (BackInnerXmlTextB.Count > 0)
- {
- string dataXml = BackInnerXmlTextB[0];
- BackInnerXmlTextB.Clear();
- BackInnerXmlTextB.Add(dataXml);
- }
- }
- else
- {
- BackInnerXmlTextB.Clear();
- if (BackInnerXmlTextA.Count > 0)
- {
- string dataXml = BackInnerXmlTextA[0];
- BackInnerXmlTextA.Clear();
- BackInnerXmlTextA.Add(dataXml);
- }
- }
- if (isSelectA)
- {
- _pathPrefixA = prefixPath;
- _mapLineTextA = new Dictionary<string, LineDataItem>();
- BackInnerXmlTextA.Add(recipeContent);
- }
- else
- {
- _pathPrefixB = prefixPath;
- _mapLineTextB = new Dictionary<string, LineDataItem>();
- BackInnerXmlTextB.Add(recipeContent);
- }
- LoadrecipeContentData(recipeContent, isSelectA);
- }
- public void LoadData(string path, string content, bool isSelectA, bool isCurrent)
- {
- var array = path.Split(new char[] { '\\' });
- string recipeName = array[array.Length - 1];
- string prefixPath = (isSelectA ? RecipeA : RecipeB).Replace(recipeName, "");
- string recipeContent = content;
- if (string.IsNullOrEmpty(recipeContent))
- {
- MessageBox.Show($"{prefixPath}\\{recipeName} is empty, please confirm the file is valid.");
- return;
- }
- if (isSelectA)
- {
- BackInnerXmlTextA.Clear();
- if (BackInnerXmlTextB.Count > 0)
- {
- string dataXml = BackInnerXmlTextB[0];
- BackInnerXmlTextB.Clear();
- BackInnerXmlTextB.Add(dataXml);
- }
- }
- else
- {
- BackInnerXmlTextB.Clear();
- if (BackInnerXmlTextA.Count > 0)
- {
- string dataXml = BackInnerXmlTextA[0];
- BackInnerXmlTextA.Clear();
- BackInnerXmlTextA.Add(dataXml);
- }
- }
- if (isSelectA)
- {
- _pathPrefixA = prefixPath;
- _mapLineTextA = new Dictionary<string, LineDataItem>();
- BackInnerXmlTextA.Add(recipeContent);
- }
- else
- {
- _pathPrefixB = prefixPath;
- _mapLineTextB = new Dictionary<string, LineDataItem>();
- BackInnerXmlTextB.Add(recipeContent);
- }
- LoadrecipeContentData(recipeContent, isSelectA);
- }
- public void LoadTableData(string selectedRecipePath, bool isSelectA, bool isCurrent, bool isFullPath)
- {
- var array = selectedRecipePath.Split(new char[] { '\\' });
- string recipeName = array[array.Length - 1];
- XmlDocument doc = isSelectA ? _domA : _domB;
- string prefixPath = (isSelectA ? RecipeA : RecipeB).Replace(recipeName, "");
- var _recipeProvider = new RecipeProvider();
- string recipeContent;
- if (isSelectA)
- {
- recipeContent = isFullPath ? _recipeProvider.LoadRecipeByFullPath(selectedRecipePath) : _recipeProvider.LoadRecipe(prefixPath, recipeName, false);
- }
- else
- {
- if (isCurrent)
- {
- recipeContent = _recipeProvider.LoadRecipe(prefixPath, recipeName);
- }
- else
- {
- recipeContent = _recipeProvider.LoadRestoreRecipe(prefixPath, recipeName);
- }
- }
- if (string.IsNullOrEmpty(recipeContent))
- {
- MessageBox.Show($"{prefixPath}\\{recipeName} is empty, please confirm the file is valid.");
- return;
- }
- if (isSelectA)
- {
- _pathPrefixA = prefixPath;
- }
- else
- {
- _pathPrefixB = prefixPath;
- }
- LoadTableRecipeContentData(recipeContent, isSelectA);
- }
- public void LoadTableData(string path, string content, bool isSelectA, bool isCurrent)
- {
- var array = path.Split(new char[] { '\\' });
- string recipeName = array[array.Length - 1];
- string prefixPath = (isSelectA ? RecipeA : RecipeB).Replace(recipeName, "");
- string recipeContent = content;
- if (string.IsNullOrEmpty(recipeContent))
- {
- MessageBox.Show($"{prefixPath}\\{recipeName} is empty, please confirm the file is valid.");
- return;
- }
- if (isSelectA)
- {
- _pathPrefixA = prefixPath;
- }
- else
- {
- _pathPrefixB = prefixPath;
- }
- LoadTableRecipeContentData(recipeContent, isSelectA);
- }
- public void StepGridSelectionChangedA()
- {
- //if (StepSelectionA == null)
- //{
- // ParamListA.Clear();
- // NotifyOfPropertyChange(nameof(ParamListA));
- // return;
- //}
- //if (_mapStepParamA.ContainsKey(StepSelectionA.StepNumber))
- //{
- // ParamListA = _mapStepParamA[StepSelectionA.StepNumber];
- // foreach (ParamDataItem item in ParamListA)
- // {
- // item.IsHidden = (!item.IsDiff && !item.IsExtra && IsShowDiffParams) ? true : false;
- // }
- // NotifyOfPropertyChange(nameof(ParamListA));
- // NotifyOfPropertyChange(nameof(StepSelectionA));
- // StepSelectionA.InvokePropertyChanged();
- //}
- }
- private void LoadrecipeContentData(string recipeContent, bool isSelectA)
- {
- XmlDocument doc = isSelectA ? _domA : _domB;
- if (isSelectA)
- {
- _mapLineTextA = new Dictionary<string, LineDataItem>();
- //BackInnerXmlTextA.Add(recipeContent);
- }
- else
- {
- _mapLineTextB = new Dictionary<string, LineDataItem>();
- //BackInnerXmlTextB.Add(recipeContent);
- }
- string[] allText = recipeContent.Split(new string[] { "\r\n" }, StringSplitOptions.None);
- int number = 0;
- ObservableCollection<LineDataItem> lineData = new ObservableCollection<LineDataItem>();
- foreach (string lineText in allText)
- {
- LineDataItem line = new LineDataItem();
- line.LineNumber = (++number).ToString();
- line.LineText = lineText;
- if (!string.IsNullOrEmpty(lineText))
- {
- lineData.Add(line);
- if (isSelectA)
- {
- _mapLineTextA[line.LineNumber] = line;
- }
- else
- {
- _mapLineTextB[line.LineNumber] = line;
- }
- }
- }
- doc.LoadXml(recipeContent);
- ObservableCollection<StepDataItem> stepData = new ObservableCollection<StepDataItem>();
- XmlNodeList nodeSteps = doc.SelectNodes($"Aitex/TableRecipeData/Module[@Name='PM1']/Step");
- if (nodeSteps == null)
- nodeSteps = doc.SelectNodes($"Aitex/TableRecipeData/Step");
- foreach (XmlNode nodeStep in nodeSteps)
- {
- ObservableCollection<ParamDataItem> paramData = new ObservableCollection<ParamDataItem>();
- StepDataItem step = new StepDataItem();
- foreach (XmlAttribute attr in nodeStep.Attributes)
- {
- if (attr.Name == "StepNo")
- step.StepNumber = attr.Value;
- else if (attr.Name == "Name")
- step.StepName = attr.Value;
- else
- {
- if (!attr.Name.Contains("IsSaved"))
- {
- ParamDataItem param = new ParamDataItem();
- param.ParamName = attr.Name;
- param.ParamValue = attr.Value;
- paramData.Add(param);
- }
- }
- }
- stepData.Add(step);
- if (isSelectA)
- {
- _mapStepParamA[step.StepNumber] = paramData;
- }
- else
- {
- _mapStepParamB[step.StepNumber] = paramData;
- }
- }
- if (isSelectA)
- {
- StepListA = new ObservableCollection<StepDataItem>(stepData.OrderBy(x => int.Parse(x.StepNumber)));
- NotifyOfPropertyChange(nameof(StepListA));
- WholeListA = new ObservableCollection<LineDataItem>(lineData.OrderBy(x => int.Parse(x.LineNumber)));
- NotifyOfPropertyChange(nameof(WholeListA));
- }
- else
- {
- StepListB = new ObservableCollection<StepDataItem>(stepData.OrderBy(x => int.Parse(x.StepNumber)));
- NotifyOfPropertyChange(nameof(StepListB));
- WholeListB = new ObservableCollection<LineDataItem>(lineData.OrderBy(x => int.Parse(x.LineNumber)));
- NotifyOfPropertyChange(nameof(WholeListB));
- }
- }
- private void LoadTableRecipeContentData(string recipeContent, bool isSelectA)
- {
- XmlDocument doc = isSelectA ? _domA : _domB;
- string[] allText = recipeContent.Split(new string[] { "\r\n" }, StringSplitOptions.None);
- int number = 0;
- doc.LoadXml(recipeContent);
- XmlNodeList nodeTables = doc.SelectNodes($"Aitex/TableRecipeData/Tables/Table");
- if (isSelectA)
- {
- tableStepListA.Clear();
- _mapTableStepParamA.Clear();
- }
- else
- {
- tableStepListB.Clear();
- _mapTableStepParamB.Clear();
- }
- foreach (XmlNode nodeTable in nodeTables)
- {
- TableDataItem tableDataItem = new TableDataItem();
- foreach (XmlAttribute attrTable in nodeTable.Attributes)
- {
- switch (attrTable.Name)
- {
- case "Index":
- tableDataItem.TableIndex = attrTable.Value;
- break;
- case "Name":
- tableDataItem.TableName = attrTable.Value;
- break;
- case "EndStatus":
- tableDataItem.EndStatus = attrTable.Value;
- break;
- default:
- break;
- }
- }
- XmlNodeList nodeSteps = nodeTable.SelectNodes("Step");
- ObservableCollection<StepDataItem> stepData = new ObservableCollection<StepDataItem>();
- Dictionary<string, ObservableCollection<ParamDataItem>> _tempMapStepParamA = new Dictionary<string, ObservableCollection<ParamDataItem>>();
- Dictionary<string, ObservableCollection<ParamDataItem>> _tempMapStepParamB = new Dictionary<string, ObservableCollection<ParamDataItem>>();
- foreach (XmlNode nodeStep in nodeSteps)
- {
- ObservableCollection<ParamDataItem> paramData = new ObservableCollection<ParamDataItem>();
- StepDataItem step = new StepDataItem();
- foreach (XmlAttribute attr in nodeStep.Attributes)
- {
- if (attr.Name == "StepNo")
- step.StepNumber = attr.Value;
- else if (attr.Name == "Name")
- step.StepName = attr.Value;
- else
- {
- if (!attr.Name.Contains("IsSaved"))
- {
- ParamDataItem param = new ParamDataItem();
- param.ParamName = attr.Name;
- param.ParamValue = attr.Value;
- paramData.Add(param);
- }
- }
- }
- stepData.Add(step);
- if (isSelectA)
- {
- _mapStepParamA[step.StepNumber] = paramData;
- _tempMapStepParamA[step.StepNumber] = paramData;
- }
- else
- {
- _mapStepParamB[step.StepNumber] = paramData;
- _tempMapStepParamB[step.StepNumber] = paramData;
- }
- }
- if (isSelectA)
- {
- var tableTemp = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == tableDataItem.TableIndex);
- if (tableTemp != null)
- {
- _mapTableStepParamA[tableTemp] = _tempMapStepParamA;
- }
- else
- {
- _mapTableStepParamA.Add(tableDataItem, _tempMapStepParamA);
- }
- int tbIndex = 1;
- int.TryParse(tableDataItem.TableIndex, out tbIndex);
- if (tableStepListA.Keys.Contains(tbIndex))
- {
- tableStepListA[tbIndex] = stepData;
- }
- else
- {
- tableStepListA.Add(tbIndex, stepData);
- }
- }
- else
- {
- var tableTemp = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == tableDataItem.TableIndex);
- if (tableTemp != null)
- {
- _mapTableStepParamB[tableTemp] = _tempMapStepParamB;
- }
- else
- {
- _mapTableStepParamB.Add(tableDataItem, _tempMapStepParamB);
- }
- int tbIndex = 1;
- int.TryParse(tableDataItem.TableIndex, out tbIndex);
- if (tableStepListB.Keys.Contains(tbIndex))
- {
- tableStepListB[tbIndex] = stepData;
- }
- else
- {
- tableStepListB.Add(tbIndex, stepData);
- }
- }
- }
- }
- public void ParamGridSelectionChangedB()
- {
- if (ParamSelectionB == null)
- {
- return;
- }
- NotifyOfPropertyChange(nameof(ParamSelectionB));
- ParamSelectionB.InvokePropertyChanged();
- }
- public void WholeGridSelectionChangedA()
- {
- if (LineSelectionA == null)
- {
- return;
- }
- NotifyOfPropertyChange(nameof(LineSelectionA));
- LineSelectionA.InvokePropertyChanged();
- }
- public void WholeGridSelectionChangedB()
- {
- if (LineSelectionB == null)
- {
- return;
- }
- NotifyOfPropertyChange(nameof(LineSelectionB));
- LineSelectionB.InvokePropertyChanged();
- }
- public void SaveLineA()
- {
- if (LineSelectionA == null)
- return;
- foreach (LineDataItem lineDataItem in WholeListA)
- {
- if (lineDataItem.LineNumber == LineSelectionA.LineNumber)
- {
- lineDataItem.LineText = LineSelectionA.LineText;
- break;
- }
- }
- string recipeContent = "";
- for (int i = 0; i < WholeListA.Count; i++)
- {
- recipeContent += WholeListA[i].LineText + ((i == WholeListB.Count - 1) ? "" : "\r\n");
- }
- CopyToInnerXml(recipeContent, true);
- LoadrecipeContentData(recipeContent, true);
- Recompare();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- public void SaveLineB()
- {
- if (LineSelectionB == null)
- return;
- foreach (LineDataItem lineDataItem in WholeListB)
- {
- if (lineDataItem.LineNumber == LineSelectionB.LineNumber)
- {
- lineDataItem.LineText = LineSelectionB.LineText;
- break;
- }
- }
- string recipeContent = "";
- for (int i = 0; i < WholeListB.Count; i++)
- {
- recipeContent += WholeListB[i].LineText + ((i == WholeListB.Count - 1) ? "" : "\r\n");
- }
- CopyToInnerXml(recipeContent, false);
- LoadrecipeContentData(recipeContent, false);
- Recompare();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- private void Recompare()
- {
- if (IsCompareBySName)
- {
- RecompareStepByName();
- }
- RecompareWhole();
- }
- private void RecompareStepByStep()
- {
- if (StepListA == null || StepListB == null)
- return;
- var stepAMaxNumber = (StepListA == null || StepListA.Count() == 0) ? 0 : StepListA.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- var stepBMaxNumber = (StepListB == null || StepListB.Count() == 0) ? 0 : StepListB.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- int stepMaxNumber = stepAMaxNumber > stepBMaxNumber ? stepAMaxNumber : stepBMaxNumber;
- for (int i = 0; i < stepMaxNumber + 1; i++)
- {
- StepDataItem getStepA = (StepListA == null || StepListA.Count() == 0) ? null : (StepListA.Where(x => x.StepNumber == i.ToString()) == null ? null : StepListA.Where(x => x.StepNumber == i.ToString()).FirstOrDefault());
- StepDataItem getStepB = (StepListB == null || StepListB.Count() == 0) ? null : (StepListB.Where(x => x.StepNumber == i.ToString()) == null ? null : StepListB.Where(x => x.StepNumber == i.ToString()).FirstOrDefault());
- if (getStepA != null && getStepB != null)
- {
- if (getStepA.StepName == getStepB.StepName)
- getStepA.IsDiffName = getStepB.IsDiffName = false;
- else
- getStepA.IsDiffName = getStepB.IsDiffName = true;
- ObservableCollection<ParamDataItem> paramA = _mapStepParamA.ContainsKey(i.ToString()) ? _mapStepParamA[i.ToString()] : null;
- ObservableCollection<ParamDataItem> paramB = _mapStepParamB.ContainsKey(i.ToString()) ? _mapStepParamB[i.ToString()] : null;
- bool isDiff = false;
- bool IsExtra = true;
- if (paramA != null && paramB == null)
- {
- foreach (var pa in paramA)
- {
- pa.IsExtra = true;
- pa.IsDiff = false;
- }
- }
- else if (paramA == null && paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.IsExtra = true;
- pb.IsDiff = false;
- }
- }
- else if (paramA != null && paramB != null)
- {
- foreach (var pa in paramA)
- {
- var getParam = paramB.Where(pb => pb.ParamName == pa.ParamName).FirstOrDefault();
- if (getParam != null)
- {
- pa.IsExtra = false;
- getParam.IsExtra = false;
- getParam.IsDiff = pa.IsDiff = (pa.ParamValue != getParam.ParamValue);
- if (pa.ParamValue != getParam.ParamValue)
- {
- isDiff = true;
- }
- }
- }
- getStepA.IsExtra = getStepB.IsExtra = false;
- }
- if (paramA != null)
- {
- foreach (var pa in paramA)
- {
- pa.InvokePropertyChanged();
- }
- }
- if (paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.InvokePropertyChanged();
- }
- }
- getStepA.IsDiff = getStepB.IsDiff = isDiff;
- getStepA.IsHidden = getStepB.IsHidden = !isDiff && IsShowDiffSteps ? true : false;
- getStepA.InvokePropertyChanged();
- getStepB.InvokePropertyChanged();
- }
- else if (getStepA == null && getStepB != null)
- {
- getStepB.IsExtra = true;
- getStepB.IsDiff = false;
- ObservableCollection<ParamDataItem> paramB = _mapStepParamB.ContainsKey(getStepB.StepNumber) ? _mapStepParamB[getStepB.StepNumber] : null;
- foreach (var pb in paramB)
- {
- pb.IsExtra = false;
- pb.IsDiff = false;
- pb.InvokePropertyChanged();
- }
- getStepB.InvokePropertyChanged();
- continue;
- }
- else if (getStepA != null && getStepB == null)
- {
- getStepA.IsExtra = true;
- getStepA.IsDiff = false;
- ObservableCollection<ParamDataItem> paramA = _mapStepParamA.ContainsKey(getStepA.StepNumber) ? _mapStepParamA[getStepA.StepNumber] : null;
- foreach (var pa in paramA)
- {
- pa.IsExtra = false;
- pa.IsDiff = false;
- pa.InvokePropertyChanged();
- }
- getStepA.InvokePropertyChanged();
- continue;
- }
- else
- {
- continue;
- }
- }
- NotifyOfPropertyChange(nameof(StepListA));
- NotifyOfPropertyChange(nameof(StepListB));
- }
- private void RecompareStepByName()
- {
- if (StepListA == null || StepListB == null)
- return;
- var stepAMaxNumber = (StepListA == null || StepListA.Count() == 0) ? 0 : StepListA.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- var stepBMaxNumber = (StepListB == null || StepListB.Count() == 0) ? 0 : StepListB.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- int stepMaxNumber = stepAMaxNumber > stepBMaxNumber ? stepAMaxNumber : stepBMaxNumber;
- foreach (var getStepA in StepListA)
- {
- StepDataItem getStepB = (StepListB.Where(x => x.StepName == getStepA.StepName) == null ? null : StepListB.Where(x => x.StepName == getStepA.StepName).FirstOrDefault());
- if (getStepB == null)
- {
- getStepA.IsDiff = false;
- getStepA.IsExtra = true;
- continue;
- }
- getStepA.IsDiffName = getStepB.IsDiffName = true;
- ObservableCollection<ParamDataItem> paramA = _mapStepParamA.ContainsKey(getStepA.StepNumber) ? _mapStepParamA[getStepA.StepNumber] : null;
- ObservableCollection<ParamDataItem> paramB = _mapStepParamB.ContainsKey(getStepB.StepNumber) ? _mapStepParamB[getStepB.StepNumber] : null;
- bool isDiff = false;
- bool IsExtra = true;
- if (paramA != null && paramB == null)
- {
- foreach (var pa in paramA)
- {
- pa.IsExtra = true;
- pa.IsDiff = false;
- }
- }
- else if (paramA == null && paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.IsExtra = true;
- pb.IsDiff = false;
- }
- }
- else if (paramA != null && paramB != null)
- {
- foreach (var pa in paramA)
- {
- var getParam = paramB.Where(pb => pb.ParamName == pa.ParamName).FirstOrDefault();
- if (getParam != null)
- {
- pa.IsExtra = false;
- getParam.IsExtra = false;
- getParam.IsDiff = pa.IsDiff = (pa.ParamValue != getParam.ParamValue);
- if (pa.ParamValue != getParam.ParamValue)
- {
- isDiff = true;
- }
- }
- }
- getStepA.IsExtra = getStepB.IsExtra = false;
- }
- if (paramA != null)
- {
- foreach (var pa in paramA)
- {
- pa.InvokePropertyChanged();
- }
- }
- if (paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.InvokePropertyChanged();
- }
- }
- getStepA.IsDiff = getStepB.IsDiff = isDiff;
- getStepA.IsHidden = getStepB.IsHidden = !isDiff && IsShowDiffSteps ? true : false;
- getStepA.InvokePropertyChanged();
- getStepB.InvokePropertyChanged();
- }
- foreach (var getStepB in StepListB)
- {
- StepDataItem getStepA = (StepListA.Where(x => x.StepName == getStepB.StepName) == null ? null : StepListA.Where(x => x.StepName == getStepB.StepName).FirstOrDefault());
- if (getStepA == null)
- {
- getStepB.IsDiff = false;
- getStepB.IsExtra = true;
- continue;
- }
- ObservableCollection<ParamDataItem> paramA = _mapStepParamA.ContainsKey(getStepA.StepNumber) ? _mapStepParamA[getStepA.StepNumber] : null;
- ObservableCollection<ParamDataItem> paramB = _mapStepParamB.ContainsKey(getStepB.StepNumber) ? _mapStepParamB[getStepB.StepNumber] : null;
- bool isDiff = false;
- foreach (var pb in paramB)
- {
- var getParam = paramA.Where(p => p.ParamName == pb.ParamName).FirstOrDefault();
- if (getParam != null)
- {
- pb.IsExtra = false;
- getParam.IsExtra = false;
- getParam.IsDiff = pb.IsDiff = (pb.ParamValue != getParam.ParamValue);
- if (pb.ParamValue != getParam.ParamValue)
- {
- isDiff = true;
- }
- getParam.IsDiff = pb.IsDiff = (pb.ParamValue != getParam.ParamValue);
- }
- pb.InvokePropertyChanged();
- }
- getStepB.IsExtra = false;
- getStepB.IsDiff = isDiff;
- getStepB.InvokePropertyChanged();
- }
- NotifyOfPropertyChange(nameof(StepListA));
- NotifyOfPropertyChange(nameof(StepListB));
- }
- private void RecompareTableByName()
- {
- for (int i = 1; i < 21; i++)
- {
- ObservableCollection<StepDataItem> _stepListA = null;
- ObservableCollection<StepDataItem> _stepListB = null;
- if (tableStepListA.Keys.Contains(i))
- {
- _stepListA = tableStepListA[i];
- }
- if (tableStepListB.Keys.Contains(i))
- {
- _stepListB = tableStepListB[i];
- }
- if (_stepListA == null || _stepListB == null)
- return;
- var stepAMaxNumber = (_stepListA == null || _stepListA.Count() == 0) ? 0 : _stepListA.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- var stepBMaxNumber = (_stepListB == null || _stepListB.Count() == 0) ? 0 : _stepListB.Select(stepItem => int.Parse(stepItem.StepNumber)).Max();
- int stepMaxNumber = stepAMaxNumber > stepBMaxNumber ? stepAMaxNumber : stepBMaxNumber;
- foreach (var getStepA in _stepListA)
- {
- StepDataItem getStepB = (_stepListB.Where(x => x.StepName == getStepA.StepName) == null ? null : _stepListB.Where(x => x.StepName == getStepA.StepName).FirstOrDefault());
- if (getStepB == null)
- {
- getStepA.IsDiff = false;
- getStepA.IsExtra = true;
- continue;
- }
- getStepA.IsDiffName = getStepB.IsDiffName = true;
- var tempA = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- ObservableCollection<ParamDataItem> paramA = tempA != null && _mapTableStepParamA[tempA].ContainsKey(getStepA.StepNumber) ? _mapTableStepParamA[tempA][getStepA.StepNumber] : null;
- var tempB = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- ObservableCollection<ParamDataItem> paramB = tempB != null && _mapTableStepParamB[tempB].ContainsKey(getStepB.StepNumber) ? _mapTableStepParamB[tempB][getStepB.StepNumber] : null;
- bool isDiff = false;
- bool IsExtra = true;
- if (paramA != null && paramB == null)
- {
- foreach (var pa in paramA)
- {
- pa.IsExtra = true;
- pa.IsDiff = false;
- }
- }
- else if (paramA == null && paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.IsExtra = true;
- pb.IsDiff = false;
- }
- }
- else if (paramA != null && paramB != null)
- {
- foreach (var pa in paramA)
- {
- var getParam = paramB.Where(pb => pb.ParamName == pa.ParamName).FirstOrDefault();
- if (getParam != null)
- {
- pa.IsExtra = false;
- getParam.IsExtra = false;
- getParam.IsDiff = pa.IsDiff = (pa.ParamValue != getParam.ParamValue);
- if (pa.ParamValue != getParam.ParamValue)
- {
- isDiff = true;
- }
- }
- }
- getStepA.IsExtra = getStepB.IsExtra = false;
- }
- if (paramA != null)
- {
- foreach (var pa in paramA)
- {
- pa.InvokePropertyChanged();
- }
- }
- if (paramB != null)
- {
- foreach (var pb in paramB)
- {
- pb.InvokePropertyChanged();
- }
- }
- getStepA.IsDiff = getStepB.IsDiff = isDiff;
- getStepA.IsHidden = getStepB.IsHidden = !isDiff && IsShowDiffSteps ? true : false;
- //getStepA.InvokePropertyChanged();
- //getStepB.InvokePropertyChanged();
- }
- foreach (var getStepB in _stepListB)
- {
- StepDataItem getStepA = (_stepListA.Where(x => x.StepName == getStepB.StepName) == null ? null : _stepListA.Where(x => x.StepName == getStepB.StepName).FirstOrDefault());
- if (getStepA == null)
- {
- getStepB.IsDiff = false;
- getStepB.IsExtra = true;
- continue;
- }
- var tempA = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- ObservableCollection<ParamDataItem> paramA = tempA != null && _mapTableStepParamA[tempA].ContainsKey(getStepA.StepNumber) ? _mapTableStepParamA[tempA][getStepA.StepNumber] : null;
- var tempB = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- ObservableCollection<ParamDataItem> paramB = tempB != null && _mapTableStepParamB[tempB].ContainsKey(getStepB.StepNumber) ? _mapTableStepParamB[tempB][getStepB.StepNumber] : null;
- bool isDiff = false;
- foreach (var pb in paramB)
- {
- var getParam = paramA.Where(p => p.ParamName == pb.ParamName).FirstOrDefault();
- if (getParam != null)
- {
- pb.IsExtra = false;
- getParam.IsExtra = false;
- getParam.IsDiff = pb.IsDiff = (pb.ParamValue != getParam.ParamValue);
- if (pb.ParamValue != getParam.ParamValue)
- {
- isDiff = true;
- }
- getParam.IsDiff = pb.IsDiff = (pb.ParamValue != getParam.ParamValue);
- }
- pb.InvokePropertyChanged();
- }
- getStepB.IsExtra = false;
- getStepB.IsDiff = isDiff;
- getStepB.InvokePropertyChanged();
- }
- var tempParA = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- var tempParB = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == i.ToString());
- if (tempParA != null) tempParA.IsDiff = _stepListA?.Where(x => x.IsDiff).Count() == 0 ? false : true;
- if (tempParB != null) tempParB.IsDiff = _stepListB?.Where(x => x.IsDiff).Count() == 0 ? false : true;
- }
- NotifyOfPropertyChange(nameof(StepListA));
- NotifyOfPropertyChange(nameof(StepListB));
- }
- //private void RecompareStep()
- //{
- // if (StepListA == null || StepListB == null)
- // return;
- // int i = 0;
- // for (i = 0; i < StepListA.Count && i < StepListB.Count; i++)
- // {
- // if (StepListA[i].StepName == StepListB[i].StepName)
- // StepListA[i].IsDiffName = StepListB[i].IsDiffName = false;
- // else
- // StepListA[i].IsDiffName = StepListB[i].IsDiffName = true;
- // ObservableCollection<ParamDataItem> paramA = _mapStepParamA[StepListA[i].StepNumber];
- // ObservableCollection<ParamDataItem> paramB = _mapStepParamB[StepListB[i].StepNumber];
- // bool isDiff = false;
- // bool IsExtra = true;
- // foreach (var pa in paramA)
- // {
- // pa.IsExtra = true;
- // }
- // foreach (var pb in paramB)
- // {
- // pb.IsExtra = true;
- // }
- // foreach (var pa in paramA)
- // {
- // foreach (var pb in paramB)
- // {
- // if (pb.ParamName == pa.ParamName)
- // {
- // pb.IsExtra = false;
- // pa.IsExtra = false;
- // pb.IsDiff = pa.IsDiff = (pa.ParamValue != pb.ParamValue);
- // if (pa.IsDiff)
- // isDiff = true;
- // break;
- // }
- // }
- // }
- // foreach (var pa in paramA)
- // {
- // pa.InvokePropertyChanged();
- // }
- // foreach (var pb in paramB)
- // {
- // pb.InvokePropertyChanged();
- // }
- // StepListA[i].IsDiff = StepListB[i].IsDiff = isDiff;
- // StepListA[i].IsExtra = StepListB[i].IsExtra = false;
- // StepListA[i].IsHidden = StepListB[i].IsHidden = !isDiff && IsShowDiffSteps ? true : false;
- // StepListA[i].InvokePropertyChanged();
- // StepListB[i].InvokePropertyChanged();
- // }
- // for (int j = i; j < StepListA.Count; j++)
- // {
- // StepListA[j].IsDiff = false;
- // StepListA[j].IsExtra = true;
- // StepListA[j].InvokePropertyChanged();
- // foreach (var pa in _mapStepParamA[StepListA[j].StepNumber])
- // {
- // pa.InvokePropertyChanged();
- // }
- // }
- // for (int k = i; k < StepListB.Count; k++)
- // {
- // StepListB[k].IsDiff = false;
- // StepListB[k].IsExtra = true;
- // WholeListB[k].InvokePropertyChanged();
- // _mapLineTextB[WholeListB[k].LineNumber].InvokePropertyChanged();
- // foreach (var pb in _mapStepParamB[StepListB[k].StepNumber])
- // {
- // pb.InvokePropertyChanged();
- // }
- // }
- // NotifyOfPropertyChange(nameof(StepListA));
- // NotifyOfPropertyChange(nameof(StepListB));
- //}
- private void RecompareWhole()
- {
- if (WholeListA == null || WholeListB == null)
- return;
- int i = 0;
- for (i = 0; i < WholeListA.Count && i < WholeListB.Count; i++)
- {
- LineDataItem lineA = _mapLineTextA[WholeListA[i].LineNumber];
- LineDataItem lineB = _mapLineTextB[WholeListB[i].LineNumber];
- bool isDiff = false;
- lineB.IsDiff = lineA.IsDiff = (lineA.LineText != lineB.LineText);
- if (lineA.IsDiff)
- isDiff = true;
- WholeListA[i].IsDiff = WholeListB[i].IsDiff = isDiff;
- WholeListA[i].IsExtra = WholeListB[i].IsExtra = false;
- _mapLineTextA[WholeListA[i].LineNumber].IsDiff = _mapLineTextB[WholeListB[i].LineNumber].IsDiff = isDiff;
- _mapLineTextA[WholeListA[i].LineNumber].IsExtra = _mapLineTextB[WholeListB[i].LineNumber].IsExtra = false;
- lineA.InvokePropertyChanged();
- lineB.InvokePropertyChanged();
- WholeListA[i].InvokePropertyChanged();
- WholeListB[i].InvokePropertyChanged();
- }
- for (int j = i; j < WholeListA.Count; j++)
- {
- WholeListA[j].IsDiff = false;
- WholeListA[j].IsExtra = true;
- _mapLineTextA[WholeListA[j].LineNumber].IsDiff = false;
- _mapLineTextA[WholeListA[j].LineNumber].IsExtra = true;
- if (!(_mapLineTextA[WholeListA[j].LineNumber].LineText.Contains("<Step StepNo") || _mapLineTextA[WholeListA[j].LineNumber].LineText.Contains("<Moudule Name")))
- {
- WholeListA[j].IsDiff = false;
- WholeListA[j].IsExtra = false;
- }
- WholeListA[j].InvokePropertyChanged();
- _mapLineTextA[WholeListA[j].LineNumber].InvokePropertyChanged();
- }
- for (int k = i; k < WholeListB.Count; k++)
- {
- WholeListB[k].IsDiff = false;
- WholeListB[k].IsExtra = true;
- _mapLineTextB[WholeListB[k].LineNumber].IsDiff = false;
- _mapLineTextB[WholeListB[k].LineNumber].IsExtra = true;
- if (!(_mapLineTextB[WholeListB[k].LineNumber].LineText.Contains("<Step StepNo") || _mapLineTextB[WholeListB[k].LineNumber].LineText.Contains("<Moudule Name")))
- {
- WholeListB[k].IsDiff = false;
- WholeListB[k].IsExtra = false;
- }
- WholeListB[k].InvokePropertyChanged();
- _mapLineTextB[WholeListB[k].LineNumber].InvokePropertyChanged();
- }
- NotifyOfPropertyChange(nameof(WholeListA));
- NotifyOfPropertyChange(nameof(WholeListB));
- }
- private void SyncStepSelection(TwoStepDataItem stepData)
- {
- if (stepData == null)
- return;
- var getStepA = StepListA.Where(x => x.StepName == stepData.AStepName).FirstOrDefault();
- var getStepB = StepListB.Where(x => x.StepName == stepData.BStepName).FirstOrDefault();
- if (getStepA == null && getStepB == null)
- {
- ParamList.Clear();
- return;
- }
- else if (getStepA != null && getStepB == null)
- {
- ParamListA = _mapStepParamA[getStepA.StepNumber];
- foreach (var item in ParamListA)
- {
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.AParamValue = item.ParamValue;
- par.IsDiff = false;
- par.IsExtra = item.IsExtra;
- par.BParamValue = "--";
- }
- else
- {
- TwoParamDataItem param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.AParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- param.BParamValue = "--";
- ParamList.Add(param);
- }
- }
- }
- else if (getStepA == null && getStepB != null)
- {
- ParamListB = _mapStepParamB[getStepB.StepNumber];
- foreach (var item in ParamListB)
- {
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.BParamValue = item.ParamValue;
- par.IsDiff = false;
- par.IsExtra = item.IsExtra;
- par.AParamValue = "--";
- }
- else
- {
- var param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.BParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- param.AParamValue = "--";
- ParamList.Add(param);
- }
- }
- }
- else
- {
- ParamListA = _mapStepParamA[getStepA.StepNumber];
- ParamListB = _mapStepParamB[getStepB.StepNumber];
- foreach (var item in ParamListA)
- {
- var bValue = ParamListB.FirstOrDefault(x => x.ParamName == item.ParamName)?.ParamValue;
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.AParamValue = item.ParamValue;
- par.IsDiff = item.IsDiff;
- par.IsExtra = item.IsExtra;
- if (bValue != null)
- {
- par.BParamValue = bValue;
- }
- else
- {
- par.BParamValue = "--";
- }
- }
- else
- {
- var param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.AParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- if (bValue != null)
- {
- param.BParamValue = bValue;
- }
- else
- {
- param.BParamValue = "--";
- }
- ParamList.Add(param);
- }
- }
- }
- //NotifyOfPropertyChange(nameof(StepSelection));
- //StepSelection.InvokePropertyChanged();
- }
- private void SyncTableStepSelection(TwoStepDataItem stepData)
- {
- if (stepData == null)
- return;
- var getStepA = tableStepListA[SelectTableIndex].Where(x => x.StepName == stepData.AStepName).FirstOrDefault();
- var getStepB = tableStepListB[SelectTableIndex].Where(x => x.StepName == stepData.BStepName).FirstOrDefault();
- if (getStepA == null && getStepB == null)
- {
- ParamList.Clear();
- return;
- }
- else if (getStepA != null && getStepB == null)
- {
- var tempPar = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == SelectTableIndex.ToString());
- ParamListA.Clear();
- if (tempPar != null)
- {
- _mapTableStepParamA[tempPar][getStepA.StepNumber].ToList().ForEach(x => ParamListA.Add(x));
- }
- foreach (var item in ParamListA)
- {
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.AParamValue = item.ParamValue;
- par.IsDiff = false;
- par.IsExtra = item.IsExtra;
- par.BParamValue = "--";
- }
- else
- {
- TwoParamDataItem param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.AParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- param.BParamValue = "--";
- ParamList.Add(param);
- }
- }
- }
- else if (getStepA == null && getStepB != null)
- {
- var tempPar = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == SelectTableIndex.ToString());
- ParamListB.Clear();
- if (tempPar != null)
- {
- _mapTableStepParamB[tempPar][getStepB.StepNumber].ToList().ForEach(x => ParamListB.Add(x));
- }
- foreach (var item in ParamListB)
- {
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.BParamValue = item.ParamValue;
- par.IsDiff = false;
- par.IsExtra = item.IsExtra;
- par.AParamValue = "--";
- }
- else
- {
- var param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.BParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- param.AParamValue = "--";
- ParamList.Add(param);
- }
- }
- }
- else
- {
- var tempPar = _mapTableStepParamA.Keys.FirstOrDefault(x => x.TableIndex == SelectTableIndex.ToString());
- ParamListA.Clear();
- if (tempPar != null)
- {
- _mapTableStepParamA[tempPar][getStepA.StepNumber].ToList().ForEach(x => ParamListA.Add(x));
- }
- var tempParB = _mapTableStepParamB.Keys.FirstOrDefault(x => x.TableIndex == SelectTableIndex.ToString());
- ParamListB.Clear();
- if (tempParB != null)
- {
- _mapTableStepParamB[tempParB][getStepB.StepNumber].ToList().ForEach(x => ParamListB.Add(x));
- }
- foreach (var item in ParamListA)
- {
- var bValue = ParamListB.FirstOrDefault(x => x.ParamName == item.ParamName)?.ParamValue;
- var par = ParamList.FirstOrDefault(x => x.ParamName == item.ParamName);
- if (par != null)
- {
- par.AParamValue = item.ParamValue;
- par.IsExtra = item.IsExtra;
- if (bValue != null)
- {
- par.IsDiff = item.ParamValue != bValue;
- par.BParamValue = bValue;
- }
- else
- {
- par.BParamValue = "--";
- }
- }
- else
- {
- var param = new TwoParamDataItem();
- param.ParamName = item.ParamName;
- param.AParamValue = item.ParamValue;
- param.IsDiff = item.IsDiff;
- param.IsExtra = item.IsExtra;
- if (bValue != null)
- {
- param.BParamValue = bValue;
- }
- else
- {
- param.BParamValue = "--";
- }
- ParamList.Add(param);
- }
- }
- }
- //NotifyOfPropertyChange(nameof(StepSelection));
- //StepSelection.InvokePropertyChanged();
- }
- private void SyncParamSelection(ParamDataItem paramData, bool isSelectA)
- {
- try
- {
- if (paramData == null)
- return;
- if (isSelectA)
- {
- if (IsCompareBySName)
- {
- //var getSameStepName = StepListA.Where(x => x.StepName == StepSelectionB.StepName).FirstOrDefault();
- //if (getSameStepName == null) return;
- //if (_mapStepParamA.ContainsKey(getSameStepName.StepNumber))
- //{
- // ParamListA = _mapStepParamA[getSameStepName.StepNumber];
- // NotifyOfPropertyChange(nameof(ParamListA));
- //}
- //else
- // return;
- //foreach (var item in ParamListA)
- //{
- // if (item.ParamName == paramData.ParamName)
- // {
- // _paramSelectionA = item;
- // NotifyOfPropertyChange(nameof(ParamSelectionA));
- // ParamSelectionA.InvokePropertyChanged();
- // }
- //}
- }
- }
- else
- {
- //if (IsCompareByStep)
- //{
- // if (ParamListB == null)
- // {
- // if (_mapStepParamB.ContainsKey(StepSelectionA.StepNumber))
- // {
- // ParamListB = _mapStepParamB[StepSelectionA.StepNumber];
- // NotifyOfPropertyChange(nameof(ParamListB));
- // }
- // else
- // return;
- // }
- // foreach (var item in ParamListB)
- // {
- // if (item.ParamName == paramData.ParamName)
- // {
- // _paramSelectionB = item;
- // NotifyOfPropertyChange(nameof(ParamSelectionB));
- // ParamSelectionB.InvokePropertyChanged();
- // }
- // }
- //}
- //if (IsCompareBySName)
- //{
- // if (ParamListB == null)
- // {
- // var getSameStepName = StepListB.Where(x => x.StepName == StepSelectionA.StepName).FirstOrDefault();
- // if (_mapStepParamB.ContainsKey(getSameStepName.StepNumber))
- // {
- // ParamListB = _mapStepParamB[getSameStepName.StepNumber];
- // NotifyOfPropertyChange(nameof(ParamListB));
- // }
- // else
- // return;
- // }
- // foreach (var item in ParamListB)
- // {
- // if (item.ParamName == paramData.ParamName)
- // {
- // _paramSelectionB = item;
- // NotifyOfPropertyChange(nameof(ParamSelectionB));
- // ParamSelectionB.InvokePropertyChanged();
- // }
- // }
- //}
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex.Message);
- }
- }
- private void SyncLineSelection(LineDataItem lineData, bool isSelectA)
- {
- if (lineData == null)
- return;
- if (isSelectA)
- {
- foreach (var item in WholeListA)
- {
- if (item.LineNumber == lineData.LineNumber)
- {
- _lineSelectionA = item;
- NotifyOfPropertyChange(nameof(LineSelectionA));
- LineSelectionA.InvokePropertyChanged();
- }
- }
- }
- else
- {
- foreach (var item in WholeListB)
- {
- if (item.LineNumber == lineData.LineNumber)
- {
- _lineSelectionB = item;
- NotifyOfPropertyChange(nameof(LineSelectionB));
- LineSelectionB.InvokePropertyChanged();
- }
- }
- }
- }
- public void RemoveA()
- {
- RemoveRecipe(true);
- }
- public void RemoveB()
- {
- RemoveRecipe(false);
- }
- private void RemoveSelectB()
- {
- StepListB?.Clear();
- ParamListB?.Clear();
- WholeListB?.Clear();
- RecipeB = string.Empty;
- _mapStepParamB?.Clear();
- _paramSelectionB = null;
- NotifyOfPropertyChange(nameof(StepListB));
- NotifyOfPropertyChange(nameof(ParamListB));
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- NotifyOfPropertyChange(nameof(ParamSelectionB));
- }
- private void RemoveRecipe(bool isSelectA)
- {
- if (!DialogBox.Confirm($"Are you sure you want to remove the recipe? \r\n{RecipeB}"))
- return;
- if (isSelectA)
- {
- StepListA?.Clear();
- ParamListA?.Clear();
- WholeListA?.Clear();
- RecipeA = string.Empty;
- _mapStepParamA?.Clear();
- NotifyOfPropertyChange(nameof(StepListA));
- NotifyOfPropertyChange(nameof(ParamListA));
- NotifyOfPropertyChange(nameof(RecipeA));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveA));
- }
- else
- {
- StepListB?.Clear();
- ParamListB?.Clear();
- WholeListB?.Clear();
- RecipeB = string.Empty;
- _mapStepParamB?.Clear();
- _paramSelectionB = null;
- NotifyOfPropertyChange(nameof(StepListB));
- NotifyOfPropertyChange(nameof(ParamListB));
- NotifyOfPropertyChange(nameof(RecipeB));
- NotifyOfPropertyChange(nameof(EnableButtonRemoveB));
- NotifyOfPropertyChange(nameof(ParamSelectionB));
- }
- }
- private void DeleteInnerXml(bool isSelectA)
- {
- try
- {
- XmlDocument docTo = isSelectA ? _domA : _domB;
- //XmlNode nodeModule = docTo.SelectSingleNode($"Aitex/TableRecipeData/Module[@Name='PM1']");{_module}
- // doc.SelectNodes($"Aitex/TableRecipeData/Module[@Name='PM1']/Step");
- XmlNodeList nodeSteps = docTo.SelectNodes($"Aitex/TableRecipeData/Module[@Name='PM1']/Step");
- if (nodeSteps == null)
- nodeSteps = docTo.SelectNodes($"Aitex/TableRecipeData/Step");
- List<XmlNode> oldNodeSteps = new List<XmlNode>();
- foreach (XmlNode nodeTemp in nodeSteps)
- {
- oldNodeSteps.Add(nodeTemp.Clone());
- }
- XmlNodeList backSteps = docTo.SelectNodes($"Aitex/TableRecipeData/Module[@Name='PM1']/BakeStep");
- if (backSteps == null)
- backSteps = docTo.SelectNodes($"Aitex/TableRecipeData/BakeStep");
- List<XmlNode> oldBackNodeSteps = new List<XmlNode>();
- foreach (XmlNode nodeTemp in backSteps)
- {
- oldBackNodeSteps.Add(nodeTemp.Clone());
- }
- XmlNode stepsNode = docTo.SelectSingleNode($"Aitex/TableRecipeData/Module[@Name='PM1']/Step").ParentNode;
- stepsNode.RemoveAll();
- (stepsNode as XmlElement).SetAttribute("Name", "PM1"); //微釜的recipe为什么都是PM1?,如果recipe改了,此处要改回(stepsNode as XmlElement).SetAttribute("Name", _module);
- ObservableCollection<StepDataItem> stepListTo = isSelectA ? StepListA : StepListB;
- if (stepsNode == null)
- {
- return;
- }
- foreach (StepDataItem item in stepListTo)
- {
- XmlElement DeviceTree = docTo.CreateElement("Step");
- DeviceTree.SetAttribute("StepNo", item.StepNumber.ToString());
- DeviceTree.SetAttribute("Name", item.StepName);
- stepsNode.AppendChild(DeviceTree);
- }
- foreach (XmlNode nodeStep in stepsNode)
- {
- string stepNumber = nodeStep.Attributes["StepNo"].Value;
- ObservableCollection<ParamDataItem> paramList =
- isSelectA ? _mapStepParamA[stepNumber] : _mapStepParamB[stepNumber];
- foreach (var param in paramList)
- {
- (nodeStep as XmlElement).SetAttribute(param.ParamName, param.ParamValue);
- }
- }
- foreach (XmlNode nodeStep in backSteps)
- {
- stepsNode.AppendChild(nodeStep);
- }
- string backText = getXmlText(isSelectA ? _domA : _domB);
- LoadrecipeContentData(backText, isSelectA);
- Recompare();
- SyncShowDiffSteps(IsShowDiffSteps);
- if (isSelectA)
- {
- BackInnerXmlTextA.Add(backText);
- }
- else
- {
- BackInnerXmlTextB.Add(backText);
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex.Message);
- }
- }
- public void SelectedRecipeTable()
- {
- ItemsSelectDialogViewModel itemsSelectDialogViewModel = new ItemsSelectDialogViewModel();
- itemsSelectDialogViewModel.Items.Clear();
- var tables = _mapTableStepParamA.Keys;
- foreach (var item in tables)
- {
- TwoTableDataItem twoTableDataItem = new TwoTableDataItem();
- int tableIndex = -1;
- int.TryParse(item.TableIndex, out tableIndex);
- if (tableIndex != -1)
- {
- twoTableDataItem.Index = tableIndex;
- twoTableDataItem.ATableName = item.TableName;
- var tablesB = _mapTableStepParamB.Keys;
- var tableB = tablesB.FirstOrDefault(x => x.TableIndex == item.TableIndex);
- if (tableB != null)
- {
- twoTableDataItem.BTableName = tableB.TableName;
- twoTableDataItem.IsDiff = tableB.IsDiff;
- }
- itemsSelectDialogViewModel.Items.Add(twoTableDataItem);
- }
- }
- WindowManager wm = new WindowManager();
- bool? bret = wm.ShowDialog(itemsSelectDialogViewModel);
- if ((bool)bret)
- {
- var item = itemsSelectDialogViewModel.SelectedItem;
- SelectedTwoTableData = item;
- SelectTableIndex = item.Index;
- GetTableStepList(true, item.Index);
- GetTableStepList(false, item.Index);
- SyncShowDiffSteps(IsShowDiffSteps);
- if (StepList != null && StepList.Count > 0)
- SyncTableStepSelection(StepList[0]);
- SyncShowDiffParams(_isShowDiffParams);
- }
- }
- private string getXmlText(XmlDocument xmlDocument)
- {
- (new RecipeProvider()).SaveRecipe("", "RecipeTemp", xmlDocument.InnerXml);
- var _recipeProvider = new RecipeProvider();
- var recipeContent = _recipeProvider.LoadRecipe("", "RecipeTemp", false);
- return recipeContent;
- }
- public void LineCopyToLeft(LineDataItem lineData)
- {
- LineCopy(lineData, false);
- }
- public void LineCopyToRight(LineDataItem lineData)
- {
- LineCopy(lineData, true);
- }
- public void LineCopy(LineDataItem lineData, bool isFromA)
- {
- try
- {
- LineDataItem lineFrom = lineData;
- ObservableCollection<LineDataItem> lineListTo = isFromA ? WholeListB : WholeListA;
- Dictionary<string, LineDataItem> mapFrom = isFromA ? _mapLineTextA : _mapLineTextB;
- Dictionary<string, LineDataItem> mapTo = isFromA ? _mapLineTextB : _mapLineTextA;
- var tempLine = lineListTo.Where(x => x.LineNumber == lineFrom.LineNumber).FirstOrDefault();
- if (tempLine != null)
- {
- tempLine.LineText = lineFrom.LineText;
- tempLine.IsDiff = lineFrom.IsDiff = false;
- tempLine.IsExtra = lineFrom.IsExtra = false;
- }
- string recipeContent = "";
- if (isFromA)
- {
- for (int i = 0; i < WholeListB.Count; i++)
- {
- recipeContent += WholeListB[i].LineText + ((i == WholeListB.Count - 1) ? "" : "\r\n");
- }
- }
- else
- {
- for (int i = 0; i < WholeListA.Count; i++)
- {
- recipeContent += WholeListA[i].LineText + ((i == WholeListB.Count - 1) ? "" : "\r\n");
- }
- }
- CopyToInnerXml(recipeContent, !isFromA);
- LoadrecipeContentData(recipeContent, !isFromA);
- Recompare();
- SyncShowDiffSteps(IsShowDiffSteps);
- }
- catch (Exception ex)
- {
- LOG.Write(ex.Message);
- }
- }
- private void CopyToInnerXml(string recipeContent, bool isSelectA)
- {
- XmlDocument doc = isSelectA ? _domA : _domB;
- doc.InnerXml = recipeContent;
- if (isSelectA)
- {
- BackInnerXmlTextA.Add(recipeContent);
- }
- else
- {
- BackInnerXmlTextB.Add(recipeContent);
- }
- }
- public void SaveA()
- {
- Save(true);
- }
- public void SaveB()
- {
- Save(false);
- }
- private void Save(bool isSelectA)
- {
- XmlDocument doc = isSelectA ? _domA : _domB;
- XmlNodeList nodeSteps = doc.SelectNodes($"Aitex/TableRecipeData/Module[@Name='PM1']/Step");
- if (nodeSteps == null)
- nodeSteps = doc.SelectNodes($"Aitex/TableRecipeData/Step");
- if (isSelectA)
- {
- (new RecipeProvider()).SaveRecipe("", RecipeA, doc.InnerXml);
- }
- else
- {
- (new RecipeProvider()).SaveRecipe("", RecipeB, doc.InnerXml);
- }
- }
- private bool _isStepModel = true;
- public bool IsStepModel
- {
- get { return _isStepModel; }
- set
- {
- _isStepModel = value;
- _isWholeModel = !_isStepModel;
- StepVisibility = _isStepModel ? Visibility.Visible : Visibility.Hidden;
- WholeVisibility = _isWholeModel ? Visibility.Visible : Visibility.Hidden;
- InvokePropertyChanged(nameof(IsStepModel));
- InvokePropertyChanged(nameof(IsWholeModel));
- InvokePropertyChanged(nameof(StepVisibility));
- InvokePropertyChanged(nameof(WholeVisibility));
- }
- }
- private bool _isWholeModel;
- public bool IsWholeModel
- {
- get { return _isWholeModel; }
- set
- {
- _isWholeModel = value;
- _isStepModel = !_isWholeModel;
- StepVisibility = _isStepModel ? Visibility.Visible : Visibility.Hidden;
- WholeVisibility = _isWholeModel ? Visibility.Visible : Visibility.Hidden;
- InvokePropertyChanged(nameof(IsWholeModel));
- InvokePropertyChanged(nameof(IsStepModel));
- InvokePropertyChanged(nameof(StepVisibility));
- InvokePropertyChanged(nameof(WholeVisibility));
- }
- }
- public Visibility StepVisibility
- {
- get; set;
- }
- public Visibility WholeVisibility
- {
- get; set;
- }
- private bool _isShowDiffSteps;
- public bool IsShowDiffSteps
- {
- get { return _isShowDiffSteps; }
- set
- {
- _isShowDiffSteps = value;
- _isShowAllSteps = !_isShowDiffSteps;
- SyncShowDiffSteps(_isShowDiffSteps);
- InvokePropertyChanged(nameof(IsShowDiffSteps));
- InvokePropertyChanged(nameof(IsShowAllSteps));
- }
- }
- private bool _isShowAllSteps = true;
- public bool IsShowAllSteps
- {
- get { return _isShowAllSteps; }
- set
- {
- _isShowAllSteps = value;
- _isShowDiffSteps = !_isShowAllSteps;
- SyncShowDiffSteps(_isShowDiffSteps);
- InvokePropertyChanged(nameof(IsShowAllSteps));
- InvokePropertyChanged(nameof(IsShowDiffSteps));
- }
- }
- private bool _isShowDiffParams;
- public bool IsShowDiffParams
- {
- get { return _isShowDiffParams; }
- set
- {
- _isShowDiffParams = value;
- SyncShowDiffParams(_isShowDiffParams);
- _isShowAllParams = !_isShowDiffParams;
- InvokePropertyChanged(nameof(IsShowDiffParams));
- InvokePropertyChanged(nameof(IsShowAllParams));
- }
- }
- private bool _isShowAllParams = true;
- public bool IsShowAllParams
- {
- get { return _isShowAllParams; }
- set
- {
- _isShowAllParams = value;
- _isShowDiffParams = !_isShowAllParams;
- SyncShowDiffParams(_isShowDiffParams);
- InvokePropertyChanged(nameof(IsShowDiffParams));
- InvokePropertyChanged(nameof(IsShowAllParams));
- }
- }
- private bool _isCompareBySName = true;
- public bool IsCompareBySName
- {
- get { return _isCompareBySName; }
- set
- {
- _isCompareBySName = value;
- Recompare();
- SyncShowDiffSteps(_isShowDiffSteps);
- InvokePropertyChanged(nameof(IsCompareBySName));
- }
- }
- private void SyncShowDiffSteps(bool isShowDiffSteps)
- {
- if (StepListA == null || StepListB == null)
- return;
- foreach (var item in StepList)
- {
- item.IsHidden = (IsShowDiffSteps ? (item.IsDiff == false && item.IsExtra == false) : false);
- }
- NotifyOfPropertyChange(nameof(StepList));
- }
- private void SyncShowDiffParams(bool isShowDiffParams)
- {
- if (ParamListA == null || ParamListB == null)
- return;
- if (isShowDiffParams)
- {
- foreach (var item in ParamList)
- {
- if (item.IsDiff == false && item.IsExtra == false)
- {
- item.IsHidden = isShowDiffParams;
- }
- else
- {
- item.IsHidden = false;
- }
- }
- }
- else
- {
- foreach (var item in ParamList)
- {
- item.IsHidden = isShowDiffParams;
- }
- }
- NotifyOfPropertyChange(nameof(ParamList));
- }
- }
- }
|