| | |
| | | using WIDESEA_ITaskInfoService; |
| | | using WIDESEA_Model.Models; |
| | | using WIDESEA_TaskInfoRepository; |
| | | using static WIDESEA_ITaskInfoService.ITaskService; |
| | | |
| | | namespace WIDESEA_TaskInfoService |
| | | { |
| | |
| | | Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(task.PalletCode); |
| | | //æ¥è´§ä½ |
| | | Dt_LocationInfo locationInfo = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == task.TargetAddress); |
| | | |
| | | Dt_StockInfoDetail dt_StockInfodetail = _stockService.StockInfoDetailService.Repository.QueryFirst(x => x.OrderNo == task.PalletCode); |
| | | CheckCompleted(stockInfo, locationInfo); |
| | | |
| | | if (stockInfo.MaterialType == (int)InventoryMaterialType.空æ) |
| | | { |
| | | string currentTime = DateTime.Now.ToString("HHmmss"); |
| | | stockInfo.PalletCode = "KTP" + currentTime; |
| | | } |
| | | stockInfo.LocationCode = task.TargetAddress; |
| | | stockInfo.StockStatus = StockStatusEmun.å·²å
¥åº.ObjToInt(); |
| | | _stockService.StockInfoService.Repository.UpdateData(stockInfo); |
| | | if (_stockService.StockInfoService.Repository.UpdateData(stockInfo)) |
| | | { |
| | | string[] Pallet = stockInfo.PalletCode.Split("-"); |
| | | Dt_StockInfoDetail dt_StockInfoDetail = new() |
| | | { |
| | | StockId = stockInfo.Id, |
| | | MaterielCode = Pallet[0], //ç©æç¼å· |
| | | MaterielName = Pallet[1], //æè´¨ |
| | | OrderNo = stockInfo.PalletCode, //åæ®ï¼æçæ¡ç ï¼ |
| | | BatchNo = Pallet[2], //æ¹æ¬¡å· |
| | | SerialNumber = Pallet[2], //åºåå· |
| | | StockQuantity = decimal.Parse(Pallet[3]), //åºåå· |
| | | OutboundQuantity = decimal.Parse(Pallet[3]), //åºåå· |
| | | Status = (int)StockStatusEmun.å·²å
¥åº, |
| | | Creater = "WMS", |
| | | CreateDate = DateTime.Now, |
| | | }; |
| | | _stockService.StockInfoDetailService.AddData(dt_StockInfoDetail); |
| | | } |
| | | |
| | | if(dt_StockInfodetail != null) |
| | | { |
| | | dt_StockInfodetail.Status = StockStatusEmun.å·²å
¥åº.ObjToInt(); |
| | | _stockService.StockInfoDetailService.Repository.UpdateData(dt_StockInfodetail); |
| | | } |
| | | beforeQuantity = stockInfo.Details.Where(x => x.Id != 0).Sum(x => x.StockQuantity); |
| | | |
| | | int beforeStatus = locationInfo.LocationStatus; |
| | | locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); |
| | | if (stockInfo.MaterialType == (int)InventoryMaterialType.空æ) |
| | | { |
| | | locationInfo.LocationStatus = LocationStatusEnum.Pallet.ObjToInt(); |
| | | } |
| | | else |
| | | { |
| | | locationInfo.LocationStatus = LocationStatusEnum.InStock.ObjToInt(); |
| | | } |
| | | _basicService.LocationInfoService.UpdateLocationFree(locationInfo, task.TaskNum, StockChangeType.Inbound.ObjToInt(), false); |
| | | |
| | | _basicService.LocationInfoService.Repository.UpdateData(locationInfo); |
| | |
| | | return WebResponseContent.Instance.OK(); |
| | | } |
| | | |
| | | public WebResponseContent RelocationTaskCompleted(string PalletCode,string SourceAddress, string TargetAddress) |
| | | public WebResponseContent RelocationTaskCompleted(GenerateInv2 generate) |
| | | { |
| | | Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(PalletCode); |
| | | Dt_StockInfo stockInfo = _stockService.StockInfoService.Repository.GetStockInfo(generate.PalletCode); |
| | | |
| | | Dt_LocationInfo locationpoint = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == SourceAddress); |
| | | Dt_LocationInfo locationEnd = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == TargetAddress); |
| | | Dt_LocationInfo locationpoint = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == generate.SourceAddress); |
| | | Dt_LocationInfo locationEnd = _basicService.LocationInfoService.Repository.QueryFirst(x => x.LocationCode == generate.TargetAddress); |
| | | List<Dt_LocationInfo> loca = new List<Dt_LocationInfo>(); |
| | | |
| | | stockInfo.LocationCode = locationEnd.LocationCode; |