From 9da68fc16ccd0fba6472096ae298e4bcdf5d12b8 Mon Sep 17 00:00:00 2001 From: Ben Lin <maobin001@msn.com> Date: 星期一, 04 十一月 2024 15:43:56 +0800 Subject: [PATCH] 从工单中解绑正在生产的条码api --- Tiger.Business.MES/BIZ/BIZ_MES_WO.cs | 152 ++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 145 insertions(+), 7 deletions(-) diff --git a/Tiger.Business.MES/BIZ/BIZ_MES_WO.cs b/Tiger.Business.MES/BIZ/BIZ_MES_WO.cs index f135d86..c4c1db2 100644 --- a/Tiger.Business.MES/BIZ/BIZ_MES_WO.cs +++ b/Tiger.Business.MES/BIZ/BIZ_MES_WO.cs @@ -18,6 +18,7 @@ using System.Drawing.Printing; using System.Net.NetworkInformation; using Tiger.Model.MES.Yada; +using static Microsoft.CodeAnalysis.CSharp.SyntaxTokenParser; namespace Tiger.Business.MES { @@ -453,13 +454,104 @@ } /// <summary> + /// 鏇存柊琛屼负涓殑绠卞彿 + /// </summary> + /// <param name="code"></param> + /// <returns></returns> + public async Task<ApiAction> SavePrintLabelInAct(string code) + { + var result = new ApiAction(); + try + { + var woSn = await Biz.Db.Queryable<BIZ_MES_WO_SN>().Where(q=>q.SN == code || q.FLOW_SN == code || q.OUTER_SN == code).FirstAsync(); + if (woSn == null) + { + result.IsSuccessed = false; + result.LocaleMsg = new($"鏉$爜涓嶅瓨鍦紒"); + return result; + } + //鍙栧緱鍖呰鍒楄〃 + var pkgList = Biz.Db.Queryable<MES_WIP_PKG>().Where(q => q.PARENT_SN == woSn.OUTER_SN && q.OPER_CODE == "SpecPackingNode").ToList(); + if (pkgList.Count == 0) + { + result.IsSuccessed = false; + result.LocaleMsg = new($"鏉$爜涓嶅瓨鍦紒"); + return result; + } + List<MES_WIP_ACT> actlist = new List<MES_WIP_ACT>(); + //瀹㈡埛鏍囩 + var wipAct = Biz.Db.Queryable<MES_WIP_ACT>().Where(q => q.CARTON_SN == woSn.OUTER_SN && q.NODE_ID == pkgList[0].NODE_ID && !SqlFunc.IsNullOrEmpty(q.ACT_VALUE_3)).First(); + if (!wipAct.IsNullOrEmpty()) + { + var label = JsonConvert.DeserializeObject<BAS_LABEL_TEMP>(wipAct.ACT_VALUE_3); + var cardNo = label.Variables.Where(q => q.VAR_NAME == "CardQR").FirstOrDefault(); + if (!woSn.OUTER_SN.IsNullOrEmpty() && !cardNo.IsNullOrEmpty() && !cardNo.Value.StartsWith(woSn.OUTER_SN)) + { + cardNo.Value = $"{woSn.OUTER_SN}{cardNo.Value}"; + } + string ACT_VALUE_3 = JsonConvert.SerializeObject(label); + foreach (var pkg in pkgList) + { + var actSn = Biz.Db.Queryable<MES_WIP_ACT>().Where(q => q.WIP_ID == pkg.WIP_ID && q.NODE_ID == pkg.NODE_ID && q.ACT_VALUE_4 == "Customer").First(); + if (!actSn.IsNullOrEmpty()) + { + actSn.ACT_VALUE_3 = ACT_VALUE_3; + actlist.Add(actSn); + } + } + } + //鍏ュ簱鏍囩 + var wipActInStore = Biz.Db.Queryable<MES_WIP_ACT>().Where(q => q.SN == woSn.SN && q.NODE_ID == pkgList[0].NODE_ID && !SqlFunc.IsNullOrEmpty(q.ACT_VALUE_3) && q.ACT_VALUE_4 == "InStroe").First(); + if (!wipActInStore.IsNullOrEmpty()) + { + var label = JsonConvert.DeserializeObject<BAS_LABEL_TEMP>(wipActInStore.ACT_VALUE_3); + var cardNo = label.Variables.Where(q => q.VAR_NAME == "CardQR").FirstOrDefault(); + if (!woSn.OUTER_SN.IsNullOrEmpty() && !cardNo.IsNullOrEmpty() && !cardNo.Value.StartsWith(woSn.OUTER_SN)) + { + cardNo.Value = $"{woSn.OUTER_SN}{cardNo.Value}"; + } + var xh = label.Variables.Where(q => q.VAR_NAME == "XH").FirstOrDefault(); + if (!woSn.OUTER_SN.IsNullOrEmpty() && !xh.IsNullOrEmpty()) + { + xh.Value = $"{woSn.OUTER_SN}"; + } + string ACT_VALUE_3 = JsonConvert.SerializeObject(label); + foreach (var pkg in pkgList) + { + var actSn = Biz.Db.Queryable<MES_WIP_ACT>().Where(q => q.WIP_ID == pkg.WIP_ID && q.NODE_ID == pkg.NODE_ID && q.ACT_VALUE_4 == "InStroe").First(); + if (!actSn.IsNullOrEmpty()) + { + actSn.ACT_VALUE_3 = ACT_VALUE_3; + actlist.Add(actSn); + } + } + } + var db = Biz.Db; + var dbTran = db.UseTran(() => + { + db.Updateable(actlist).UpdateColumns(q => new { q.ACT_VALUE_3 }).ExecuteCommand(); + }); + if (!dbTran.IsSuccess) + { + result.IsSuccessed = false; + result.LocaleMsg = new($"鏇存柊琛屼负鏃ュ織涓殑绠卞彿寮傚父"); + } + } + catch (Exception ex) + { + result.CatchExceptionWithLog(ex, "鏇存柊琛屼负鏃ュ織涓殑绠卞彿寮傚父"); + } + return result; + } + + /// <summary> /// 鑾峰彇閲嶆墦鏍囩淇℃伅 /// </summary> /// <param name="input"></param> /// <returns></returns> - public async Task<ApiAction<LOG_LABEL_PRINT>> GetRePrintInfo(RePrintInput input) + public async Task<ApiAction> GetRePrintInfo(RePrintInput input) { - var result = new ApiAction<LOG_LABEL_PRINT>(); + var result = new ApiAction(); try { //鍏堟煡鍑哄伐鍗曟潯鐮佷腑鏄惁瀛樺湪 @@ -470,11 +562,30 @@ result.LocaleMsg = new($"鏉$爜涓嶅瓨鍦紒"); return result; } - - result.Data = await Biz.Db.Queryable<LOG_LABEL_PRINT>() + var woNode = await Biz.Db.Queryable<MES_WO_NODE>().Where(q => q.WORK_ORDER.Equals(woSn.WORK_ORDER) && q.OPER_CODE== "SpecPackingNode").FirstAsync(); + if (woNode == null) + { + result.IsSuccessed = false; + result.LocaleMsg = new($"宸ヨ壓璺嚎鑺傜偣[SpecPackingNode-瑁呯]涓嶅瓨鍦�"); + return result; + } + string printParam = ""; + var labelPrint = await Biz.Db.Queryable<LOG_LABEL_PRINT>() .WhereIF(input.ReqType == 0, q => q.SN.Equals(woSn.SN) || q.SN.Equals(woSn.FLOW_SN)) //鐧界洅鏍囩 - .WhereIF(input.ReqType == 1, q => q.SN.Equals(woSn.OUTER_SN)) //绠辨爣绛� + .WhereIF(input.ReqType == 1, q => q.SN.Equals(woSn.OUTER_SN) && q.PRINT_LABEL != "InStoreLabel") //绠辨爣绛�-瀹㈡埛 + .WhereIF(input.ReqType == 2, q => q.SN.Equals(woSn.OUTER_SN) && q.PRINT_LABEL == "InStoreLabel") //绠辨爣绛�-鍏ュ簱 .FirstAsync(); + //濡傛灉鏌ヤ笉鍒板氨鍘昏涓烘棩蹇楁煡 + if (labelPrint.IsNullOrEmpty() && input.ReqType == 1) + { + printParam = Biz.Db.Queryable<MES_WIP_ACT>().Where(q => (q.SN.Equals(input.Code) || q.FLOW_SN.Equals(input.Code)) && q.ACT_VALUE_4 == "Customer").First()?.ACT_VALUE_3 ?? ""; + } + else + { + printParam = labelPrint.PRINT_PARAM; + } + result.Data = printParam; + result.LocaleMsg = new($"閲嶆墦鏉$爜[{input.Code}]鐨勬爣绛炬垚鍔�"); } catch (Exception ex) { @@ -498,11 +609,11 @@ if (db.Queryable<mes_ShipList>().Any(q => q.MoDoc.Equals(wo) && SqlFunc.DateIsSame(q.BusinessDate, DateTime.Now) && q.Status == 2 && q.Org == org.ID.ToInt64())) { result.Data = "Customer"; + result.LocaleMsg = new($"鍑鸿揣淇℃伅瀛樺湪锛�"); } else { - result.LocaleMsg = new($"鍑鸿揣淇℃伅瀛樺湪锛�"); - result.Data = "InStore"; + result.Data = "InStoreLabel"; } } catch (Exception ex) @@ -511,5 +622,32 @@ } return result; } + + /// <summary> + /// + /// </summary> + /// <param name="SN"></param> + /// <param name="user"></param> + /// <returns></returns> + public async Task<ApiAction> UnbindWipSnFromWO(UnbindWipSnInput input) + { + var result = new ApiAction(); + try + { + var wipList = await Biz.Db.Queryable<MES_WIP_DATA>().Where(q => q.SN.Equals(input.SN) || q.FLOW_SN.Equals(input.SN)).ToListAsync(); + if (wipList.Count == 0) + { + result.IsSuccessed = false; + result.LocaleMsg = new($"瑙g粦鐨勬潯鐮佷笉瀛樺湪褰撳墠鎿嶄綔琛ㄤ腑锛�"); + } + var wo = await Biz.Db.Queryable<BIZ_MES_WO>().Where(q => q.ORDER_NO == wipList[0].WORK_ORDER).FirstAsync(); + result = WorkBatch.UnbindWipSnFromWO(wo, wipList, input.user); + } + catch (Exception ex) + { + result.CatchExceptionWithLog(ex, "瑙g粦鏉$爜寮傚父"); + } + return result; + } } } -- Gitblit v1.9.3