From 8bfaf7141c88f41d3dbd1995cfb9cb015ca0d1d6 Mon Sep 17 00:00:00 2001 From: Rodney Chen <rodney.chen@hotmail.com> Date: 星期五, 02 八月 2024 16:34:13 +0800 Subject: [PATCH] 整理了工序传入传出参数 --- Tiger.Business.MES/Transaction/PackingNode.cs | 298 ++++++++++++++++++++++++++++++++++++----------------------- 1 files changed, 180 insertions(+), 118 deletions(-) diff --git a/Tiger.Business.MES/Transaction/PackingNode.cs b/Tiger.Business.MES/Transaction/PackingNode.cs index 20b6f99..404ff34 100644 --- a/Tiger.Business.MES/Transaction/PackingNode.cs +++ b/Tiger.Business.MES/Transaction/PackingNode.cs @@ -10,6 +10,7 @@ using System.Threading.Tasks; using Tiger.Model; using Tiger.Model.Entitys.MES.Position; +using Tiger.Business.MES.WorkAction; namespace Tiger.Business.MES.Transaction { @@ -26,7 +27,14 @@ } #region Propertys & Variables - + /// <summary> + /// 宸ュ簭褰撳墠鎵ц鐨勬寚浠や唬鐮侊紝鍖呮嫭锛�<br/> + /// {null or ""}锛氬伐搴忕┖闂诧紝鎸囦护涓虹┖鍒欒涓哄伐搴忔病鏈夋墽琛屼换浣曟寚浠�<br/> + /// NodeSubmit锛氫骇鍝佽繃绔欙紝姝e父浜у搧杩囩珯閫昏緫<br/> + /// PkgSubmit锛氭墜鍔ㄧ粨鏉熷寘瑁咃紝鎵嬪姩淇濆瓨鏆傚瓨鐨勫寘瑁呮暟鎹�<br/> + /// </summary> + public string NodeCmd { get; set; } + public PackingAction TempPkgAction { get; set; } #endregion Propertys & Variables #region Functions @@ -37,116 +45,128 @@ /// <returns></returns> public async Task<ApiAction<SubmitOutput>> Submit(SubmitInput input) { - var action = new ApiAction<SubmitOutput>(); + var action = new ApiAction<SubmitOutput>(new SubmitOutput()); try { - //宸ユ鍒楄〃涓虹┖鎴栬�呭伐搴忚妭鐐瑰伐姝ユ湁鏈畬鎴愭椂锛屼紭鍏堝畬鎴愬伐搴忚妭鐐瑰伐姝� - if (Steps.IsNullOrEmpty() || !IsFinishNodeSteps) + //PkgSubmit锛氭墜鍔ㄧ粨鏉熷寘瑁咃紝鎵嬪姩淇濆瓨鏆傚瓨鐨勫寘瑁呮暟鎹� + if (NodeCmd == "PkgSubmit") { - //鍏堝垽鏂綋鍓嶅伐鍗曚笉涓虹┖涓斿綋鍓嶅矖浣嶅湪褰撳墠宸ュ崟鏄笉鏄绔欙紝濡傛灉鏄垯涓嶅厑璁稿彉鏇村綋鍓嶅伐鍗曪紝灏濊瘯鎶婃潯鐮佺粦瀹氬埌褰撳墠宸ュ崟 - if (!CurBatch.IsNullOrEmpty() && CurBatch.IsFirstNode(PostCode)) - { - action = NodeSubmit(action, input); - return action; - } - //褰撳墠宀椾綅鍦ㄥ綋鍓嶅伐鍗曚笉鏄绔欙紝鍒欐煡鎵炬潯鐮佸凡缁戝畾鐨勫伐鍗曞綋浣滃綋鍓嶅伐鍗� - else - { - var wosn = Biz.Db.Queryable<BIZ_MES_WO_BATCH, BIZ_MES_WO_SN>((b, s) => new JoinQueryInfos(JoinType.Inner, b.ORDER_NO == s.WORK_ORDER)).ByAuth(input.AuthOption) - .Where((b, s) => s.SN == input.SN && b.ACT_LINE == CurLine.LINE_CODE && (b.STATUS == BIZ_MES_WO_BATCH.STATUSs.Release.GetValue() || b.STATUS == BIZ_MES_WO_BATCH.STATUSs.Working.GetValue())) - .Select((b, s) => new { Batch = b, SN = s }).First(); - //鏌ユ壘鍒版潯鐮佸凡缁戝畾鐨勫伐鍗� - if (!wosn.IsNullOrEmpty()) - { - if (CurBatch?.Batch?.ORDER_NO != wosn.Batch.ORDER_NO) - { - //鏉$爜宸茬粦瀹氱殑宸ュ崟涓嶇瓑浜庡綋鍓嶅伐鍗曞垯閲嶆柊閫夋嫨宸ュ崟 - var result = await SelectOrder(new() { AuthOption = input.AuthOption, OrderNo = wosn.Batch.ORDER_NO }); - if (!result.IsSuccessed) - { - action.IsSuccessed = result.IsSuccessed; - action.LocaleMsg = result.LocaleMsg; - return action; - } - } - //鏉$爜杩囩珯 - action = NodeSubmit(action, input); - return action; - } - //鏌ユ壘涓嶅埌鏉$爜宸茬粦瀹氱殑宸ュ崟 - else - { - //娌℃湁褰撳墠宸ュ崟锛屽垯鍏堥�夋嫨宸ュ崟鍚庡啀鎵弿鏉$爜 - if (CurBatch.IsNullOrEmpty()) - { - action.IsSuccessed = false; - //action.LocaleMsg = new($"鏈�夋嫨宸ュ崟锛岃鍏堥�夋嫨瑕佺敓浜х殑宸ュ崟"); - action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.NotSelectOrderException"); - return action; - } - //鏈夊綋鍓嶅伐鍗曚笖涓嶆槸鎶曞叆锛屽垯鎻愮ず鏉$爜鏈姇鍏ョ敓浜э紝璇峰厛鍘婚绔欐壂鎻� - else - { - action.IsSuccessed = false; - //action.LocaleMsg = new($"鏉$爜[{input.SN}]灏氭湭鎶曞叆鐢熶骇锛岃鍏堝幓棣栫珯鎵弿", input.SN); - action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.NotInputException", input.SN); - return action; - } - } - } - } - //瀹屾垚宸ュ簭鑺傜偣宸ユ鍚庯紝鍚庡紑濮嬫墽琛屽綋鍓嶅伐搴忕殑琛屼负宸ユ - else if(IsFinishNodeSteps && !IsFinishAllSteps) - { - var submitStep = Steps.Where(q => q.ID == input.CurStepID && !q.IsFinished).FirstOrDefault(); - if (submitStep.IsNullOrEmpty()) + action = TempPkgAction.Submit(input); + //濡傛灉琛屼负琚爣璁版垚宸插畬鎴愶紝鍒欓噸缃伐搴� + if (TempPkgAction.IsFinished) { - action = BeginNextActionStep(input); - return action; + ResetNode(); } - else + return action; + } + //NodeSubmit锛氫骇鍝佽繃绔欙紝姝e父浜у搧杩囩珯閫昏緫 + else + { + NodeCmd = "NodeSubmit"; + //宸ユ鍒楄〃涓虹┖鎴栬�呭伐搴忚妭鐐瑰伐姝ユ湁鏈畬鎴愭椂锛屼紭鍏堝畬鎴愬伐搴忚妭鐐瑰伐姝� + if (Steps.IsNullOrEmpty() || !IsFinishNodeSteps) { - var result = submitStep.Submit(input); - //濡傛灉褰撳墠宸ユ宸插畬鎴愶紝寮�濮嬫墽琛屼笅涓�宸ユ - if (result.IsSuccessed && submitStep.IsFinished) + //鍏堝垽鏂綋鍓嶅伐鍗曚笉涓虹┖涓斿綋鍓嶅矖浣嶅湪褰撳墠宸ュ崟鏄笉鏄绔欙紝濡傛灉鏄垯涓嶅厑璁稿彉鏇村綋鍓嶅伐鍗曪紝灏濊瘯鎶婃潯鐮佺粦瀹氬埌褰撳墠宸ュ崟 + if (!CurBatch.IsNullOrEmpty() && CurBatch.IsFirstNode(PostCode)) { - result = BeginNextActionStep(input); + action = NodeSubmit(action, input); + return action; } - //濡傛灉褰撳墠宸ユ鏈畬鎴� + //褰撳墠宀椾綅鍦ㄥ綋鍓嶅伐鍗曚笉鏄绔欙紝鍒欐煡鎵炬潯鐮佸凡缁戝畾鐨勫伐鍗曞綋浣滃綋鍓嶅伐鍗� else { - //琛屼负鎵ц鍑洪敊锛屽伐姝ヨ閲嶇疆 - if (Steps.IsNullOrEmpty()) + var wosn = Biz.Db.Queryable<BIZ_MES_WO_BATCH, BIZ_MES_WO_SN>((q, s) => new JoinQueryInfos(JoinType.Inner, q.ORDER_NO == s.WORK_ORDER)) + .ByAuth(input.AuthOption) + .Where((q, s) => s.SN == input.SN && q.ACT_LINE == CurLine.LINE_CODE && (q.STATUS == BIZ_MES_WO_BATCH.STATUSs.Release.GetValue() || q.STATUS == BIZ_MES_WO_BATCH.STATUSs.Working.GetValue())) + .Select((q, s) => new { Batch = q, SN = s }).First(); + //鏌ユ壘鍒版潯鐮佸凡缁戝畾鐨勫伐鍗� + if (!wosn.IsNullOrEmpty()) { - result.LocaleMsg = new(Biz.T(result.LocaleMsg, input.Locale) + Biz.T(Biz.L("MES.Transaction.Position.RescanSN"), input.Locale)); + if (CurBatch?.Batch?.ORDER_NO != wosn.Batch.ORDER_NO) + { + //鏉$爜宸茬粦瀹氱殑宸ュ崟涓嶇瓑浜庡綋鍓嶅伐鍗曞垯閲嶆柊閫夋嫨宸ュ崟 + var result = await SelectOrder(new() { AuthOption = input.AuthOption, OrderNo = wosn.Batch.ORDER_NO }); + if (!result.IsSuccessed) + { + action.IsSuccessed = result.IsSuccessed; + action.LocaleMsg = result.LocaleMsg; + return action; + } + } + //鏉$爜杩囩珯 + action = NodeSubmit(action, input); + return action; } + //鏌ユ壘涓嶅埌鏉$爜宸茬粦瀹氱殑宸ュ崟 else { - result.Data.IsFinished = IsFinishAllSteps; - result.Data.CurWO = CurBatch.WO.ORDER_NO; - result.Data.CurBatch = CurBatch.Batch.BATCH_NO; - result.Data.CurNode = CurStep.NodeAct.ACT_NAME; - result.Data.StepActCode = CurStep.NodeAct.ACT_CODE; - result.Data.NextStepID = CurStep.ID; + //娌℃湁褰撳墠宸ュ崟锛屽垯鍏堥�夋嫨宸ュ崟鍚庡啀鎵弿鏉$爜 + if (CurBatch.IsNullOrEmpty()) + { + action.IsSuccessed = false; + //action.LocaleMsg = new($"鏈�夋嫨宸ュ崟锛岃鍏堥�夋嫨瑕佺敓浜х殑宸ュ崟"); + action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.NotSelectOrderException"); + return action; + } + //鏈夊綋鍓嶅伐鍗曚笖涓嶆槸鎶曞叆锛屽垯鎻愮ず鏉$爜鏈姇鍏ョ敓浜э紝璇峰厛鍘婚绔欐壂鎻� + else + { + action.IsSuccessed = false; + //action.LocaleMsg = new($"鏉$爜[{input.SN}]灏氭湭鎶曞叆鐢熶骇锛岃鍏堝幓棣栫珯鎵弿", input.SN); + action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.NotInputException", input.SN); + return action; + } } } - //濡傛灉鎵�鏈夊伐姝ラ兘瀹屾垚 - if (IsFinishAllSteps) - { - return DoIfFinishAllSteps(result); - } - return result; } + //瀹屾垚宸ュ簭鑺傜偣宸ユ鍚庯紝鍚庡紑濮嬫墽琛屽綋鍓嶅伐搴忕殑琛屼负宸ユ + else if (IsFinishNodeSteps && !IsFinishAllSteps) + { + var submitStep = Steps.Where(q => q.ID == input.CurStepID && !q.IsFinished).FirstOrDefault(); + if (submitStep.IsNullOrEmpty()) + { + action = BeginNextActionStep(input); + return action; + } + else + { + var result = submitStep.Submit(input); + //濡傛灉褰撳墠宸ユ宸插畬鎴愶紝寮�濮嬫墽琛屼笅涓�宸ユ + if (result.IsSuccessed && submitStep.IsFinished) + { + result = BeginNextActionStep(input); + } + //濡傛灉褰撳墠宸ユ鏈畬鎴� + else + { + //琛屼负鎵ц鍑洪敊锛屽伐姝ヨ閲嶇疆 + if (Steps.IsNullOrEmpty()) + { + result.LocaleMsg = new(Biz.T(result.LocaleMsg, input.Locale) + Biz.T(Biz.L("MES.Transaction.Position.RescanSN"), input.Locale)); + } + else + { + result.Data.SetValue(CurBatch, CurStep, CurStep?.ID, IsFinishAllSteps); + } + } + //濡傛灉鎵�鏈夊伐姝ラ兘瀹屾垚 + if (IsFinishAllSteps) + { + return DoIfFinishAllSteps(result); + } + return result; + } + } + //娌℃湁鍙墽琛岀殑宸ユ + ResetNode(); + action.IsSuccessed = false; + //action.LocaleMsg = new($"宀椾綅[{CurPosition.POST_CODE}]宸ユ鎵ц寮傚父锛岃閲嶆柊鎵弿浜у搧鏉$爜", CurPosition.POST_CODE); + action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.WorkStepException", CurPosition.POST_CODE); } - //娌℃湁鍙墽琛岀殑宸ユ - ResetSteps(); - action.IsSuccessed = false; - //action.LocaleMsg = new($"宀椾綅[{CurPosition.POST_CODE}]宸ユ鎵ц寮傚父锛岃閲嶆柊鎵弿浜у搧鏉$爜", CurPosition.POST_CODE); - action.LocaleMsg = new("MES.Transaction.PackingNode.Submit.WorkStepException", CurPosition.POST_CODE); } catch (Exception ex) { - action.CatchExceptionWithLog(ex, $"鍖呰宸ュ簭锛氭壂鎻忎骇鍝佹潯鐮佸紓甯�"); + action.CatchExceptionWithLog(ex, $"鍖呰宸ュ簭锛氭彁浜ゆ搷浣滄暟鎹紓甯�"); } return action; } @@ -169,7 +189,7 @@ return woStatus; } //闈炴硶杩囩珯闃插憜锛氳繘鍏ュ伐搴忔椂瑕佸鍔犲垽鏂潯鐮佹槸鍚︽寜娴佺▼杩囩珯 - var wipSN = Biz.Db.Queryable<MES_WIP_DATA>().Where(q => q.SN == input.SN && q.WORK_ORDER == CurBatch.WO.ORDER_NO).IncludesAllFirstLayer().First() ?? new MES_WIP_DATA() + var wipSN = Biz.Db.Queryable<MES_WIP_DATA>().IncludesAllFirstLayer().First(q => q.SN == input.SN && q.WORK_ORDER == CurBatch.WO.ORDER_NO) ?? new MES_WIP_DATA() { SN = input.SN, STATUS = MES_WIP_DATA.STATUSs.Init.GetValue(), @@ -188,15 +208,6 @@ { return canGotoNext; } - //if (nextNodes.Any(q => q.ID == curNode.ID)) - //{ - // action.IsSuccessed = false; - // action.Data.CurWO = CurBatch.WO.ORDER_NO; - // action.Data.CurBatch = CurBatch.Batch.BATCH_NO; - // action.LocaleMsg = new($"鏉$爜[{wipSN.SN}]杩囩珯鎵弿閿欒锛岃鍏堥�氳繃浠ヤ笅宸ュ簭锛歿string.Join(", ", nextNodes.Select(q => q.NODE_NAME))}"); - // action.LocaleMsg = new("MES.Transaction.PackingNode.NotNextNodeException", wipSN.SN, string.Join(", ", nextNodes.Select(q => q.NODE_NAME))); - // return action; - //} //褰撳伐姝ュ垪琛ㄤ负绌猴紝鍒欐墽琛屽綋鍓嶅伐搴忕殑蹇呰閫昏緫褰撲綔绗竴涓伐搴忚妭鐐癸紝瀹屾垚鍚庢寜闇�姹傚垱寤哄悗缁殑宸ユ鍒楄〃 if (Steps.IsNullOrEmpty()) @@ -268,7 +279,6 @@ Steps.Clear(); var curStep = new Biz.WorkStep(IWorkStep.Types.Node, this) { - NodeID = curNode.ID, Sequence = Steps.Count + 1, Node = curNode, DBSubmitAction = () => @@ -281,7 +291,7 @@ }; Steps.Add(curStep); - //鏈夐渶瑕佸垯娣诲姞宸ュ簭鑺傜偣鐨勫叾浠栧伐姝� + //鏈夐渶瑕佺敤鎴锋彁浜や俊鎭垯娣诲姞宸ュ簭鑺傜偣鐨勫叾浠栧伐姝� //鏈�鍚庢坊鍔犲綋鍓嶅伐搴忕殑琛屼负宸ユ GenerateSteps(curStep); @@ -302,7 +312,7 @@ //鏈畬鎴愭墍鏈夊伐姝� if (!IsFinishAllSteps) { - var result = new ApiAction<SubmitOutput>(); + var result = new ApiAction<SubmitOutput>(new SubmitOutput()); //鏈畬鎴愭墍鏈夊伐搴忚妭鐐瑰伐姝� if (!IsFinishNodeSteps) { @@ -311,18 +321,14 @@ NextSteps.Clear(); NextSteps.Add(next); //鏍规嵁鍚庣画宸ユ杩斿洖ApiAction - result.Data.IsFinished = IsFinishAllSteps; - result.Data.CurWO = CurBatch.WO.ORDER_NO; - result.Data.CurBatch = CurBatch.Batch.BATCH_NO; - result.Data.CurNode = CurStep.Node.NODE_NAME; - result.Data.NextStepID = next.ID; - + result.Data.SetValue(CurBatch, CurStep, next.ID, IsFinishAllSteps); + //鏍规嵁宸ュ簭鑺傜偣宸ユ鐨勫簭鍙疯繑鍥炵浉搴旂殑鎿嶄綔鎻愮ず switch (next.Sequence) { case 2: //action.LocaleMsg = new($"璇锋墽琛岀浜屾"); - result.LocaleMsg = new("MES.Transaction.PackingNode.绗簩姝ユ搷浣滄彁绀�"); + result.LocaleMsg = new("MES.Transaction.CollectNode.绗簩姝ユ搷浣滄彁绀�"); break; default: break; @@ -338,18 +344,14 @@ //宸插畬鎴愭墍鏈夊伐姝� else { - action.Data.IsFinished = IsFinishAllSteps; - action.Data.CurWO = CurBatch.WO.ORDER_NO; - action.Data.CurBatch = CurBatch.Batch.BATCH_NO; - action.Data.CurNode = CurStep.Node.NODE_NAME; - action.Data.NextStepID = ""; + action.Data.SetValue(CurBatch, CurStep, "", IsFinishAllSteps); action = DoIfFinishAllSteps(action); } } catch (Exception ex) { - ResetSteps(); - action.CatchExceptionWithLog(ex, $"鍖呰宸ュ簭锛氭壂鎻忎骇鍝佹潯鐮佸紓甯�"); + ResetNode(); + action.CatchExceptionWithLog(ex, $"鍖呰宸ュ簭锛氬伐搴忚妭鐐瑰伐姝ユ彁浜ゆ暟鎹紓甯�"); } return action; } @@ -377,11 +379,71 @@ //淇濆瓨鎴愬姛锛岃繑鍥炶繃绔欐秷鎭� //action.LocaleMsg = new($"宸ュ崟[{CurWipSN.WORK_ORDER}]鐨勬潯鐮乕{CurWipSN.SN}]鍦ㄥ矖浣峓{CurWipSN.POST_CODE}]宸ュ簭[{CurWipSN.NODE_NAME}]杩囩珯鎴愬姛锛岀姸鎬乕{CurWipSN.STATUS.GetEnumDesc<MES_WIP_DATA.STATUSs>()}]", CurWipSN.WORK_ORDER, CurWipSN.SN, CurWipSN.POST_CODE, CurWipSN.NODE_NAME, CurWipSN.STATUS.GetEnumDesc<MES_WIP_DATA.STATUSs>()); action.LocaleMsg = new("MES.Transaction.PackingNode.ScanSn.PassSuccess", CurWipSN.WORK_ORDER, CurWipSN.SN, CurWipSN.POST_CODE, CurWipSN.NODE_NAME, CurWipSN.STATUS.GetEnumDesc<MES_WIP_DATA.STATUSs>()); - + //閲嶇疆宸ュ簭 + ResetNode(); return action; } + + /// <summary> + /// 鍖呰宸ュ簭锛氭墜鍔ㄧ粨鏉熷寘瑁� + /// </summary> + /// <returns></returns> + public async Task<ApiAction<SubmitOutput>> CompletePkg() + { + var action = new ApiAction<SubmitOutput>(new SubmitOutput()); + try + { + //PkgSubmit锛氭墜鍔ㄧ粨鏉熷寘瑁咃紝淇濆瓨鏆傚瓨鐨勫寘瑁呮暟鎹� + if (NodeCmd.IsNullOrEmpty("PkgSubmit") == "PkgSubmit") + { + if (Context.ContainsKey("CurPackage")) + { + NodeCmd = "PkgSubmit"; + + TempPkgAction = new PackingAction(); + TempPkgAction.Init(null, this, null, null); + action = TempPkgAction.Submit(null); + } + else + { + action.IsSuccessed = false; + //action.LocaleMsg = new($"鎵句笉鍒版殏瀛樼殑鍖呰鏁版嵁锛屾棤闇�鎵嬪姩缁撴潫鍖呰"); + action.LocaleMsg = new("MES.Transaction.PackingNode.NoCurPackage"); + } + } + //宸ュ簭澶勪簬鍏朵粬鍛戒护妯″紡锛屼笉鍏佽鎵嬪姩缁撴潫鍖呰 + else + { + switch (NodeCmd) + { + case "NodeSubmit": + action.IsSuccessed = false; + //action.LocaleMsg = new($"姝e湪杩涜鏉$爜[{CurWipSN.SN}]鐨勮繃绔欎笟鍔★紝涓嶅厑璁告墜鍔ㄧ粨鏉熷寘瑁�"); + action.LocaleMsg = new("MES.Transaction.PackingNode.WorkingOnNodeSubmit", CurWipSN.SN); + break; + default: + break; + } + } + } + catch (Exception ex) + { + action.CatchExceptionWithLog(ex, $"鍖呰宸ュ簭锛氭墜鍔ㄧ粨鏉熷寘瑁呭紓甯�"); + } + return action; + } + #endregion Functions + /// <summary> + /// 閲嶇疆褰撳墠宸ユ锛屾湁闇�瑕佸垯閲嶅啓姝ゆ柟娉� + /// </summary> + public override void ResetNode() + { + base.ResetNode(); + NodeCmd = null; + } + public override bool Close(bool needSaveHistoryLog = false) { //needSaveHistoryLog = true; -- Gitblit v1.9.3