| | |
| | | [DisplayName("分页查询分拣任务表")] |
| | | public async Task<SqlSugarPagedList<WcsCheckTaskOutput>> Page(PageWcsCheckTaskInput input) |
| | | { |
| | | input.SearchKey = input.SearchKey?.Trim(); |
| | | input.SearchKey = input.SearchKey?.Trim(); |
| | | var query = _wcsCheckTaskRep.AsQueryable() |
| | | .WhereIF(!string.IsNullOrEmpty(input.SearchKey), u => |
| | | u.OrderNo.Contains(input.SearchKey) |
| | |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.Status), u => u.Status.Contains(input.Status.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.PZNo), u => u.PZNo.Contains(input.PZNo.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.PalletNo), u => u.PalletNo.Contains(input.PalletNo.Trim())) |
| | | .WhereIF(input.BoxInsert>0, u => u.BoxInsert == input.BoxInsert) |
| | | .WhereIF(input.BoxCount>0, u => u.BoxCount == input.BoxCount) |
| | | .WhereIF(input.Qty>0, u => u.Qty == input.Qty) |
| | | .WhereIF(input.FinishQty>0, u => u.FinishQty == input.FinishQty) |
| | | .WhereIF(input.BoxInsert > 0, u => u.BoxInsert == input.BoxInsert) |
| | | .WhereIF(input.BoxCount > 0, u => u.BoxCount == input.BoxCount) |
| | | .WhereIF(input.Qty > 0, u => u.Qty == input.Qty) |
| | | .WhereIF(input.FinishQty > 0, u => u.FinishQty == input.FinishQty) |
| | | .WhereIF(input.BindTimeRange != null && input.BindTimeRange.Length == 2, u => u.BindTime >= input.BindTimeRange[0] && u.BindTime <= input.BindTimeRange[1]) |
| | | .WhereIF(input.BindUserId>0, u => u.BindUserId == input.BindUserId) |
| | | .WhereIF(input.BindUserId > 0, u => u.BindUserId == input.BindUserId) |
| | | .Select<WcsCheckTaskOutput>(); |
| | | return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize); |
| | | return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize); |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | checkTaskInfo.LotNo = taskInfo.LotNo; |
| | | checkTaskInfo.SkuNo = taskInfo.SkuNo; |
| | | checkTaskInfo.SkuName = taskInfo.SkuName; |
| | | checkTaskInfo.BoxType = taskInfo.BoxType; |
| | | //checkTaskInfo.BoxType = taskInfo.BoxType; |
| | | checkTaskInfo.Qty = taskInfo.Qty; |
| | | checkTaskInfo.Status = "1";//已绑定 |
| | | checkTaskInfo.PZNo = skuInfo.PZNo; |
| | | checkTaskInfo.PZNo = skuInfo.PZNo; |
| | | |
| | | #region#给PLC写入抓箱品种号 |
| | | var modPlc = await _wcsDeviceRep.Context.Queryable<WcsPlc>().FirstAsync(s => s.Id == deviceInfo.PlcId); |
| | | if (modPlc == null) |
| | | if (checkTaskInfo.Id >= 6) |
| | | { |
| | | throw Oops.Bah("找不到PLC信息"); |
| | | } |
| | | PLCUtil modUtil = new PLCUtil(modPlc); |
| | | if (modUtil.Connected) |
| | | { |
| | | var ret = modUtil.SetPlcDBValue(checkTaskInfo.PosType, checkTaskInfo.DbNumber, checkTaskInfo.PlcPos, checkTaskInfo.PZNo); |
| | | if (ret.IsSucceed) |
| | | var modPlc = await _wcsDeviceRep.Context.Queryable<WcsPlc>().FirstAsync(s => s.Id == deviceInfo.PlcId); |
| | | if (modPlc == null) |
| | | { |
| | | //写入流程字成功后更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(checkTaskInfo).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | throw Oops.Bah("找不到PLC信息"); |
| | | } |
| | | PLCUtil modUtil = new PLCUtil(modPlc); |
| | | if (modUtil.Connected) |
| | | { |
| | | var ret = modUtil.SetPlcDBValue(checkTaskInfo.PosType, checkTaskInfo.DbNumber, checkTaskInfo.PlcPos, checkTaskInfo.PZNo); |
| | | if (ret.IsSucceed) |
| | | { |
| | | //写入流程字成功后更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(checkTaskInfo).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("与PCL交互失败,绑定失败!"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("与PCL交互失败,绑定失败!"); |
| | | throw Oops.Bah("PCL未连接,绑定失败!"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("PCL未连接,绑定失败!"); |
| | | await _wcsCheckTaskRep.AsUpdateable(checkTaskInfo).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | } |
| | | #endregion |
| | | } |
| | |
| | | // throw Oops.Bah($"找不到工位号:208的设备信息"); |
| | | // } |
| | | // PLCUtil modUtil = new PLCUtil(modPlc); |
| | | |
| | | |
| | | // var ret = modUtil.SetPlcDBValue(checkTaskList2.PosTypeLot, checkTaskList2.DbNumber, checkTaskList2.PosLot, "1"); |
| | | // return; |
| | | //} |
| | |
| | | PLCUtil modUtil = new PLCUtil(modPlc); |
| | | if (modUtil.Connected) |
| | | { |
| | | var ret = modUtil.SetPlcDBValue(item.PosTypeLot, item.DbNumber, item.PosLot, "0"); // 解绑分道 |
| | | if (ret.IsSucceed) |
| | | { |
| | | //写入流程字成功后更新分拣任务 |
| | | item.OrderNo = ""; |
| | | item.TaskNo = ""; |
| | | item.LotNo = ""; |
| | | item.SkuNo = ""; |
| | | item.SkuName = ""; |
| | | item.BoxType = ""; |
| | | item.Qty = 0; |
| | | item.PZNo = ""; |
| | | item.Status = "0";//未绑定 |
| | | // 写入结批信号 |
| | | var ret = modUtil.SetPlcDBValue(item.PosTypeLot, item.DbNumber, item.PosLot, "1"); |
| | | //var ret1 = modUtil.SetPlcDBValue(item.PosTypeLot, item.DbNumber, item.PosLot, "0"); // 解绑分道 |
| | | //if (ret1.IsSucceed) |
| | | //{ |
| | | // //写入流程字成功后更新分拣任务 |
| | | // item.OrderNo = ""; |
| | | // item.TaskNo = ""; |
| | | // item.LotNo = ""; |
| | | // item.SkuNo = ""; |
| | | // item.SkuName = ""; |
| | | // item.BoxType = ""; |
| | | // item.Qty = 0; |
| | | // item.PZNo = ""; |
| | | // item.Status = "0";//未绑定 |
| | | |
| | | //更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(item).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("与PCL交互失败,结批失败!"); |
| | | } |
| | | // //更新分拣任务 |
| | | // await _wcsCheckTaskRep.AsUpdateable(item).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | //} |
| | | //else |
| | | //{ |
| | | // throw Oops.Bah("与PCL交互失败,结批失败!"); |
| | | //} |
| | | } |
| | | else |
| | | { |
| | |
| | | #endregion |
| | | } |
| | | } |
| | | /// <summary> |
| | | /// 任务解绑 |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | [HttpPost] |
| | | [ApiDescriptionSettings(Name = "UnBindTaskForPLC")] |
| | | [DisplayName("任务解绑")] |
| | | public async Task UnBindTaskForPLC(BaseIdInput input) |
| | | { |
| | | var modCheckTask = await _wcsCheckTaskRep.AsQueryable().FirstAsync(s => s.Id == input.Id); |
| | | if (modCheckTask == null) |
| | | throw Oops.Bah("找不到该信息"); |
| | | if (modCheckTask.Status != "1") |
| | | throw Oops.Bah("该任务已解绑"); |
| | | modCheckTask.Status = "0"; |
| | | modCheckTask.OrderNo = ""; |
| | | modCheckTask.TaskNo = ""; |
| | | modCheckTask.SkuNo = ""; |
| | | modCheckTask.SkuName = ""; |
| | | modCheckTask.LotNo = ""; |
| | | modCheckTask.PZNo = ""; |
| | | modCheckTask.BoxType = ""; |
| | | modCheckTask.Qty = 0; |
| | | |
| | | await _wcsCheckTaskRep.AsUpdateable(modCheckTask).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | |
| | | |
| | | } |
| | | } |