| | |
| | | using System; |
| | | using System.Collections.Generic; |
| | | using System.ComponentModel; |
| | | using System.Data; |
| | | using System.Linq; |
| | | using System.Reflection.Metadata; |
| | | using System.Security.Cryptography.X509Certificates; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | |
| | | using Model.ModelDto; |
| | | using Model.ModelDto.BllCheckDto; |
| | | using Model.ModelDto.PdaDto; |
| | | using Model.ModelDto.SysDto; |
| | | using Newtonsoft.Json; |
| | | using SqlSugar; |
| | | using Utility; |
| | |
| | | |
| | | #endregion |
| | | |
| | | #region 库存查询 |
| | | |
| | | |
| | | /// <summary> |
| | | /// pda库存查询 |
| | | /// </summary> |
| | | /// <param name="locatNo">储位编号</param> |
| | | /// <param name="palletNo">托盘号</param> |
| | | /// <param name="boxNo">箱码</param> |
| | | /// <returns></returns> |
| | | public async Task<List<DataStockDetail>> GetStockQueryList(string locatNo, string palletNo) |
| | | public List<StockDetailWithQtyDto> GetStockQueryList(string locatNo, string palletNo, string boxNo) |
| | | { |
| | | return await Db.Queryable<DataStockDetail>() |
| | | .Where(s => s.IsDel == "0" && s.LocatNo.Contains(locatNo) || s.PalletNo.Contains(palletNo)) |
| | | .OrderBy(s => new { s.LotNo, s.LocatNo, s.PalletNo }) |
| | | .ToListAsync(); |
| | | string dataSql = "", whereStr = ""; |
| | | |
| | | if (string.IsNullOrWhiteSpace(boxNo)) |
| | | { |
| | | whereStr = string.IsNullOrWhiteSpace(locatNo) ? "1=1" : $@"LocatNo='{locatNo}'"; |
| | | |
| | | dataSql = $@"select SkuName,SkuNo,LotNo,LocatNo,PalletNo,sum(isnull(Qty,0)) as Qty,sum(isnull(LockQty,0)) as LockQty,sum(isnull(LockQty,0)) as FrozenQty |
| | | from DataStockDetail |
| | | where IsDel='0' and PalletNo='{palletNo}' and {whereStr} |
| | | group by SkuName,SkuNo,LotNo,LocatNo,PalletNo |
| | | order by SkuNo,LotNo"; |
| | | } |
| | | else |
| | | { |
| | | whereStr = string.IsNullOrWhiteSpace(palletNo) ? "1=1" : $@"a.PalletNo='{palletNo}'"; |
| | | |
| | | dataSql = $@"select a.SkuName,a.SkuNo,a.LotNo,b.LocatNo,a.PalletNo,sum(isnull(a.Qty,0)) as Qty,0 as LockQty,0 as FrozenQty |
| | | from DataBoxInfo a |
| | | left join DataStockDetail b on b.Id=a.StockDetailId |
| | | where a.IsDel='0' and a.BoxNo='{boxNo}' and {whereStr} |
| | | group by a.SkuName,a.SkuNo,a.LotNo,b.LocatNo,a.PalletNo |
| | | order by a.SkuNo,a.LotNo"; |
| | | } |
| | | DataTable dataDt = Db.Ado.GetDataTable(dataSql); |
| | | |
| | | var result = dataDt.Rows.Cast<DataRow>().Select(e => new StockDetailWithQtyDto |
| | | { |
| | | LocatNo = e["LocatNo"] + "", |
| | | PalletNo = e["PalletNo"] + "", |
| | | SkuNo = e["SkuNo"] + "", |
| | | SkuName = e["SkuName"] + "", |
| | | LotNo = e["LotNo"] + "", |
| | | Qty = Convert.ToDecimal(e["Qty"]), |
| | | LockQty = Convert.ToDecimal(e["LockQty"]), |
| | | FrozenQty = Convert.ToDecimal(e["FrozenQty"]) |
| | | }); |
| | | |
| | | return result.ToList(); |
| | | } |
| | | #region 注释代码 |
| | | /* |
| | | public async Task<List<StockDetailWithQtyDto>> GetStockQueryList(string locatNo, string palletNo, string boxNo) |
| | | { |
| | | |
| | | return await Db.Queryable<DataStockDetail>("a") |
| | | .InnerJoin<DataBoxInfo>((a, b) => a.LotNo == b.LotNo) |
| | | .Where((a, b) => a.IsDel == "0") |
| | | .WhereIF(!string.IsNullOrWhiteSpace(locatNo), (a, b) => a.LocatNo.Contains(locatNo)) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(palletNo), (a, b) => a.PalletNo.Contains(palletNo)) |
| | | .WhereIF(!string.IsNullOrWhiteSpace(boxNo), (a, b) => b.BoxNo.Contains(boxNo)) |
| | | .GroupBy((a, b) => new |
| | | { |
| | | a.LotNo, |
| | | a.LotText, |
| | | a.SupplierLot, |
| | | a.OwnerNo, |
| | | a.OwnerName, |
| | | a.SupplierNo, |
| | | a.SupplierName, |
| | | a.SkuNo, |
| | | a.SkuName, |
| | | a.Standard, |
| | | a.LockQty, |
| | | a.FrozenQty, |
| | | a.InspectQty, |
| | | a.ASNNo, |
| | | a.ASNDetailNo, |
| | | a.SONo, |
| | | a.WareHouseNo, |
| | | a.RoadwayNo, |
| | | a.AreaNo, |
| | | a.LocatNo, |
| | | a.PalletNo, |
| | | a.PalletNo2, |
| | | a.PalletNo3, |
| | | a.PalletTags, |
| | | a.CompleteTime, |
| | | a.ProductionTime, |
| | | a.ExpirationTime, |
| | | a.Status, |
| | | a.InspectMark, |
| | | a.BitPalletMark, |
| | | a.InspectStatus, |
| | | a.InspectTime, |
| | | a.PackagNo, |
| | | a.IsBale, |
| | | a.IsBelt, |
| | | a.UDF5, |
| | | a.IsDel, |
| | | a.CreateTime, |
| | | a.CreateUser, |
| | | a.UpdateTime, |
| | | a.UpdateUser, |
| | | a.Demo |
| | | }) |
| | | .OrderBy((a, b) => new { a.LotNo, a.LocatNo, a.PalletNo }) |
| | | .Select((a, b) => new StockDetailWithQtyDto |
| | | { |
| | | LotNo = a.LotNo, |
| | | LotText = a.LotText, |
| | | SupplierLot = a.SupplierLot, |
| | | OwnerNo = a.OwnerNo, |
| | | OwnerName = a.OwnerName, |
| | | SupplierNo = a.SupplierNo, |
| | | SupplierName = a.SupplierName, |
| | | SkuNo = a.SkuNo, |
| | | SkuName = a.SkuName, |
| | | Standard = a.Standard, |
| | | Qty = SqlFunc.AggregateSum(b.Qty), // DataBoxInfo的Qty字段 |
| | | LockQty = a.LockQty, |
| | | FrozenQty = a.FrozenQty, |
| | | InspectQty = a.InspectQty, |
| | | ASNNo = a.ASNNo, |
| | | ASNDetailNo = a.ASNDetailNo, |
| | | SONo = a.SONo, |
| | | WareHouseNo = a.WareHouseNo, |
| | | RoadwayNo = a.RoadwayNo, |
| | | AreaNo = a.AreaNo, |
| | | LocatNo = a.LocatNo, |
| | | PalletNo = a.PalletNo, |
| | | PalletNo2 = a.PalletNo2, |
| | | PalletNo3 = a.PalletNo3, |
| | | PalletTags = a.PalletTags, |
| | | CompleteTime = a.CompleteTime, |
| | | ProductionTime = a.ProductionTime, |
| | | ExpirationTime = a.ExpirationTime, |
| | | Status = a.Status, |
| | | InspectMark = a.InspectMark, |
| | | BitPalletMark = a.BitPalletMark, |
| | | InspectStatus = a.InspectStatus, |
| | | InspectTime = a.InspectTime, |
| | | PackagNo = a.PackagNo, |
| | | IsBale = a.IsBale, |
| | | IsBelt = a.IsBelt, |
| | | UDF5 = a.UDF5, |
| | | IsDel = a.IsDel, |
| | | CreateTime = a.CreateTime, |
| | | CreateUser = a.CreateUser, |
| | | UpdateTime = a.UpdateTime, |
| | | UpdateUser = a.UpdateUser, |
| | | Demo = a.Demo |
| | | }) |
| | | .ToListAsync(); |
| | | } |
| | | */ |
| | | #endregion |
| | | |
| | | |
| | | #region 托盘变更(托盘解绑绑定) |
| | | |
| | |
| | | { |
| | | throw Oops.Bah("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (models.WareHouseNo != "W04") |
| | | if (models.WareHouseNo != "W04" && models.WareHouseNo != "W02") |
| | | { |
| | | throw Oops.Bah("该托盘未在平库内,请检查!"); |
| | | throw Oops.Bah("该托盘未在平库内或货架库内,请检查!"); |
| | | } |
| | | return models.LocatNo; |
| | | } |
| | |
| | | { |
| | | throw Oops.Bah("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (models.WareHouseNo != "W04") |
| | | if (models.WareHouseNo != "W04" && models.WareHouseNo != "W02") |
| | | { |
| | | throw Oops.Bah("该托盘未在平库内,请检查!"); |
| | | } |
| | |
| | | throw Oops.Bah("储位信息不存在,请检查!"); |
| | | } |
| | | |
| | | |
| | | storageArea = await Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.AreaNo != storageLocat.AreaNo && w.WareHouseNo == "W04").OrderBy(o => o.AreaNo).ToListAsync(); |
| | | |
| | | if (models.WareHouseNo == "W02") |
| | | { |
| | | storageArea = await Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.AreaNo != storageLocat.AreaNo && w.WareHouseNo == "W04" && (w.AreaNo == "B01" || w.AreaNo == "B02" || w.AreaNo == "B05")).OrderBy(o => o.AreaNo).ToListAsync(); |
| | | } |
| | | else |
| | | { |
| | | storageArea = await Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.AreaNo != storageLocat.AreaNo && w.WareHouseNo == "W04").OrderBy(o => o.AreaNo).ToListAsync(); |
| | | } |
| | | |
| | | } |
| | | return storageArea; |
| | | } |
| | | /// <summary> |
| | | /// 根据区域号获取储位地址集合 |
| | | /// </summary> |
| | | /// <param name="areaNo"></param> |
| | | /// <returns></returns> |
| | | /// <exception cref="Exception"></exception> |
| | | public List<string> GetLocatByArea(string areaNo) |
| | | { |
| | | try |
| | | { |
| | | if (string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | throw new Exception("请选择区域"); |
| | | } |
| | | var _list = Db.Queryable<SysStorageLocat>().Where(w => w.IsDel == "0" && w.AreaNo == areaNo && w.WareHouseNo == "W04").Select(s => s.LocatNo).ToList(); |
| | | |
| | | return _list; |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | throw new Exception(ex.Message); |
| | | } |
| | | } |
| | | /// <summary> |
| | | /// 获取已分配的出库单据 |
| | |
| | | /// <param name="palletNo"></param> |
| | | /// <param name="areaNo"></param> |
| | | /// <param name="ruku"></param> |
| | | public async Task AgvTransport(string palletNo, string areaNo, string ruku, string url, int userId) |
| | | /*public async Task AgvTransport(string palletNo, string areaNo, string ruku, string url, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | { |
| | | throw Oops.Bah("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (stockDetail.WareHouseNo != "W04") |
| | | if (stockDetail.WareHouseNo != "W04" && stockDetail.WareHouseNo != "W02") |
| | | { |
| | | throw Oops.Bah("该托盘未在平库内,请检查!"); |
| | | } |
| | |
| | | { |
| | | throw new Exception(e.Message); |
| | | } |
| | | }*/ |
| | | |
| | | public async Task AgvTransport(string palletNo, string areaNo, string locatNoEnd, string ruku, string url, int userId) |
| | | { |
| | | try |
| | | { |
| | | if (string.IsNullOrEmpty(palletNo)) |
| | | { |
| | | throw Oops.Bah("请扫描托盘条码!"); |
| | | } |
| | | if (string.IsNullOrEmpty(areaNo) && string.IsNullOrEmpty(ruku)) |
| | | { |
| | | throw Oops.Bah("请选择目标区域或入库口!"); |
| | | } |
| | | if (!string.IsNullOrEmpty(areaNo) && !string.IsNullOrEmpty(ruku)) |
| | | { |
| | | throw Oops.Bah("目标区域和入库口不能同时选择!"); |
| | | } |
| | | string EndLocat = string.Empty;//目标位置 |
| | | |
| | | var log = await Db.Queryable<LogTask>().FirstAsync(w => w.IsDel == "0" && w.PalletNo == palletNo && (w.Status == "0" || w.Status == "1")); |
| | | if (log != null) |
| | | { |
| | | throw Oops.Bah("该托盘已有等待执行或正在执行的任务!"); |
| | | } |
| | | var stockDetail = await Db.Queryable<DataStockDetail>().FirstAsync(w => w.IsDel == "0" && w.PalletNo == palletNo); |
| | | if (stockDetail == null) |
| | | { |
| | | throw Oops.Bah("托盘上物料库存明细信息不存在,请检查!"); |
| | | } |
| | | if (!string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | var storageArea = await Db.Queryable<SysStorageArea>().FirstAsync(w => w.IsDel == "0" && w.AreaNo == areaNo); |
| | | if (storageArea == null) |
| | | { |
| | | throw Oops.Bah("所选区域信息不存在,请检查!"); |
| | | } |
| | | if (!string.IsNullOrEmpty(locatNoEnd)) |
| | | { |
| | | EndLocat = locatNoEnd;//指定储位地址 |
| | | } |
| | | else |
| | | { |
| | | EndLocat = await GetLocat(areaNo);//系统分配储位地址 |
| | | } |
| | | } |
| | | else |
| | | { |
| | | EndLocat = ruku; |
| | | } |
| | | var stock = await Db.Queryable<DataStock>().FirstAsync(w => w.IsDel == "0" && w.SkuNo == stockDetail.SkuNo && w.LotNo == stockDetail.LotNo); |
| | | if (stock == null) |
| | | { |
| | | throw Oops.Bah("托盘上物料库存信息不存在,请检查!"); |
| | | } |
| | | if (string.IsNullOrEmpty(stockDetail.LocatNo)) |
| | | { |
| | | throw Oops.Bah("托盘储位信息不存在,请检查!"); |
| | | } |
| | | if (stockDetail.WareHouseNo != "W04" && stockDetail.WareHouseNo != "W02") |
| | | { |
| | | throw Oops.Bah("该托盘未在平库或货架库内,请检查!"); |
| | | } |
| | | |
| | | //起始储位信息 |
| | | var storageLocat = await Db.Queryable<SysStorageLocat>().FirstAsync(w => w.IsDel == "0" && w.LocatNo == stockDetail.LocatNo); |
| | | if (storageLocat == null) |
| | | { |
| | | throw Oops.Bah("储位信息不存在,请检查!"); |
| | | } |
| | | //目标储位信息 |
| | | var storageLocatEnd = new SysStorageLocat(); |
| | | if (!string.IsNullOrEmpty(areaNo)) |
| | | { |
| | | storageLocatEnd = await Db.Queryable<SysStorageLocat>().FirstAsync(w => w.IsDel == "0" && w.LocatNo == EndLocat && w.Flag == "0" && w.WareHouseNo == "W04" && w.AreaNo == areaNo); |
| | | } |
| | | else |
| | | { |
| | | storageLocatEnd = await Db.Queryable<SysStorageLocat>().FirstAsync(w => w.IsDel == "0" && w.LocatNo == EndLocat && w.Flag == "0" && w.WareHouseNo == "W04"); |
| | | } |
| | | if (storageLocatEnd == null) |
| | | { |
| | | throw Oops.Bah("目标储位信息不存在,请检查!"); |
| | | } |
| | | if ((storageLocatEnd.AreaNo == "B01" || storageLocatEnd.AreaNo == "B02" || storageLocatEnd.AreaNo == "B05") && storageLocatEnd.Status != "0") |
| | | { |
| | | throw Oops.Bah("目标储位不是空闲状态,请检查!"); |
| | | } |
| | | |
| | | |
| | | //添加出库任务 |
| | | var taskNo = new Common().GetMaxNo("TK"); |
| | | var moveTask = new LogTask |
| | | { |
| | | TaskNo = taskNo, |
| | | Sender = "WMS", |
| | | Receiver = "WCS", |
| | | IsSuccess = 0, //是否下发成功 0失败 1成功 |
| | | |
| | | StartLocat = stockDetail.LocatNo,//起始位置 |
| | | EndLocat = EndLocat,//目标位置 |
| | | PalletNo = palletNo,//托盘码 |
| | | Msg = string.Format("转运任务:{0}=>>{1}", stockDetail.LocatNo, EndLocat), |
| | | IsSend = 1,//是否可再次下发 |
| | | IsCancel = 1,//是否可取消 |
| | | IsFinish = 1,//是否可完成 |
| | | Type = "2",//任务类型 0 入库任务 1 出库任务 2 移库任务 |
| | | Status = "0",//任务状态0:等待执行1正在执行2执行完成 |
| | | OrderType = "3",//0 入库单 1 出库单 2 盘点单 3 移库单 |
| | | |
| | | CreateTime = DateTime.Now |
| | | }; |
| | | await Db.Insertable(moveTask).ExecuteCommandAsync(); |
| | | |
| | | //修改库存明细信息 |
| | | //stockDetail.Status = "4";//移库锁定 |
| | | //stockDetail.LockQty = stockDetail.Qty;//锁定库存数量 |
| | | //await Db.Updateable(stockDetail).ExecuteCommandAsync(); |
| | | ////修改库存信息 |
| | | //stock.LockQty += (decimal)stockDetail.Qty; |
| | | //await Db.Updateable(stock).ExecuteCommandAsync(); |
| | | |
| | | //修改起始储位地址状态 |
| | | storageLocat.Status = "5";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | await Db.Updateable(storageLocat).ExecuteCommandAsync(); |
| | | |
| | | //修改目标储位地址状态 |
| | | if (storageLocatEnd != null) |
| | | { |
| | | storageLocatEnd.Status = "4";//0:空储位 1:有物品 2:入库中 3:出库中 4:移入中 5:移出中 |
| | | await Db.Updateable(storageLocatEnd).ExecuteCommandAsync(); |
| | | } |
| | | //添加操作日志记录 |
| | | var k = new OperationCrServer().AddLogOperationCr("PDA模块", "AGV转运", palletNo, "移库", $"PDA呼叫小车对托盘号:{palletNo}发起转运", userId); |
| | | |
| | | var outDto = new List<OutCommandDto> |
| | | { |
| | | new OutCommandDto() |
| | | { |
| | | TaskNo = moveTask.TaskNo, // 任务号 |
| | | TaskType = "2",// 任务类型 0入 1出 2移 |
| | | PalletNo = moveTask.PalletNo,//托盘号 |
| | | |
| | | StartLocate = moveTask.StartLocat, // 起始位置 |
| | | EndLocate = EndLocat, // 目标位置 |
| | | |
| | | Order = 999, |
| | | Type = PLCTypeEnum.AGV |
| | | |
| | | } |
| | | }; |
| | | |
| | | // 正式运行程序放开 |
| | | var list2 = outDto.Select(m => m.TaskNo).ToList(); |
| | | var jsonData = JsonConvert.SerializeObject(outDto); |
| | | string response = ""; |
| | | |
| | | try |
| | | { |
| | | var time1 = DateTime.Now;//发送时间 .ToString("yyyy-MM-dd HH:mm:ss") |
| | | response = HttpHelper.DoPost(url, jsonData, "下发给WCS出库命令", "WCS"); |
| | | var time2 = DateTime.Now;//返回时间 .ToString("yyyy-MM-dd HH:mm:ss") |
| | | |
| | | //解析返回数据 |
| | | var wcsModel = JsonConvert.DeserializeObject<WcsModel2>(response); |
| | | if (wcsModel.code == 200) |
| | | { |
| | | // 更改任务的发送返回时间// |
| | | new TaskServer().EditTaskIssueOk(list2, time1, time2); |
| | | } |
| | | else |
| | | { |
| | | new TaskServer().EditTaskIssueNo(list2, time1, time2, wcsModel.message); |
| | | throw new Exception(wcsModel.message); |
| | | } |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | throw new Exception(ex.Message); |
| | | } |
| | | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | | throw new Exception(e.Message); |
| | | } |
| | | } |
| | | /// <summary> |
| | | /// 呼叫agv转运空托盘 |
| | |
| | | { |
| | | throw Oops.Bah("该托盘信息不存在!"); |
| | | } |
| | | if (palletInfo.Status!="0") |
| | | if (palletInfo.Status != "0") |
| | | { |
| | | throw Oops.Bah("该托盘不是空托盘!"); |
| | | } |
| | |
| | | { |
| | | throw Oops.Bah("获取目标储位失败!"); |
| | | } |
| | | |
| | | |
| | | //起始储位信息 |
| | | var storageLocat = await Db.Queryable<SysStorageLocat>().FirstAsync(w => w.IsDel == "0" && w.LocatNo == locatNo); |
| | | if (storageLocat == null) |
| | |
| | | { |
| | | locatInfo2 = storageLocatList.Where(w => w.IsDel == "0" && w.Flag == "0" && w.Status == "0") |
| | | .OrderByDescending(m => m.Layer).OrderByDescending(m => m.Column).OrderByDescending(m => m.Row).First(); |
| | | } |
| | | } |
| | | |
| | | if (locatInfo2 != null) |
| | | { |
| | |
| | | #endregion |
| | | |
| | | #region 零箱解绑 |
| | | public void LingxingUnbind(string palletNo,string boxNo, int userId) |
| | | public void LingxingUnbind(string palletNo, string boxNo, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | } |
| | | //开启事务 |
| | | Db.BeginTran(); |
| | | |
| | | |
| | | //库存箱支明细信息 |
| | | var boxList = Db.Queryable<DataBoxInfo>().Where(w => w.IsDel == "0" && w.BoxNo == boxNo).ToList(); |
| | | var boxList = Db.Queryable<DataBoxInfo>().Where(w => w.IsDel == "0" && w.BoxNo == boxNo && w.Status == "2").ToList(); |
| | | if (boxList.Count != 1) |
| | | { |
| | | throw new Exception("该箱码信息错误,存在多个此箱码信息"); |
| | | } |
| | | var boxInfo = boxList.First(); |
| | | if (boxInfo.Qty<=devanQty) |
| | | if (boxInfo.Qty <= devanQty) |
| | | { |
| | | throw new Exception("拆箱数量大等于当前箱内数量"); |
| | | } |
| | | |
| | | |
| | | boxInfo.Qty -= devanQty; |
| | | boxInfo.BitBoxMark = "1"; |
| | | //更新箱码库存表 |
| | |
| | | //如果结果大于0,则说明第一个字符串大于第二个字符串。 |
| | | var maxBoxCode = maxBoxCode1; |
| | | var bol = String.CompareOrdinal(maxBoxCode1, maxBoxCode2); |
| | | if (bol<0) |
| | | if (bol < 0) |
| | | { |
| | | maxBoxCode = maxBoxCode2; |
| | | } |
| | |
| | | BoxNo = boxNoNew, |
| | | Qty = devanQty, |
| | | FullQty = boxInfo.FullQty, |
| | | |
| | | |
| | | Status = "2",//0:未组托 1:已组托 2:已入库 3:已出库 4:已分配 5:已拣货 |
| | | LotNo = boxInfo.LotNo, |
| | | LotText = boxInfo.LotText, |
| | | SkuNo = boxInfo.SkuNo, |
| | | SkuName = boxInfo.SkuName, |
| | | Standard = boxInfo.Standard, |
| | | |
| | | |
| | | SupplierLot = boxInfo.SupplierLot, |
| | | InspectStatus = boxInfo.InspectStatus, |
| | | InspectMark = boxInfo.InspectMark, |
| | |
| | | |
| | | #region 获取拆箱的信息打印 |
| | | |
| | | |
| | | |
| | | var data = new BoxListInfoDto() |
| | | { |
| | | SkuNo = boxInfo.SkuNo, |
| | | SkuName = boxInfo.SkuName, |
| | | LotNo = boxInfo.LotNo, |
| | | BoxNoList = new List<string>() { boxNoNew } , |
| | | BoxNoList = new List<string>() { boxNoNew }, |
| | | Date1 = boxInfo.ProductionTime == null ? "" : Convert.ToDateTime(boxInfo.ProductionTime).ToString("yyyy-MM-dd"), |
| | | Date2 = boxInfo.ExpirationTime == null ? "" : Convert.ToDateTime(boxInfo.ExpirationTime).ToString("yyyy-MM-dd"), |
| | | }; |
| | | |
| | | |
| | | #endregion |
| | | |
| | | return data; |
| | |
| | | { |
| | | try |
| | | { |
| | | var stockDetail = Db.Queryable<DataStockDetail>().Where(m => m.PalletNo == palletNo).GroupBy(m=>m.SONo).Select(m=>m.SONo).ToList(); |
| | | var stockDetail = Db.Queryable<DataStockDetail>().Where(m => m.PalletNo == palletNo).GroupBy(m => m.SONo).Select(m => m.SONo).ToList(); |
| | | if (stockDetail.Count == 0) |
| | | { |
| | | throw new Exception("没有查询到托盘库存信息"); |
| | |
| | | throw new Exception("库存托盘没有信息"); |
| | | } |
| | | var locate = stockDetail.First().LocatNo; |
| | | var locatList = Db.Queryable<SysStorageLocat>().Where(m=>m.WareHouseNo == "W04" && (m.AreaNo == "B06" || m.AreaNo == "B07" || m.AreaNo == "B09") && m.IsDel == "0").ToList(); |
| | | var locatList = Db.Queryable<SysStorageLocat>().Where(m => m.WareHouseNo == "W04" && (m.AreaNo == "B06" || m.AreaNo == "B07" || m.AreaNo == "B09" || m.AreaNo == "B24") && m.IsDel == "0").ToList(); |
| | | var locat = locatList.FirstOrDefault(m => m.LocatNo == locate); |
| | | //判断托盘储位是否在车间 |
| | | if (locat == null) |
| | |
| | | locat.Status = "0"; |
| | | Db.Updateable(locat).ExecuteCommand(); |
| | | //判断托盘信息 |
| | | |
| | | |
| | | foreach (var item in stockDetail) |
| | | { |
| | | if (item.UDF5 != "1" || string.IsNullOrWhiteSpace(item.SONo)) |
| | | { |
| | | continue; |
| | | } |
| | | |
| | | |
| | | //item.WareHouseNo = ""; |
| | | //item.RoadwayNo = ""; |
| | | //item.AreaNo = ""; |
| | |
| | | /// </summary> |
| | | /// <param name="boxNo"></param> |
| | | /// <param name="pallNo"></param> |
| | | public void GetBoxInfo(string boxNo,string pallNo) |
| | | public void GetBoxInfo(string boxNo, string pallNo) |
| | | { |
| | | try |
| | | { |
| | | var boxInfo = Db.Queryable<DataBoxInfo>().Where(m=>m.IsDel == "0" && m.BoxNo == boxNo).ToList(); |
| | | var boxInfo = Db.Queryable<DataBoxInfo>().Where(m => m.IsDel == "0" && m.BoxNo == boxNo).ToList(); |
| | | if (!string.IsNullOrWhiteSpace(pallNo)) |
| | | { |
| | | boxInfo = boxInfo.Where(m=>m.PalletNo == pallNo).ToList(); |
| | | boxInfo = boxInfo.Where(m => m.PalletNo == pallNo).ToList(); |
| | | } |
| | | if (boxInfo.Count!=1) |
| | | if (boxInfo.Count != 1) |
| | | { |
| | | throw new Exception("标签信息错误,请联系管理员"); |
| | | } |
| | | |
| | | |
| | | } |
| | | catch (Exception e) |
| | | { |
| | |
| | | } |
| | | } |
| | | |
| | | public void UpPalletByBox(string boxNo,string pallet,string palletNew,int userId) |
| | | public void UpPalletByBox(string boxNo, string pallet, string palletNew, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | { |
| | | throw new Exception("参数错误,托盘、新托盘、箱码均不能为空"); |
| | | } |
| | | var boxInfoList = Db.Queryable<DataBoxInfo>().Where(m=>m.IsDel == "0" && m.BoxNo == boxNo).ToList(); |
| | | var boxInfoList = Db.Queryable<DataBoxInfo>().Where(m => m.IsDel == "0" && m.BoxNo == boxNo).ToList(); |
| | | if (boxInfoList.Count != 1) |
| | | { |
| | | throw new Exception("标签信息数量不是1条"); |
| | | } |
| | | var boxInfo = boxInfoList.First(); |
| | | var detail1 = Db.Queryable<DataStockDetail>().First(m=>m.IsDel == "0" && m.PalletNo == pallet && m.Id == boxInfo.StockDetailId ); |
| | | var detail1 = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.PalletNo == pallet && m.Id == boxInfo.StockDetailId); |
| | | if (detail1 == null) |
| | | { |
| | | throw new Exception("未查询到托盘和箱码的库存明细"); |
| | |
| | | throw new Exception("未查询到新托盘信息"); |
| | | } |
| | | var detailNewBl = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.PalletNo == palletNew && (m.SkuNo != boxInfo.SkuNo || m.LotNo != boxInfo.LotNo)); |
| | | if (detailNewBl!=null) |
| | | if (detailNewBl != null) |
| | | { |
| | | throw new Exception("新托盘上已有其他物料箱信息"); |
| | | } |
| | |
| | | detailNew.Qty = boxInfo.Qty; |
| | | detailNew.LockQty = 0; |
| | | detailNew.FrozenQty = 0; |
| | | detailNew.InspectQty = 0; |
| | | detailNew.InspectQty = 0; |
| | | detailNew.ASNNo = ""; |
| | | |
| | | detailNew.PalletNo = palletNew; |
| | |
| | | try |
| | | { |
| | | var data = new List<SelectSkuLotNo>(); |
| | | var detailList = Db.Queryable<DataStockDetail>().Where(m=>m.IsDel == "0" && m.PalletNo == palletNo).ToList(); |
| | | var detailList = Db.Queryable<DataStockDetail>().Where(m => m.IsDel == "0" && m.PalletNo == palletNo).ToList(); |
| | | |
| | | foreach (var item in detailList) |
| | | { |
| | | if (data.Count(m=>m.DetailId == item.Id.ToString()) == 0) |
| | | if (data.Count(m => m.DetailId == item.Id.ToString()) == 0) |
| | | { |
| | | data.Add(new SelectSkuLotNo() |
| | | { |
| | |
| | | /// <param name="qty"></param> |
| | | /// <param name="userId"></param> |
| | | /// <exception cref="Exception"></exception> |
| | | public void UpPalletByQty(string palletNo,string palletNoNew,string detailId,decimal qty,int userId) |
| | | public void UpPalletByQty(string palletNo, string palletNoNew, string detailId, decimal qty, int userId) |
| | | { |
| | | try |
| | | { |
| | |
| | | { |
| | | throw new Exception("参数错误,托盘、新托盘、物料批次均不能为空"); |
| | | } |
| | | if (qty<=0) |
| | | if (qty <= 0) |
| | | { |
| | | throw new Exception("参数数量不能为小等0"); |
| | | } |
| | | var detailId2 = int.Parse(detailId); |
| | | var detailId2 = int.Parse(detailId); |
| | | var detail1 = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.PalletNo == palletNo && m.Id == detailId2); |
| | | if (detail1 == null) |
| | | { |
| | |
| | | { |
| | | throw new Exception("未查询到新托盘信息"); |
| | | } |
| | | |
| | | |
| | | //添加/更新库存托盘信息 |
| | | var detailNew1 = Db.Queryable<DataStockDetail>().First(m => m.IsDel == "0" && m.PalletNo == palletNoNew && m.SkuNo == detail1.SkuNo && m.LotNo == detail1.LotNo); |
| | | var newId = 0; |
| | |
| | | Db.Updateable(detail1).ExecuteCommand(); |
| | | } |
| | | |
| | | |
| | | |
| | | //添加操作日志 |
| | | new OperationCrServer().AddLogOperationCr("库内作业", "操作日志", palletNo, "编辑", $"物料拆托:{detail1.SkuName}物料换托,原托盘{palletNo},新托盘{palletNoNew}", userId); |
| | | |