PretreatmentAppService.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. using Business.Core.MongoDBHelper;
  2. using Business.Core.Utilities;
  3. using Business.ResourceExamineManagement.Dto;
  4. using Bussiness.Model.MES.IC;
  5. using Bussiness.Model.Production;
  6. using Bussiness.MongoModel.MES.IC;
  7. using SixLabors.ImageSharp;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using Volo.Abp.Application.Services;
  14. namespace Business.ResourceExamineManagement
  15. {
  16. public class PretreatmentAppService : ApplicationService
  17. {
  18. SnowFlake help = new SnowFlake();
  19. //构造函数
  20. public PretreatmentAppService() {
  21. }
  22. /// <summary>
  23. /// BOM预处理
  24. /// </summary>
  25. /// <param name="orderid"></param>
  26. /// <param name="BomId"></param>
  27. /// <param name="Quantity"></param>
  28. public List<BomChildExamineDto> BomPretreatment(long? BomId, List<mo_ic_bom> bomlist, List<mo_ic_bom_child> bomchildlist, List<mo_ic_item> icitemlist)
  29. {
  30. if (BomId == null)
  31. {
  32. //throw new bu
  33. }
  34. List<BomChildExamineDto> returnlist = new List<BomChildExamineDto>();
  35. var bom = bomlist.Find(s => s.mysql_id == BomId);
  36. if (bom == null)
  37. {
  38. return returnlist;
  39. }
  40. var dto = new BomChildExamineDto();
  41. dto.item_id = bom.icitem_id;
  42. dto.bom_id = BomId.Value;
  43. dto.bom_number = bom.bom_number;
  44. dto.level = 1;
  45. dto.id = help.NextId();
  46. dto.parent_id = help.NextId();
  47. dto.qty = 1;
  48. dto.num = "1";
  49. dto.num_order = 1;
  50. dto.isbom = 1;
  51. dto.is_replace = 0;
  52. dto.haveicsubs = 0;
  53. dto.substitute_code = "";
  54. dto.icitem_ids = "";
  55. int type = 0;
  56. GetBomList(bomlist, bomchildlist, icitemlist, dto, returnlist, type);
  57. return returnlist;
  58. }
  59. /// <summary>
  60. /// BOM预处理层级组装
  61. /// </summary>
  62. /// <param name="bomlist"></param>
  63. /// <param name="bomchildlist"></param>
  64. /// <param name="icitemlist"></param>
  65. /// <param name="dto"></param>
  66. /// <param name="returnlist"></param>
  67. public void GetBomList(List<mo_ic_bom> bomlist, List<mo_ic_bom_child> bomchildlist, List<mo_ic_item> icitemlist, BomChildExamineDto dto, List<BomChildExamineDto> returnlist, int type)
  68. {
  69. int level = dto.level + 1;//初始化定义level层级
  70. var bom = bomlist.Where(s => s.mysql_id == dto.bom_id).FirstOrDefault();
  71. mo_ic_item item = new mo_ic_item();
  72. if (bom != null)
  73. {
  74. item = icitemlist.Where(a => a.mysql_id == bom.icitem_id).FirstOrDefault();
  75. }
  76. else
  77. {
  78. item = icitemlist.Where(a => a.mysql_id == dto.item_id).FirstOrDefault();
  79. }
  80. if (item == null)
  81. {
  82. return;
  83. }
  84. dto.item_id = item.mysql_id;
  85. dto.item_name = bom.item_name;
  86. dto.item_code = bom.item_number;
  87. dto.model = item.model;
  88. dto.unit = bom.unit;
  89. dto.erp_cls = item.erp_cls;
  90. dto.erp_cls_name = item.erp_cls_name;
  91. dto.type = type;
  92. dto.item_number = item.number;
  93. //var bdto = ObjectMapper.Map<ic_bom,BomChildExamineDto>(bom);
  94. returnlist.Add(dto);
  95. var childlist = bomchildlist.Where(a => a.bom_id == bom.mysql_id).ToList();
  96. int idx = 1;
  97. foreach (var c in childlist)
  98. {
  99. string childNum = dto.num + "." + idx.ToString();
  100. long order_num = long.Parse(dto.num_order.ToString() + (idx.ToString().PadLeft(3, '0')));
  101. var icitem = icitemlist.Where(a => a.mysql_id == c.icitem_id).FirstOrDefault();
  102. var childBom = bomlist.Where(a => a.icitem_id == c.icitem_id).FirstOrDefault();
  103. //如果此明细查的到BOM信息,则代表此child是一个子BOM。
  104. if (childBom != null)
  105. {
  106. var cdto = new BomChildExamineDto();
  107. cdto.id = help.NextId();
  108. cdto.level = level;
  109. cdto.parent_id = dto.id;
  110. cdto.bom_child_id = c.mysql_id;
  111. cdto.qty = c.qty.Value;
  112. cdto.backflush = c.backflush;
  113. cdto.num = childNum;
  114. cdto.num_order = order_num;
  115. cdto.isbom = 1;
  116. cdto.is_replace = c.is_replace;
  117. cdto.haveicsubs = c.haveicsubs;
  118. cdto.substitute_code = c.substitute_code;
  119. cdto.icitem_ids = c.icitem_ids;
  120. cdto.type = type;
  121. cdto.item_id = childBom.icitem_id;
  122. cdto.bom_id = childBom.mysql_id;
  123. cdto.bom_number = childBom.bom_number;
  124. //递归寻找子级
  125. GetBomList(bomlist, bomchildlist, icitemlist, cdto, returnlist, type);
  126. }
  127. else
  128. {
  129. if (icitem != null)
  130. {
  131. var childDto = new BomChildExamineDto();
  132. childDto.level = level;
  133. childDto.bom_id = dto.bom_id;
  134. childDto.bom_child_id = c.mysql_id;
  135. childDto.id = help.NextId();
  136. childDto.parent_id = dto.id;
  137. childDto.item_id = icitem.mysql_id;
  138. childDto.item_name = icitem.name;
  139. childDto.item_code = icitem.number;
  140. childDto.num = childNum;
  141. childDto.num_order = order_num;
  142. childDto.model = icitem.model;
  143. childDto.unit = c.unit;
  144. childDto.erp_cls = icitem.erp_cls;
  145. childDto.erp_cls_name = icitem.erp_cls_name;
  146. childDto.backflush = c.backflush;
  147. childDto.qty = c.qty.Value;
  148. childDto.isbom = 0;
  149. childDto.is_replace = c.is_replace;
  150. childDto.haveicsubs = c.haveicsubs;
  151. childDto.substitute_code = c.substitute_code;
  152. childDto.icitem_ids = c.icitem_ids;
  153. childDto.type = type;
  154. childDto.item_number = icitem.number;
  155. returnlist.Add(childDto);
  156. }
  157. }
  158. idx++;
  159. }
  160. }
  161. /// <summary>
  162. /// BOM替代关系预处理
  163. /// </summary>
  164. /// <param name="returnlist"></param>
  165. /// <param name="bomlist"></param>
  166. /// <param name="bomchildlist"></param>
  167. /// <param name="icitemlist"></param>
  168. /// <param name="sublist"></param>
  169. /// <param name="suballlist"></param>
  170. /// <param name="subdtllist"></param>
  171. public void BomSubstitute(List<BomChildExamineDto> returnlist, List<mo_ic_bom> bomlist, List<mo_ic_bom_child> bomchildlist, List<mo_ic_item> icitemlist, List<mo_ic_substitute> sublist, List<mo_ic_substitute_all> suballlist, List<mo_ic_substitute_all_dtl> subdtllist)
  172. {
  173. List<long> childidList = new List<long>();
  174. int type = 1;
  175. List<BomChildExamineDto> addlist = new List<BomChildExamineDto>();
  176. //除顶级外,其他层级关系全带出来。生成平铺
  177. foreach (var item in returnlist)
  178. {
  179. //最顶级、虚拟件
  180. if (item.level == 1 || item.erp_cls == 4 || childidList.Contains(item.bom_child_id.GetValueOrDefault()))
  181. {
  182. continue;
  183. }
  184. //有替代关系
  185. if (item.haveicsubs != 1)
  186. {
  187. continue;
  188. }
  189. if (!string.IsNullOrEmpty(item.icitem_ids))
  190. {
  191. long cid = 1;
  192. var cids = item.icitem_ids.Split(',');
  193. foreach (var c in cids)
  194. {
  195. if (long.TryParse(c, out cid))
  196. {
  197. childidList.Add(cid);
  198. }
  199. }
  200. }
  201. //找到当前物料的替代群组关系集
  202. var sl = sublist.Find(s => s.substitute_code == item.substitute_code);
  203. if (sl != null)
  204. {
  205. var sall = suballlist.Where(s => s.substitute_id == sl.mysql_id).ToList();
  206. foreach (var sal in sall)
  207. {
  208. var sadl = subdtllist.Where(s => s.substitute_allid == sal.mysql_id).ToList();
  209. foreach (var dtl in sadl)
  210. {
  211. if (sal.main_material.GetValueOrDefault() != 1)
  212. {
  213. //递归将替代关系组装出来。
  214. SubstitutePretreatment(sl, sal, dtl, item, addlist, icitemlist, bomlist, bomchildlist, type);
  215. }
  216. else
  217. {
  218. //将主料赋值上属性
  219. var dtlitem = returnlist.Find(s => s.item_id == dtl.icitem_id && s.level == item.level);
  220. dtlitem.substitute_all_num = sal.order_num;//群组优先级
  221. }
  222. }
  223. }
  224. }
  225. }
  226. returnlist.AddRange(addlist);
  227. }
  228. /// <summary>
  229. /// 替代关系递归组装出来
  230. /// </summary>
  231. /// <param name="sal"></param>
  232. /// <param name="dtl"></param>
  233. /// <param name="toDto"></param>
  234. /// <param name="returnlist"></param>
  235. /// <param name="icitemlist"></param>
  236. /// <param name="bomlist"></param>
  237. /// <param name="bomchildlist"></param>
  238. public void SubstitutePretreatment(mo_ic_substitute sl, mo_ic_substitute_all sal, mo_ic_substitute_all_dtl dtl, BomChildExamineDto toDto, List<BomChildExamineDto> returnlist, List<mo_ic_item> icitemlist, List<mo_ic_bom> bomlist, List<mo_ic_bom_child> bomchildlist, int type)
  239. {
  240. //如果dtl对应的icitem是BOM,还需要向下继续展开。
  241. //List<BomChildExamineDto> returnlist = new List<BomChildExamineDto>();
  242. var dto = new BomChildExamineDto();
  243. var bom = bomlist.Where(s => s.icitem_id == dtl.icitem_id).FirstOrDefault();
  244. var icitem = icitemlist.Find(s => s.mysql_id == dtl.icitem_id);
  245. if (icitem == null)
  246. {
  247. return;
  248. }
  249. dto.id = help.NextId();
  250. dto.level = toDto.level;
  251. dto.parent_id = toDto.parent_id;
  252. dto.item_id = icitem.mysql_id;
  253. dto.item_name = icitem.name;
  254. dto.item_code = icitem.number;
  255. dto.num = toDto.num;
  256. dto.num_order = toDto.num_order;
  257. dto.model = icitem.model;
  258. dto.unit = icitem.unit;
  259. dto.erp_cls = icitem.erp_cls;
  260. dto.erp_cls_name = icitem.erp_cls_name;
  261. dto.backflush = toDto.backflush;
  262. //dto.qty = toDto.qty;
  263. //dto.replace_amount = dtl.replace_amount.Value;
  264. dto.qty = dtl.replace_amount == null ? 1 : dtl.replace_amount.Value;
  265. dto.is_replace = 0;
  266. dto.haveicsubs = 0;
  267. dto.substitute_code = "";
  268. dto.icitem_ids = "";
  269. dto.substitute_strategy = sl.substitute_strategy == null ? 0 : sl.substitute_strategy.Value;//替代策略
  270. dto.substitute_mode = sl.substitute_mode == null ? 0 : sl.substitute_mode.Value;//替代方式
  271. dto.type = type;
  272. dto.substitute_all_num = sal.order_num;//群组优先级
  273. if (bom != null)
  274. {
  275. dto.bom_id = bom.mysql_id;
  276. dto.qty = dtl.replace_amount == null ? 1 : dtl.replace_amount.Value;
  277. dto.isbom = 1;
  278. dto.is_replace = 0;
  279. dto.haveicsubs = 0;
  280. dto.substitute_code = "";
  281. dto.icitem_ids = "";
  282. GetBomList(bomlist, bomchildlist, icitemlist, dto, returnlist, type);
  283. }
  284. else
  285. {
  286. dto.bom_id = null;
  287. dto.isbom = 0;
  288. returnlist.Add(dto);
  289. }
  290. }
  291. }
  292. }