using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; using TouchSocket.Core; using WCS.BLL.Config; using WCS.BLL.DbModels; using WCS.BLL.HardWare; using WCS.BLL.Manager; using WCS.BLL.Services.IService; using WCS.DAL; using WCS.DAL.Db; using WCS.DAL.DbModels; using WCS.Model; using WCS.Model.ApiModel; using WCS.Model.ApiModel.InOutRecord; using WCS.Model.ApiModel.StoreInfo; using WCS.Model.ApiModel.User; namespace WCS.BLL.Services.Service { public class StoreInfoService : IStoreInfoService { public async Task> GetShelves(GetShelvesRequest request) { try { var recordsQueryable = DbHelp.db.Queryable() ; var totalCount = await recordsQueryable.CountAsync(); var records = await recordsQueryable .Skip((request.PageNumber - 1) * request.PageSize).Take(request.PageSize) .ToListAsync(); //生成序号 for (int i = 0; i < records.Count; i++) { records[i].RowNumber = (request.PageNumber - 1) * request.PageSize + i + 1; } return new PageQueryResponse() { Code = 200, Message = $"success", Data = new PageQueryResponseData() { TotalCount = totalCount, MaxPage = request.PageSize == 0 ? 0 : (int)Math.Ceiling((decimal)totalCount / request.PageSize), Count = records.Count, Lists = records.ToList() } }; } catch (Exception ex) { return new PageQueryResponse() { Code = 300, Message = $"操作失败:{ex.Message}", }; } } public async Task> addOrUpdateShelfInfo(AddShelfInfoRequest request) { try { var shelfnfo = await DbHelp.db.Queryable() .FirstAsync(); //修改货架信息 if (request.AddOrUpdate == AddOrUpdate.Update) { var existId = shelfnfo == null ? 0 : shelfnfo.Id; shelfnfo = await DbHelp.db.Queryable() .Where(t => t.Id == request.ShelfInfo.Id) .FirstAsync(); if (shelfnfo == null) { return new ResponseCommon { Code = 201, Message = $"更新货架信息失败:货架不存在!", Data = null }; } else if (existId != shelfnfo.Id) { return new ResponseCommon { Code = 201, Message = $"更新货架信息失败:已存在货架编码!", Data = null }; } else { var rowNum = await DbHelp.db.Updateable(shelfnfo).ExecuteCommandAsync(); if (rowNum == 0) { return new ResponseCommon { Code = 201, Message = $"更新货架信息失败:请重试!", Data = null }; } else { return new ResponseCommon { Code = 200, Message = $"更新货架信息成功!", Data = null }; } } } else if (request.AddOrUpdate == AddOrUpdate.Add) { if (shelfnfo != null) { return new ResponseCommon { Code = 201, Message = $"货架信息失败:货架已存在!", Data = null }; } else { var newShelfInfo = new ShelfInfo() { }; var rowNum = await DbHelp.db.Insertable(newShelfInfo).ExecuteCommandAsync(); if (rowNum == 0) { return new ResponseCommon { Code = 201, Message = $"添加货架信息失败:请重试!", Data = null }; } else { return new ResponseCommon { Code = 200, Message = $"添加货架信息成功!", Data = null }; } } } else if (request.AddOrUpdate == AddOrUpdate.Delete) { shelfnfo = await DbHelp.db.Queryable() .Where(t => t.Id == request.ShelfInfo.Id) .FirstAsync(); if (shelfnfo == null) { return new ResponseCommon { Code = 201, Message = $"删除货架信息失败:货架{request.ShelfInfo}不存在!", Data = null }; } else { var rowNum = await DbHelp.db.Deleteable(shelfnfo).ExecuteCommandAsync(); if (rowNum == 0) { return new ResponseCommon { Code = 201, Message = $"删除货架信息失败:请重试!", Data = null }; } else { return new ResponseCommon { Code = 200, Message = $"删除货架信息成功!", Data = null }; } } } else { var response = new ResponseCommon { Code = 300, Message = "不支持的操作!", Data = null }; return response; } } catch (Exception ex) { var response = new ResponseCommon { Code = 300, Message = $"操作失败:{ex.Message}", Data = null }; return response; } } #region 模组管理 /// /// 发送指令获取模组的电压值 /// /// /// /// #endregion #region 库位管理 public async Task> GetStores(GetStoresRequest request) { try { var recordsQueryable = DbHelp.db.Queryable() .WhereIF(!string.IsNullOrEmpty(request.ShelfCode), t => t.ShelfCode.Contains(request.ShelfCode)) .WhereIF(!string.IsNullOrEmpty(request.ModuleCode), t => t.ModuleCode.Contains(request.ModuleCode)) .WhereIF(!string.IsNullOrEmpty(request.StoreCode), t => t.StoreCode.Contains(request.StoreCode)) .WhereIF(!string.IsNullOrEmpty(request.CurrentMatSN), t => t.CurrentMatSn.Contains(request.CurrentMatSN)) ; var totalCount = await recordsQueryable.CountAsync(); var records = await recordsQueryable .Skip((request.PageNumber - 1) * request.PageSize).Take(request.PageSize) .ToListAsync(); //生成序号 for (int i = 0; i < records.Count; i++) { records[i].RowNumber = (request.PageNumber - 1) * request.PageSize + i + 1; } return new PageQueryResponse() { Code = 200, Message = $"success", Data = new PageQueryResponseData() { TotalCount = totalCount, MaxPage = request.PageSize == 0 ? 0 : (int)Math.Ceiling((decimal)totalCount / request.PageSize), Count = records.Count, Lists = records.ToList() } }; } catch (Exception ex) { return new PageQueryResponse() { Code = 300, Message = $"操作失败:{ex.Message}", }; } } public async Task disableOrEnableStore(DisableOrEnableStoreRequest request) { //找到库位 var storeInfo = await DbHelp.db.Queryable() .Where(t => t.Id == request.StoreId) .FirstAsync(); //库位不存在 if (storeInfo == null) { return new ResponseCommon() { Code = 201, Message = $"操作失败:库位{request.SroreCode}不存在!" }; } try { DbHelp.db.BeginTran(); //禁用需要删除当前库存数据 if (request.DisableOrEnable == DisableOrEnableEnum.Disable) { //盟讯公司发送钉钉消息 if (LocalFile.Config.IsMx) { var DingDing = string.Empty; MXBackgroundThread.SendDingDingMsg($"【智能货架】库位{storeInfo.StoreCode}被屏蔽(库位管理),请及时调查或维保硬件!", new List { "104379", "103595" }, ref DingDing); Logs.Write($"【智能货架】库位{storeInfo.StoreCode}被屏蔽(库位管理),请及时调查或维保硬件!"); } //库位 storeInfo.CurrentMatSn = "禁用"; //库存数据处理 var inventorys = DbHelp.db.Queryable() .Where(t => t.StoreId == storeInfo.Id) .ToList(); if (inventorys != null && inventorys.Count > 0) { //删除并进行出入库记录 foreach (var inventory in inventorys) { var inOutRecord = new InOutRecord() { StoreCode = storeInfo.StoreCode, StoreId = storeInfo.Id, StoreInfo = storeInfo, R = storeInfo.R, C = storeInfo.C, Wei = storeInfo.Wei, BigShelfCode = storeInfo.BigShelfCode, GroupName = storeInfo.GroupName, MatSN = inventory.MatSN, MatCode = inventory.MatCode, MatName = inventory.MatName, MatSpec = inventory.MatSpec, MatBatch = inventory.MatBatch, MatQty = inventory.MatQty, MatCustomer = inventory.MatCustomer, MatSupplier = inventory.MatSupplier, OperateUser = request.UserName + "(禁用库位)", Direction = DirectionEnum.丢失, }; DbHelp.db.Insertable(inOutRecord).ExecuteCommand(); DbHelp.db.Deleteable(inventory).ExecuteCommand(); } } } else { storeInfo.CurrentMatSn = string.Empty; } DbHelp.db.Updateable(storeInfo).ExecuteCommand(); DbHelp.db.CommitTran(); return new ResponseCommon() { Code = 200, Message = $"Success" }; } catch (Exception ex) { DbHelp.db.RollbackTran(); return new ResponseCommon() { Code = 300, Message = $"操作失败:异常{ex.Message}!" }; } } #endregion } }