| | |
| | | { |
| | | return content.Error("éè´ä¿¡æ¯ä¸è½ä¼ å
¥ä¸ºç©º"); |
| | | } |
| | | if (eRPPurchaseOrderDTO.PurchaseInDetail == null || eRPPurchaseOrderDTO.PurchaseInDetail.Count <= 0) |
| | | { |
| | | return content.Error("éè´æç»ä¿¡æ¯ä¸è½ä¼ å
¥ä¸ºç©º"); |
| | | } |
| | | Dt_Warehouse warehouse = _basicRepository.WarehouseRepository.QueryFirst(x=>x.WarehouseCode==eRPPurchaseOrderDTO.WarehouseCode); |
| | | if (warehouse==null) |
| | | { |
| | |
| | | Dt_PurchaseOrder purchaseOrder = _mapper.Map<Dt_PurchaseOrder>(eRPPurchaseOrderDTO); |
| | | purchaseOrderDetails.ForEach(x => |
| | | { |
| | | Dt_MaterielInfo? materielInfo = materielInfos.FirstOrDefault(t => t.MaterielCode == x.MaterialCode); |
| | | if (materielInfo != null) |
| | | if (warehouse.WarehouseCode == WarehouseEnum.LLDYL.ToString() && x.PurchaseDetailThickness <= 0) |
| | | { |
| | | |
| | | throw new Exception($"ç©æ{x.MaterialCode}æ¡ç {x.BarCode}ç´å¾é大äº0"); |
| | | } |
| | | if (purchaseOrderDetailsOld.FirstOrDefault(t => t.BarCode == x.BarCode) != null) |
| | | { |
| | | throw new Exception($"éè´ååå·{purchaseOrder.PurchaseOrderNo}æ¡ç {x.BarCode}å·²åå¨"); |
| | | } |
| | | Dt_MaterielInfo? materielInfo = materielInfos.FirstOrDefault(t => t.MaterielCode == x.MaterialCode); |
| | | x.MaterielName = materielInfo?.MaterielName; |
| | | x.Unit = materielInfo?.MaterielUnit; |
| | | x.MaterielSpec= materielInfo?.MaterielSpec; |
| | | x.MaterielSpec = materielInfo?.MaterielSpec; |
| | | }); |
| | | purchaseOrder.Details = purchaseOrderDetails; |
| | | purchaseOrder.WarehouseId = warehouse.WarehouseId; |
| | |
| | | BaseDal.Db.InsertNav(purchaseOrder).Include(x=>x.Details).ExecuteCommand(); |
| | | |
| | | } |
| | | //else if (eRPPurchaseOrderDTO.OperateType == 2) |
| | | //{ |
| | | // //夿æ¯å¦åå¨ |
| | | // Dt_UserInfo? userInfoOld = OlduserInfos.FirstOrDefault(x => x.Code == eRPUserInfoDTO.StaffCode); |
| | | // if (userInfoOld == null) |
| | | // { |
| | | // return content.Error($"æ´æ°å·¥å·{eRPUserInfoDTO.StaffCode}ï¼åå·¥{eRPUserInfoDTO.StaffName}ä¸åå¨"); |
| | | // } |
| | | // Dt_UserInfo userInfo = _mapper.Map<Dt_UserInfo>(eRPUserInfoDTO); |
| | | // userInfo.Id = userInfoOld.Id; |
| | | // Sys_User user = _userRepository.QueryFirst(x => x.UserName == userInfo.Code); |
| | | // if (userInfoOld == null) |
| | | // { |
| | | // return content.Error($"æ´æ°å·¥å·{eRPUserInfoDTO.StaffCode}ï¼åå·¥{eRPUserInfoDTO.StaffName}ï¼WMSè´¦å·ä¸åå¨"); |
| | | // } |
| | | // user.Enable = (byte)userInfo.State; |
| | | // user.UserTrueName = userInfo.Name; |
| | | // //æ´æ° |
| | | // BaseDal.UpdateData(userInfo); |
| | | // _userRepository.UpdateData(user); |
| | | //} |
| | | //else if (eRPPurchaseOrderDTO.OperateType == 3) |
| | | //{ |
| | | // //夿æ¯å¦åå¨ |
| | | // Dt_UserInfo? userInfoOld = OlduserInfos.FirstOrDefault(x => x.Code == eRPUserInfoDTO.StaffCode); |
| | | // if (userInfoOld == null) |
| | | // { |
| | | // return content.Error($"æ´æ°å·¥å·{eRPUserInfoDTO.StaffCode}ï¼åå·¥{eRPUserInfoDTO.StaffName}ä¸åå¨"); |
| | | // } |
| | | // BaseDal.DeleteData(userInfoOld); |
| | | //} |
| | | else if (eRPPurchaseOrderDTO.OperateType == 2) |
| | | { |
| | | //夿æ¯å¦åå¨ |
| | | Dt_PurchaseOrder? purchaseOrderOld = purchaseOrdersOld.FirstOrDefault(x => x.PurchaseOrderNo == eRPPurchaseOrderDTO.PurchaseInCode); |
| | | if (purchaseOrderOld == null) |
| | | { |
| | | return content.Error($"éè´ååå·{eRPPurchaseOrderDTO.PurchaseInCode}ä¿¡æ¯ä¸åå¨"); |
| | | } |
| | | if (purchaseOrderOld.PurchaseOrderStatus != InOrderStatusEnum.æªå¼å§.ObjToInt()) |
| | | { |
| | | return content.Error($"éè´ååå·{purchaseOrderOld.PurchaseOrderNo}ç¶æä¸º{(InOrderStatusEnum)purchaseOrderOld.PurchaseOrderStatus}"); |
| | | } |
| | | List<string> barCodesOld = purchaseOrderOld.Details.Select(x => x.BarCode).ToList(); |
| | | List<Dt_PurchaseOrderDetail> purchaseOrderDetails = eRPPurchaseOrderDTO.PurchaseInDetail.Select(x => _mapper.Map<Dt_PurchaseOrderDetail>(x)).ToList(); |
| | | Dt_PurchaseOrder purchaseOrder = _mapper.Map<Dt_PurchaseOrder>(eRPPurchaseOrderDTO); |
| | | purchaseOrder.Id = purchaseOrderOld.Id; |
| | | purchaseOrderDetails.ForEach(x => |
| | | { |
| | | if (warehouse.WarehouseCode == WarehouseEnum.LLDYL.ToString() && x.PurchaseDetailThickness <= 0) |
| | | { |
| | | throw new Exception($"ç©æ{x.MaterialCode}æ¡ç {x.BarCode}ç´å¾é大äº0"); |
| | | } |
| | | if (purchaseOrderDetailsOld.FirstOrDefault(t => t.BarCode == x.BarCode) != null && !barCodesOld.Contains(x.BarCode)) |
| | | { |
| | | throw new Exception($"éè´ååå·{purchaseOrder.PurchaseOrderNo}æ¡ç {x.BarCode}å·²åå¨"); |
| | | } |
| | | Dt_MaterielInfo? materielInfo = materielInfos.FirstOrDefault(t => t.MaterielCode == x.MaterialCode); |
| | | x.MaterielName = materielInfo?.MaterielName; |
| | | x.Unit = materielInfo?.MaterielUnit; |
| | | x.MaterielSpec = materielInfo?.MaterielSpec; |
| | | }); |
| | | purchaseOrder.Details = purchaseOrderDetails; |
| | | purchaseOrder.WarehouseId = warehouse.WarehouseId; |
| | | //æ´æ° |
| | | BaseDal.Db.UpdateNav(purchaseOrder).Include(x => x.Details).ExecuteCommand(); |
| | | } |
| | | else if (eRPPurchaseOrderDTO.OperateType == 3) |
| | | { |
| | | //夿æ¯å¦åå¨ |
| | | Dt_PurchaseOrder? purchaseOrderOld = purchaseOrdersOld.FirstOrDefault(x => x.PurchaseOrderNo == eRPPurchaseOrderDTO.PurchaseInCode); |
| | | if (purchaseOrderOld == null) |
| | | { |
| | | return content.Error($"éè´ååå·{eRPPurchaseOrderDTO.PurchaseInCode}ä¿¡æ¯ä¸åå¨"); |
| | | } |
| | | if (purchaseOrderOld.PurchaseOrderStatus != InOrderStatusEnum.æªå¼å§.ObjToInt()) |
| | | { |
| | | return content.Error($"éè´ååå·{purchaseOrderOld.PurchaseOrderNo}ç¶æä¸º{(InOrderStatusEnum)purchaseOrderOld.PurchaseOrderStatus}"); |
| | | } |
| | | //å é¤ |
| | | BaseDal.Db.DeleteNav(purchaseOrderOld).Include(x => x.Details).ExecuteCommand(); |
| | | } |
| | | else |
| | | { |
| | | return content.Error("æªæ¾å°æä½ç±»å"); |
| | |
| | | Dt_ReturnOutOrder? returnOutOrderOld = returnOutOrdersOld.FirstOrDefault(x => x.ReturnNo == eRPReturnOrderDTO.ReturnCode); |
| | | if (returnOutOrderOld != null) |
| | | { |
| | | return content.Error($"éè´§ åå·{returnOutOrderOld.ReturnNo}ä¿¡æ¯å·²åå¨"); |
| | | return content.Error($"éè´§åå·{returnOutOrderOld.ReturnNo}ä¿¡æ¯å·²åå¨"); |
| | | } |
| | | List<Dt_ReturnOutOrderDetail> returnOutOrderDetails = eRPReturnOrderDTO.ReturnDetail.Select(x => _mapper.Map<Dt_ReturnOutOrderDetail>(x)).ToList(); |
| | | Dt_ReturnOutOrder returnOutOrderAdd = _mapper.Map<Dt_ReturnOutOrder>(eRPReturnOrderDTO); |