|  |  |  | 
|---|
|  |  |  | using log4net.Core; | 
|---|
|  |  |  | using Mapster; | 
|---|
|  |  |  | using Masuit.Tools; | 
|---|
|  |  |  | using Masuit.Tools.Models; | 
|---|
|  |  |  | using WIDESEA_DTO.MOM; | 
|---|
|  |  |  | using WIDESEA_DTO.WMS; | 
|---|
|  |  |  | using WIDESEA_IStorageBasicRepository; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private AgingOutputDto MapToAgingOutputDto(DtStockInfo stock, ResponseEqptRunDto info) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // TODO Value值根据MOM下发的静置时间到当前时间的分钟数 | 
|---|
|  |  |  | return new AgingOutputDto | 
|---|
|  |  |  | { | 
|---|
|  |  |  | OpFlag = 1, | 
|---|
|  |  |  | 
|---|
|  |  |  | SlotNo = x.OrderNo.ToInt32(), | 
|---|
|  |  |  | SerialNo = x.SerialNumber, | 
|---|
|  |  |  | SerialNoResult = true, | 
|---|
|  |  |  | ParameterInfo = info.ParameterInfo.Select(x => new ParameterInfo() | 
|---|
|  |  |  | ParameterInfo = info.ParameterInfo.Select(y => new ParameterInfo() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | LowerLomit = x.LowerControlLimit, | 
|---|
|  |  |  | UpperLimit = x.UpperControlLimit, | 
|---|
|  |  |  | ParameterResult = x.EquipmentAvailabilityFlag, | 
|---|
|  |  |  | ParameterCode = x.ParameterCode, | 
|---|
|  |  |  | ParameterDesc = x.Description, | 
|---|
|  |  |  | TargetValue = x.TargetValue, | 
|---|
|  |  |  | Value = (DateTime.Now - stock.CreateDate).TotalMinutes.ToString(), | 
|---|
|  |  |  | DefectCode = x.UOMCode | 
|---|
|  |  |  | LowerLomit = y.LowerControlLimit, | 
|---|
|  |  |  | UpperLimit = y.UpperControlLimit, | 
|---|
|  |  |  | ParameterResult = y.EquipmentAvailabilityFlag, | 
|---|
|  |  |  | ParameterCode = y.ParameterCode, | 
|---|
|  |  |  | ParameterDesc = y.Description, | 
|---|
|  |  |  | TargetValue = y.TargetValue, | 
|---|
|  |  |  | Value = (DateTime.Parse(stock.LinedProcessFeedbackTime, null, System.Globalization.DateTimeStyles.RoundtripKind).ToLocalTime() - stock.CreateDate).TotalMinutes.ToString(), | 
|---|
|  |  |  | DefectCode = y.UOMCode | 
|---|
|  |  |  | }).ToList() | 
|---|
|  |  |  | }).ToList() | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="task">任务数据合集</param> | 
|---|
|  |  |  | /// <returns>返回结果集</returns> | 
|---|
|  |  |  | //public async Task<WebResponseContent> CompleteInboundTaskAsync(Dt_Task task) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  | //    try | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        var boxing = await _boxingInfoRepository.QueryFirstNavAsync(x => x.PalletCode == task.PalletCode); | 
|---|
|  |  |  | //        var locationInf = await _locationRepository.QueryFirstAsync(x => x.LocationCode == task.TargetAddress); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        locationInf.LocationStatus = (int)LocationEnum.InStock; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        // 创建历史任务实例模型 | 
|---|
|  |  |  | //        var taskHty = CreateHistoricalTask(task); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        // 创建库存实例模型 | 
|---|
|  |  |  | //        DtStockInfo stock; | 
|---|
|  |  |  | //        if (boxing == null) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            // 空托盘 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            stock = new DtStockInfo() | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                PalletCode = task.PalletCode, | 
|---|
|  |  |  | //                LocationCode = task.TargetAddress, | 
|---|
|  |  |  | //                CreateDate = DateTime.Now, | 
|---|
|  |  |  | //                Creater = "system", | 
|---|
|  |  |  | //                IsFull = boxing.IsFull, | 
|---|
|  |  |  | //                StockInfoDetails = new List<DtStockInfoDetail>() | 
|---|
|  |  |  | //                { | 
|---|
|  |  |  | //                    new DtStockInfoDetail() | 
|---|
|  |  |  | //                    { | 
|---|
|  |  |  | //                         MaterielCode = "空托盘", | 
|---|
|  |  |  | //                         Id = 0, | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            }; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        else | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            // 实盘 | 
|---|
|  |  |  | //            var boxDetail = boxing.BoxingInfoDetails.Adapt<List<DtStockInfoDetail>>(); | 
|---|
|  |  |  | //            // 创建库存实例模型 | 
|---|
|  |  |  | //            stock = new DtStockInfo() | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                PalletCode = task.PalletCode, | 
|---|
|  |  |  | //                LocationCode = task.TargetAddress, | 
|---|
|  |  |  | //                CreateDate = DateTime.Now, | 
|---|
|  |  |  | //                Creater = "system", | 
|---|
|  |  |  | //                IsFull = boxing.IsFull, | 
|---|
|  |  |  | //                StockInfoDetails = boxDetail, | 
|---|
|  |  |  | //            }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            AgingInputDto agingInputDto = new AgingInputDto() | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                SerialNos = boxing.BoxingInfoDetails | 
|---|
|  |  |  | //                    .Select(item => new SerialNoInDto { SerialNo = item.SerialNumber, PositionNo = item.OrderNo }) | 
|---|
|  |  |  | //                    .ToList(), | 
|---|
|  |  |  | //                TrayBarcode = task.PalletCode, | 
|---|
|  |  |  | //                OpFlag = 1 | 
|---|
|  |  |  | //            }; | 
|---|
|  |  |  | //            var result = await _agingInOrOutInputService.GetOCVInputAsync(agingInputDto); | 
|---|
|  |  |  | //            stock.Remark = JsonConvert.DeserializeObject<ResponeAgingInputDto>(result.Data.ToString()).LinedProcessFeedbackTime; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            LogFactory.GetLog("任务完成").InfoFormat(true, "入库任务完成", $"货位地址:{task.TargetAddress},修改后货位数据:{locationInf}"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //        // 执行数据库事务 | 
|---|
|  |  |  | //        bool isResult = await ExecuteTransaction(stock, taskHty, locationInf, task.TaskId); | 
|---|
|  |  |  | //        if (isResult) | 
|---|
|  |  |  | //            content.OK("入库任务完成成功"); | 
|---|
|  |  |  | //        else | 
|---|
|  |  |  | //            content.Error("入库任务完成失败"); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    catch (Exception err) | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        Console.WriteLine(err.Message.ToString()); | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //    return content; | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 完成入库任务 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | /// <param name="task">任务数据合集</param> | 
|---|
|  |  |  | /// <returns>返回结果集</returns> | 
|---|
|  |  |  | public async Task<WebResponseContent> CompleteInboundTaskAsync(Dt_Task task) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 初始化响应内容 | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | MaterielCode = "空托盘", | 
|---|
|  |  |  | Id = 0, | 
|---|
|  |  |  | Status = (int)StockStateEmun.已入库 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | private DtStockInfo CreateFullPalletStock(Dt_Task task, DtLocationInfo locationInf, DtBoxingInfo boxing) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var boxDetail = boxing.BoxingInfoDetails.Adapt<List<DtStockInfoDetail>>(); | 
|---|
|  |  |  | boxDetail.ForEach(x => { x.Status = (int)StockStateEmun.已入库; }); | 
|---|
|  |  |  | var stock = new DtStockInfo() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | PalletCode = task.PalletCode, | 
|---|
|  |  |  | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | var result = _agingInOrOutInputService.GetOCVInputAsync(agingInputDto).Result; | 
|---|
|  |  |  | var respone = JsonConvert.DeserializeObject<ResponeAgingInputDto>(result.Data.ToString()); | 
|---|
|  |  |  | stock.Remark = respone.LinedProcessFeedbackTime; | 
|---|
|  |  |  | stock.LinedProcessFeedbackTime = respone.LinedProcessFeedbackTime; | 
|---|
|  |  |  | stock.SpecialParameterDuration = respone.SpecialParameterDuration; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 记录日志 | 
|---|
|  |  |  | LogFactory.GetLog("任务完成").InfoFormat(true, "入库任务完成", $"货位地址:{task.TargetAddress},修改后货位数据:{locationInf}"); | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Software = "WMS", | 
|---|
|  |  |  | TrayBarcode = input.PalletCode, | 
|---|
|  |  |  | //EquipmentCode = "EQ_CWJZ01" | 
|---|
|  |  |  | EquipmentCode = "ECH001-B" | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | return content.Error(result.MOMMessage); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // TODO 获取本地料框属性与整盘电芯属性获取的值进行对比,如果一致则继续,否则返回错误信息 | 
|---|
|  |  |  | var productions = await _productionRepository.QueryDataAsync(x => result.TrayBarcodePropertys.Select(x => x.TrayBarcodeProperty).ToList().Contains(x.TrayBarcodeProperty)); | 
|---|
|  |  |  | if (productions.Count <= 0) | 
|---|
|  |  |  | return content.Error("料框属性不存在"); | 
|---|
|  |  |  | //var productions = await _productionRepository.QueryDataAsync(x => result.TrayBarcodePropertys.Select(x => x.TrayBarcodeProperty).ToList().Contains(x.TrayBarcodeProperty)); | 
|---|
|  |  |  | //if (productions.Count <= 0) | 
|---|
|  |  |  | //    return content.Error("料框属性不存在"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 调用CreateBoxingInfo方法,创建组盘信息 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<string> strings = input.Position == "1088" ? new List<string>() { "CHSC01" } : new List<string>() { "JZSC01" }; | 
|---|
|  |  |  | // 调用CreateNewTask方法,创建新任务 | 
|---|
|  |  |  | content =  await CreateNewTask(input, strings); | 
|---|
|  |  |  | content = await CreateNewTask(input, strings); | 
|---|
|  |  |  | if (content.Status) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var isBox = await _boxingInfoRepository.AddDataNavAsync(boxing); | 
|---|
|  |  |  | 
|---|
|  |  |  | return content.OK(data: task); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return await CreateNewTask(input, null, 1); | 
|---|
|  |  |  | // 获取目标地址 | 
|---|
|  |  |  | List<string> strings = input.Position == "1016" ? new List<string>() { "CHSC01" } : new List<string>() { "JZSC01" }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return await CreateNewTask(input, strings, 1); | 
|---|
|  |  |  | //return await CreateNewTask(input, null, 1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 根据托盘类型查询库存信息 | 
|---|
|  |  |  | DtStockInfo stockInfo = tag == (int)TaskOutboundTypeEnum.Outbound | 
|---|
|  |  |  | ? QueryStockInfoForRealTray(areaCode, roadways) | 
|---|
|  |  |  | : QueryStockInfoForEmptyTray(areaCode, roadways); | 
|---|
|  |  |  | ? QueryStockInfoForRealTrayAsync(areaCode, roadways).Result | 
|---|
|  |  |  | : QueryStockInfoForEmptyTrayAsync(areaCode, roadways).Result; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (stockInfo == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return content.Error("库存信息不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 新增重复任务校验 | 
|---|
|  |  |  | var hasTask = BaseDal.QueryFirst(x => x.PalletCode == stockInfo.PalletCode); | 
|---|
|  |  |  | if (hasTask != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WMSTaskDTO taskDTO1 = CreateTaskDTO(hasTask); | 
|---|
|  |  |  | return content.OK("已存在空盘出库任务", data: taskDTO1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建新任务实例 | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 查询实盘库存信息 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | private DtStockInfo QueryStockInfoForRealTray(string areaCode, List<string> roadways) | 
|---|
|  |  |  | private async Task<DtStockInfo> QueryStockInfoForRealTrayAsync(string areaCode, List<string> roadways) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return _stockInfoRepository.Db.Queryable<DtStockInfo>().Where(x => x.AreaCode == areaCode && Convert.ToDateTime(x.Remark) < DateTime.Now && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && roadways.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) | 
|---|
|  |  |  | .First(); | 
|---|
|  |  |  | // TODO时间根据MOM系统配置的出库时间来获取,暂时不知道MOM返回的时间是什么所以这里测试时候在改 | 
|---|
|  |  |  | //return _stockInfoRepository.QueryFirstNavAsync(x => x.AreaCode == areaCode && Convert.ToDateTime(x.LinedProcessFeedbackTime).AddHours(Convert.ToDouble(x.SpecialParameterDuration)) < DateTime.Now | 
|---|
|  |  |  | //                        && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && roadways.Contains(x.LocationInfo.RoadwayNo) && x.StockInfoDetails.Any(x => x.Status == (int)StockStateEmun.已入库) && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock).Result; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var result = await _stockInfoRepository.Db.Queryable<DtStockInfo>().Where(x => | 
|---|
|  |  |  | x.AreaCode == areaCode && | 
|---|
|  |  |  | Convert.ToDateTime(x.LinedProcessFeedbackTime).AddHours(Convert.ToDouble(x.SpecialParameterDuration)) < DateTime.Now) | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && roadways.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | .Where(x => x.StockInfoDetails.Any(detail => detail.Status == (int)StockStateEmun.已入库)) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) | 
|---|
|  |  |  | .FirstAsync(); | 
|---|
|  |  |  | return result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// 查询空盘库存信息 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | private DtStockInfo QueryStockInfoForEmptyTray(string areaCode, List<string> roadways) | 
|---|
|  |  |  | private async Task<DtStockInfo> QueryStockInfoForEmptyTrayAsync(string areaCode, List<string> roadways) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | return _stockInfoRepository.Db.Queryable<DtStockInfo>().Where(x => x.AreaCode == areaCode && x.StockInfoDetails.Any(z => z.MaterielCode == "空托盘") && roadways.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) | 
|---|
|  |  |  | .First(); | 
|---|
|  |  |  | //return _stockInfoRepository.QueryFirstNavAsync(x => x.StockInfoDetails.Any(x => x.MaterielCode == "空托盘") && roadways.Contains(x.LocationInfo.RoadwayNo) && x.StockInfoDetails.Any(x => x.Status == (int)StockStateEmun.已入库) && x.LocationInfo.LocationStatus == (int)LocationEnum.InStock).Result; | 
|---|
|  |  |  | var result = await _stockInfoRepository.Db.Queryable<DtStockInfo>() | 
|---|
|  |  |  | .Includes(x => x.LocationInfo) | 
|---|
|  |  |  | .Where(x => x.LocationInfo.LocationStatus == (int)LocationEnum.InStock && roadways.Contains(x.LocationInfo.RoadwayNo)) | 
|---|
|  |  |  | .Includes(x => x.StockInfoDetails) | 
|---|
|  |  |  | .Where(x => x.StockInfoDetails.Any(detail => detail.Status == (int)StockStateEmun.已入库 && detail.MaterielCode == "空托盘")) | 
|---|
|  |  |  | .OrderBy(x => x.CreateDate) | 
|---|
|  |  |  | .FirstAsync(); | 
|---|
|  |  |  | return result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | 
|---|
|  |  |  | WebResponseContent content = new WebResponseContent(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取目标地址 | 
|---|
|  |  |  | string ToAddress = await GetRoadWayAsync(process); | 
|---|
|  |  |  | //string ToAddress = await GetRoadWayAsync(process); | 
|---|
|  |  |  | string ToAddress = await GetRoadWayAsync(input, process); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 创建新任务实例 | 
|---|
|  |  |  | var task = new Dt_Task | 
|---|
|  |  |  | 
|---|
|  |  |  | /// <param name="Direction">方向</param> | 
|---|
|  |  |  | /// <param name="area">关系区域</param> | 
|---|
|  |  |  | /// <returns></returns> | 
|---|
|  |  |  | public async Task<string> GetRoadWayAsync(List<string> process) | 
|---|
|  |  |  | public async Task<string> GetRoadWayAsync(RequestTaskDto input, List<string> process) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var minGroup = _locationRepository.QueryData(x => process.Contains(x.RoadwayNo) && x.LocationStatus == (int)LocationEnum.Free) | 
|---|
|  |  |  | .GroupBy(x => x.RoadwayNo) | 
|---|