| | |
| | | |
| | | using Admin.NET.Core.Service; |
| | | using AngleSharp.Dom; |
| | | using DocumentFormat.OpenXml.Vml.Office; |
| | | using Elastic.Clients.Elasticsearch.Tasks; |
| | | using Microsoft.AspNetCore.Http; |
| | | using WCS.Application.Entity; |
| | |
| | | private readonly SqlSugarRepository<WcsCheckTask> _wcsCheckTaskRep; |
| | | private readonly SqlSugarRepository<WcsDevice> _wcsDeviceRep; |
| | | private readonly SqlSugarRepository<WcsOderTask> _wcsOderTaskRep; |
| | | public WcsCheckTaskService(SqlSugarRepository<WcsCheckTask> wcsCheckTaskRep, SqlSugarRepository<WcsDevice> wcsDeviceRep, SqlSugarRepository<WcsOderTask> wcsOderTaskRep) |
| | | private readonly SqlSugarRepository<WcsMateialPzInfo> _wcsMateialPzInfoRep; |
| | | |
| | | public WcsCheckTaskService(SqlSugarRepository<WcsCheckTask> wcsCheckTaskRep, SqlSugarRepository<WcsDevice> wcsDeviceRep, SqlSugarRepository<WcsOderTask> wcsOderTaskRep, SqlSugarRepository<WcsMateialPzInfo> wcsMateialPzInfoRep) |
| | | { |
| | | _wcsCheckTaskRep = wcsCheckTaskRep; |
| | | _wcsDeviceRep = wcsDeviceRep; |
| | | _wcsOderTaskRep = wcsOderTaskRep; |
| | | _wcsMateialPzInfoRep = wcsMateialPzInfoRep; |
| | | } |
| | | |
| | | /// <summary> |
| | |
| | | .WhereIF(!string.IsNullOrEmpty(input.SearchKey), u => |
| | | u.OrderNo.Contains(input.SearchKey) |
| | | || u.RoboatNo.Contains(input.SearchKey) |
| | | || u.LineNO.Contains(input.SearchKey) |
| | | || u.LineNo.Contains(input.SearchKey) |
| | | || u.Port.Contains(input.SearchKey) |
| | | || u.LotNo.Contains(input.SearchKey) |
| | | || u.SkuNo.Contains(input.SearchKey) |
| | |
| | | ) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.OrderNo), u => u.OrderNo.Contains(input.OrderNo.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.RoboatNo), u => u.RoboatNo.Contains(input.RoboatNo.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.LineNO), u => u.LineNO.Contains(input.LineNO.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.LineNo), u => u.LineNo.Contains(input.LineNo.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.Port), u => u.Port.Contains(input.Port.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.LotNo), u => u.LotNo.Contains(input.LotNo.Trim())) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(input.SkuNo), u => u.SkuNo.Contains(input.SkuNo.Trim())) |
| | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 手动绑定任务到PLC |
| | | /// 手动绑定任务 |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | [HttpPost] |
| | | [ApiDescriptionSettings(Name = "BindTaskForPLC")] |
| | | [DisplayName("手动绑定任务到PLC")] |
| | | [DisplayName("手动绑定任务")] |
| | | public async Task BindTaskForPLC(BindTaskPLCInput input) |
| | | { |
| | | var deviceInfo = await _wcsDeviceRep.GetByIdAsync(input.deviceId); |
| | |
| | | if (taskInfo.Status > TaskStatusEnum.Doing) |
| | | { |
| | | throw Oops.Oh("任务状态异常"); |
| | | } |
| | | //物料品种信息 |
| | | var skuInfo = await _wcsMateialPzInfoRep.Context.Queryable<WcsMateialPzInfo>().Where(w => w.SkuNo == taskInfo.SkuNo).FirstAsync(); |
| | | if (skuInfo == null) |
| | | { |
| | | throw Oops.Oh("物料品种信息不存在"); |
| | | } |
| | | //分拣任务信息 |
| | | var checkTaskInfo = await _wcsCheckTaskRep.Context.Queryable<WcsCheckTask>().Where(w => w.Port == deviceInfo.StationNum).FirstAsync(); |
| | |
| | | checkTaskInfo.BoxType = taskInfo.BoxType; |
| | | checkTaskInfo.Qty = taskInfo.Qty; |
| | | checkTaskInfo.Status = "1";//已绑定 |
| | | //更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(checkTaskInfo).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | checkTaskInfo.PZNo = skuInfo.PZNo; |
| | | |
| | | #region#给PLC写入抓箱品种号 |
| | | var modPlc = await _wcsDeviceRep.Context.Queryable<WcsPlc>().FirstAsync(s => s.Id == deviceInfo.PlcId); |
| | | if (modPlc == null) |
| | | { |
| | | 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未连接,绑定失败!"); |
| | | } |
| | | #endregion |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 任务强制结批 |
| | | /// </summary> |
| | | /// <param name="input"></param> |
| | | /// <returns></returns> |
| | | [HttpPost] |
| | | [ApiDescriptionSettings(Name = "CloseTaskForPLC")] |
| | | [DisplayName("任务结批")] |
| | | public async Task CloseTaskForPLC(BindTaskPLCInput input) |
| | | [DisplayName("任务强制结批")] |
| | | public async Task CloseTaskForPLC(CloseTaskPLCInput input) |
| | | { |
| | | #region 请求PLC接口 |
| | | #endregion |
| | | //分拣任务信息 |
| | | // 注释:演示模式不绑定分道。liudl 2024-10-30 |
| | | //if (PLCTaskAction.boDemo) |
| | | //{ |
| | | // //演示模式 |
| | | // var checkTaskList2 = await _wcsCheckTaskRep.Context.Queryable<WcsCheckTask>().FirstAsync(w => w.Port == "208"); |
| | | |
| | | // var deviceInfo = await _wcsDeviceRep.Context.Queryable<WcsDevice>().FirstAsync(w => w.StationNum == "208"); |
| | | // if (deviceInfo == null) |
| | | // { |
| | | // throw Oops.Bah($"找不到工位号:208的码垛工位信息"); |
| | | // } |
| | | // var modPlc = await _wcsDeviceRep.Context.Queryable<WcsPlc>().FirstAsync(s => s.Id == deviceInfo.PlcId); |
| | | // if (modPlc == null) |
| | | // { |
| | | // throw Oops.Bah($"找不到工位号:208的设备信息"); |
| | | // } |
| | | // PLCUtil modUtil = new PLCUtil(modPlc); |
| | | |
| | | // var ret = modUtil.SetPlcDBValue(checkTaskList2.PosTypeLot, checkTaskList2.DbNumber, checkTaskList2.PosLot, "1"); |
| | | // return; |
| | | //} |
| | | |
| | | // 正常模式 |
| | | if (string.IsNullOrWhiteSpace(input.lotNo)) |
| | | { |
| | | throw Oops.Bah($"该工位未绑定任务!"); |
| | | } |
| | | var checkTaskList = _wcsCheckTaskRep.Context.Queryable<WcsCheckTask>().Where(w => w.LotNo == input.lotNo && w.Status == "1").ToList(); |
| | | if (checkTaskList.Count <= 0) |
| | | { |
| | | throw Oops.Bah("找不到该批次分拣任务信息"); |
| | | } |
| | | foreach (var item in checkTaskList) |
| | | { |
| | | item.OrderNo = ""; |
| | | item.LotNo = ""; |
| | | item.SkuNo = ""; |
| | | item.SkuName = ""; |
| | | item.BoxType = ""; |
| | | item.Qty = 0; |
| | | item.Status = "0";//未绑定 |
| | | #region#给PLC写入结批批次号 |
| | | var deviceInfo = await _wcsDeviceRep.Context.Queryable<WcsDevice>().FirstAsync(w => w.StationNum == item.Port); |
| | | if (deviceInfo == null) |
| | | { |
| | | throw Oops.Bah($"找不到工位号:{item.Port} 的码垛工位信息"); |
| | | } |
| | | var modPlc = await _wcsDeviceRep.Context.Queryable<WcsPlc>().FirstAsync(s => s.Id == deviceInfo.PlcId); |
| | | if (modPlc == null) |
| | | { |
| | | throw Oops.Bah($"找不到工位号:{item.Port} 的设备信息"); |
| | | } |
| | | 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";//未绑定 |
| | | |
| | | //更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(item).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("与PCL交互失败,结批失败!"); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Bah("PCL未连接,结批失败!"); |
| | | } |
| | | #endregion |
| | | } |
| | | //更新分拣任务 |
| | | await _wcsCheckTaskRep.AsUpdateable(checkTaskList).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommandAsync(); |
| | | } |
| | | } |