From 068a221025ffe209b25f00642f9bcd1e28861fe0 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周四, 16 10月 2025 15:58:42 +0800
Subject: [PATCH] 本次请求中物料号不能重复修复

---
 DEmon/WebWIPAPI/Controllers/MesIntegrController.cs |  390 ++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 324 insertions(+), 66 deletions(-)

diff --git a/DEmon/WebWIPAPI/Controllers/MesIntegrController.cs b/DEmon/WebWIPAPI/Controllers/MesIntegrController.cs
index 9cd7465..ed7842f 100644
--- a/DEmon/WebWIPAPI/Controllers/MesIntegrController.cs
+++ b/DEmon/WebWIPAPI/Controllers/MesIntegrController.cs
@@ -1,15 +1,20 @@
-锘縰sing iWareCommon.Common.Entity;
+锘縰sing AutoMapper;
+using iWareCommon.Common.Entity;
 using iWareCommon.Utils;
 using iWareDataCore.BASE.Entity;
 using iWareDataCore.BASE.Service;
+using iWareDataCore.TASK.Service;
 using Newtonsoft.Json;
 using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Threading;
+using System.Web.Hosting;
 using System.Web.Mvc;
 using WebWIPAPI.Models;
 using WebWIPAPI.Properties;
+using WebWIPAPI.Utils;
+using static System.Runtime.CompilerServices.RuntimeHelpers;
 using LogTextHelper = WebWIPAPI.Utils.LogTextHelper;
 
 namespace WebWIPAPI.Controllers
@@ -28,29 +33,42 @@
         public ActionResult syncMaterialInfo()
         {
             var responseMessage = new ApiResponse<List<PlaceMaterialViewEntity>>();
-            var msg = "";
-            var datalist = PlaceMaterialViewService.GetInstance().GetPlacePreview(out msg);
-            if (!string.IsNullOrEmpty(msg))
+            try
+            {
+                var msg = "";
+                var datalist = PlaceMaterialViewService.GetInstance().GetPlacePreview(out msg);
+                datalist = datalist.Where(x => !string.IsNullOrEmpty(x.MaterialCode)).ToList();
+                if (!string.IsNullOrEmpty(msg))
+                {
+                    responseMessage = new ApiResponse<List<PlaceMaterialViewEntity>>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鑾峰彇寮傚父:" + msg,
+                        Data = null,
+                    };
+                }
+                else
+                {
+                    responseMessage = new ApiResponse<List<PlaceMaterialViewEntity>>()
+                    {
+                        Code = 200,
+                        Success = true,
+                        Message = "鎴愬姛",
+                        Data = datalist,
+                    };
+                }
+            }
+            catch (Exception ex)
             {
                 responseMessage = new ApiResponse<List<PlaceMaterialViewEntity>>()
                 {
                     Code = 500,
                     Success = false,
-                    Message = "寮傚父:" + msg,
+                    Message = "寮傚父:" + ex.Message,
                     Data = null,
                 };
             }
-            else
-            {
-                responseMessage = new ApiResponse<List<PlaceMaterialViewEntity>>()
-                {
-                    Code = 200,
-                    Success = true,
-                    Message = "鎴愬姛",
-                    Data = datalist,
-                };
-            }
-
             //灏嗗璞¤浆鍖栦负json鏍煎紡
             var responseStr = JsonConvert.SerializeObject(responseMessage);
             LogTextHelper.WriteLine(Resources.LogDir, "WIPAPI:{0},{1}, {2}", "syncMaterialInfo", "璇锋眰鍙傛暟锛�" + "", "鍝嶅簲淇℃伅;" + responseStr);
@@ -68,52 +86,196 @@
             var responseMessage = new ApiResponse<string>();
             var msg = "";
 
-            #region 涓氬姟澶勭悊
+            try
+            {
+                #region 楠岃瘉
+                if (importMaterials?.Count() == 0)
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏁版嵁鏉℃暟涓�0",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importInOrder", "");
+                }
+                if (importMaterials.Select(x => x.ListNo).Distinct().Count() != 1)
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏈璇锋眰鍗曞彿蹇呴』涓哄悓涓�鍊�",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importInOrder", "");
+                }
+                if (importMaterials.GroupBy(x => x.Code).Any(g => g.Count() > 1))
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏈璇锋眰涓墿鏂欏彿涓嶈兘閲嶅",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+                }
+                #endregion
 
-            //绗竴姝ワ細鍏堟柊澧炲埌鐗╂枡鍩虹琛�
-            List<MaterialViewEntity> materials = new List<MaterialViewEntity>();
-            materials = ClassHelper.RotationMapping<List<MaterialViewEntity>, List<MaterialViewForMesEntity>>(importMaterials);
-            MaterialViewService.GetInstance().ImportExcelFromMes(materials, out msg);
+                #region 涓氬姟澶勭悊
 
-            Thread.Sleep(400);//娉ㄦ剰锛氫紤鐪犳绉掞紝鐢ㄤ簬鏁版嵁搴撲簨鍔℃彁浜�
+                //绗竴姝ワ細鍏堟柊澧炲埌鐗╂枡鍩虹琛�
+                List<MaterialViewEntity> materials = new List<MaterialViewEntity>();
 
-            string typeName = "鍏ュ簱";
-            List<InputMaterialEntity> inputmaterials = new List<InputMaterialEntity>();
-            inputmaterials = ClassHelper.RotationMapping<List<InputMaterialEntity>, List<MaterialViewForMesEntity>>(importMaterials);
-            handler_importOutOrder(typeName, inputmaterials, out msg);
+                materials = ClassHelper.RotationMapping_Json<List<MaterialViewEntity>, List<MaterialViewForMesEntity>>(importMaterials);
 
-            #endregion
 
-            if (!string.IsNullOrEmpty(msg))
+                MaterialViewService.GetInstance().ImportExcelFromMes(materials, out msg);
+                if (!string.IsNullOrEmpty(msg))
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏂板鍒扮墿鏂欏熀纭�琛ㄥ紓甯�:" + msg,
+                        Data = null,
+                    };
+                }
+                else
+                {
+                    Thread.Sleep(400);//娉ㄦ剰锛氫紤鐪犳绉掞紝鐢ㄤ簬鏁版嵁搴撲簨鍔℃彁浜�
+
+                    string typeName = "鍏ュ簱";
+                    List<InputMaterialEntity> inputmaterials = new List<InputMaterialEntity>();
+                    inputmaterials = ClassHelper.RotationMapping_Json<List<InputMaterialEntity>, List<MaterialViewForMesEntity>>(importMaterials);
+                    handler_importOutOrder(typeName, inputmaterials, out msg);
+
+                    #endregion
+
+                    if (!string.IsNullOrEmpty(msg))
+                    {
+                        responseMessage = new ApiResponse<string>()
+                        {
+                            Code = 500,
+                            Success = false,
+                            Message = "鐢熸垚鍏ュ簱浠诲姟寮傚父:" + msg,
+                            Data = null,
+                        };
+                    }
+                    else
+                    {
+                        responseMessage = new ApiResponse<string>()
+                        {
+                            Code = 200,
+                            Success = true,
+                            Message = "鎴愬姛",
+                            Data = null,
+                        };
+                    }
+                }
+
+            }
+            catch (Exception ex)
             {
                 responseMessage = new ApiResponse<string>()
                 {
                     Code = 500,
                     Success = false,
-                    Message = "寮傚父:" + msg,
-                    Data = null,
-                };
-            }
-            else
-            {
-                responseMessage = new ApiResponse<string>()
-                {
-                    Code = 200,
-                    Success = true,
-                    Message = "鎴愬姛",
+                    Message = "寮傚父:" + ex.Message,
                     Data = null,
                 };
             }
 
-            //灏嗗璞¤浆鍖栦负json鏍煎紡
-            var responseStr = JsonConvert.SerializeObject(responseMessage);
-            LogTextHelper.WriteLine(Resources.LogDir, "WIPAPI:{0},{1}, {2}", "importInOrder", "璇锋眰鍙傛暟锛�" + "", "鍝嶅簲淇℃伅;" + responseStr);
-            return Json(responseMessage, JsonRequestBehavior.DenyGet);
+            return ApiResponseHelper.ReturnApiResponse(responseMessage, "importInOrder", "");
         }
 
 
+        ///// <summary>
+        ///// 瀵煎叆鍑哄簱鍗�-鐗堟湰1锛堜娇鐢ㄥ嚭搴撳崟鎹殑鐗堟湰锛�
+        ///// </summary>
+        ///// <param name="inputmaterials"></param>
+        ///// <returns></returns>
+        //[HttpPost]
+        //public ActionResult importOutOrder(List<InputMaterialEntity> inputmaterials)
+        //{
+        //    var responseMessage = new ApiResponse<string>();
+        //    try
+        //    {
+        //        var msg = "";
+
+        //        #region 楠岃瘉
+        //        if (inputmaterials?.Count() == 0)
+        //        {
+        //            responseMessage = new ApiResponse<string>()
+        //            {
+        //                Code = 500,
+        //                Success = false,
+        //                Message = "鏁版嵁鏉℃暟涓�0",
+        //                Data = null,
+        //            };
+        //            return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+        //        }
+        //        if (inputmaterials.Select(x => x.ListNo).Distinct().Count() != 1)
+        //        {
+        //            responseMessage = new ApiResponse<string>()
+        //            {
+        //                Code = 500,
+        //                Success = false,
+        //                Message = "鏈璇锋眰鍗曞彿蹇呴』涓哄悓涓�鍊�",
+        //                Data = null,
+        //            };
+        //            return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+        //        }
+        //        #endregion
+
+        //        #region 涓氬姟澶勭悊
+
+        //        string typeName = "鍑哄簱";
+        //        handler_importOutOrder(typeName, inputmaterials, out msg);
+
+        //        #endregion
+
+        //        if (!string.IsNullOrEmpty(msg))
+        //        {
+        //            responseMessage = new ApiResponse<string>()
+        //            {
+        //                Code = 500,
+        //                Success = false,
+        //                Message = "鐢熸垚鍑哄簱浠诲姟寮傚父:" + msg,
+        //                Data = null,
+        //            };
+        //        }
+        //        else
+        //        {
+        //            responseMessage = new ApiResponse<string>()
+        //            {
+        //                Code = 200,
+        //                Success = true,
+        //                Message = "鎴愬姛",
+        //                Data = null,
+        //            };
+        //        }
+
+        //    }
+        //    catch (Exception ex)
+        //    {
+        //        responseMessage = new ApiResponse<string>()
+        //        {
+        //            Code = 500,
+        //            Success = false,
+        //            Message = "寮傚父:" + ex.Message,
+        //            Data = null,
+        //        };
+        //    }
+
+        //    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+        //}
+
+
         /// <summary>
-        /// 瀵煎叆鍑哄簱鍗�
+        /// 瀵煎叆鍑哄簱鍗�-鐗堟湰2锛堥�夋嫨搴撳瓨鍑哄簱鐨勭増鏈級
         /// </summary>
         /// <param name="inputmaterials"></param>
         /// <returns></returns>
@@ -121,42 +283,89 @@
         public ActionResult importOutOrder(List<InputMaterialEntity> inputmaterials)
         {
             var responseMessage = new ApiResponse<string>();
-            var msg = "";
+            try
+            {
+                var msg = "";
 
-            #region 涓氬姟澶勭悊
+                #region 楠岃瘉
+                if (inputmaterials?.Count() == 0)
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏁版嵁鏉℃暟涓�0",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+                }
+                if (inputmaterials.Select(x => x.ListNo).Distinct().Count() != 1)
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏈璇锋眰鍗曞彿蹇呴』涓哄悓涓�鍊�",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+                }
+                if (inputmaterials.GroupBy(x => x.Code).Any(g => g.Count() > 1))
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鏈璇锋眰涓墿鏂欏彿涓嶈兘閲嶅",
+                        Data = null,
+                    };
+                    return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
+                }
+                #endregion
 
-            string typeName = "鍑哄簱";
-            handler_importOutOrder(typeName, inputmaterials, out msg);
+                #region 涓氬姟澶勭悊
 
-            #endregion
+                string typeName = "鍑哄簱";
+                handler_OutOrder(inputmaterials, out msg);
+                //handler_importOutOrder(typeName, inputmaterials, out msg);
 
-            if (!string.IsNullOrEmpty(msg))
+                #endregion
+
+                if (!string.IsNullOrEmpty(msg))
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 500,
+                        Success = false,
+                        Message = "鐢熸垚鍑哄簱浠诲姟寮傚父:" + msg,
+                        Data = null,
+                    };
+                }
+                else
+                {
+                    responseMessage = new ApiResponse<string>()
+                    {
+                        Code = 200,
+                        Success = true,
+                        Message = "鎴愬姛",
+                        Data = null,
+                    };
+                }
+
+            }
+            catch (Exception ex)
             {
                 responseMessage = new ApiResponse<string>()
                 {
                     Code = 500,
                     Success = false,
-                    Message = "寮傚父:" + msg,
-                    Data = null,
-                };
-            }
-            else
-            {
-                responseMessage = new ApiResponse<string>()
-                {
-                    Code = 200,
-                    Success = true,
-                    Message = "鎴愬姛",
+                    Message = "寮傚父:" + ex.Message,
                     Data = null,
                 };
             }
 
-            //灏嗗璞¤浆鍖栦负json鏍煎紡
-            var responseStr = JsonConvert.SerializeObject(responseMessage);
-            LogTextHelper.WriteLine(Resources.LogDir, "WIPAPI:{0},{1}, {2}", "importOutOrder", "璇锋眰鍙傛暟锛�" + "", "鍝嶅簲淇℃伅;" + responseStr);
-            return Json(responseMessage, JsonRequestBehavior.DenyGet);
+            return ApiResponseHelper.ReturnApiResponse(responseMessage, "importOutOrder", "");
         }
-
 
         /// <summary>
         /// 鍏叡瀵煎叆 鍏ュ簱鍗曟垨鍑哄簱鍗�
@@ -181,6 +390,11 @@
                     List<int> ids = new List<int>();
                     var materials = InputMaterialService.GetInstance().GetIds(codes);
                     List<InOutListDetailEntity> detail = new List<InOutListDetailEntity>();
+                    if (materials?.Count == 0)
+                    {
+                        msg = ("鐗╂枡鏄庣粏鏌ヨ涓虹┖锛�");
+                        return;
+                    }
                     for (int i = 0; i < materials.Count; i++)
                     {
                         if (typeName == "鍏ュ簱")
@@ -251,5 +465,49 @@
             }
         }
 
+
+        /// <summary>
+        /// 閫夋嫨搴撳瓨鍑哄簱鐨勭増鏈�
+        /// </summary>
+        /// <param name="inputmaterials"></param>
+        /// <param name="msg"></param>
+        private void handler_OutOrder(List<InputMaterialEntity> inputmaterials, out string msg)
+        {
+            msg = "";
+            //鏌ユ壘搴撳瓨琛ㄤ腑鐨刬d
+            var qList = inputmaterials.Select(x => x.Code).ToList();
+            List<int> ids = PlaceMaterialViewService.GetInstance().GetPlaceMaterialViewsByCodeList(qList, out msg);
+            if (!string.IsNullOrEmpty(msg))
+            {
+                return;
+            }
+            // List<int> ids = GetSelectedDataKeyIDs(PlaceGrid);
+            if (ids.Count > 0)
+            {
+                int count = MainTaskService.GetInstance().SaveOutMainTask(ids, out msg);
+                var retMsg = msg;
+                if (count > 0)
+                {
+                    //鎴愬姛涓嶉渶瑕佸啓鏂囧瓧
+                    //msg = "鍑哄簱浠诲姟鐢熸垚鎴愬姛:" + retMsg;
+                }
+                else if (count == 0)
+                {
+                    msg = "鍑哄簱浠诲姟宸插湪浠诲姟闃熷垪涓�:" + retMsg;
+                }
+                else
+                {
+                    msg = "鍑哄簱浠诲姟鐢熸垚澶辫触锛�:" + retMsg;
+                }
+
+            }
+            else
+            {
+                msg = "瑕佸嚭搴撶殑鐗╂枡娌℃湁鍙敤搴撳瓨";
+            }
+            //Alert.Show(msg);
+            //WriteLog("搴撲綅鐗╂枡鍑哄簱" + msg, "搴撳瓨绠$悊");
+        }
+
     }
 }

--
Gitblit v1.9.3