From 55e1fa803b11e647a9072502456340e859705c76 Mon Sep 17 00:00:00 2001
From: Zhang-Hong-Lin <a3219986988@163.com>
Date: 星期五, 07 三月 2025 10:20:20 +0800
Subject: [PATCH] 1

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs |   70 ++++++++++++++++++++++++++++++-----
 1 files changed, 60 insertions(+), 10 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
index dd4b366..b89f4b0 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskService.cs"
@@ -185,6 +185,17 @@
         }
 
         /// <summary>
+        /// 鏍规嵁浠诲姟鐘舵�佹煡璇换鍔�
+        /// </summary>
+        /// <param name="deviceNo">璁惧缂栧彿</param>
+        /// <param name="currentAddress">褰撳墠鍦板潃</param>
+        /// <returns></returns>
+        public Dt_Task QueryTaskState()
+        {
+            return BaseDal.QueryFirst(x => x.TaskState== (int)TaskInStatusEnum.InNew );
+        }
+
+        /// <summary>
         /// 鏍规嵁璁惧缂栧彿銆佸綋鍓嶅湴鍧�鏌ヨ杈撻�佺嚎鏈墽琛岀殑浠诲姟
         /// </summary>
         /// <param name="deviceNo">璁惧缂栧彿</param>
@@ -252,19 +263,30 @@
                     //浼樺厛杩斿洖鎵ц鍒颁竴鍗婄殑浠诲姟缁х画鎵ц
                     return task;
                 }
+                else {
+                    //鏌ヨ澶╄溅绉诲姩浠诲姟
+                    task = BaseDal.QueryFirst(v => v.TaskType == (int)TaskMoveEnum.Mowe && v.TaskState == (int)TaskMoveStatusEnum.OutNewMove);
+                    if (task!=null)
+                    {
+                        return task;
+                    }
+                }
                 //鏌ヨ褰撳墠浠诲姟姹犱腑鏄惁瀛樺湪鐘舵�佷负闈炴柊寤虹殑
                 //task= BaseDal.QueryFirst(v => v.TaskState != (int)TaskInStatusEnum.InNew || v.TaskState != (int)TaskOutStatusEnum.OutNew);
                 //if (task != null)
                 //{
                 //    throw new Exception($"褰撳墠浠诲姟姹犱腑瀛樺湪鎵ц涓殑浠诲姟,浠诲姟鍙�:銆恵task.TaskNum}銆�");
                 //}
-                if (workTpe.Equals("In"))
+                if (task.TaskState!= (int)TaskMoveStatusEnum.OutNewMove)
                 {
-                    task = BaseDal.QueryData(v=>v.TaskType==(int)TaskInboundTypeEnum.Inbound && v.TaskState==(int)TaskInStatusEnum.InNew).OrderByDescending(v=>v.Grade) .OrderBy(v=>v.CreateDate).First();
-                }
-                else if (workTpe.Equals("Out"))
-                {
-                    task = BaseDal.QueryData(v => v.TaskType == (int)TaskOutboundTypeEnum.Outbound && v.TaskState == (int)TaskOutStatusEnum.OutNew).OrderBy(v => v.CreateDate).First();
+                    if (workTpe.Equals("In"))
+                    {
+                        task = BaseDal.QueryData(v => v.TaskType == (int)TaskInboundTypeEnum.Inbound && v.TaskState == (int)TaskInStatusEnum.InNew).OrderByDescending(v => v.Grade).OrderBy(v => v.CreateDate).First();
+                    }
+                    else if (workTpe.Equals("Out"))
+                    {
+                        task = BaseDal.QueryData(v => (v.TaskType == (int)TaskOutboundTypeEnum.Outbound || v.TaskType == (int)TaskOutboundTypeEnum.OutInventory) && v.TaskState == (int)TaskOutStatusEnum.OutNew).OrderBy(v => v.CreateDate).First();
+                    }
                 }
             }
             catch (Exception)
@@ -415,7 +437,7 @@
                 {
                     task.TaskState = (int)TaskInStatusEnum.Line_InGrabExecuting;
                 }
-                else if (status == 2 && task.TaskType == (int)TaskOutboundTypeEnum.Outbound)
+                else if (status == 2 && (task.TaskType == (int)TaskOutboundTypeEnum.Outbound || task.TaskType == (int)TaskOutboundTypeEnum.OutInventory))
                 {
                     task.TaskState = (int)TaskOutStatusEnum.Line_OutGrabExecuting;
                 }
@@ -423,9 +445,13 @@
                 {
                     task.TaskState = (int)TaskInStatusEnum.Line_InDownExecuting;
                 }
-                else if (status == 3 && task.TaskType == (int)TaskOutboundTypeEnum.Outbound)
+                else if (status == 3 && task.TaskType == (int)TaskOutboundTypeEnum.Outbound || task.TaskType == (int)TaskOutboundTypeEnum.OutInventory)
                 {
                     task.TaskState = (int)TaskOutStatusEnum.Line_OutWownExecuting;
+                }
+                else if(status == 4 && task.TaskType == (int)TaskMoveEnum.Mowe)
+                {
+                    task.TaskState = (int)TaskMoveStatusEnum.Line_OutMove;
                 }
                 task.ModifyDate = DateTime.Now;
                 BaseDal.UpdateData(task);
@@ -653,7 +679,7 @@
                     taskhty.TaskNum = nawtask.TaskNum;
                     taskhty.Roadway = nawtask.Roadway;
                     taskhty.TaskType = nawtask.TaskType;
-                    taskhty.TaskState = (int)TaskInStatusEnum.Line_InFinish;
+                    taskhty.TaskState = (int)TaskOutStatusEnum.OutFinish;
                     taskhty.SourceAddress = nawtask.SourceAddress;
                     taskhty.TargetAddress = nawtask.TargetAddress;
                     taskhty.ExceptionMessage = nawtask.ExceptionMessage;
@@ -669,7 +695,31 @@
                     _stockRepository.DeleteData(Towstock);
                     _locationRepository.UpdateData(location);
                     _locationRepository.UpdateData(locationTow);
-                    //_taskhtyRepository.AddData(taskhty);
+                    _taskhtyRepository.AddData(taskhty);
+                    BaseDal.DeleteData(nawtask);
+                    //鎻愪氦浜嬪姟
+                    _unitOfWorkManage.CommitTran();
+                }
+                else if (nawtask.TaskType == (int)TaskOutboundTypeEnum.OutInventory || nawtask.TaskType == (int)TaskMoveEnum.Mowe)
+                {
+                    //澶勭悊浠诲姟淇℃伅
+                    Dt_Task_hty taskhty = new Dt_Task_hty();
+                    taskhty.TaskNum = nawtask.TaskNum;
+                    taskhty.Roadway = nawtask.Roadway;
+                    taskhty.TaskType = nawtask.TaskType;
+                    taskhty.TaskState = (int)TaskOutStatusEnum.OutFinish;
+                    taskhty.SourceAddress = nawtask.SourceAddress;
+                    taskhty.TargetAddress = nawtask.TargetAddress;
+                    taskhty.ExceptionMessage = nawtask.ExceptionMessage;
+                    taskhty.Grade = nawtask.Grade;
+                    taskhty.Dispatchertime = nawtask.Dispatchertime;
+                    taskhty.Remark = nawtask.Remark;
+                    taskhty.PalletCode = nawtask.PalletCode;
+                    taskhty.NextAddress = nawtask.NextAddress;
+                    taskhty.CurrentAddress = nawtask.CurrentAddress;
+                    //寮�濮嬫暟鎹簱浜嬪姟
+                    _unitOfWorkManage.BeginTran();
+                    _taskhtyRepository.AddData(taskhty);
                     BaseDal.DeleteData(nawtask);
                     //鎻愪氦浜嬪姟
                     _unitOfWorkManage.CommitTran();

--
Gitblit v1.9.3