From f512b0475560ed449f936e0b7a27ba197e6bafe5 Mon Sep 17 00:00:00 2001
From: IPC-610 <IPC-610@DESKTOP-6LEOOS3>
Date: 星期四, 26 九月 2024 15:16:08 +0800
Subject: [PATCH] Merge branch 'master' of https://gitee.com/liudongl/jc24-wms

---
 Wms/WMS.BLL/BllPdaServer/PdaSoServer.cs |  787 ++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 679 insertions(+), 108 deletions(-)

diff --git a/Wms/WMS.BLL/BllPdaServer/PdaSoServer.cs b/Wms/WMS.BLL/BllPdaServer/PdaSoServer.cs
index b506589..ad272a5 100644
--- a/Wms/WMS.BLL/BllPdaServer/PdaSoServer.cs
+++ b/Wms/WMS.BLL/BllPdaServer/PdaSoServer.cs
@@ -18,6 +18,8 @@
 using WMS.BLL.LogServer;
 using WMS.DAL;
 using WMS.Entity.LogEntity;
+using Model.ModelDto.SysDto;
+using Model.ModelDto.BllSoDto;
 
 namespace WMS.BLL.BllPdaServer
 {
@@ -973,7 +975,9 @@
             try
             {
                 string strMsg = "";
-                var outDtoList = new List<OutCommandDto>(); //鍑哄簱鏁版嵁鐨勯泦鍚� 
+                var outDto1 = new List<OutCommandDto>(); //鍏堝嚭搴撴暟鎹殑闆嗗悎锛堟繁搴︿负1鐨勫偍浣嶏級
+                var outDto2 = new List<OutCommandDto>(); //鍚庡嚭搴撴暟鎹殑闆嗗悎锛堟繁搴︿负2鐨勫偍浣嶏級
+                var moveDto = new List<OutCommandDto>(); //瑕佺Щ搴撴暟鎹殑闆嗗悎
                 //鑾峰彇褰撳墠鏃堕棿
                 DateTime serverTime = Db.GetDate();
                 //鑾峰彇搴撳瓨鏄庣粏鏄惁灏忎簬绛変簬璇ュ灈鏁�
@@ -997,132 +1001,637 @@
                     return strMsg;
                 }
 
-                int i = 0;
-
+                var com = new Common();
                 Db.BeginTran();
 
                 //閬嶅巻搴撳瓨淇℃伅 
                 foreach (var s in stockDetail)
                 {
+                    //if (outDto1.Contains(m=>m.PalletNo == s.PalletNo) >0)
+                    //{
+                    //    continue;
+                    //}
                     //鑾峰彇鍌ㄤ綅淇℃伅
                     var locat = Db.Queryable<SysStorageLocat>().First(l => l.LocatNo == s.LocatNo && l.IsDel == "0" && l.WareHouseNo == "W01");
-
-                    if (locat != null)
+                    if(locat == null)
                     {
-                        if (locat.Status != "1")
-                        {
-                            continue;
-                        }
-                        //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
-                        locat.Status = "3"; //3 鍑哄簱涓�
-                        locat.UpdateTime = serverTime; //淇敼鏃堕棿
-                        locat.UpdateUser = userId; //淇敼浜�
-                        //淇敼鍌ㄤ綅淇℃伅
-                        Db.Updateable(locat).ExecuteCommand();
+                        continue;
                     }
-
-                    //澧炲姞搴撳瓨閿佸畾鏁伴噺
-                    //stock.AllotQty +=
-                    stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
-                    stock.UpdateTime = serverTime; //淇敼鏃堕棿
-                    stock.UpdateUser = userId; //淇敼浜�
-                    //淇敼搴撳瓨鎬昏〃淇℃伅
-                    Db.Updateable(stock).ExecuteCommand();
-
-                    //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
-                    //s.AllotQty += 
-                    s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
-                    s.UpdateTime = serverTime; //淇敼鏃堕棿
-                    s.UpdateUser = userId; //淇敼浜�
-                    s.Status = "2"; //2 宸插垎閰�
-                    //淇敼搴撳瓨鏄庣粏淇℃伅
-                    Db.Updateable(s).ExecuteCommand();
-
-                    #region 鍒嗛厤
-
-                    //娣诲姞鍒嗛厤琛ㄤ俊鎭�
-                    var allot = new BllExportAllot
+                    
+                    ////鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                    //locat.Status = "3"; //3 鍑哄簱涓�
+                    //locat.UpdateTime = serverTime; //淇敼鏃堕棿
+                    //locat.UpdateUser = userId; //淇敼浜�
+                    ////淇敼鍌ㄤ綅淇℃伅
+                    //Db.Updateable(locat).ExecuteCommand();
+                    
+                    if (locat.Status == "1")
                     {
-                        SONo = "",
-                        WaveNo = "",
-                        SODetailNo = 0,
-                        StockId = s.Id,
-                        LotNo = "",
-                        LotText = "",
-                        SupplierLot = "",
-                        SkuNo = s.SkuNo,
-                        SkuName = s.SkuName,
-                        Standard = s.Standard,
-                        PalletNo = s.PalletNo,
-                        IsBale = "0", //鏄惁瑁瑰寘
-                        IsBelt = "0", //鏄惁鎵撳甫
+                        if (locat.Depth == "01") //娣卞害涓�1
+                        {
+                            #region 鏀瑰彉搴撳瓨
 
-                        //BoxexQty = s.Qty,
-                        Qty = (int)s.Qty,
-                        CompleteQty = 0,
-                        Status = "1",
-                        LogisticsId = 0,
-                        IsAdvance = "0",
-                        OutMode = model.OutMode,//鍑哄簱鍙�
+                            //澧炲姞搴撳瓨閿佸畾鏁伴噺
+                            stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                            stock.UpdateTime = serverTime; //淇敼鏃堕棿
+                            stock.UpdateUser = userId; //淇敼浜�
+                            Db.Updateable(stock).ExecuteCommand();//淇敼搴撳瓨鎬昏〃淇℃伅
 
-                        CreateUser = userId,
-                        CreateTime = DateTime.Now
-                    };
-                    Db.Insertable(allot).ExecuteCommand();
+                            //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                            s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                            s.UpdateTime = serverTime; //淇敼鏃堕棿
+                            s.UpdateUser = userId; //淇敼浜�
+                            s.Status = "2"; //2 宸插垎閰�
+                            Db.Updateable(s).ExecuteCommand();//淇敼搴撳瓨鏄庣粏淇℃伅
 
-                    #endregion
+                            #endregion
 
-                    #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+                            #region 鍒嗛厤
 
-                    var taskNo = new Common().GetMaxNo("TK");
-                    var exTask = new LogTask    //鍑哄簱浠诲姟
+                            //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                            var allot = new BllExportAllot
+                            {
+                                SONo = "",
+                                WaveNo = "",
+                                SODetailNo = 0,
+                                StockId = s.Id,
+                                LotNo = "",
+                                LotText = "",
+                                SupplierLot = "",
+                                SkuNo = s.SkuNo,
+                                SkuName = s.SkuName,
+                                Standard = s.Standard,
+                                PalletNo = s.PalletNo,
+                                IsBale = "0", //鏄惁瑁瑰寘
+                                IsBelt = "0", //鏄惁鎵撳甫
+
+                                //BoxexQty = s.Qty,
+                                Qty = (int)s.Qty,
+                                CompleteQty = 0,
+                                Status = "1",
+                                LogisticsId = 0,
+                                IsAdvance = "0",
+                                OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                CreateUser = userId,
+                                CreateTime = DateTime.Now
+                            };
+                            Db.Insertable(allot).ExecuteCommand();
+
+                            #endregion
+
+                            #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+
+                            var taskNo = new Common().GetMaxNo("TK");
+                            var exTask = new LogTask    //鍑哄簱浠诲姟
+                            {
+                                TaskNo = taskNo,
+                                Sender = "WMS",
+                                Receiver = "PDA",
+                                IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                IsCancel = 1,//鏄惁鍙彇娑�
+                                IsFinish = 1,//鏄惁鍙畬鎴�
+                                Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                CreateUser = userId, //鍒涘缓浜�
+                                Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                 //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                            };
+                            outDto1.Add(new OutCommandDto()
+                            {
+                                PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                OutMode = model.OutMode,  //鐩爣鍦板潃
+                                Order = 1
+                            });
+                            Db.Insertable(exTask).ExecuteCommand();
+
+                            #endregion
+
+                            #region 鍌ㄤ綅鐘舵�佸彉鏇�
+                            //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                            locat.Status = "3"; //3 鍑哄簱涓�
+                            Db.Updateable(locat).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                            #endregion
+                        }
+                        else if (locat.Depth == "02") //娣卞害涓�2
+                        {
+                            //鑾峰彇鍑哄簱娣卞害涓�2鍌ㄤ綅鍓嶉潰鐨勫偍浣嶄俊鎭�
+                            var sql2 = $@"select * from SysStorageLocat where  WareHouseNo = '{locat.WareHouseNo}' and row = {locat.Row} and [Column] = {locat.Column} and Layer = {locat.Layer} and Depth = '01'; ";
+                            var slotBefore = Db.Ado.SqlQuery<SysStorageLocat>(sql2).First();
+                            if (slotBefore == null)
+                            {
+                                #region 鏀瑰彉搴撳瓨
+
+                                //澧炲姞搴撳瓨閿佸畾鏁伴噺
+                                stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                stock.UpdateTime = serverTime; //淇敼鏃堕棿
+                                stock.UpdateUser = userId; //淇敼浜�
+                                Db.Updateable(stock).ExecuteCommand();//淇敼搴撳瓨鎬昏〃淇℃伅
+
+                                //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                                s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                s.UpdateTime = serverTime; //淇敼鏃堕棿
+                                s.UpdateUser = userId; //淇敼浜�
+                                s.Status = "2"; //2 宸插垎閰�
+                                Db.Updateable(s).ExecuteCommand();//淇敼搴撳瓨鏄庣粏淇℃伅
+
+                                #endregion
+
+                                #region 鍒嗛厤
+
+                                //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                                var allot = new BllExportAllot
+                                {
+                                    SONo = "",
+                                    WaveNo = "",
+                                    SODetailNo = 0,
+                                    StockId = s.Id,
+                                    LotNo = "",
+                                    LotText = "",
+                                    SupplierLot = "",
+                                    SkuNo = s.SkuNo,
+                                    SkuName = s.SkuName,
+                                    Standard = s.Standard,
+                                    PalletNo = s.PalletNo,
+                                    IsBale = "0", //鏄惁瑁瑰寘
+                                    IsBelt = "0", //鏄惁鎵撳甫
+
+                                    //BoxexQty = s.Qty,
+                                    Qty = (int)s.Qty,
+                                    CompleteQty = 0,
+                                    Status = "1",
+                                    LogisticsId = 0,
+                                    IsAdvance = "0",
+                                    OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                    CreateUser = userId,
+                                    CreateTime = DateTime.Now
+                                };
+                                Db.Insertable(allot).ExecuteCommand();
+
+                                #endregion
+
+                                #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+
+                                var taskNo = new Common().GetMaxNo("TK");
+                                var exTask = new LogTask    //鍑哄簱浠诲姟
+                                {
+                                    TaskNo = taskNo,
+                                    Sender = "WMS",
+                                    Receiver = "PDA",
+                                    IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                    StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                    EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                    PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                    IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                    IsCancel = 1,//鏄惁鍙彇娑�
+                                    IsFinish = 1,//鏄惁鍙畬鎴�
+                                    Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                    Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                    OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                    CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                    CreateUser = userId, //鍒涘缓浜�
+                                    Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                     //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                                };
+                                outDto1.Add(new OutCommandDto()
+                                {
+                                    PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                    StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                    StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                    EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                    TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                    TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                    OutMode = model.OutMode,  //鐩爣鍦板潃
+                                    Order = 1
+                                });
+                                Db.Insertable(exTask).ExecuteCommand();
+
+                                #endregion
+
+                                #region 鍌ㄤ綅鐘舵�佸彉鏇�
+                                //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                                locat.Status = "3"; //3 鍑哄簱涓�
+                                Db.Updateable(locat).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                                #endregion
+                            }
+                            else
+                            {
+                                //鍒ゆ柇鍌ㄤ綅鐘舵��
+                                if (slotBefore.Status == "0")
+                                {
+                                    #region 鏀瑰彉搴撳瓨
+
+                                    //澧炲姞搴撳瓨閿佸畾鏁伴噺
+                                    stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                    stock.UpdateTime = serverTime; //淇敼鏃堕棿
+                                    stock.UpdateUser = userId; //淇敼浜�
+                                    Db.Updateable(stock).ExecuteCommand();//淇敼搴撳瓨鎬昏〃淇℃伅
+
+                                    //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                                    s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                    s.UpdateTime = serverTime; //淇敼鏃堕棿
+                                    s.UpdateUser = userId; //淇敼浜�
+                                    s.Status = "2"; //2 宸插垎閰�
+                                    Db.Updateable(s).ExecuteCommand();//淇敼搴撳瓨鏄庣粏淇℃伅
+
+                                    #endregion
+
+                                    #region 鍒嗛厤
+
+                                    //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                                    var allot = new BllExportAllot
+                                    {
+                                        SONo = "",
+                                        WaveNo = "",
+                                        SODetailNo = 0,
+                                        StockId = s.Id,
+                                        LotNo = "",
+                                        LotText = "",
+                                        SupplierLot = "",
+                                        SkuNo = s.SkuNo,
+                                        SkuName = s.SkuName,
+                                        Standard = s.Standard,
+                                        PalletNo = s.PalletNo,
+                                        IsBale = "0", //鏄惁瑁瑰寘
+                                        IsBelt = "0", //鏄惁鎵撳甫
+
+                                        //BoxexQty = s.Qty,
+                                        Qty = (int)s.Qty,
+                                        CompleteQty = 0,
+                                        Status = "1",
+                                        LogisticsId = 0,
+                                        IsAdvance = "0",
+                                        OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                        CreateUser = userId,
+                                        CreateTime = DateTime.Now
+                                    };
+                                    Db.Insertable(allot).ExecuteCommand();
+
+                                    #endregion
+
+                                    #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+
+                                    var taskNo = new Common().GetMaxNo("TK");
+                                    var exTask = new LogTask    //鍑哄簱浠诲姟
+                                    {
+                                        TaskNo = taskNo,
+                                        Sender = "WMS",
+                                        Receiver = "PDA",
+                                        IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                        StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                        EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                        PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                        IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                        IsCancel = 1,//鏄惁鍙彇娑�
+                                        IsFinish = 1,//鏄惁鍙畬鎴�
+                                        Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                        Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                        OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                        CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                        CreateUser = userId, //鍒涘缓浜�
+                                        Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                         //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                                    };
+                                    outDto1.Add(new OutCommandDto()
+                                    {
+                                        PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                        StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                        StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                        EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                        TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                        TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                        OutMode = model.OutMode,  //鐩爣鍦板潃
+                                        Order = 1
+                                    });
+                                    Db.Insertable(exTask).ExecuteCommand();
+
+                                    #endregion
+
+                                    #region 鍌ㄤ綅鐘舵�佸彉鏇�
+                                    //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                                    locat.Status = "3"; //3 鍑哄簱涓�
+                                    Db.Updateable(locat).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                                    #endregion
+                                }
+                                else if(slotBefore.Status == "1")
+                                {
+                                    //鍒ゆ柇鎵樼洏涓婄墿鏂�
+                                    var pallSku = Db.Queryable<DataStockDetail>().First(m=>m.SkuNo == "100099" && m.LocatNo == slotBefore.LocatNo);
+                                    if (pallSku == null) //绉诲簱
+                                    {
+                                        #region 鍒嗛厤
+
+                                        //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                                        var allot = new BllExportAllot
+                                        {
+                                            SONo = "",
+                                            WaveNo = "",
+                                            SODetailNo = 0,
+                                            StockId = s.Id,
+                                            LotNo = "",
+                                            LotText = "",
+                                            SupplierLot = "",
+                                            SkuNo = s.SkuNo,
+                                            SkuName = s.SkuName,
+                                            Standard = s.Standard,
+                                            PalletNo = s.PalletNo,
+                                            IsBale = "0", //鏄惁瑁瑰寘
+                                            IsBelt = "0", //鏄惁鎵撳甫
+
+                                            //BoxexQty = s.Qty,
+                                            Qty = (int)s.Qty,
+                                            CompleteQty = 0,
+                                            Status = "1",
+                                            LogisticsId = 0,
+                                            IsAdvance = "0",
+                                            OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                            CreateUser = userId,
+                                            CreateTime = DateTime.Now
+                                        };
+                                        Db.Insertable(allot).ExecuteCommand();
+
+                                        #endregion
+
+                                        #region 娣诲姞绉诲簱浠诲姟淇℃伅
+
+                                        var taskNo = new Common().GetMaxNo("TK");
+                                        var exTask = new LogTask    //鍑哄簱浠诲姟
+                                        {
+                                            TaskNo = taskNo,
+                                            Sender = "WMS",
+                                            Receiver = "PDA",
+                                            IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                            StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                            EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                            PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                            IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                            IsCancel = 1,//鏄惁鍙彇娑�
+                                            IsFinish = 1,//鏄惁鍙畬鎴�
+                                            Type = "2",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                            Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                            OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                            CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                            CreateUser = userId, //鍒涘缓浜�
+                                            Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勭Щ搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                             //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                                        };
+                                        moveDto.Add(new OutCommandDto()
+                                        {
+                                            PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                            StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                            StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                            EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                            TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                            TaskType = "2",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                            OutMode = model.OutMode,  //鐩爣鍦板潃
+                                            Order = 1
+                                        });
+                                        Db.Insertable(exTask).ExecuteCommand();
+
+                                        #endregion
+
+                                        #region 鍌ㄤ綅鐘舵�佸彉鏇�
+                                        //鏇存敼鍌ㄤ綅鐘舵�佷负绉诲嚭涓�
+                                        slotBefore.Status = "5"; //5 绉诲嚭涓�
+                                        Db.Updateable(slotBefore).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                                        #endregion
+                                    }
+                                    else  //鍑哄簱
+                                    {
+                                        #region 鏀瑰彉搴撳瓨
+
+                                        //澧炲姞搴撳瓨閿佸畾鏁伴噺
+                                        stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                        stock.UpdateTime = serverTime; //淇敼鏃堕棿
+                                        stock.UpdateUser = userId; //淇敼浜�
+                                        Db.Updateable(stock).ExecuteCommand();//淇敼搴撳瓨鎬昏〃淇℃伅
+
+                                        //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                                        s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                        s.UpdateTime = serverTime; //淇敼鏃堕棿
+                                        s.UpdateUser = userId; //淇敼浜�
+                                        s.Status = "2"; //2 宸插垎閰�
+                                        Db.Updateable(s).ExecuteCommand();//淇敼搴撳瓨鏄庣粏淇℃伅
+
+                                        #endregion
+
+                                        #region 鍒嗛厤
+
+                                        //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                                        var allot = new BllExportAllot
+                                        {
+                                            SONo = "",
+                                            WaveNo = "",
+                                            SODetailNo = 0,
+                                            StockId = s.Id,
+                                            LotNo = "",
+                                            LotText = "",
+                                            SupplierLot = "",
+                                            SkuNo = s.SkuNo,
+                                            SkuName = s.SkuName,
+                                            Standard = s.Standard,
+                                            PalletNo = s.PalletNo,
+                                            IsBale = "0", //鏄惁瑁瑰寘
+                                            IsBelt = "0", //鏄惁鎵撳甫
+
+                                            //BoxexQty = s.Qty,
+                                            Qty = (int)s.Qty,
+                                            CompleteQty = 0,
+                                            Status = "1",
+                                            LogisticsId = 0,
+                                            IsAdvance = "0",
+                                            OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                            CreateUser = userId,
+                                            CreateTime = DateTime.Now
+                                        };
+                                        Db.Insertable(allot).ExecuteCommand();
+
+                                        #endregion
+
+                                        #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+
+                                        var taskNo = new Common().GetMaxNo("TK");
+                                        var exTask = new LogTask    //鍑哄簱浠诲姟
+                                        {
+                                            TaskNo = taskNo,
+                                            Sender = "WMS",
+                                            Receiver = "PDA",
+                                            IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                            StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                            EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                            PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                            IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                            IsCancel = 1,//鏄惁鍙彇娑�
+                                            IsFinish = 1,//鏄惁鍙畬鎴�
+                                            Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                            Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                            OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                            CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                            CreateUser = userId, //鍒涘缓浜�
+                                            Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                             //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                                        };
+                                        outDto2.Add(new OutCommandDto()
+                                        {
+                                            PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                            StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                            StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                            EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                            TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                            TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                            OutMode = model.OutMode,  //鐩爣鍦板潃
+                                            Order = 1
+                                        });
+                                        Db.Insertable(exTask).ExecuteCommand();
+
+                                        #endregion
+                                        #region 鍌ㄤ綅鐘舵�佸彉鏇�
+                                        //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                                        slotBefore.Status = "3"; //3 鍑哄簱涓�
+                                        Db.Updateable(slotBefore).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                                        #endregion
+                                    }
+                                    if (int.Parse(model.Num) == outDto1.Count + outDto2.Count)
+                                    {
+                                        break;//闇�姹傚灈鏁板凡杈惧埌 鍙互鍑哄簱浜�
+                                    }
+                                    else
+                                    {
+                                        #region 鏀瑰彉搴撳瓨
+
+                                        //澧炲姞搴撳瓨閿佸畾鏁伴噺
+                                        stock.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                        stock.UpdateTime = serverTime; //淇敼鏃堕棿
+                                        stock.UpdateUser = userId; //淇敼浜�
+                                        Db.Updateable(stock).ExecuteCommand();//淇敼搴撳瓨鎬昏〃淇℃伅
+
+                                        //澧炲姞搴撳瓨鏄庣粏閿佸畾鏁伴噺
+                                        s.LockQty += (int)s.Qty; //閿佸畾鏁伴噺
+                                        s.UpdateTime = serverTime; //淇敼鏃堕棿
+                                        s.UpdateUser = userId; //淇敼浜�
+                                        s.Status = "2"; //2 宸插垎閰�
+                                        Db.Updateable(s).ExecuteCommand();//淇敼搴撳瓨鏄庣粏淇℃伅
+
+                                        #endregion
+
+                                        #region 鍒嗛厤
+
+                                        //娣诲姞鍒嗛厤琛ㄤ俊鎭�
+                                        var allot = new BllExportAllot
+                                        {
+                                            SONo = "",
+                                            WaveNo = "",
+                                            SODetailNo = 0,
+                                            StockId = s.Id,
+                                            LotNo = "",
+                                            LotText = "",
+                                            SupplierLot = "",
+                                            SkuNo = s.SkuNo,
+                                            SkuName = s.SkuName,
+                                            Standard = s.Standard,
+                                            PalletNo = s.PalletNo,
+                                            IsBale = "0", //鏄惁瑁瑰寘
+                                            IsBelt = "0", //鏄惁鎵撳甫
+
+                                            //BoxexQty = s.Qty,
+                                            Qty = (int)s.Qty,
+                                            CompleteQty = 0,
+                                            Status = "1",
+                                            LogisticsId = 0,
+                                            IsAdvance = "0",
+                                            OutMode = model.OutMode,//鍑哄簱鍙�
+
+                                            CreateUser = userId,
+                                            CreateTime = DateTime.Now
+                                        };
+                                        Db.Insertable(allot).ExecuteCommand();
+
+                                        #endregion
+
+                                        #region 娣诲姞鍑哄簱浠诲姟淇℃伅
+
+                                        var taskNo = new Common().GetMaxNo("TK");
+                                        var exTask = new LogTask    //鍑哄簱浠诲姟
+                                        {
+                                            TaskNo = taskNo,
+                                            Sender = "WMS",
+                                            Receiver = "PDA",
+                                            IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+
+                                            StartLocat = locat == null ? "" : s.LocatNo,//璧峰浣嶇疆
+                                            EndLocat = model.OutMode,//鐩爣浣嶇疆
+                                            PalletNo = s.PalletNo,//鎵樼洏鐮�
+                                            IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                            IsCancel = 1,//鏄惁鍙彇娑�
+                                            IsFinish = 1,//鏄惁鍙畬鎴�
+                                            Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                            Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                            OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
+                                            CreateTime = serverTime, //鍒涘缓鏃堕棿
+                                            CreateUser = userId, //鍒涘缓浜�
+                                            Msg = "Pda绌烘墭浠�" + locat == null ? "" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
+                                                                                                                             //FinishDate = serverTime, //瀹屾垚鏃堕棿
+                                        };
+                                        outDto2.Add(new OutCommandDto()
+                                        {
+                                            PalletNo = exTask.PalletNo,//鎵樼洏鍙�
+                                            StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
+                                            StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
+                                            EndLocate = model.OutMode, // 鐩爣浣嶇疆 
+                                            TaskNo = exTask.TaskNo, // 浠诲姟鍙�
+                                            TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
+                                            OutMode = model.OutMode,  //鐩爣鍦板潃
+                                            Order = 1
+                                        });
+                                        Db.Insertable(exTask).ExecuteCommand();
+
+                                        #endregion
+                                        #region 鍌ㄤ綅鐘舵�佸彉鏇�
+
+                                        //鏇存敼鍌ㄤ綅鐘舵�佷负鍑哄簱涓�
+                                        locat.Status = "3"; //3 鍑哄簱涓�
+                                        Db.Updateable(locat).ExecuteCommand();//淇敼鍌ㄤ綅淇℃伅
+                                        #endregion
+                                    }
+                                }
+                            }
+
+                        }
+                                                       
+                    }
+                    
+                    if (int.Parse(model.Num) == outDto1.Count+ outDto2.Count)
                     {
-                        TaskNo = taskNo,
-                        Sender = "WMS",
-                        Receiver = "PDA",
-                        IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
-
-                        StartLocat = locat == null ? "闆剁搴�" : s.LocatNo,//璧峰浣嶇疆
-                        EndLocat = model.OutMode,//鐩爣浣嶇疆
-                        PalletNo = s.PalletNo,//鎵樼洏鐮�
-                        IsSend = 1,//鏄惁鍙啀娆′笅鍙�
-                        IsCancel = 1,//鏄惁鍙彇娑�
-                        IsFinish = 1,//鏄惁鍙畬鎴�
-                        Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
-                        Status = "1",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
-                        OrderType = "1",//0 鍏ュ簱鍗� 1 鍑哄簱鍗�  2 鐩樼偣鍗�  3 绉诲簱鍗�
-                        CreateTime = serverTime, //鍒涘缓鏃堕棿
-                        CreateUser = userId, //鍒涘缓浜�
-                        Msg = "Pda绌烘墭浠�" + locat == null ? "闆剁搴�" : s.LocatNo + "鍒�" + model.OutMode + "鐨勫嚭搴撲换鍔�", //鍏抽敭淇℃伅
-                        //FinishDate = serverTime, //瀹屾垚鏃堕棿
-                    };
-                    outDtoList.Add(new OutCommandDto()
-                    {
-                        PalletNo = exTask.PalletNo,//鎵樼洏鍙�
-                        StartLocate = exTask.StartLocat, // 璧峰浣嶇疆
-                        StartRoadway = locat.RoadwayNo, //鎵�灞炲贩閬�
-                        EndLocate = model.OutMode, // 鐩爣浣嶇疆 
-                        TaskNo = exTask.TaskNo, // 浠诲姟鍙�
-                        TaskType = "1",// 浠诲姟绫诲瀷 (鍑哄簱)
-                        OutMode = model.OutMode,  //鐩爣鍦板潃
-                        Order = 1
-                    });
-                    Db.Insertable(exTask).ExecuteCommand();
-
-                    #endregion
-                    i += 1;
-                    if (i == int.Parse(model.Num))
-                    {
-                        //闇�姹傚灈鏁板凡杈惧埌 鍙互鍑哄簱浜�
-                        break;
+                        break;//闇�姹傚灈鏁板凡杈惧埌 鍙互鍑哄簱浜�
                     }
                 }
-
-                if (outDtoList.Count > 0)
+                outDto1.AddRange(moveDto);
+                outDto1.AddRange(outDto2);
+                if (outDto1.Count > 0)
                 {
                     // 姝e紡杩愯绋嬪簭鏀惧紑
-                    var list2 = outDtoList.Select(m => m.TaskNo).ToList();
-                    var jsonData = JsonConvert.SerializeObject(outDtoList);
+                    var list2 = outDto1.Select(m => m.TaskNo).ToList();
+                    var jsonData = JsonConvert.SerializeObject(outDto1);
                     string response = "";
 
                     try
@@ -1153,7 +1662,7 @@
                 }
 
                 //娣诲姞鎿嶄綔鏃ュ織璁板綍
-                var k = new OperationSOServer().AddLogOperationSo("PDA妯″潡", "绌烘墭鍑哄簱", i + "", "涓嬪彂", $"鐢≒DA涓嬪彂浜� {i} 涓┖鎵樺灈", userId);
+                var k = new OperationSOServer().AddLogOperationSo("PDA妯″潡", "绌烘墭鍑哄簱", int.Parse(model.Num) + "", "涓嬪彂", $"鐢≒DA涓嬪彂浜� {int.Parse(model.Num)} 涓┖鎵樺灈", userId);
                 Db.CommitTran();
 
                 return "";
@@ -1167,6 +1676,68 @@
 
         }
 
+        public string MoveAddress(string oldAddress, string roadWay, string skuNo)//01020201  鎺�-鍒�-灞�-娣卞害
+        {
+            string nowAddress = "";
+
+            //鏍规嵁鐗╂枡缂栫爜鑾峰彇瀵瑰簲鍖哄煙
+            var skuCategoryNo = Db.Queryable<SysMaterials>().Where(a => a.IsDel == "0" && a.SkuNo == skuNo).Select(a => a.CategoryNo).First();
+            var category = Db.Queryable<SysMaterialCategory>().First(a => a.IsDel == "0" && a.CategoryNo == skuCategoryNo);
+
+            // 鑾峰彇绉诲簱鐩爣鍌ㄤ綅
+            var row = int.Parse(oldAddress.Substring(0, 2));
+            var lie = int.Parse(oldAddress.Substring(2, 2));
+            var ceng = int.Parse(oldAddress.Substring(4, 2));
+
+            var sqlString = $@"select LocatNo,[Row],[Column],Layer, (ABS(Row-{row}) + ABS([Column]-{lie}) + ABS(Layer-{ceng}))  as distNum from SysStorageLocat where Flag = '0' and Status = '0' and Depth = '02' and RoadwayNo = '{roadWay}' and AreaNo in ('{category.AreaNo}') order by distNum;";
+
+            var addressModels = Db.Ado.SqlQuery<AddressCls>(sqlString).ToList();
+            if (addressModels.Count > 0)   // 鍒ゆ柇鍚屽贩閬撳唴鎺掔┖搴撲綅
+            {
+                var listLocaete = new List<string>();
+                foreach (var item in addressModels)
+                {
+                    // 鐩爣鍐呭簱浣嶅搴旂殑澶栧簱浣�
+                    string addressee = item.LocatNo.Substring(0, 6) + "01";
+
+                    // 鍒ゆ柇鐩爣搴撲綅鐨勫搴撲綅鏄惁瀛樺湪璐х墿   (姝e父鎯呭喌涓嬫鍦ㄧЩ鍏ユ儏鍐典笉瀛樺湪锛屽洜涓虹Щ搴撳厛绉诲叆閲岄潰锛屽悗绉诲叆澶栭潰)
+                    //SlotStatus 0: 绌哄偍浣� 1锛氭湁璐�  2锛氭鍦ㄥ叆搴�  3锛氭鍦ㄥ嚭搴�   4锛氭鍦ㄧЩ鍏�  5锛氭鍦ㄧЩ鍑�
+                    sqlString = $"select count(*) from SysStorageLocat where LocatNo = '{addressee}' and Status = '0' and Flag in ('0','1') ; ";
+                    var rowNum = Db.Ado.SqlQuery<int>(sqlString).First();
+                    if (rowNum == 0)
+                    {
+                        continue;
+                    }
+                    else
+                    {
+                        nowAddress = item.LocatNo;
+                        break;
+                    }
+                }
+            }
+            if (nowAddress == "")
+            {
+                // 鍒ゆ柇鍚屽贩閬撳鎺掔┖搴撲綅
+                sqlString = $@"select LocatNo,[Row],[Column],Layer, (ABS(Row-{row}) + ABS([Column]-{lie}) + ABS(Layer-{ceng}))  as distNum 
+                                from SysStorageLocat 
+                                where Flag = '0' and Status = '0' and Depth = '01' and RoadwayNo = '{roadWay}' and AreaNo  in '{category}' 
+                                order by distNum;";
+                var adderModeling = Db.Ado.SqlQuery<AddressCls>(sqlString).ToList();
+                if (adderModeling.Count > 0)
+                {
+                    nowAddress = adderModeling[0].LocatNo;
+                }
+                else
+                {
+                    // 搴撳唴涓嶅瓨鍦ㄧ┖鍌ㄤ綅  
+                    nowAddress = "";
+                }
+            }
+
+
+            return nowAddress;
+        }
+
         //鑾峰彇骞冲簱鎵樼洏淇℃伅
         public List<BoxInfo> GetPingKuInfoByPallet(string soNo, string palletNo)
         {

--
Gitblit v1.8.0