| | |
| | | using AutoMapper; |
| | | using LogLibrary.Log; |
| | | using Newtonsoft.Json; |
| | | using SqlSugar; |
| | | using System; |
| | | using System.Collections.Generic; |
| | | using System.Data; |
| | | using System.Linq; |
| | | using System.Reflection.Metadata; |
| | | using System.Text; |
| | |
| | | using WIDESEA_IBasicService; |
| | | using WIDESEA_IInboundRepository; |
| | | using WIDESEA_IInboundService; |
| | | using WIDESEA_InboundRepository; |
| | | using WIDESEA_IStockService; |
| | | using WIDESEA_ITaskInfoRepository; |
| | | using WIDESEA_Model; |
| | | using WIDESEA_Model.Models; |
| | | using WIDESEA_Model.Models.Inbound; |
| | | using WIDESEA_Model.Models.System.Request; |
| | | |
| | | namespace WIDESEA_InboundService |
| | | { |
| | |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | List<MatSerialNumberDTO> matSerialNumberDTOs = CodeAnalysisHelper.CodeAnalysis<MatSerialNumberDTO>(AnalysisCode.InnerCode, materielGroupDTO.SerialNumbers); |
| | | (bool, string, object?) result2 = ModelValidate.ValidateModelData(matSerialNumberDTOs); |
| | | if (!result2.Item1) return content = WebResponseContent.Instance.Error(result2.Item2); |
| | | |
| | | List<string> materielCodes = matSerialNumberDTOs.GroupBy(x => x.MaterielCode).Select(x => x.Key).ToList(); |
| | | |
| | | List<Dt_MaterielInfo> materielInfos = _basicService.MaterielInfoService.GetMaterielInfos(materielCodes); |
| | | |
| | | Dt_InboundOrder inboundOrder = GetInboundOrder(materielGroupDTO.OrderNo); |
| | | |
| | | |
| | | materielGroupDTO.OrderNo = GetOrderNo(); |
| | | Dt_StockInfo? stockInfo = _stockService.StockInfoService.GetStockByPalletCode(materielGroupDTO.PalletCode); |
| | | |
| | | (bool, string, object?) result = CheckMaterielGroupParam(materielGroupDTO, matSerialNumberDTOs, materielInfos, materielCodes, inboundOrder, stockInfo); |
| | | (bool, string, object?) result = CheckMaterielGroupParam(materielGroupDTO, stockInfo); |
| | | if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); |
| | | |
| | | if (stockInfo == null) |
| | | { |
| | | stockInfo = new Dt_StockInfo(); |
| | | stockInfo.Details = new List<Dt_StockInfoDetail>(); |
| | | } |
| | | |
| | | List<Dt_StockInfoDetail> stockInfoDetails = _mapper.Map<List<Dt_StockInfoDetail>>(matSerialNumberDTOs); |
| | | stockInfoDetails.ForEach(x => |
| | | { |
| | | x.Status = 0; |
| | | x.OrderNo = inboundOrder.OrderNo; |
| | | x.MaterielName = materielInfos.FirstOrDefault(v => v.MaterielCode == x.MaterielCode)?.MaterielName ?? ""; |
| | | x.StockId = stockInfo.Id != 0 ? stockInfo.Id : 0; |
| | | }); |
| | | if (stockInfo.Id == 0) |
| | | { |
| | | stockInfo.PalletCode = materielGroupDTO.PalletCode; |
| | | stockInfo.StockStatus = StockStatusEmun.ç»çæå.ObjToInt(); |
| | | stockInfo.Creater = "ç«åºWMS"; |
| | | stockInfo.Details = new List<Dt_StockInfoDetail>(); |
| | | |
| | | } |
| | | stockInfo.Details.AddRange(stockInfoDetails); |
| | | |
| | | List<Dt_InboundOrderDetail> inboundOrderDetails = new List<Dt_InboundOrderDetail>(); |
| | | for (int i = 0; i < materielCodes.Count; i++) |
| | | List<Dt_StockInfoDetail> stockInfoDetails = new List<Dt_StockInfoDetail>(); |
| | | List<Dt_LabelMaster> notExistLabels = new List<Dt_LabelMaster>(); |
| | | foreach (var lablel in materielGroupDTO.SerialNumbers) |
| | | { |
| | | decimal stockQuantity = stockInfoDetails.Where(x => x.MaterielCode == materielCodes[i]).Sum(x => x.StockQuantity); |
| | | inboundOrderDetails.AddRange(_inboundOrderDetailService.UpdateReceiptQuantity(inboundOrder.Details.Where(x => x.MaterielCode == materielCodes[i]).ToList(), stockQuantity)); |
| | | } |
| | | List<int> updateDetailIds = inboundOrderDetails.Select(x => x.Id).ToList(); |
| | | if (inboundOrderDetails.FirstOrDefault(x => x.OrderDetailStatus != OrderDetailStatusEnum.Over.ObjToInt()) == null && inboundOrder.Details.FirstOrDefault(x => !updateDetailIds.Contains(x.Id) && x.OrderDetailStatus != OrderDetailStatusEnum.Over.ObjToInt()) == null) |
| | | { |
| | | inboundOrder.OrderStatus = InboundStatusEnum.å
¥åºå®æ.ObjToInt(); |
| | | BaseDal.DeleteAndMoveIntoHty(inboundOrder, App.User.UserId == 0 ? OperateType.èªå¨å®æ : OperateType.äººå·¥å®æ); |
| | | for (int i = 0; i < inboundOrderDetails.Count; i++) |
| | | Dt_LabelMaster labmaster = _labelMasterRepository.QueryFirst(x => x.LABEL_NO == lablel); |
| | | if(labmaster == null) |
| | | { |
| | | _inboundOrderDetailService.Repository.DeleteAndMoveIntoHty(inboundOrderDetails[i], App.User.UserId == 0 ? OperateType.èªå¨å®æ : OperateType.äººå·¥å®æ); |
| | | //éè¿æ¡ç æ¥å£åæ¥æ¡ç ä¸»æ°æ® |
| | | var res= _sys_JobService.GetLabMaster(lablel); |
| | | if (res != null && res.Status) |
| | | { |
| | | labmaster = _labelMasterRepository.QueryFirst(x => x.LABEL_NO == lablel); |
| | | if (labmaster == null) |
| | | { |
| | | notExistLabels.Add(labmaster); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error("ç»çæ¡ç å¨ä¸æ¸¸WMSç³»ç»ä¸ä¸åå¨!"); |
| | | } |
| | | } |
| | | if(labmaster!=null) |
| | | { |
| | | //ä¸»æ°æ®æ¡ç ç¶æå
许ç»çï¼01å·²æ¶æå¾
è´¨æ£ï¼02å·²æ¶ææ éè´¨æ£ï¼03å¾
è¿ä»å·²è´¨æ£ï¼09已䏿¶ï¼ |
| | | //ä¸»æ°æ®æ¡ç ç¶æä¸å
许ç»çï¼00å建ï¼04已质æ£å¾
éè´§ï¼05æ¶ææ¿éè´§ï¼06åºæ¿éè´§ï¼07å·²è¿ä»ï¼08已䏿¶ï¼10å·²åºåºï¼11å·²å»ç»ï¼12å·²éå®ï¼20å
³éçï¼ |
| | | if (labmaster.LABEL_STATUS=="00"|| labmaster.LABEL_STATUS == "04" || labmaster.LABEL_STATUS == "05"|| labmaster.LABEL_STATUS == "06" || labmaster.LABEL_STATUS == "07" || labmaster.LABEL_STATUS == "08" || labmaster.LABEL_STATUS == "10" || labmaster.LABEL_STATUS == "11" || labmaster.LABEL_STATUS == "12" || labmaster.LABEL_STATUS == "20") |
| | | { |
| | | return content = WebResponseContent.Instance.Error("ä¸»æ°æ®æ¡ç ç¶æä¸å
许ç»ç!æ¡ç ç¶æï¼"+ labmaster.LABEL_STATUS); |
| | | } |
| | | } |
| | | } |
| | | else if (inboundOrder.OrderStatus == InboundStatusEnum.æªå¼å§.ObjToInt()) |
| | | if (notExistLabels.Count == 0) |
| | | { |
| | | inboundOrder.OrderStatus = InboundStatusEnum.å
¥åºä¸.ObjToInt(); |
| | | } |
| | | foreach (var item in materielGroupDTO.SerialNumbers) |
| | | { |
| | | Dt_LabelMaster labmaster = _labelMasterRepository.QueryFirst(x => x.LABEL_NO == item); |
| | | Dt_StockInfoDetail dt_StockInfoDetail = new Dt_StockInfoDetail(); |
| | | dt_StockInfoDetail.Status = 0; |
| | | dt_StockInfoDetail.OrderNo = materielGroupDTO.OrderNo; |
| | | dt_StockInfoDetail.StockId = stockInfo.Id != 0 ? stockInfo.Id : 0; |
| | | dt_StockInfoDetail.MaterielCode = labmaster.MATNR; |
| | | dt_StockInfoDetail.MaterielName = labmaster.MAKTX; |
| | | dt_StockInfoDetail.BatchNo = labmaster.BATCH; |
| | | dt_StockInfoDetail.SerialNumber = labmaster.LABEL_NO; |
| | | dt_StockInfoDetail.StockQuantity = int.Parse(labmaster.BOX_QTY); |
| | | dt_StockInfoDetail.OutboundQuantity = 0; |
| | | dt_StockInfoDetail.Creater = "System"; |
| | | stockInfoDetails.Add(dt_StockInfoDetail); |
| | | stockInfo.Details.AddRange(stockInfoDetails); |
| | | } |
| | | content = MaterielGroupUpdateData(stockInfo); |
| | | |
| | | content = MaterielGroupUpdateData(inboundOrder, inboundOrderDetails, stockInfo); |
| | | } |
| | | else |
| | | { |
| | | content = WebResponseContent.Instance.Error("ç»çæ¡ç å¨ä¸æ¸¸WMSç³»ç»ä¸ä¸åå¨!"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | finally |
| | | { |
| | | |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// 使éåç»ç |
| | | /// </summary> |
| | | /// <param name="materielGroupDTO"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent ReturnMaterielGroup(MaterielGroupDTO materielGroupDTO, ReturnInventoryRequest inventoryRequest) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | Dt_StockInfo? stockInfo = _stockService.StockInfoService.GetStockByPalletCode(materielGroupDTO.PalletCode); |
| | | (bool, string, object?) result = CheckMaterielGroupParam(materielGroupDTO, stockInfo); |
| | | if (!result.Item1) return content = WebResponseContent.Instance.Error(result.Item2); |
| | | if (stockInfo == null) |
| | | { |
| | | stockInfo = new Dt_StockInfo(); |
| | | stockInfo.PalletCode = materielGroupDTO.PalletCode; |
| | | stockInfo.StockStatus = StockStatusEmun.ç»çæå.ObjToInt(); |
| | | stockInfo.Creater = "WMS"; |
| | | stockInfo.Details = new List<Dt_StockInfoDetail>(); |
| | | |
| | | } |
| | | List<Dt_StockInfoDetail> stockInfoDetails = new List<Dt_StockInfoDetail>(); |
| | | |
| | | foreach (var item in inventoryRequest.DATA) |
| | | { |
| | | |
| | | Dt_StockInfoDetail dt_StockInfoDetail = new Dt_StockInfoDetail(); |
| | | dt_StockInfoDetail.Status = 0; |
| | | dt_StockInfoDetail.OrderNo = materielGroupDTO.OrderNo; |
| | | dt_StockInfoDetail.StockId = stockInfo.Id != 0 ? stockInfo.Id : 0; |
| | | dt_StockInfoDetail.MaterielCode = item.MATNR; |
| | | dt_StockInfoDetail.MaterielName = ""; |
| | | dt_StockInfoDetail.BatchNo = ""; |
| | | dt_StockInfoDetail.SerialNumber = item.LABEL_NO; |
| | | dt_StockInfoDetail.StockQuantity = int.Parse(item.QTY); |
| | | dt_StockInfoDetail.OutboundQuantity = 0; |
| | | dt_StockInfoDetail.Creater = "WMS"; |
| | | stockInfoDetails.Add(dt_StockInfoDetail); |
| | | stockInfo.Details.AddRange(stockInfoDetails); |
| | | } |
| | | content = MaterielGroupUpdateData(stockInfo); |
| | | |
| | | |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | content = WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | finally |
| | | { |
| | | |
| | | } |
| | | return content; |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ ¹æ®BYDWMSç»çä¿¡æ¯ï¼åçæç«åºç»çä¿¡æ¯ |
| | | /// </summary> |
| | | /// <param name="inventoryRequest"></param> |
| | | /// <returns></returns> |
| | | public ReturnInventoryResponse returnInventory(string inventoryRequeststr) |
| | | { |
| | | |
| | | new LogFactory().GetLog("WMSæ¥å£").InfoFormat(true, "returnInventory", "使éåä¿¡æ¯", $"{inventoryRequeststr}"); |
| | | ReturnInventoryRequest inventoryRequest = JsonConvert.DeserializeObject<ReturnInventoryRequest>(inventoryRequeststr); |
| | | ReturnInventoryResponse response= new ReturnInventoryResponse(); |
| | | MaterielGroupDTO materielGroupDTO = new MaterielGroupDTO(); |
| | | materielGroupDTO.PalletCode = inventoryRequest.TPNUM; |
| | | materielGroupDTO.OrderNo = inventoryRequest.IZLID; //éè´§å
¥åºæä»¤ |
| | | List<string> SerialNumbers = new List<string>(); |
| | | Dt_MainReturnInventory dt_MainReturnInventoryOld = _mainReturnInventoryRepository.QueryFirst(x => x.RETURN_NO == inventoryRequest.RETURN_NO && x.RETURN_ITEM_NO == inventoryRequest.RETURN_ITEM_NO); |
| | | if (dt_MainReturnInventoryOld == null) |
| | | { |
| | | //ä¿ååéæ°æ®å°æ¬å° |
| | | Dt_MainReturnInventory dt_MainReturnInventory = new Dt_MainReturnInventory(); |
| | | dt_MainReturnInventory.WH_NUMBER = inventoryRequest.WH_NUMBER; |
| | | dt_MainReturnInventory.BUSINESS_CODE = inventoryRequest.BUSINESS_CODE; |
| | | dt_MainReturnInventory.BUSINESS_NAME = inventoryRequest.BUSINESS_NAME; |
| | | dt_MainReturnInventory.WERKS = inventoryRequest.WERKS; |
| | | dt_MainReturnInventory.LGORT = inventoryRequest.LGORT; |
| | | dt_MainReturnInventory.TOTAL_RETURN_QTY = inventoryRequest.TOTAL_RETURN_QTY; |
| | | dt_MainReturnInventory.RETURN_NO = inventoryRequest.RETURN_NO; |
| | | dt_MainReturnInventory.RETURN_ITEM_NO = inventoryRequest.RETURN_ITEM_NO; |
| | | dt_MainReturnInventory.TPNUM = inventoryRequest.TPNUM; |
| | | dt_MainReturnInventory.YLZD1 = inventoryRequest.YLZD1; |
| | | dt_MainReturnInventory.YLZD2 = inventoryRequest.YLZD2; |
| | | dt_MainReturnInventory.YLZD3 = inventoryRequest.YLZD3; |
| | | dt_MainReturnInventory.YLZD4 = inventoryRequest.YLZD4; |
| | | dt_MainReturnInventory.YLZD5 = inventoryRequest.YLZD5; |
| | | dt_MainReturnInventory.IZLID = inventoryRequest.IZLID; |
| | | dt_MainReturnInventory.SYSNOD = inventoryRequest.SYSNOD; |
| | | dt_MainReturnInventory.MO_NO = inventoryRequest.MO_NO; |
| | | foreach (ReturnInventory item in inventoryRequest.DATA) |
| | | { |
| | | Dt_ReturnInventoryDetail dt_ReturnInventoryDetail = new Dt_ReturnInventoryDetail(); |
| | | dt_ReturnInventoryDetail.LABEL_NO = item.LABEL_NO; |
| | | dt_ReturnInventoryDetail.SOBKZ = item.SOBKZ; |
| | | dt_ReturnInventoryDetail.UNIT = item.UNIT; |
| | | dt_ReturnInventoryDetail.LGORT = item.LGORT; |
| | | dt_ReturnInventoryDetail.QTY = item.QTY; |
| | | dt_ReturnInventoryDetail.LIFNR = item.LIFNR; |
| | | dt_ReturnInventoryDetail.F_LGORT = item.F_LGORT; |
| | | dt_ReturnInventoryDetail.MATNR = item.MATNR; |
| | | _ReturnInventoryDetailRepository.AddData(dt_ReturnInventoryDetail); |
| | | SerialNumbers.Add(item.LABEL_NO); |
| | | } |
| | | materielGroupDTO.SerialNumbers = SerialNumbers; |
| | | _mainReturnInventoryRepository.AddData(dt_MainReturnInventory); |
| | | WebResponseContent content = ReturnMaterielGroup(materielGroupDTO, inventoryRequest); |
| | | if (content.Status) |
| | | { |
| | | response.MSGTY = "S"; |
| | | response.MSGTX = ""; |
| | | } |
| | | else |
| | | { |
| | | response.MSGTY = "E"; |
| | | response.MSGTX = content.Message; |
| | | } |
| | | } |
| | | else |
| | | { |
| | | response.MSGTY = "E"; |
| | | response.MSGTX = "ä¸è½éå¤ç³è¯·ï¼"; |
| | | |
| | | } |
| | | return response; |
| | | } |
| | | /// <summary> |
| | | /// çæè®¢åå· |
| | | /// </summary> |
| | | /// <returns></returns> |
| | | public string GetOrderNo() |
| | | { |
| | | DataTable dt = BaseDal.QueryTable("SELECT FORMAT(NEXT VALUE FOR dbo.seqOrderNum, '000000000');"); |
| | | return DateTime.Now.ToString("yyyyMMdd") + dt.Rows[0][0].ToString(); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// æ¤éç»ç |
| | | /// </summary> |
| | | /// <param name="materielGroupDTO"></param> |
| | | /// <returns></returns> |
| | | public WebResponseContent MaterielGroupRevoke(string PalletCode) |
| | | { |
| | | WebResponseContent content = new WebResponseContent(); |
| | | try |
| | | { |
| | | Dt_StockInfo? stockInfo = _stockService.StockInfoService.GetStockByPalletCode(PalletCode); |
| | | if(stockInfo != null) |
| | | { |
| | | if(stockInfo.StockStatus!= (int)StockStatusEmun.ç»çæå) |
| | | { |
| | | return content = WebResponseContent.Instance.Error("ç»çæåç¶ææå¯ä»¥æ¤éç»çï¼"); |
| | | } |
| | | else |
| | | { |
| | | stockInfo.StockStatus = (int)StockStatusEmun.ç»çæ¤é; |
| | | foreach (var item in stockInfo.Details) |
| | | { |
| | | item.Status = (int)OutStockStatus.æ¤é; |
| | | } |
| | | } |
| | | content = MaterielGroupUpdateData(stockInfo); |
| | | |
| | | } |
| | | else |
| | | { |
| | | return content = WebResponseContent.Instance.Error("ç»çä¿¡æ¯ä¸åå¨ï¼"); |
| | | } |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | |
| | | return WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// ç»çæ°æ®æ´æ° |
| | | /// </summary> |
| | | /// <param name="inboundOrder">å
¥åºå</param> |
| | | /// <param name="inboundOrderDetails">å
¥åºåæç»</param> |
| | | /// <param name="stockInfo">ç»çæ°æ®</param> |
| | | /// <returns></returns> |
| | | public WebResponseContent MaterielGroupUpdateData(Dt_StockInfo stockInfo) |
| | | { |
| | | try |
| | | { |
| | | _unitOfWorkManage.BeginTran(); |
| | | _stockService.StockInfoService.AddMaterielGroup(stockInfo); |
| | | _unitOfWorkManage.CommitTran(); |
| | | return WebResponseContent.Instance.OK(); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | _unitOfWorkManage.RollbackTran(); |
| | | return WebResponseContent.Instance.Error(ex.Message); |
| | | } |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// éªè¯ç»çæ°æ® |
| | |
| | | return (true, "æå", materielGroupDTO); |
| | | } |
| | | |
| | | |
| | | /// <summary> |
| | | /// éªè¯ç»çæ°æ® |
| | | /// </summary> |
| | | /// <param name="materielGroupDTO">ç©æç»çDTO</param> |
| | | /// <param name="stockInfo">ç»çä¿¡æ¯</param> |
| | | /// <returns></returns> |
| | | public (bool, string, object?) CheckMaterielGroupParam(MaterielGroupDTO materielGroupDTO, Dt_StockInfo stockInfo) |
| | | { |
| | | (bool, string, object?) result = ModelValidate.ValidateModelData(materielGroupDTO); |
| | | if (!result.Item1) return result; |
| | | |
| | | if (_taskRepository.QueryFirst(x => x.PalletCode == materielGroupDTO.PalletCode) != null) |
| | | { |
| | | return (false, "该æçå·å·²æä»»å¡", materielGroupDTO); |
| | | } |
| | | |
| | | if (stockInfo != null && !string.IsNullOrEmpty(stockInfo.LocationCode) && stockInfo.StockStatus != StockStatusEmun.ç»çæå.ObjToInt()) |
| | | { |
| | | return (false, "已䏿¶çæçä¸è½å次ç»ç", materielGroupDTO); |
| | | } |
| | | |
| | | if (_stockService.StockInfoDetailService.ExistSerialNumbers(materielGroupDTO.SerialNumbers)) |
| | | { |
| | | return (false, "æåºåå·å¨åºåä¸å·²åå¨", materielGroupDTO); |
| | | } |
| | | |
| | | return (true, "æå", materielGroupDTO); |
| | | } |
| | | |
| | | |
| | | |
| | | /// <summary> |
| | | /// PDAå页æ¥è¯¢æ°æ® |
| | | /// </summary> |