From 1650f3fe1467d21074b597042861c46f3a8c4447 Mon Sep 17 00:00:00 2001
From: zhaowc <526854230@qq.com>
Date: 星期二, 01 四月 2025 10:11:24 +0800
Subject: [PATCH] 问题修改

---
 Wms/Wms/Controllers/SysController.cs |  339 ++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 317 insertions(+), 22 deletions(-)

diff --git a/Wms/Wms/Controllers/SysController.cs b/Wms/Wms/Controllers/SysController.cs
index b60a331..607e3bb 100644
--- a/Wms/Wms/Controllers/SysController.cs
+++ b/Wms/Wms/Controllers/SysController.cs
@@ -20,6 +20,8 @@
 using System.Security.Cryptography;
 using Model.ModelDto;
 using Model.ModelDto.LogDto;
+using Newtonsoft.Json.Linq;
+using Model.ModelVm.LogVm;
 
 namespace Wms.Controllers
 {
@@ -42,7 +44,7 @@
         private readonly IExceptionServer _table; //寮傚父澶勭悊
         private readonly IHeaderSettingsServer _headerSet;//琛ㄥご璁剧疆
 
-        private readonly IMaterialCategory _category;//鐗╂枡绫诲埆
+        private readonly IMaterialCategoryServer _category;//鐗╂枡绫诲埆
 
         /// <summary>
         /// 鏋勯�犲嚱鏁�
@@ -58,7 +60,7 @@
         /// <param name="operation">鎿嶄綔鏃ュ織</param>
         /// <param name="table">寮傚父澶勭悊</param>
         /// <param name="category">鐗╂枡绫诲埆</param>
-        public SysController(IWareHouseServer wareHouseSvc, IStorageAreaServer areaSvc, IStorageRoadwayServer roadwaySvc, IStorageLocatServer locatSvc, IPalletsServer palletSvc, IPalletTrackServer palletTrackSvc, IMenuServer menuSvc, IDictionaryServer dic, IOperationSysServer operation, IExceptionServer table, IHeaderSettingsServer headerSet, IMaterialCategory category)
+        public SysController(IWareHouseServer wareHouseSvc, IStorageAreaServer areaSvc, IStorageRoadwayServer roadwaySvc, IStorageLocatServer locatSvc, IPalletsServer palletSvc, IPalletTrackServer palletTrackSvc, IMenuServer menuSvc, IDictionaryServer dic, IOperationSysServer operation, IExceptionServer table, IHeaderSettingsServer headerSet, IMaterialCategoryServer category)
         {
             _wareHouseSvc = wareHouseSvc; //浠撳簱
             _areaSvc = areaSvc; //鍖哄煙
@@ -734,6 +736,50 @@
                 return Ok(new { code = 1, msg = e.Message });
             }
         }
+
+        /// <summary>
+        /// 娣诲姞鍖哄煙淇℃伅
+        /// </summary>
+        /// <param name="model">妯″瀷</param>
+        /// <returns></returns> 
+        [HttpPost]
+        public IActionResult InsertStorageArea(SysStorageArea model)
+        {
+            try
+            {
+                //鑾峰彇褰撳墠鐧诲綍鐨勭敤鎴稩D
+                var claimsIdentity = this.User.Identity as ClaimsIdentity;
+                if (claimsIdentity == null)
+                {
+                    return Ok(new { code = 1, msg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                }
+                var userId = claimsIdentity.FindFirst(ClaimTypes.Name)?.Value;
+                if (string.IsNullOrWhiteSpace(userId))
+                {
+                    return Ok(new { code = 1, msg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                }
+                model.CreateUser = int.Parse(userId);
+                string bolls = _areaSvc.InsertStorageArea(model);
+                var arr = bolls.Split(":");
+                if (arr[0] != "-1")
+                {
+                    SysStorageArea area = _areaSvc.GetStorageMaxArea();
+                    _operation.InsertOperation("浠撳簱璁剧疆", "鍖哄煙绠$悊", area.AreaNo, "娣诲姞", "娣诲姞鍖哄煙淇℃伅 鍖哄煙鍙凤細" + area.AreaNo, Convert.ToInt32(userId));
+                    return Ok(new { code = 0, msg = bolls, data = "" });
+                }
+                else
+                {
+                    return Ok(new { code = 1, msg = bolls, data = "" });
+                }
+
+            }
+            catch (Exception e)
+            {
+                return Ok(new { code = 1, msg = e.Message });
+            }
+
+        }
+
         /// <summary>
         /// 淇敼鍖哄煙淇℃伅
         /// </summary>
@@ -1011,7 +1057,7 @@
             }
         }
         /// <summary>
-        /// 娣诲姞鍌ㄤ綅淇℃伅
+        /// 娣诲姞绔嬩綋搴撳偍浣嶄俊鎭�
         /// </summary>
         /// <param name="model">妯″瀷</param>
         /// <returns></returns> 
@@ -1056,6 +1102,54 @@
                 return Ok(new { code = 400, ErrorMsg = "鏁版嵁鏍煎紡閿欒" });
             }
         }
+
+        /// <summary>
+        /// 娣诲姞骞冲簱鍌ㄤ綅淇℃伅
+        /// </summary>
+        /// <param name="model">妯″瀷</param>
+        /// <returns></returns> 
+        [AllowAnonymous]
+        [HttpPost]
+        public async Task<IActionResult> AddPkStorageLocat(AddLocateVm model)
+        {
+            if (ModelState.IsValid)
+            {
+                try
+                {
+                    //鑾峰彇褰撳墠鐧诲綍鐨勭敤鎴稩D
+                    //var claimsIdentity = this.User.Identity as ClaimsIdentity;
+                    //if (claimsIdentity == null)
+                    //{
+                    //    return Ok(new { code = 400, ErrorMsg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                    //}
+                    //var userId = claimsIdentity.FindFirst(ClaimTypes.Name)?.Value;
+                    //if (string.IsNullOrWhiteSpace(userId))
+                    //{
+                    //    return Ok(new { code = 400, ErrorMsg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                    //}
+                    var bolls = await _locatSvc.AddPkStorageLocat(model, 1);
+                    if (bolls > 0)
+                    {
+                        await _operation.InsertOperation("浠撳簱璁剧疆", "鍌ㄤ綅绠$悊", model.RoadwayNo, "娣诲姞", "娣诲姞鍌ㄤ綅淇℃伅 鍌ㄤ綅鍙凤細" + model.RoadwayNo, 1);
+                        return Ok(new { code = 200, ErrorMsg = "娣诲姞鎴愬姛", data = bolls });
+                    }
+                    else
+                    {
+                        return Ok(new { code = 400, ErrorMsg = "娣诲姞澶辫触", data = "" });
+                    }
+
+                }
+                catch (Exception e)
+                {
+                    return Ok(new { code = 400, ErrorMsg = "璇疯仈绯荤鐞嗗憳/" + e.Message });
+                }
+            }
+            else //鏁版嵁鏍煎紡閿欒
+            {
+                return Ok(new { code = 400, ErrorMsg = "鏁版嵁鏍煎紡閿欒" });
+            }
+        }
+
         /// <summary>
         /// 淇敼鍌ㄤ綅淇℃伅
         /// </summary>
@@ -1133,11 +1227,16 @@
                         string msg = "鍌ㄤ綅鐘舵�� 鍌ㄤ綅鍙凤細" + storage.RoadwayNo;
                         if (model.Id.Count > 1)
                         {
-                            foreach (var item in model.Id)
+                            var sstorage = _locatSvc.GetStorageLocat(model.Id);
+                            foreach (var item in sstorage)
                             {
-                                storage = _locatSvc.GetStorageLocat(item);
-                                _operation.InsertOperation("浠撳簱璁剧疆", "鍌ㄤ綅绠$悊", storage.LocatNo, "鎵归噺缂栬緫", "鎵归噺淇敼鍌ㄤ綅淇℃伅 鍌ㄤ綅鍙凤細" + storage.LocatNo, Convert.ToInt32(userId));
+                                _operation.InsertOperation("浠撳簱璁剧疆", "鍌ㄤ綅绠$悊", item.LocatNo, "鎵归噺缂栬緫", "鎵归噺淇敼鍌ㄤ綅淇℃伅 鍌ㄤ綅鍙凤細" + item.LocatNo, Convert.ToInt32(userId));
                             }
+                            //foreach (var item in model.Id)
+                            //{
+                            //    storage = _locatSvc.GetStorageLocat(item);
+                            //    _operation.InsertOperation("浠撳簱璁剧疆", "鍌ㄤ綅绠$悊", storage.LocatNo, "鎵归噺缂栬緫", "鎵归噺淇敼鍌ㄤ綅淇℃伅 鍌ㄤ綅鍙凤細" + storage.LocatNo, Convert.ToInt32(userId));
+                            //}
                         }
                         else
                         {
@@ -1162,6 +1261,47 @@
                 return Ok(new { code = 1, msg = "鏁版嵁鏍煎紡閿欒" });
             }
         }
+
+        /// <summary>
+        /// 淇敼鍌ㄤ綅鐘舵�佹爣璇嗕俊鎭泦鍚�
+        /// </summary>
+        /// <param name="model">妯″瀷</param>
+        /// <returns></returns>
+        [HttpPost]
+        public IActionResult EditStorageLocatListNew (EditLocateListNewVm model)
+        {
+            try
+            {
+                //鑾峰彇褰撳墠鐧诲綍鐨勭敤鎴稩D
+                var claimsIdentity = this.User.Identity as ClaimsIdentity;
+                if (claimsIdentity == null)
+                {
+                    return Ok(new { code = 1, msg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                }
+                var userId = claimsIdentity.FindFirst(ClaimTypes.Name)?.Value;
+                if (string.IsNullOrWhiteSpace(userId))
+                {
+                    return Ok(new { code = 1, msg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
+                }
+                var bolls = _locatSvc.EditStorageLocatListNew(model, int.Parse(userId));
+                if (bolls)
+                {
+                    _operation.InsertOperation("浠撳簱璁剧疆", "鍌ㄤ綅绠$悊", "", "淇敼", $"淇敼宸烽亾锛歿model.RoadWayNo}銆佹帓:{model.Row}銆佸垪:{model.Column}銆佸眰:{model.Layer}銆佹繁搴︼細{model.Dept}鐨勫尯鍩燂細{model.AreaNo}銆佺姸鎬�:{model.Status}銆佹爣璇嗭細{model.Flag}鐨勫偍浣嶄俊鎭� ", Convert.ToInt32(userId));
+
+                    return Ok(new { code = 0, msg = "缂栬緫鎴愬姛", data = "" });
+                }
+                else
+                {
+                    return Ok(new { code = 1, msg = "缂栬緫澶辫触", data = "" });
+                }
+
+            }
+            catch (Exception e)
+            {
+                return Ok(new { code = 1, msg = e.Message });
+            }
+        }
+
         #endregion
 
         #region 鎵樼洏鏉$爜绠$悊
@@ -1276,17 +1416,21 @@
                 {
                     throw new Exception("褰撳墠鏄剧ず鐨勬潯鐮佷笉鏄渶鏂版潯鐮侊紝璇烽噸鏂版坊鍔�");
                 }
-                string str = model.PalletNo.Substring(3, 5);
-                string remove = model.PalletNo.Substring(0, 3);
+                string str = model.PalletNo.Substring(2, 6);
+                string remove = model.PalletNo.Substring(0, 2);
                 int sibelius = Convert.ToInt16(str);
                 for (int i = 0; i < model.GroupCount; i++)
                 {
+                    if (sibelius>999999)
+                    {
+                        throw new Exception("鎵樼洏缁勪腑宸叉湁鎵樼洏鐮佷綅鏁板凡杈句笂绾�");
+                    }
                     if (i != 0)
                     {
                         sibelius += 1;
                     }
 
-                    string code = remove + Convert.ToString(sibelius).PadLeft(5, '0');
+                    string code = remove + Convert.ToString(sibelius).PadLeft(6, '0');
                     for (int j = 0; j < model.SameCount; j++)
                     {
                         var re = BarcodeHelper.GetCodeBarBase64(code, 80, 50);
@@ -1443,6 +1587,7 @@
 
         #region 鍌ㄤ綅鍥句緥
 
+        #region 绔嬪簱
         /// <summary>
         /// 鏍规嵁浠撳簱 鎺�
         /// </summary>
@@ -1559,6 +1704,41 @@
             });
         }
 
+
+
+        #endregion
+
+        #region 骞冲簱
+
+        /// <summary>
+        /// 鏍规嵁浠撳簱 鎺�
+        /// </summary>
+        /// <param name="wareHouseNo">浠撳簱</param>
+        /// <param name="row">鎺�</param>
+        /// <param name="depth">娣卞害</param>
+        /// <returns></returns>
+        [HttpGet]
+        public IActionResult GetFlatLibraryLegend(string wareHouseNo, string row)
+        {
+            //鑾峰彇鍌ㄤ綅淇℃伅
+            List<SysStorageLocat> storagelist = _locatSvc.GetFlatLibraryLegend(wareHouseNo, row);
+
+            //Dictionary<string, int> dic = new Dictionary<string, int>()
+            //{
+            //    "B01"
+            //};
+
+            return Ok(new
+            {
+                data = storagelist,
+                //dic,
+                code = 0,
+                msg = ""
+            });
+        }
+
+        #endregion
+
         /// <summary>
         /// 鏍规嵁鍌ㄤ綅鍦板潃鑾峰彇鍌ㄤ綅涓婄殑鎵樼洏鍜岀墿鍝佷俊鎭�
         /// </summary>
@@ -1611,7 +1791,7 @@
                 {
                     data = list,
                     code = 1,
-                    msg = "鑾峰彇鐗╂枡绫诲埆淇℃伅鎴愬姛"
+                    msg = "鑾峰彇鐗╂枡閫昏緫搴撳尯淇℃伅鎴愬姛"
                 });
             }
             catch (Exception ex)
@@ -1620,8 +1800,100 @@
                 {
                     data = "",
                     code = 0,
-                    msg = "鑾峰彇鐗╂枡绫诲埆淇℃伅寮傚父"
+                    msg = ex.Message
                 });
+            }
+        }
+
+        /// <summary>
+        /// 鑾峰彇鐗╂枡绫诲埆涓嬫媺鑿滃崟淇℃伅
+        /// </summary>
+        /// <returns></returns>
+        /// <exception cref="Exception"></exception>
+        [HttpGet]
+        public IActionResult GetMaterialCategories1()
+        {
+            try
+            {
+                var list = _category.GetMaterialCategories();
+                return Ok(new
+                {
+                    data = list,
+                    code = 1,
+                    msg = "鑾峰彇鐗╂枡閫昏緫搴撳尯淇℃伅鎴愬姛"
+                });
+            }
+            catch (Exception ex)
+            {
+                return Ok(new
+                {
+                    data = "",
+                    code = 0,
+                    msg = ex.Message
+                });
+            }
+        }
+
+
+        /// <summary>
+        /// 鏍规嵁Id鑾峰彇鐗╂枡绫诲埆淇℃伅
+        /// </summary>
+        /// <param name="Id">Id</param>
+        /// <returns></returns>
+        /// <exception cref="Exception"></exception>
+        [HttpGet]
+        public IActionResult GetMaterialCategoriesById(int Id)
+        {
+            try
+            {
+                var list = _category.GetMaterialCategoriesById(Id);
+                return Ok(new
+                {
+                    data = list,
+                    code = 1,
+                    msg = "鏍规嵁Id鑾峰彇閫昏緫搴撳尯淇℃伅鎴愬姛"
+                });
+            }
+            catch (Exception ex)
+            {
+                return Ok(new
+                {
+                    data = "",
+                    code = 0,
+                    msg = ex.Message
+                });
+            }
+        }
+
+        /// <summary>
+        /// 鑾峰彇鍖哄煙淇℃伅
+        /// </summary>
+        /// <returns></returns>
+        [HttpGet]
+        public IActionResult GetStorageAreaList()
+        {
+            try
+            {
+                var bolls = _category.GetStorageAreaList();
+
+                List<XmSelectDto> list = new List<XmSelectDto>();
+
+                foreach (var item in bolls)
+                {
+                    XmSelectDto list1 = new XmSelectDto()
+                    {
+                        name = item.AreaName, //鍖哄煙鍚嶇О
+                        value = item.AreaNo, //鍖哄煙鍙�
+                        selected = false, //鏄惁閫変腑
+                    };
+                    list.Add(list1);
+                }
+
+                return Ok(new { code = 0, msg = "鍖哄煙淇℃伅", data = bolls, list });
+            }
+            catch (Exception e)
+            {
+                return Ok(new { code = 1, msg = e.Message });
             }
         }
 
@@ -1651,13 +1923,13 @@
 
                 var list = _category.InsertMaterialCategories(category);
 
-                _operation.InsertOperation("鍩虹淇℃伅", "鐗╂枡绫诲埆", category.CategoryNo, "鏂板", "鏂板绫诲埆淇℃伅 绫诲埆鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
+                _operation.InsertOperation("鍩虹淇℃伅", "閫昏緫搴撳尯", category.CategoryNo, "娣诲姞", "娣诲姞閫昏緫搴撳尯淇℃伅 閫昏緫搴撳尯鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
 
                 return Ok(new
                 {
                     data = list,
                     code = 1,
-                    msg = "鏂板鐗╂枡绫诲埆淇℃伅鎴愬姛"
+                    msg = "鏂板鐗╂枡閫昏緫搴撳尯淇℃伅鎴愬姛"
                 });
 
 
@@ -1668,7 +1940,7 @@
                 {
                     data = "",
                     code = 0,
-                    msg = "鏂板鐗╂枡绫诲埆淇℃伅寮傚父"
+                    msg = ex.Message
                 });
             }
         }
@@ -1699,13 +1971,13 @@
 
                 var list = _category.ExitMaterialCategories(category);
 
-                _operation.InsertOperation("鍩虹淇℃伅", "鐗╂枡绫诲埆", category.CategoryNo, "缂栬緫", "缂栬緫绫诲埆淇℃伅 绫诲埆鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
+                _operation.InsertOperation("鍩虹淇℃伅", "閫昏緫搴撳尯", category.CategoryNo, "缂栬緫", "缂栬緫閫昏緫搴撳尯淇℃伅 閫昏緫搴撳尯鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
 
                 return Ok(new
                 {
                     data = list,
                     code = 1,
-                    msg = "缂栬緫鐗╂枡绫诲埆淇℃伅鎴愬姛"
+                    msg = "缂栬緫鐗╂枡閫昏緫搴撳尯淇℃伅鎴愬姛"
                 });
 
 
@@ -1716,7 +1988,7 @@
                 {
                     data = "",
                     code = 0,
-                    msg = "缂栬緫鐗╂枡绫诲埆淇℃伅寮傚父"
+                    msg = ex.Message
                 });
             }
         }
@@ -1728,7 +2000,7 @@
         /// <returns></returns>
         /// <exception cref="Exception"></exception>
         [HttpPost]
-        public IActionResult DeleteMaterialCategories(SysMaterialCategory category)
+        public IActionResult DeleteMaterialCategories(MaterialCategoryDto category)
         {
             try
             {
@@ -1743,17 +2015,17 @@
                 {
                     return Ok(new { code = 1, msg = "涓鸿幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" });
                 }
-                category.UpdateUser = int.Parse(userId);
+                category.UpdateUser = userId;
 
                 var list = _category.DeleteMaterialCategories(category);
 
-                _operation.InsertOperation("鍩虹淇℃伅", "鐗╂枡绫诲埆", category.CategoryNo, "鍒犻櫎", "鍒犻櫎绫诲埆淇℃伅 绫诲埆鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
+                _operation.InsertOperation("鍩虹淇℃伅", "閫昏緫搴撳尯", category.CategoryNo, "鍒犻櫎", "鍒犻櫎閫昏緫搴撳尯淇℃伅 閫昏緫搴撳尯鍙凤細" + category.CategoryNo, Convert.ToInt32(userId));
 
                 return Ok(new
                 {
                     data = list,
                     code = 1,
-                    msg = "鍒犻櫎鐗╂枡绫诲埆淇℃伅鎴愬姛"
+                    msg = "鍒犻櫎鐗╂枡閫昏緫搴撳尯淇℃伅鎴愬姛"
                 });
 
 
@@ -1764,14 +2036,37 @@
                 {
                     data = "",
                     code = 0,
-                    msg = "鍒犻櫎鐗╂枡绫诲埆淇℃伅寮傚父"
+                    msg = ex.Message
                 });
             }
         }
 
         #endregion
 
+        #region 鎿嶄綔鏃ュ織
 
+        /// <summary>
+        /// 鑾峰彇鎿嶄綔鏃ュ織淇℃伅
+        /// </summary>
+        /// <param name="model"></param>
+        /// <returns></returns>
+        [AllowAnonymous]
+        [HttpPost]
+        public IActionResult GetLogOperationList(GetOperationVm model)
+        {
+            try
+            {
+                var bolls = _operation.GetOperationList(model.MenuName, model.Type, model.Msg, model.StartTime, model.EndTime, model.Page, model.Limit, out int count);
+
+                return Ok(new { code = 0, count, msg = "鎿嶄綔鏃ュ織淇℃伅", data = bolls });
+            }
+            catch (Exception e)
+            {
+                return Ok(new { code = 1, msg = e.Message });
+            }
+        }
+
+        #endregion
 
         #region 鏁版嵁琛ㄦ牸琛ㄥご鑷畾涔�(閫氱敤鏂规硶)
         /// <summary>

--
Gitblit v1.8.0