| | |
| | | using WIDESEA_Model.Models; |
| | | using WIDESEA_Model.Models.Inbound; |
| | | using static WIDESEA_Common.HouseInventoryIn; |
| | | using static WIDESEA_Common.HouseSyncretism; |
| | | using static WIDESEA_Common.InventoryAllocate; |
| | | using Parameter = WIDESEA_Common.Parameter; |
| | | |
| | | namespace WIDESEA_InboundService |
| | |
| | | var targetAddress = saveModel.MainData["targetAddress"]; |
| | | |
| | | Dt_StockInfo stockInfo = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Includes(x => x.Details).Where(x => x.PalletCode == soussAddress).First(); |
| | | Dt_StockInfo stockInfo1 = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Includes(x => x.Details).Where(x => x.PalletCode == targetAddress).First(); |
| | | Dt_Warehouse warehouse = _warehouseService.Repository.QueryFirst(x => x.WarehouseId == stockInfo1.WarehouseId); |
| | | if (stockInfo == null || stockInfo1 == null) |
| | | Dt_StockInfo targetstockInfo = _stockRepository.StockInfoRepository.Db.Queryable<Dt_StockInfo>().Includes(x => x.Details).Where(x => x.PalletCode == targetAddress).First(); |
| | | Dt_Warehouse warehouse = _warehouseService.Repository.QueryFirst(x => x.WarehouseId == targetstockInfo.WarehouseId); |
| | | if (stockInfo == null || targetstockInfo == null) |
| | | { |
| | | throw new Exception("库存未找到托盘号"); |
| | | } |
| | | foreach (var item in stockInfo.Details) |
| | | { |
| | | item.StockId = stockInfo1.Id; |
| | | item.StockId = targetstockInfo.Id; |
| | | } |
| | | if (warehouse.WarehouseCode == "SC02_CP") |
| | | { |
| | | warehouse.WarehouseCode = "SC01_CP"; |
| | | } |
| | | if (warehouse.WarehouseCode == "SC02_BC") |
| | | { |
| | | warehouse.WarehouseCode = "SC01_BC"; |
| | | } |
| | | var houseSyncretism = new HouseSyncretism |
| | | { |
| | | ApiType = "AsnController", |
| | | Method = "AsrsGroudingAsn", |
| | | Parameters = new List<HouseSyncretism.data> |
| | | ApiType = "InventoryMoveController", |
| | | Method = "AsrsSubmitMoveDatas", |
| | | |
| | | Parameters = new List<HouseSyncretism.Parame> |
| | | { |
| | | new HouseSyncretism.data |
| | | new HouseSyncretism.Parame { |
| | | Value = stockInfo.Details.Select(g => new Parame.Syncretism |
| | | { |
| | | Lpn=stockInfo.PalletCode, |
| | | MoveType=0, |
| | | WareHouseCode=warehouse.WarehouseCode, |
| | | ItemCode = g.MaterielCode, |
| | | MoveNumber = g.StockQuantity, |
| | | LotNo = g.BatchNo, |
| | | WipBatch = g.BatchNo, |
| | | LocationName = stockInfo.LocationCode, |
| | | TargetLocName = targetstockInfo.LocationCode, |
| | | TargetLpn = targetstockInfo.PalletCode, |
| | | |
| | | }).ToList() |
| | | } |
| | | } |
| | | // Parameters = stockInfo.Details.Select(g => new HouseSyncretism.data |
| | | // { |
| | | // Lpn = stockInfo.PalletCode, |
| | | // MoveType = 0, |
| | | // WareHouseCode = warehouse.WarehouseCode, |
| | | // ItemCode = g.MaterielCode, |
| | | // MoveNumber = g.StockQuantity, |
| | | // //LotNo = g., |
| | | // WipBatch = g.BatchNo, |
| | | // LocationName = stockInfo.PalletCode, |
| | | // TargetLocName = targetstockInfo.PalletCode, |
| | | // TargetLpn = targetstockInfo.PalletCode, |
| | | |
| | | // }).ToList() |
| | | //}; |
| | | }; |
| | | |
| | | var authResult = AuthenticateWithWMS(); |
| | | if (authResult.IsSuccess) |
| | | { |
| | |
| | | |
| | | } |
| | | _unitOfWorkManage.BeginTran(); |
| | | stockInfo1.Details.AddRange(stockInfo.Details); |
| | | _stockRepository.StockInfoRepository.UpdateData(stockInfo1); |
| | | stockInfo.Details.Clear(); |
| | | _stockRepository.StockInfoRepository.UpdateData(stockInfo); |
| | | targetstockInfo.Details.AddRange(stockInfo.Details); |
| | | _stockRepository.StockInfoRepository.UpdateData(targetstockInfo); |
| | | _stockRepository.StockInfoDetailRepository.UpdateData(stockInfo.Details); |
| | | _stockRepository.StockInfoRepository.DeleteData(stockInfo); |
| | | _unitOfWorkManage.CommitTran(); |
| | | webResponseContent = WebResponseContent.Instance.OK("合托成功"); |
| | | } |