From ee8d6bd6c4077c3aeb84170bec819264b5ca29d8 Mon Sep 17 00:00:00 2001
From: wxw <Administrator@DESKTOP-5BIMHQ3>
Date: 星期六, 07 六月 2025 11:32:53 +0800
Subject: [PATCH] 任务列表增加单据查询

---
 Admin.NET/WCS.Application/OpenApi/DemoOpenApi.cs |  210 +++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 174 insertions(+), 36 deletions(-)

diff --git a/Admin.NET/WCS.Application/OpenApi/DemoOpenApi.cs b/Admin.NET/WCS.Application/OpenApi/DemoOpenApi.cs
index 8890284..f7ee732 100644
--- a/Admin.NET/WCS.Application/OpenApi/DemoOpenApi.cs
+++ b/Admin.NET/WCS.Application/OpenApi/DemoOpenApi.cs
@@ -1,5 +1,6 @@
 锘縰sing Dm.filter;
 using DocumentFormat.OpenXml.Drawing.Charts;
+using DocumentFormat.OpenXml.Office.CustomUI;
 using DocumentFormat.OpenXml.Presentation;
 using Elastic.Clients.Elasticsearch;
 using Furion.Logging;
@@ -79,6 +80,8 @@
         ResponseModel result = new ResponseModel();
         try
         {
+            string str = JsonConvert.SerializeObject(models);
+            Log.Information("鎺ユ敹WMS鍑哄叆搴撲换鍔★紝浠诲姟鍙凤細" + models.TaskNo + ",鎵樼洏鍙凤細"+ models.PalletNo);
             // 楠岃瘉浠诲姟鏄惁宸插瓨鍦�
             var taskInfo = _db.Queryable<WcsTask>().First(w => w.TaskNo == models.TaskNo);
             if (taskInfo != null)
@@ -97,6 +100,8 @@
             }
             Enum type;
             var bale = "0";
+            var nqty = "0";
+            var ncomqty = "0";
             if (models.TaskType == "0" )
             {
                 type = TaskTypeEnum.In;
@@ -114,6 +119,14 @@
             {
                 type = TaskTypeEnum.Move;
             }
+            if (!string.IsNullOrEmpty( models.Qty))
+            {
+                nqty = models.Qty;
+            }
+            if (!string.IsNullOrEmpty(models.CompleteQty))
+            {
+                nqty = models.CompleteQty;
+            }
             //鏂板浠诲姟
             var taskAdd = new WcsTask()
             {
@@ -123,18 +136,20 @@
                 //IsSuccess =TaskSuccessEnum.Success,
                 Levels = 999,
                 Origin = "WMS",
-                StartRoadway= models.StartRoadway,
+                StartRoadway = models.StartRoadway,
                 StartLocate = models.StartLocate,
                 EndLocate = models.EndLocate,
-                EndRoadway= models.EndRoadway,
+                EndRoadway = models.EndRoadway,
                 PalletNo = models.PalletNo,
                 IsBale = bale,
 
 
-                //LotNo =models.LotNo,
-                //SkuNo=models.SkuNo,
-                //SkuName=models.SkuName,
-                //Qty=models.Qty
+                LotNo = models.LotNo,
+                SkuName = models.SkuName,
+                Qty = int.Parse(nqty),
+                CompleteQty = int.Parse(ncomqty),
+
+                OrderNo = models.OrderNo
             };
             _db.Insertable(taskAdd).ExecuteCommand();           
 
@@ -371,26 +386,129 @@
                 return new ResponseFuMaModel() { Success = "-1", Message = "璇ユ壒娆℃湭杩涜鍒嗘嫞鎴栧凡缁撴壒" };
             }
 
-            //鑾峰彇鍖呰鏁伴噺
             int Fqty = int.Parse(models.FinishQty);
-            var boxinfolog = _db.Queryable<WcsBoxInfoLog>().Where(m => m.SkuNo == models.SkuNo && m.LotNo == models.LotNo && m.BitBoxMark == "0").First();
-            if (boxinfolog == null)
-            {
-                var boxinfo = _db.Queryable<WcsBoxInfo>().Where(m => m.SkuNo == models.SkuNo && m.LotNo == models.LotNo && m.BitBoxMark == "0").First();
-                Fqty = (int)(Fqty /boxinfo.QtyCount);
-            }
-            else
-            {
-                Fqty = (int)(Fqty / boxinfolog.QtyCount);
-            }
-            
+            int Jpqty = 0;
             //鍐欏叆璇ヤ换鍔″畬鎴愭暟閲�
             foreach (var item in num)
             {
+                int jp = 0;//缁撴壒鏄惁闇�瑕佺粍鐩�0锛氫笉闇�瑕侊紝1锛氶渶瑕併�備笉闇�瑕佺粍鐩樺垯鐩存帴閲婃斁鍒嗛亾锛岄渶瑕佺粍鐩樺垯涓嬪彂PLC棰勭粨鎵逛俊鍙�
                 item.FinishQty = Fqty;
-            }
-            _db.Updateable(num).ExecuteCommand();
+                //鍒ゆ柇褰撳墠鍗曟嵁鐮佸灈鏁伴噺鏄惁鍜屽畬宸ユ暟閲忕浉绛夛紝鏄垯缁撴壒璇ュ崟鎹�
+                //鑾峰彇宸茬粍鐩樻暟閲�
+                var checkNum = _db.Queryable<WcsBoxInfoLog>().Where(m => m.SkuNo == models.SkuNo && m.LotNo == models.LotNo && m.OrderCode == item.OrderNo).ToList();//缁勭洏琛ㄧ鐮佷俊鎭�
+                if (checkNum.Count>0)
+                {
+                    if (!(string.IsNullOrEmpty(checkNum.First().BoxNo2))||!(string.IsNullOrEmpty(checkNum.First().BoxNo3)))//鏈夋敮鐮�
+                    {
+                        foreach (var item2 in checkNum)
+                        {
+                            Jpqty = (int)(Jpqty + item2.Qty);
+                        }
+                    }
+                    else//鏃犳敮鐮�
+                    {
+                        foreach (var item2 in checkNum)
+                        {
+                            Jpqty = (int)(Jpqty + item2.QtyCount);
+                        }
+                    }
+                }
+                
+                //鑾峰彇宸叉彃鐮佹暟閲�
+                var checkNum2 = _db.Queryable<WcsBoxInfo>().Where(m =>m.BitBoxMark != "1" && m.SkuNo == models.SkuNo && m.LotNo == models.LotNo &&(m.PalletNo != null || m.PalletNo != "") && m.OrderCode == item.OrderNo).ToList();//绠辩爜琛ㄥ凡鐮佸灈绠辩爜淇℃伅
+                if (checkNum2.Count>0)
+                {
+                    jp = 1;//绠辩爜琛ㄨ繕鏈夋湭缁勭洏绠憋紝闇�瑕佺粍鐩�
+                    if (!string.IsNullOrEmpty(checkNum2.First().BoxNo2)||!string.IsNullOrEmpty(checkNum2.First().BoxNo3))//鏈夋敮鐮�
+                    {
+                        foreach (var item2 in checkNum2)
+                        {
+                            Jpqty = (int)(Jpqty + item2.Qty);
+                        }
+                    }
+                    else//鏃犳敮鐮�
+                    {
+                        foreach (var item2 in checkNum2)
+                        {
+                            Jpqty = (int)(Jpqty + item2.QtyCount);
+                        }
+                    }
+                }
 
+                //鑾峰彇闆剁鏁伴噺
+                var checkNum3 = _db.Queryable<WcsBoxInfo>().Where(m => m.BitBoxMark == "1" && m.SkuNo == models.SkuNo && m.LotNo == models.LotNo).ToList();
+                if (checkNum3.Count > 0) 
+                {
+                    if (!string.IsNullOrEmpty(checkNum3.First().BoxNo2) || !string.IsNullOrEmpty(checkNum3.First().BoxNo3))//鏈夋敮鐮�
+                    {
+                        foreach (var item3 in checkNum3)
+                        {
+                            Jpqty = (int)(Jpqty + item3.Qty);
+                        }
+                    }
+                    else//鏃犳敮鐮�
+                    {
+                        foreach (var item3 in checkNum3)
+                        {
+                            Jpqty = (int)(Jpqty + item3.QtyCount);
+                        }
+                    }
+                }
+
+                if (Jpqty == Fqty)
+                {
+                    var modPlc = _db.Queryable<WcsPlc>().Where(s => s.Type == PLCTypeEnum.ConveyorLine && s.Text == ("2灞傛墭鐩樿緭閫佺嚎")).First();
+                    if (modPlc == null)
+                        throw Oops.Bah("鏈壘鍒拌緭閫佺嚎PLC");
+                    PLCUtil plcConn = new PLCUtil(modPlc);
+                    //鍒ゆ柇褰撳墠鍒嗛亾鏄惁鏈夋湭缁勭洏绠�
+                    if (jp == 0)
+                    {
+                        // 鍒嗛亾瑙g粦锛屾姄绠卞搧绉嶅啓鍏�0
+                        var ret1 = plcConn.SetPlcDBValue(item.PosTypeLot, item.DbNumber, item.PlcPos, "0");
+                        if (ret1.IsSucceed)
+                        {
+                            //鏇存柊鍏ュ簱璁㈠崟
+                            var orderTask = _db.Queryable<WcsOderTask>().Where(w => w.SkuNo == item.SkuNo && w.LotNo == item.LotNo && w.IsDelete == false).ToList();
+                            if (orderTask.Count > 0)
+                            {
+                                foreach (var item2 in orderTask)
+                                {
+                                    item2.Status = TaskStatusEnum.Complete;
+                                    _db.Updateable(item2).ExecuteCommand();
+                                }
+                            }
+                            //鍐欏叆娴佺▼瀛楁垚鍔熷悗鏇存柊鍒嗘嫞浠诲姟    liudl 鏈�鍚庝竴鎵樼洏鐢宠瀹屽叆搴撴墠鍙竻绌�
+                            item.OrderNo = "";
+                            item.TaskNo = "";
+                            item.LotNo = "";
+                            item.SkuNo = "";
+                            item.SkuName = "";
+                            item.BoxType = "";
+                            item.Qty = 0;
+                            item.PZNo = "";
+                            item.Status = "0";      // 缁戝畾鍒嗛亾 0锛氳В缁�  1锛氱粦瀹� 
+                            item.FinishQty = 0;
+
+                            //鏇存柊鍒嗘嫞浠诲姟
+                            _db.Updateable(item).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync();
+                        }
+                    }
+                    else 
+                    { 
+                        //棰勭粨鎵逛俊鍙蜂笅鍙�
+                    
+                        var ret2 = plcConn.SetPlcDBValue(item.PosType, item.DbNumber, item.PosLot, "1");//鍐欏叆寮�濮嬬粨鎵逛俊鍙�
+                        if (ret2.IsSucceed)
+                        {
+                            item.Status = "2";//缁撴壒涓�
+                        }
+                        else { throw new Exception("瀹屽伐缁撴壒淇″彿涓嬪彂缁橮LC閿欒"); }
+                    }
+                    _db.Updateable(item).ExecuteCommand();
+                }
+            }
+            
             return new ResponseFuMaModel() { Success = "0", Message = "鎺ュ彈瀹屽伐缁撴壒鏁伴噺鎴愬姛" };
         }
         catch (Exception ex)
@@ -415,36 +533,42 @@
             string str = JsonConvert.SerializeObject(models);
             Log.Information("鎺ユ敹WMS鍏ュ簱鏀捐揣纭锛屾斁璐у彛锛�" + models.Port+"鍏ュ簱鍙�");
 
-            var portno = "";
+            var portno = models.Port;
+            var layer = "3";
             switch (models.Port)
             {
                 case "033":
                     portno = "33";
+                    layer = "1";
                     break;
                 case "039":
                     portno = "39";
+                    layer = "1";
                     break;
                 case "044":
                     portno = "44";
+                    layer = "1";
                     break;
                 case "051":
                     portno = "51";
+                    layer = "1";
                     break;
             }
 
             //妫�娴嬪叆搴撳彛鐘舵�侊紝120涓哄彲鏀撅紝鍗犵敤鍒欎慨鏀逛负130
-
-            WcsDeviceDto mod = new WcsDeviceDto();
-            var plcConn = mod.PLCUtil;
+            var modPlc = _db.Queryable<WcsPlc>().Where(s => s.Type == PLCTypeEnum.ConveyorLine && s.Text == (layer + "灞傛墭鐩樿緭閫佺嚎")).First();
+            if (modPlc == null)
+                throw Oops.Bah("鏈壘鍒拌緭閫佺嚎PLC");
+            PLCUtil plcConn = new PLCUtil(modPlc);
             //鑾峰彇宸ヤ綅鐐逛綅淇℃伅
             var listPlcDevice = _db.Queryable<WcsDevice>().Where(s => s.LedIP != null && s.StationNum == portno).First();
-            var modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "PLC娴佺▼瀛�").First();
+            var modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "PLC").First();
 
             var (res1, val) = plcConn.GetPlcDBValue(modDevice.PosType, listPlcDevice.DbNumber, modDevice.PlcPos);
             if (val.ToString() == "120")
             {
                 //璇诲彇鎴愬姛鍚庡啓鍏�130
-                modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS娴佺▼瀛�").First();
+                modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS").First();
                 var ret = plcConn.SetPlcDBValue(modDevice.PosType, listPlcDevice.DbNumber, modDevice.PlcPos, "130");//鍗犵敤姝ゅ伐浣�
                 if (ret.IsSucceed)
                 {
@@ -473,33 +597,40 @@
         try
         {
             string str = JsonConvert.SerializeObject(models);
-            Log.Information("鎺ユ敹WMS鍏ュ簱鏀捐揣纭锛屾斁璐у彛锛�" + models.Port + "鍏ュ簱鍙�");
+            Log.Information("鎺ユ敹WMS鍏ュ簱鏀捐揣璇锋眰锛屾斁璐у彛锛�" + models.Port + "鍏ュ簱鍙�");
 
-            var portno = "";
+            var portno = models.Port;
+            var layer = "3";
             switch (models.Port)
             {
                 case "033":
                     portno = "33";
+                    layer = "1";
                     break;
                 case "039":
                     portno = "39";
+                    layer = "1";
                     break;
                 case "044":
                     portno = "44";
+                    layer = "1";
                     break;
                 case "051":
                     portno = "51";
+                    layer = "1";
                     break;
             }
 
-            WcsDeviceDto mod = new WcsDeviceDto();
-            var plcConn = mod.PLCUtil;
+            var modPlc = _db.Queryable<WcsPlc>().Where(s => s.Type == PLCTypeEnum.ConveyorLine && s.Text == (layer + "灞傛墭鐩樿緭閫佺嚎")).First();
+            if (modPlc == null)
+                throw Oops.Bah("鏈壘鍒拌緭閫佺嚎PLC");
+            PLCUtil plcConn = new PLCUtil(modPlc);
             //鑾峰彇宸ヤ綅鐐逛綅淇℃伅
             var listPlcDevice = _db.Queryable<WcsDevice>().Where(s=>s.LedIP != null && s.StationNum == portno).First();
             var modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "浠诲姟鍙�").First();
             plcConn.SetPlcDBValue(modDevice.PosType, listPlcDevice.DbNumber, modDevice.PlcPos, models.TaskNo);//鍐欏叆浠诲姟鍙�
                                                                                                               //
-            modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS娴佺▼瀛�").First();
+            modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS").First();
             var ret = plcConn.SetPlcDBValue(modDevice.PosType, listPlcDevice.DbNumber, modDevice.PlcPos, "140");//鍐欏叆寮�濮嬫斁璐т俊鍙�
             if (ret.IsSucceed)
             {
@@ -529,30 +660,37 @@
         try
         {
             string str = JsonConvert.SerializeObject(models);
-            Log.Information("鎺ユ敹WMS鍏ュ簱鏀捐揣纭锛屾斁璐у彛锛�" + models.Port + "鍏ュ簱鍙�");
+            Log.Information("鎺ユ敹WMS鍏ュ簱鏀捐揣瀹屾垚锛屾斁璐у彛锛�" + models.Port + "鍏ュ簱鍙�");
 
-            var portno = "";
+            var portno = models.Port;
+            var layer = "3";
             switch (models.Port)
             {
                 case "033":
                     portno = "33";
+                    layer = "1";
                     break;
                 case "039":
                     portno = "39";
+                    layer = "1";
                     break;
                 case "044":
                     portno = "44";
+                    layer = "1";
                     break;
                 case "051":
                     portno = "51";
+                    layer = "1";
                     break;
             }
 
-            WcsDeviceDto mod = new WcsDeviceDto();
-            var plcConn = mod.PLCUtil;
+            var modPlc = _db.Queryable<WcsPlc>().Where(s => s.Type == PLCTypeEnum.ConveyorLine && s.Text == (layer + "灞傛墭鐩樿緭閫佺嚎")).First();
+            if (modPlc == null)
+                throw Oops.Bah("鏈壘鍒拌緭閫佺嚎PLC");
+            PLCUtil plcConn = new PLCUtil(modPlc);
             //鑾峰彇宸ヤ綅鐐逛綅淇℃伅
             var listPlcDevice = _db.Queryable<WcsDevice>().Where(s => s.LedIP != null && s.StationNum == portno).First();
-            var modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS娴佺▼瀛�").First();
+            var modDevice = _db.Queryable<WcsPosition>().Where(s => s.StationNum == portno && s.Text == "WCS").First();
 
             var ret = plcConn.SetPlcDBValue(modDevice.PosType, listPlcDevice.DbNumber, modDevice.PlcPos, "160");//鏀惧畬鎴�
             if (ret.IsSucceed)

--
Gitblit v1.8.0