BaseInvService.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. using Dm;
  2. using NPOI.SS.Formula.Functions;
  3. using Org.BouncyCastle.Asn1.Ocsp;
  4. using Org.BouncyCastle.Bcpg;
  5. using SqlSugar;
  6. using System;
  7. using System.Collections;
  8. using System.Collections.Generic;
  9. using System.Diagnostics;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using wms.sqlsugar.model.hj;
  14. using WMS.BZModels;
  15. using WMS.BZModels.Dto.HJ.BillInvDtos;
  16. using WMS.BZModels.Dto.HJ.TaskDtos;
  17. using WMS.Info;
  18. using WMS.BZSqlSugar;
  19. using WMS.Util;
  20. using static log4net.Appender.ColoredConsoleAppender;
  21. using static NPOI.HSSF.Util.HSSFColor;
  22. using static System.Formats.Asn1.AsnWriter;
  23. namespace WMS.BZServices.HJ
  24. {
  25. public class BaseInvService
  26. {
  27. private readonly Repository<BillInvnow> _billInvnowrepository;
  28. public BaseInvService(Repository<BillInvnow> billInvnowrepository)
  29. {
  30. _billInvnowrepository = billInvnowrepository;
  31. }
  32. public PagedInfo<BillInvNowDto> GetPageList(Pagination pagination, BillInvNowQueryDto billInvNowQueryDto)
  33. {
  34. ISugarQueryable<BillInvNowDto> sugarQueryable = GetQueryable(billInvNowQueryDto);
  35. var list = sugarQueryable.ToPage(pagination);
  36. return list;
  37. }
  38. public IList<BillInvNowDto> GetList(BillInvNowQueryDto billInvNowQueryDto)
  39. {
  40. ISugarQueryable<BillInvNowDto> sugarQueryable = GetQueryable(billInvNowQueryDto);
  41. var list = sugarQueryable.ToList();
  42. return list;
  43. }
  44. private ISugarQueryable<BillInvNowDto> GetQueryable(BillInvNowQueryDto billInvNowQueryDto)
  45. {
  46. var predicate = Expressionable.Create<BillInvnow, BaseWarecell>();
  47. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.KeyWord), (billInvnow, warecell) => warecell.Code.Contains(billInvNowQueryDto.KeyWord) || billInvnow.ContGrpBarCode.Contains(billInvNowQueryDto.KeyWord) || billInvnow.MatCode.Contains(billInvNowQueryDto.KeyWord) || billInvnow.MatName.Contains(billInvNowQueryDto.KeyWord) || billInvnow.InvBarCode.Contains(billInvNowQueryDto.KeyWord));
  48. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.Id), (billInvnow, warecell) => billInvnow.Id.ToString().Contains(billInvNowQueryDto.Id));
  49. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.ContGrpId), (billInvnow, warecell) => billInvnow.ContGrpId.ToString().Contains(billInvNowQueryDto.ContGrpId));
  50. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.EquContGrpId), (billInvnow, warecell) => billInvnow.ContGrpId.ToString().Equals(billInvNowQueryDto.EquContGrpId));
  51. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.MatCode), (billInvnow, warecell) => billInvnow.MatCode.Contains(billInvNowQueryDto.MatCode));
  52. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.MatName), (billInvnow, warecell) => billInvnow.MatName.Contains(billInvNowQueryDto.MatName));
  53. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.RFIDBarCode), (billInvnow, warecell) => billInvnow.RFIDBarCode.Contains(billInvNowQueryDto.RFIDBarCode));
  54. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.InvBarCode), (billInvnow, warecell) => billInvnow.InvBarCode.Contains(billInvNowQueryDto.InvBarCode));
  55. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.PutRow), (billInvnow, warecell) => billInvnow.PutRow.Equals(billInvNowQueryDto.PutRow));
  56. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.PutCol), (billInvnow, warecell) => billInvnow.PutCol.Equals(billInvNowQueryDto.PutCol));
  57. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.PutLayer), (billInvnow, warecell) => billInvnow.PutLayer.Equals(billInvNowQueryDto.PutLayer));
  58. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.Grade), (billInvnow, warecell) => billInvnow.Grade.Contains(billInvNowQueryDto.Grade));
  59. predicate = predicate.AndIF(billInvNowQueryDto != null && billInvNowQueryDto.OneInTimeBegin.HasValue, (billInvnow, warecell) => billInvnow.OneInTime >= billInvNowQueryDto.OneInTimeBegin);
  60. predicate = predicate.AndIF(billInvNowQueryDto != null && billInvNowQueryDto.OneInTimeEnd.HasValue, (billInvnow, warecell) => billInvnow.OneInTime <= billInvNowQueryDto.OneInTimeEnd);
  61. predicate = predicate.AndIF(billInvNowQueryDto != null && billInvNowQueryDto.ProductTimeBegin.HasValue, (billInvnow, warecell) => billInvnow.ProductTime >= billInvNowQueryDto.ProductTimeBegin);
  62. predicate = predicate.AndIF(billInvNowQueryDto != null && billInvNowQueryDto.ProductTimeEnd.HasValue, (billInvnow, warecell) => billInvnow.ProductTime <= billInvNowQueryDto.ProductTimeEnd);
  63. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.Tunnel), (billInvnow, warecell) => warecell.Tunnel.Equals(billInvNowQueryDto.Tunnel));
  64. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.Code), (billInvnow, warecell) => warecell.Code.Contains(billInvNowQueryDto.Code));
  65. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.IsSurplus), (billInvnow, warecell) => billInvnow.IsSurplus.Equals(billInvNowQueryDto.IsSurplus));
  66. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.IsRework), (billInvnow, warecell) => billInvnow.IsRework.Equals(billInvNowQueryDto.IsRework));
  67. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.IsFail), (billInvnow, warecell) => billInvnow.IsFail.Equals(billInvNowQueryDto.IsFail));
  68. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.IsFast), (billInvnow, warecell) => billInvnow.IsFast.Equals(billInvNowQueryDto.IsFast));
  69. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.IsBack), (billInvnow, warecell) => billInvnow.IsBack.Equals(billInvNowQueryDto.IsBack));
  70. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.ExecStateCode), (billInvnow, warecell) => billInvnow.ExecStateCode.Equals(billInvNowQueryDto.ExecStateCode));
  71. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.ContGrpType), (billInvnow, warecell) => billInvnow.ContGrpType.Equals(billInvNowQueryDto.ContGrpType));
  72. if (!string.IsNullOrEmpty(billInvNowQueryDto?.InvStateCode))
  73. {
  74. var enums = (InvState)Enum.ToObject(typeof(InvState), Convert.ToInt32(billInvNowQueryDto?.InvStateCode));
  75. predicate = predicate.AndIF(!string.IsNullOrEmpty(billInvNowQueryDto?.InvStateCode), (billInvnow, warecell) => billInvnow.InvStateCode.Equals(enums.ToString()));
  76. }
  77. var sugarQueryable = _billInvnowrepository.Context.Queryable<BillInvnow, BaseWarecell>((billInvnow, warecell) => new object[] {
  78. JoinType.Left,billInvnow.ContGrpId == warecell.ContGrpId && billInvnow.WarehouseId ==warecell.WarehouseId }).Where(predicate.ToExpression())
  79. .Select((billInvnow, warecell) => new BillInvNowDto
  80. {
  81. Id = billInvnow.Id.ToString(),
  82. WarehouseId = billInvnow.WarehouseId.ToString(),
  83. ContGrpId = billInvnow.ContGrpId.ToString(),
  84. ContGrpBarCode = billInvnow.ContGrpBarCode,
  85. ContGrpType = billInvnow.ContGrpType,
  86. BoxBarCode = billInvnow.BoxBarCode,
  87. BomDocsNo = billInvnow.BomDocsNo,
  88. BomMatId = billInvnow.BomMatId.ToString(),
  89. BomMatCode = billInvnow.BomMatCode,
  90. BomMatName = billInvnow.BomMatName,
  91. BomSetId = billInvnow.BomSetId.ToString(),
  92. ExecStateCode = billInvnow.ExecStateCode,
  93. InvStateCode = billInvnow.InvStateCode,
  94. ExecDocsNo = billInvnow.ExecDocsNo,
  95. ExecDocsRowNo = billInvnow.ExecDocsRowNo,
  96. ExecDocsTypeCode = billInvnow.ExecDocsTypeCode,
  97. InvInOut = billInvnow.InvInOut,
  98. ExecWho = billInvnow.ExecWho,
  99. ExecTime = billInvnow.ExecTime,
  100. PutRow = billInvnow.PutRow,
  101. PutCol = billInvnow.PutCol,
  102. PutLayer = billInvnow.PutLayer,
  103. InvBarCode = billInvnow.InvBarCode,
  104. InDocsNo = billInvnow.InDocsNo,
  105. InDocsRowNo = billInvnow.InDocsRowNo,
  106. SuppCode = billInvnow.SuppCode,
  107. SuppName = billInvnow.SuppName,
  108. CustCode = billInvnow.CustCode,
  109. CustName = billInvnow.CustName,
  110. MatId = billInvnow.MatId.ToString(),
  111. MatCode = billInvnow.MatCode,
  112. MatName = billInvnow.MatName,
  113. TolWQty = billInvnow.TolWQty,
  114. NetWQty = billInvnow.NetWQty,
  115. TareWQty = billInvnow.TareWQty,
  116. LengthQty = billInvnow.LengthQty,
  117. CaQty = billInvnow.CaQty,
  118. SolderQty = billInvnow.SolderQty,
  119. ContUsageQty = billInvnow.ContUsageQty,
  120. BatchNo = billInvnow.BatchNo,
  121. ProductTime = billInvnow.ProductTime,
  122. OneInTime = billInvnow.OneInTime,
  123. RodBarCode = billInvnow.RodBarCode,
  124. HWBarCode = billInvnow.HWBarCode,
  125. RFIDBarCode = billInvnow.RFIDBarCode,
  126. CLBarCode = billInvnow.CLBarCode,
  127. HWTypeCode = billInvnow.HWTypeCode,
  128. BoilerNo = billInvnow.BoilerNo,
  129. PackNo = billInvnow.PackNo,
  130. BrandNo = billInvnow.BrandNo,
  131. ExecStd = billInvnow.ExecStd,
  132. LicenceCode = billInvnow.LicenceCode,
  133. IsSurplus = billInvnow.IsSurplus,
  134. IsRework = billInvnow.IsRework,
  135. IsBlack = billInvnow.IsBlack,
  136. IsCore = billInvnow.IsCore,
  137. IsFast = billInvnow.IsFast,
  138. IsFail = billInvnow.IsFail,
  139. FailReason = billInvnow.FailReason,
  140. SilkTypeCode = billInvnow.SilkTypeCode,
  141. Grade = billInvnow.Grade,
  142. IsBack = billInvnow.IsBack,
  143. BackReason = billInvnow.BackReason,
  144. IsTorsChk = billInvnow.IsTorsChk,
  145. TorsChkQty = billInvnow.TorsChkQty,
  146. TorsChkTime = billInvnow.TorsChkTime,
  147. TorsChkValue = billInvnow.TorsChkValue,
  148. TorsChkMachCode = billInvnow.TorsChkMachCode,
  149. ProcessDocsCode = billInvnow.ProcessDocsCode,
  150. ProductMachCode = billInvnow.ProductMachCode,
  151. ProductLineNo = billInvnow.ProductLineNo,
  152. HoldDuration=billInvnow.HoldDuration,
  153. Remark = billInvnow.Remark,
  154. Default1 = billInvnow.Default1,
  155. Default2 = billInvnow.Default2,
  156. Default3 = billInvnow.Default3,
  157. AddWho = billInvnow.AddWho,
  158. AddTime = billInvnow.AddTime,
  159. EditWho = billInvnow.EditWho,
  160. EditTime = billInvnow.EditTime,
  161. Size = billInvnow.Size,
  162. Memo = billInvnow.Memo,
  163. Tunnel = warecell.Tunnel,
  164. Code = warecell.Code,
  165. CellState = warecell.IsStop,
  166. }).MergeTable();
  167. return sugarQueryable;
  168. }
  169. public List<EnumEntity> InvStateList()
  170. {
  171. return BZModels.Extensions.EnumToList<InvState>();
  172. }
  173. public List<EnumEntity> TaskStatusList()
  174. {
  175. return BZModels.Extensions.EnumToList<BZModels.TaskStatus>();
  176. }
  177. public List<EnumEntity> TaskTypeList()
  178. {
  179. return BZModels.Extensions.EnumToList<TaskType>();
  180. }
  181. public List<EnumEntity2> TaskBusTypeList()
  182. {
  183. return BZModels.Extensions.EnumToListDesc<TaskBusType>();
  184. }
  185. public List<EnumEntity> AGVTaskTypeList()
  186. {
  187. return BZModels.Extensions.EnumToList<AGVTaskType>();
  188. }
  189. public List<EnumEntity> FackbeekTypeList()
  190. {
  191. return BZModels.Extensions.EnumToList<FackbeekType>();
  192. }
  193. public List<EnumEntity> AGVTaskStatus()
  194. {
  195. return BZModels.Extensions.EnumToList<AGVTaskStatus>();
  196. }
  197. public List<EnumEntity> ContGrpTypeList()
  198. {
  199. return BZModels.Extensions.EnumToList<ContGrpType>();
  200. }
  201. public List<EnumEntity> DocTypeList()
  202. {
  203. return BZModels.Extensions.EnumToList<DocType>();
  204. }
  205. public List<EnumEntity> DocStateList()
  206. {
  207. return BZModels.Extensions.EnumToList<DocState>();
  208. }
  209. public List<EnumEntity> LocationStateList()
  210. {
  211. return BZModels.Extensions.EnumToList<LocationState>();
  212. }
  213. public List<EnumEntity> AutoManualOutTypeList()
  214. {
  215. return BZModels.Extensions.EnumToList<AutoManualOutType>();
  216. }
  217. public List<EnumEntity2> InvLockStateList()
  218. {
  219. return BZModels.Extensions.EnumToListIdDesc<InvLockState>();
  220. }
  221. public List<EnumEntity> YesNoList()
  222. {
  223. return BZModels.Extensions.EnumToList<YesNo>();
  224. }
  225. }
  226. }