From fb745c842df36edc5101291a7f239c11c97bcc2f Mon Sep 17 00:00:00 2001
From: wangxinhui <wangxinhui@hnkhzn.com>
Date: 星期四, 11 九月 2025 16:46:33 +0800
Subject: [PATCH] 最新代码更新,BST,MES部分

---
 项目代码/WMS/WMSServices/WIDESEA_BasicService/SupplierInfoService.cs |  131 +++++++++++++++++++++++++------------------
 1 files changed, 77 insertions(+), 54 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_BasicService/SupplierInfoService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_BasicService/SupplierInfoService.cs"
index a682d53..02e7383 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_BasicService/SupplierInfoService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WMSServices/WIDESEA_BasicService/SupplierInfoService.cs"
@@ -1,10 +1,14 @@
-锘縰sing System;
+锘縰sing AutoMapper;
+using SqlSugar.Extensions;
+using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
 using System.Threading.Tasks;
 using WIDESEA_BasicRepository;
+using WIDESEA_Common.MaterielEnum;
 using WIDESEA_Core;
+using WIDESEA_Core.BaseRepository;
 using WIDESEA_Core.BaseServices;
 using WIDESEA_DTO.Basic;
 using WIDESEA_IBasicRepository;
@@ -15,79 +19,98 @@
 {
     public class SupplierInfoService : ServiceBase<Dt_SupplierInfo, ISupplierInfoRepository>, ISupplierInfoService
     {
-        public SupplierInfoService(ISupplierInfoRepository BaseDal) : base(BaseDal)
-        {
-        }
-
         public ISupplierInfoRepository Repository => BaseDal;
 
-        public WebResponseContent ReceiveSupplier(SupplierDTO model)
+        private readonly IUnitOfWorkManage _unitOfWorkManage;
+        private readonly IMapper _mapper;
+        public SupplierInfoService(ISupplierInfoRepository BaseDal,IUnitOfWorkManage unitOfWorkManage,IMapper mapper) : base(BaseDal)
         {
+            _unitOfWorkManage = unitOfWorkManage;
+            _mapper = mapper;
+        }
+        /// <summary>
+        /// 娣诲姞鑰佸巶渚涘簲鍟嗕俊鎭�
+        /// </summary>
+        /// <param name="bSTSupplierDTOs"></param>
+        /// <returns></returns>
+        public WebResponseContent AddSupplier(List<BSTSupplierDTO> bSTSupplierDTOs)
+        {
+            WebResponseContent content = new WebResponseContent();
             try
             {
-                if (model.OperateType == "0")
+                List<Dt_SupplierInfo> OldsupplierInfos = BaseDal.QueryData(x => x.InvOrgId == MaterielInvOrgEnum.鑰佸巶.ObjToInt());
+                //鏂板
+                List<BSTSupplierDTO> bSTSupplierDTOsAdd = bSTSupplierDTOs.Where(x => x.Way == 1).ToList();
+                //淇敼
+                List<BSTSupplierDTO> bSTSupplierDTOsUpdate = bSTSupplierDTOs.Where(x => x.Way == 2).ToList();
+                //鍒犻櫎
+                List<BSTSupplierDTO> bSTSupplierDTOsDTODel = bSTSupplierDTOs.Where(x => x.Way == 3).ToList();
+                List<Dt_SupplierInfo> supplierInfosAdd = new List<Dt_SupplierInfo>();
+                List<Dt_SupplierInfo> supplierInfosUpdate = new List<Dt_SupplierInfo>();
+                //鏂板
+                if (bSTSupplierDTOsAdd.Count > 0)
                 {
-                    Dt_SupplierInfo supplierInfo = new Dt_SupplierInfo()
+                    //鍒ゆ柇閲嶅鎻掑叆
+                    Dt_SupplierInfo? ExistSupplier = OldsupplierInfos.FirstOrDefault(x => bSTSupplierDTOsAdd.Select(x => x.VendId).Contains(x.SupplierSourceId));
+                    if (ExistSupplier != null)
                     {
-                        Status = 1,
-                        SupplierCode = model.Code,
-                        ContactAddress = model.ContactAddress,
-                        ContactNumber = model.ContactNumber,
-                        Contacts = model.Contacts,
-                        Description = model.Description,
-                        Email = model.Email,
-                        InvOrgId = model.InvOrgId,
-                        SupplierName = model.Name,
-                        SupplierShortName = model.ShortName
-                    };
+                        return content.Error($"渚涘簲鍟唟nameof(BSTSupplierDTO.VendId)}:{ExistSupplier.SupplierSourceId}宸插瓨鍦�");
+                    }
 
-                    BaseDal.AddData(supplierInfo);
-                }
-                else if (model.OperateType == "1")
-                {
-                    Dt_SupplierInfo supplierInfo = BaseDal.QueryFirst(x => x.SupplierCode == model.Code);
-                    if (supplierInfo == null)
+                    foreach (var item in bSTSupplierDTOsAdd)
                     {
-                        Dt_SupplierInfo supplierInfoAddNew = new Dt_SupplierInfo()
+                        if (bSTSupplierDTOsUpdate.FirstOrDefault(x => x.VendId == item.VendId) != null)
                         {
-                            Status = 1,
-                            SupplierCode = model.Code,
-                            ContactAddress = model.ContactAddress,
-                            ContactNumber = model.ContactNumber,
-                            Contacts = model.Contacts,
-                            Description = model.Description,
-                            Email = model.Email,
-                            InvOrgId = model.InvOrgId,
-                            SupplierName = model.Name,
-                            SupplierShortName = model.ShortName
-                        };
-
-                        BaseDal.AddData(supplierInfoAddNew);
-                    }
-                    else
-                    {
-                        supplierInfo.Status = 1;
-                        supplierInfo.SupplierCode = model.Code;
-                        supplierInfo.SupplierName = model.Name;
-                        supplierInfo.SupplierShortName = model.ShortName;
-                        BaseDal.UpdateData(supplierInfo);
+                            continue;
+                        }
+                        Dt_SupplierInfo supplierInfo = _mapper.Map<Dt_SupplierInfo>(item);
+                        supplierInfosAdd.Add(supplierInfo);
                     }
                 }
-                else if (model.OperateType == "2")
+                //鏇存柊
+                if (bSTSupplierDTOsUpdate.Count > 0)
                 {
-                    Dt_SupplierInfo supplierInfo = BaseDal.QueryFirst(x => x.SupplierCode == model.Code);
-                    if (supplierInfo == null)
+                    //鑾峰彇宸插瓨鍦ㄧ殑鐗╂枡
+                    List<Dt_SupplierInfo>? ExistbSTSuppliersUpdate = OldsupplierInfos.Where(x => bSTSupplierDTOsUpdate.Select(x => x.VendId).Contains(x.SupplierSourceId)).ToList();
+                    foreach (var item in bSTSupplierDTOsUpdate)
                     {
-                        return WebResponseContent.Instance.Error($"鏈壘鍒拌渚涘簲鍟嗕俊鎭�");
+                        Dt_SupplierInfo? supplierInfoUpdate = ExistbSTSuppliersUpdate.FirstOrDefault(x => x.SupplierSourceId == item.VendId);
+                        //濡傛灉鐗╂枡宸插瓨鍦ㄥ垯杩涜鏇存敼
+                        if (supplierInfoUpdate != null)
+                        {
+                            supplierInfoUpdate.SupplierSourceId = item.VendId;
+                            supplierInfoUpdate.SupplierCode = item.VendNo;
+                            supplierInfoUpdate.SupplierShortName = item.ShortName;
+                            supplierInfoUpdate.SupplierName = item.ShortName;
+                            supplierInfoUpdate.Contacts = item.BusinessContact;
+                            supplierInfoUpdate.ContactNumber = item.Tel;
+                            supplierInfoUpdate.ContactAddress = item.Address;
+                            supplierInfosUpdate.Add(supplierInfoUpdate);
+                        }
+                        else//濡傛灉涓嶅瓨鍦ㄥ垯杩涜鏂板
+                        {
+                            Dt_SupplierInfo supplierInfo = _mapper.Map<Dt_SupplierInfo>(item);
+                            supplierInfosAdd.Add(supplierInfo);
+                        }
                     }
-                    BaseDal.DeleteData(supplierInfo);
                 }
-                return WebResponseContent.Instance.OK();
+                //鍒犻櫎
+                if (bSTSupplierDTOsDTODel.Count > 0)
+                {
+
+                }
+                //鏇存柊鏁版嵁
+                _unitOfWorkManage.CommitTran();
+                BaseDal.AddData(supplierInfosAdd);
+                BaseDal.UpdateData(supplierInfosUpdate);
+                _unitOfWorkManage.CommitTran();
+                content.OK("鎺ユ敹鎴愬姛");
             }
             catch (Exception ex)
             {
-                return WebResponseContent.Instance.Error(ex.Message);
+                content.Error(ex.Message);
             }
+            return content;
         }
     }
 }

--
Gitblit v1.9.3