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