@things-factory/worksheet-base 8.0.0-beta.8 → 8.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (288) hide show
  1. package/dist-server/controllers/inbound/unloading-worksheet-controller.js +2 -0
  2. package/dist-server/controllers/inbound/unloading-worksheet-controller.js.map +1 -1
  3. package/dist-server/graphql/resolvers/worksheet/vas-candidates.d.ts +2 -0
  4. package/dist-server/tsconfig.tsbuildinfo +1 -1
  5. package/dist-server/utils/inventory-util.d.ts +2 -0
  6. package/package.json +17 -17
  7. package/server/constants/index.ts +5 -0
  8. package/server/constants/rule-type.ts +4 -0
  9. package/server/constants/target-type.ts +6 -0
  10. package/server/constants/template.ts +12 -0
  11. package/server/constants/transaction-type.ts +9 -0
  12. package/server/constants/worksheet.ts +38 -0
  13. package/server/controllers/ecommerce/ecommerce-controller.ts +209 -0
  14. package/server/controllers/ecommerce/index.ts +2 -0
  15. package/server/controllers/ecommerce/sellercraft-controller.ts +358 -0
  16. package/server/controllers/inbound/index.ts +4 -0
  17. package/server/controllers/inbound/putaway-returning-worksheet-controller.ts +450 -0
  18. package/server/controllers/inbound/putaway-worksheet-controller.ts +454 -0
  19. package/server/controllers/inbound/unloading-returning-worksheet-controller.ts +291 -0
  20. package/server/controllers/inbound/unloading-worksheet-controller.ts +1400 -0
  21. package/server/controllers/index.ts +21 -0
  22. package/server/controllers/inspect/cycle-count-worksheet-controller.ts +537 -0
  23. package/server/controllers/inspect/index.ts +1 -0
  24. package/server/controllers/outbound/index.ts +5 -0
  25. package/server/controllers/outbound/loading-worksheet-controller.ts +377 -0
  26. package/server/controllers/outbound/packing-worksheet-controller.ts +449 -0
  27. package/server/controllers/outbound/picking-worksheet-controller.ts +1769 -0
  28. package/server/controllers/outbound/returning-worksheet-controller.ts +254 -0
  29. package/server/controllers/outbound/sorting-worksheet-controller.ts +554 -0
  30. package/server/controllers/render-elccl-grn.ts +228 -0
  31. package/server/controllers/render-fm-grn.ts +287 -0
  32. package/server/controllers/render-grn.ts +285 -0
  33. package/server/controllers/render-invoices.ts +201 -0
  34. package/server/controllers/render-job-sheet.ts +208 -0
  35. package/server/controllers/render-kimeda-grn.ts +185 -0
  36. package/server/controllers/render-manifest.ts +76 -0
  37. package/server/controllers/render-manual-do.ts +227 -0
  38. package/server/controllers/render-orientage-do.ts +376 -0
  39. package/server/controllers/render-orientage-grn.ts +191 -0
  40. package/server/controllers/render-po.ts +182 -0
  41. package/server/controllers/render-ro-do.ts +404 -0
  42. package/server/controllers/render-seebuu-grn.ts +208 -0
  43. package/server/controllers/vas/index.ts +1 -0
  44. package/server/controllers/vas/vas-worksheet-controller.ts +848 -0
  45. package/server/controllers/worksheet-controller.ts +1267 -0
  46. package/server/entities/index.ts +8 -0
  47. package/server/entities/warehouse-bizplace-onhand-inventory.ts +148 -0
  48. package/server/entities/worksheet-detail.ts +106 -0
  49. package/server/entities/worksheet-movement.ts +34 -0
  50. package/server/entities/worksheet.ts +100 -0
  51. package/server/graphql/index.ts +7 -0
  52. package/server/graphql/resolvers/index.ts +8 -0
  53. package/server/graphql/resolvers/pallet/index.ts +7 -0
  54. package/server/graphql/resolvers/pallet/pallet-outbound.ts +92 -0
  55. package/server/graphql/resolvers/worksheet/batch-picking-worksheet.ts +137 -0
  56. package/server/graphql/resolvers/worksheet/cancel-draft-release-order.ts +20 -0
  57. package/server/graphql/resolvers/worksheet/check-inventory-release.ts +37 -0
  58. package/server/graphql/resolvers/worksheet/check-stock-take-current-location.ts +63 -0
  59. package/server/graphql/resolvers/worksheet/confirm-cancellation-release-order.ts +213 -0
  60. package/server/graphql/resolvers/worksheet/create-worksheet.ts +21 -0
  61. package/server/graphql/resolvers/worksheet/cross-dock-picking.ts +173 -0
  62. package/server/graphql/resolvers/worksheet/cycle-count-adjustment.ts +211 -0
  63. package/server/graphql/resolvers/worksheet/cycle-count-worksheet.ts +79 -0
  64. package/server/graphql/resolvers/worksheet/delete-worksheet.ts +21 -0
  65. package/server/graphql/resolvers/worksheet/delivery-order-by-worksheet.ts +104 -0
  66. package/server/graphql/resolvers/worksheet/fetch-delivery-order-ro.ts +191 -0
  67. package/server/graphql/resolvers/worksheet/fetch-sellercraft-document.ts +69 -0
  68. package/server/graphql/resolvers/worksheet/find-release-orders-by-task-no.ts +36 -0
  69. package/server/graphql/resolvers/worksheet/find-release-orders-by-worksheet-no.ts +29 -0
  70. package/server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts +80 -0
  71. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-arrival-notice-worksheet.ts +100 -0
  72. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-batch-picking-worksheet.ts +26 -0
  73. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-cycle-count-worksheet.ts +51 -0
  74. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-multiple-release-good-worksheet.ts +17 -0
  75. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-return-worksheet.ts +69 -0
  76. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-worksheet.ts +65 -0
  77. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-putaway-worksheet.ts +54 -0
  78. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-release-good-worksheet.ts +114 -0
  79. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-return-order-worksheet.ts +45 -0
  80. package/server/graphql/resolvers/worksheet/generate-worksheet/generate-vas-order-worksheet.ts +35 -0
  81. package/server/graphql/resolvers/worksheet/generate-worksheet/index.ts +23 -0
  82. package/server/graphql/resolvers/worksheet/having-vas.ts +45 -0
  83. package/server/graphql/resolvers/worksheet/index.ts +142 -0
  84. package/server/graphql/resolvers/worksheet/inspecting/activate-cycle-count.ts +24 -0
  85. package/server/graphql/resolvers/worksheet/inspecting/add-extra-pallet.ts +49 -0
  86. package/server/graphql/resolvers/worksheet/inspecting/check-missing-pallet.ts +18 -0
  87. package/server/graphql/resolvers/worksheet/inspecting/complete-inspection.ts +41 -0
  88. package/server/graphql/resolvers/worksheet/inspecting/index.ts +17 -0
  89. package/server/graphql/resolvers/worksheet/inspecting/inspecting.ts +30 -0
  90. package/server/graphql/resolvers/worksheet/inspecting/relocate-pallet.ts +46 -0
  91. package/server/graphql/resolvers/worksheet/inspecting/undo-inspection.ts +23 -0
  92. package/server/graphql/resolvers/worksheet/inventories-by-pallet.ts +150 -0
  93. package/server/graphql/resolvers/worksheet/loaded-inventories.ts +40 -0
  94. package/server/graphql/resolvers/worksheet/loading/activate-loading.ts +73 -0
  95. package/server/graphql/resolvers/worksheet/loading/complete-loading.ts +165 -0
  96. package/server/graphql/resolvers/worksheet/loading/index.ts +11 -0
  97. package/server/graphql/resolvers/worksheet/loading/loading.ts +46 -0
  98. package/server/graphql/resolvers/worksheet/loading/undo-loading.ts +25 -0
  99. package/server/graphql/resolvers/worksheet/loading-worksheet.ts +150 -0
  100. package/server/graphql/resolvers/worksheet/not-tally-target-inventories.ts +34 -0
  101. package/server/graphql/resolvers/worksheet/packing/activate-packing.ts +69 -0
  102. package/server/graphql/resolvers/worksheet/packing/complete-packing.ts +102 -0
  103. package/server/graphql/resolvers/worksheet/packing/index.ts +13 -0
  104. package/server/graphql/resolvers/worksheet/packing/packing.ts +59 -0
  105. package/server/graphql/resolvers/worksheet/packing/scan-product-packing.ts +70 -0
  106. package/server/graphql/resolvers/worksheet/packing/undo-serial-number-packing.ts +24 -0
  107. package/server/graphql/resolvers/worksheet/packing-worksheet.ts +378 -0
  108. package/server/graphql/resolvers/worksheet/palletizing-pallets.ts +142 -0
  109. package/server/graphql/resolvers/worksheet/pending-cancellation-release-order.ts +234 -0
  110. package/server/graphql/resolvers/worksheet/picking/activate-batch-picking.ts +40 -0
  111. package/server/graphql/resolvers/worksheet/picking/activate-picking.ts +98 -0
  112. package/server/graphql/resolvers/worksheet/picking/assign-picking-inventories.ts +50 -0
  113. package/server/graphql/resolvers/worksheet/picking/assign-picking-worker.ts +44 -0
  114. package/server/graphql/resolvers/worksheet/picking/batch-picking.ts +32 -0
  115. package/server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts +137 -0
  116. package/server/graphql/resolvers/worksheet/picking/complete-picking.ts +282 -0
  117. package/server/graphql/resolvers/worksheet/picking/fetch-and-assign-picking-task.ts +121 -0
  118. package/server/graphql/resolvers/worksheet/picking/index.ts +31 -0
  119. package/server/graphql/resolvers/worksheet/picking/my-picking-assignment-status.ts +35 -0
  120. package/server/graphql/resolvers/worksheet/picking/picking-assignment-status-by-user.ts +96 -0
  121. package/server/graphql/resolvers/worksheet/picking/picking.ts +55 -0
  122. package/server/graphql/resolvers/worksheet/picking/scan-product-batch-picking.ts +52 -0
  123. package/server/graphql/resolvers/worksheet/picking/scan-product-picking.ts +25 -0
  124. package/server/graphql/resolvers/worksheet/picking/seal-tote.ts +25 -0
  125. package/server/graphql/resolvers/worksheet/picking/undo-picking-assignment.ts +31 -0
  126. package/server/graphql/resolvers/worksheet/picking/undo-serial-number-picking.ts +24 -0
  127. package/server/graphql/resolvers/worksheet/picking-worksheet.ts +147 -0
  128. package/server/graphql/resolvers/worksheet/proceed-extra-products.ts +242 -0
  129. package/server/graphql/resolvers/worksheet/putaway/activate-putaway.ts +51 -0
  130. package/server/graphql/resolvers/worksheet/putaway/complete-putaway.ts +105 -0
  131. package/server/graphql/resolvers/worksheet/putaway/index.ts +11 -0
  132. package/server/graphql/resolvers/worksheet/putaway/putaway.ts +26 -0
  133. package/server/graphql/resolvers/worksheet/putaway/undo-putaway.ts +25 -0
  134. package/server/graphql/resolvers/worksheet/putaway-return/activate-putaway-return.ts +55 -0
  135. package/server/graphql/resolvers/worksheet/putaway-return/complete-putaway-return.ts +38 -0
  136. package/server/graphql/resolvers/worksheet/putaway-return/index.ts +11 -0
  137. package/server/graphql/resolvers/worksheet/putaway-return/putaway-return.ts +30 -0
  138. package/server/graphql/resolvers/worksheet/putaway-return/undo-putaway-return.ts +29 -0
  139. package/server/graphql/resolvers/worksheet/putaway-returning-worksheet.ts +83 -0
  140. package/server/graphql/resolvers/worksheet/putaway-worksheet.ts +82 -0
  141. package/server/graphql/resolvers/worksheet/recommend-putway-location.ts +133 -0
  142. package/server/graphql/resolvers/worksheet/reject-cancellation-release-order.ts +186 -0
  143. package/server/graphql/resolvers/worksheet/relocate-pallet.ts +67 -0
  144. package/server/graphql/resolvers/worksheet/replace-picking-pallets.ts +127 -0
  145. package/server/graphql/resolvers/worksheet/return-worksheet.ts +70 -0
  146. package/server/graphql/resolvers/worksheet/returning/activate-return.ts +24 -0
  147. package/server/graphql/resolvers/worksheet/returning/complete-return.ts +39 -0
  148. package/server/graphql/resolvers/worksheet/returning/index.ts +9 -0
  149. package/server/graphql/resolvers/worksheet/returning/returning.ts +26 -0
  150. package/server/graphql/resolvers/worksheet/sorting/activate-sorting.ts +25 -0
  151. package/server/graphql/resolvers/worksheet/sorting/complete-order-sorting.ts +40 -0
  152. package/server/graphql/resolvers/worksheet/sorting/complete-worksheet-sorting.ts +23 -0
  153. package/server/graphql/resolvers/worksheet/sorting/index.ts +13 -0
  154. package/server/graphql/resolvers/worksheet/sorting/scan-product-sorting.ts +31 -0
  155. package/server/graphql/resolvers/worksheet/sorting/sorting-product.ts +32 -0
  156. package/server/graphql/resolvers/worksheet/sorting-worksheet.ts +87 -0
  157. package/server/graphql/resolvers/worksheet/transfer.ts +176 -0
  158. package/server/graphql/resolvers/worksheet/unloaded-inventories-by-reusable-pallet.ts +54 -0
  159. package/server/graphql/resolvers/worksheet/unloaded-inventories.ts +78 -0
  160. package/server/graphql/resolvers/worksheet/unloading/activate-unloading.ts +56 -0
  161. package/server/graphql/resolvers/worksheet/unloading/complete-product-scan-unload.ts +25 -0
  162. package/server/graphql/resolvers/worksheet/unloading/complete-unloading-partially.ts +25 -0
  163. package/server/graphql/resolvers/worksheet/unloading/complete-unloading.ts +76 -0
  164. package/server/graphql/resolvers/worksheet/unloading/index.ts +21 -0
  165. package/server/graphql/resolvers/worksheet/unloading/scan-product-unload.ts +26 -0
  166. package/server/graphql/resolvers/worksheet/unloading/scan-serial-number-unload.ts +26 -0
  167. package/server/graphql/resolvers/worksheet/unloading/undo-serial-number-unload.ts +24 -0
  168. package/server/graphql/resolvers/worksheet/unloading/undo-unloading.ts +25 -0
  169. package/server/graphql/resolvers/worksheet/unloading/unload.ts +26 -0
  170. package/server/graphql/resolvers/worksheet/unloading-return/activate-unloading-return.ts +28 -0
  171. package/server/graphql/resolvers/worksheet/unloading-return/complete-unload-return-partially.ts +29 -0
  172. package/server/graphql/resolvers/worksheet/unloading-return/complete-unload-returning.ts +91 -0
  173. package/server/graphql/resolvers/worksheet/unloading-return/index.ts +9 -0
  174. package/server/graphql/resolvers/worksheet/unloading-return-worksheet.ts +75 -0
  175. package/server/graphql/resolvers/worksheet/unloading-worksheet.ts +98 -0
  176. package/server/graphql/resolvers/worksheet/update-worksheet.ts +25 -0
  177. package/server/graphql/resolvers/worksheet/vas/activate-vas.ts +25 -0
  178. package/server/graphql/resolvers/worksheet/vas/assign-vas-inventories.ts +25 -0
  179. package/server/graphql/resolvers/worksheet/vas/complete-vas.ts +72 -0
  180. package/server/graphql/resolvers/worksheet/vas/execute-vas.ts +31 -0
  181. package/server/graphql/resolvers/worksheet/vas/index.ts +15 -0
  182. package/server/graphql/resolvers/worksheet/vas/undo-vas-inventory.ts +24 -0
  183. package/server/graphql/resolvers/worksheet/vas/undo-vas.ts +24 -0
  184. package/server/graphql/resolvers/worksheet/vas-candidates.ts +177 -0
  185. package/server/graphql/resolvers/worksheet/vas-inventories.ts +41 -0
  186. package/server/graphql/resolvers/worksheet/vas-transactions/common-utils.ts +1182 -0
  187. package/server/graphql/resolvers/worksheet/vas-transactions/index.ts +5 -0
  188. package/server/graphql/resolvers/worksheet/vas-transactions/interfaces/index.ts +56 -0
  189. package/server/graphql/resolvers/worksheet/vas-transactions/interfaces/relabeling.ts +20 -0
  190. package/server/graphql/resolvers/worksheet/vas-transactions/interfaces/repackaging.ts +27 -0
  191. package/server/graphql/resolvers/worksheet/vas-transactions/interfaces/repalletizing.ts +14 -0
  192. package/server/graphql/resolvers/worksheet/vas-transactions/interfaces/unpacking.ts +14 -0
  193. package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/check-relabelable.ts +96 -0
  194. package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/complete-relabeling.ts +93 -0
  195. package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/index.ts +4 -0
  196. package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/relabeling.ts +105 -0
  197. package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/undo-relabeling.ts +40 -0
  198. package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/complete-repackaging.ts +236 -0
  199. package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/index.ts +3 -0
  200. package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/repackaging.ts +402 -0
  201. package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/undo-repackaging.ts +166 -0
  202. package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/complete-repalletizing.ts +116 -0
  203. package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/index.ts +3 -0
  204. package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/repalletizing.ts +167 -0
  205. package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/undo-repalletizing.ts +74 -0
  206. package/server/graphql/resolvers/worksheet/vas-transactions/unpacking/complete-unpacking.ts +20 -0
  207. package/server/graphql/resolvers/worksheet/vas-transactions/unpacking/index.ts +2 -0
  208. package/server/graphql/resolvers/worksheet/vas-transactions/unpacking/unpacking.ts +164 -0
  209. package/server/graphql/resolvers/worksheet/vas-worksheet.ts +110 -0
  210. package/server/graphql/resolvers/worksheet/worksheet-by-order-no.ts +43 -0
  211. package/server/graphql/resolvers/worksheet/worksheet-with-pagination.ts +46 -0
  212. package/server/graphql/resolvers/worksheet/worksheet.ts +330 -0
  213. package/server/graphql/resolvers/worksheet/worksheets.ts +493 -0
  214. package/server/graphql/resolvers/worksheet-detail/check-progressing-pallet.ts +22 -0
  215. package/server/graphql/resolvers/worksheet-detail/create-worksheet-detail.ts +38 -0
  216. package/server/graphql/resolvers/worksheet-detail/delete-worksheet-detail.ts +18 -0
  217. package/server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details-by-bulk.ts +206 -0
  218. package/server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details.ts +165 -0
  219. package/server/graphql/resolvers/worksheet-detail/generate-carton-id.ts +26 -0
  220. package/server/graphql/resolvers/worksheet-detail/generate-pallet-id.ts +94 -0
  221. package/server/graphql/resolvers/worksheet-detail/generate-picking-worksheet-details.ts +259 -0
  222. package/server/graphql/resolvers/worksheet-detail/generate-release-good-worksheet-details.ts +142 -0
  223. package/server/graphql/resolvers/worksheet-detail/index.ts +34 -0
  224. package/server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.ts +165 -0
  225. package/server/graphql/resolvers/worksheet-detail/update-worksheet-detail.ts +39 -0
  226. package/server/graphql/resolvers/worksheet-detail/worksheet-detail.ts +19 -0
  227. package/server/graphql/resolvers/worksheet-detail/worksheet-details-by-product-group.ts +56 -0
  228. package/server/graphql/resolvers/worksheet-detail/worksheet-details.ts +21 -0
  229. package/server/graphql/resolvers/worksheet-movement/create-worksheet-movement.ts +17 -0
  230. package/server/graphql/resolvers/worksheet-movement/delete-worksheet-movement.ts +12 -0
  231. package/server/graphql/resolvers/worksheet-movement/index.ts +17 -0
  232. package/server/graphql/resolvers/worksheet-movement/update-worksheet-movement.ts +15 -0
  233. package/server/graphql/resolvers/worksheet-movement/worksheet-movement.ts +10 -0
  234. package/server/graphql/resolvers/worksheet-movement/worksheet-movements.ts +14 -0
  235. package/server/graphql/types/index.ts +15 -0
  236. package/server/graphql/types/pallet/index.ts +12 -0
  237. package/server/graphql/types/pallet/pallet.ts +7 -0
  238. package/server/graphql/types/worksheet/arrival-notice-worksheet.ts +8 -0
  239. package/server/graphql/types/worksheet/batch-pick-worksheet-info.ts +9 -0
  240. package/server/graphql/types/worksheet/contact-point-info.ts +12 -0
  241. package/server/graphql/types/worksheet/cycle-count-worksheet.ts +16 -0
  242. package/server/graphql/types/worksheet/delivery-info.ts +11 -0
  243. package/server/graphql/types/worksheet/delivery-order-info.ts +25 -0
  244. package/server/graphql/types/worksheet/delivery-order-ro.ts +15 -0
  245. package/server/graphql/types/worksheet/delivery-worksheet.ts +7 -0
  246. package/server/graphql/types/worksheet/executing-worksheet.ts +8 -0
  247. package/server/graphql/types/worksheet/find-release-orders-by-task-no.ts +8 -0
  248. package/server/graphql/types/worksheet/goods-delivery-note.ts +8 -0
  249. package/server/graphql/types/worksheet/index.ts +750 -0
  250. package/server/graphql/types/worksheet/inventory-check-worksheet.ts +7 -0
  251. package/server/graphql/types/worksheet/loaded-worksheet-detail.ts +9 -0
  252. package/server/graphql/types/worksheet/multiple-release-good-worksheet.ts +8 -0
  253. package/server/graphql/types/worksheet/my-picking-assignment-status.ts +9 -0
  254. package/server/graphql/types/worksheet/new-worksheet.ts +10 -0
  255. package/server/graphql/types/worksheet/picking-assignment-status.ts +9 -0
  256. package/server/graphql/types/worksheet/product-approval.ts +11 -0
  257. package/server/graphql/types/worksheet/release-good-worksheet.ts +8 -0
  258. package/server/graphql/types/worksheet/return-order-worksheet.ts +8 -0
  259. package/server/graphql/types/worksheet/sellercraft-document.ts +8 -0
  260. package/server/graphql/types/worksheet/vas-order-worksheet.ts +7 -0
  261. package/server/graphql/types/worksheet/vas-worksheet.ts +8 -0
  262. package/server/graphql/types/worksheet/worksheet-detail-info.ts +68 -0
  263. package/server/graphql/types/worksheet/worksheet-info.ts +33 -0
  264. package/server/graphql/types/worksheet/worksheet-list.ts +8 -0
  265. package/server/graphql/types/worksheet/worksheet-patch.ts +19 -0
  266. package/server/graphql/types/worksheet/worksheet-with-pagination.ts +9 -0
  267. package/server/graphql/types/worksheet/worksheet.ts +34 -0
  268. package/server/graphql/types/worksheet-detail/index.ts +81 -0
  269. package/server/graphql/types/worksheet-detail/inventory-detail.ts +39 -0
  270. package/server/graphql/types/worksheet-detail/new-worksheet-detail.ts +20 -0
  271. package/server/graphql/types/worksheet-detail/pallet-info.ts +8 -0
  272. package/server/graphql/types/worksheet-detail/worksheet-detail-list.ts +8 -0
  273. package/server/graphql/types/worksheet-detail/worksheet-detail-patch.ts +28 -0
  274. package/server/graphql/types/worksheet-detail/worksheet-detail.ts +29 -0
  275. package/server/graphql/types/worksheet-movement/index.ts +30 -0
  276. package/server/graphql/types/worksheet-movement/new-worksheet-movement.ts +8 -0
  277. package/server/graphql/types/worksheet-movement/worksheet-movement-list.ts +8 -0
  278. package/server/graphql/types/worksheet-movement/worksheet-movement-patch.ts +8 -0
  279. package/server/graphql/types/worksheet-movement/worksheet-movement.ts +10 -0
  280. package/server/index.ts +14 -0
  281. package/server/middlewares/index.ts +3 -0
  282. package/server/migrations/index.ts +9 -0
  283. package/server/routes.ts +80 -0
  284. package/server/utils/datetime-util.ts +54 -0
  285. package/server/utils/index.ts +4 -0
  286. package/server/utils/inventory-util.ts +390 -0
  287. package/server/utils/worksheet-no-generator.ts +206 -0
  288. package/server/utils/worksheet-util.ts +85 -0
@@ -0,0 +1,164 @@
1
+ import { Bizplace } from '@things-factory/biz-base'
2
+ import { generateId } from '@things-factory/id-rule-base'
3
+ import { Product } from '@things-factory/product-base'
4
+ import { ORDER_PRODUCT_STATUS, OrderNoGenerator, OrderProduct, OrderVas, ReleaseGood } from '@things-factory/sales-base'
5
+
6
+ import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../../../constants'
7
+ import { VasWorksheetController } from '../../../../../controllers/vas/vas-worksheet-controller'
8
+ import { Worksheet, WorksheetDetail } from '../../../../../entities'
9
+ import { WorksheetNoGenerator } from '../../../../../utils'
10
+ import { executeVas } from '../../vas/execute-vas'
11
+ import { getWorksheetDetailByName } from '../common-utils'
12
+ import { RefOrderType } from '../interfaces'
13
+
14
+ export const unpackingResolver = {
15
+ async unpacking(
16
+ _: any,
17
+ { worksheetDetailName, childProductId, unpackQty, unpackUomValue, palletId, locationName },
18
+ context: any
19
+ ) {
20
+ const { tx, domain, user } = context.state
21
+
22
+ const childProduct: Product = await tx.getRepository(Product).findOne({
23
+ where: { id: childProductId },
24
+ relations: ['domain']
25
+ })
26
+ if (!childProduct) throw new Error(`Couldn't find product by its sku (${childProduct.sku})`)
27
+
28
+ // Find target worksheet detail & target order vas & bizplace
29
+ const wsd: WorksheetDetail = await getWorksheetDetailByName(tx, domain, worksheetDetailName)
30
+ let { bizplace, targetVas }: { bizplace: Bizplace; targetVas: OrderVas } = wsd
31
+
32
+ // Init refOrder
33
+ //@ts-ignore
34
+ const { arrivalNotice, releaseGood, vasOrder }: { [key: string]: RefOrderType } = targetVas
35
+ const refOrder: RefOrderType = arrivalNotice || releaseGood || vasOrder || null
36
+ if (!refOrder) throw new Error(`Couldn't find reference order with current order vas`)
37
+
38
+ if (!palletId && refOrder instanceof ReleaseGood) {
39
+ // auto generate pallet ID for release order
40
+ const today = new Date()
41
+ const year = today.getFullYear()
42
+ const month = today.getMonth()
43
+ const day = today.getDate()
44
+
45
+ const yy = String(year).substr(String(year).length - 2)
46
+ const mm = String(month + 1).padStart(2, '0')
47
+ const dd = String(day).padStart(2, '0')
48
+
49
+ const date = yy + mm + dd
50
+ palletId = await generateId({
51
+ domain,
52
+ type: 'vas_pallet_id',
53
+ seed: {
54
+ batchId: targetVas.targetBatchId,
55
+ date: date
56
+ }
57
+ })
58
+
59
+ // to get refInventory location to assign as new inventory location
60
+ if (!locationName) {
61
+ const foundOrderVas: OrderVas = await tx.getRepository(OrderVas).findOne({
62
+ where: { id: targetVas.id },
63
+ relations: ['targetProduct', 'inventory', 'inventory.location']
64
+ })
65
+
66
+ locationName = foundOrderVas?.inventory?.location.name
67
+ }
68
+ }
69
+
70
+ if (palletId) {
71
+ const worksheetController: VasWorksheetController = new VasWorksheetController(tx, domain, user)
72
+ await worksheetController.unpackingWithPallet(
73
+ worksheetDetailName,
74
+ childProduct,
75
+ unpackQty,
76
+ unpackUomValue,
77
+ palletId,
78
+ locationName,
79
+ refOrder
80
+ )
81
+ } else {
82
+ let foundOP: OrderProduct = await tx.getRepository(OrderProduct).findOne({
83
+ where: {
84
+ domain: { id: domain.id },
85
+ arrivalNotice: { id: arrivalNotice.id },
86
+ batchId: targetVas.targetBatchId,
87
+ product: { id: targetVas.targetProduct.id }
88
+ }
89
+ })
90
+
91
+ //Create new order product for unpacked products
92
+ let newOP: OrderProduct = new OrderProduct()
93
+ newOP.domain = domain
94
+ newOP.bizplace = bizplace
95
+ newOP.name = OrderNoGenerator.orderProduct()
96
+ newOP.batchId = targetVas.targetBatchId
97
+ newOP.packingType = childProduct.packingType
98
+ newOP.uom = childProduct.primaryUnit
99
+ newOP.packQty = unpackQty
100
+ newOP.uomValue = unpackUomValue
101
+ newOP.palletQty = null
102
+ newOP.totalUomValue =
103
+ (Number(unpackQty) * Number(unpackUomValue)).toFixed(2) + ' ' + (childProduct.primaryUnit || '')
104
+ newOP.status = ORDER_PRODUCT_STATUS.READY_TO_UNLOAD
105
+ //@ts-ignore
106
+ newOP.arrivalNotice = arrivalNotice
107
+ newOP.product = childProduct
108
+ newOP.creator = user
109
+ newOP.updater = user
110
+
111
+ await tx.getRepository(OrderProduct).save(newOP)
112
+
113
+ // update unpackQty and unpackUomValue of original product
114
+ foundOP.unpackQty = unpackQty
115
+ foundOP.unpackUomValue = unpackUomValue
116
+
117
+ // update packQty and totalUomValue of original product
118
+ foundOP.packQty -= targetVas.qty
119
+ foundOP.totalUomValue = `${(foundOP.uomValue * foundOP.packQty).toFixed(2)} ${foundOP.uom}`
120
+
121
+ // update the order product status to DONE if remaining packQty is 0
122
+ // -- so that the user will never see this product during unloading and putaway stages
123
+ // if (foundOP.packQty === 0) foundOP.status = ORDER_PRODUCT_STATUS.TERMINATED
124
+
125
+ await tx.getRepository(OrderProduct).save(foundOP)
126
+
127
+ let worksheet: Worksheet = await tx.getRepository(Worksheet).findOne({
128
+ where: {
129
+ domain: { id: domain.id },
130
+ arrivalNotice: { id: arrivalNotice.id },
131
+ type: WORKSHEET_TYPE.UNLOADING
132
+ }
133
+ })
134
+
135
+ let worksheetDetails: WorksheetDetail = new WorksheetDetail()
136
+ worksheetDetails.name = WorksheetNoGenerator.generate(WORKSHEET_TYPE.UNLOADING, true)
137
+ worksheetDetails.seq = 0
138
+ worksheetDetails.type = WORKSHEET_TYPE.UNLOADING
139
+ worksheetDetails.status = WORKSHEET_STATUS.DEACTIVATED
140
+ worksheetDetails.domain = domain
141
+ worksheetDetails.bizplace = bizplace
142
+ worksheetDetails.worksheet = worksheet
143
+ worksheetDetails.targetProduct = newOP
144
+ worksheetDetails.creator = user
145
+ worksheetDetails.updater = user
146
+
147
+ await tx.getRepository(WorksheetDetail).save(worksheetDetails)
148
+
149
+ // update actualQty & actualUomValue of order vas
150
+ let actualQty: number = 0
151
+ let actualUomValue: number = 0
152
+
153
+ actualQty = Number(targetVas.actualQty) + Number(unpackQty)
154
+ actualUomValue = Number(targetVas.actualUomValue) + Number(unpackUomValue)
155
+
156
+ let newTargetVas: OrderVas = Object.assign({}, targetVas)
157
+ newTargetVas.actualQty = actualQty
158
+ newTargetVas.actualUomValue = actualUomValue
159
+ await tx.getRepository(OrderVas).save(newTargetVas)
160
+
161
+ await executeVas(tx, domain, user, wsd)
162
+ }
163
+ }
164
+ }
@@ -0,0 +1,110 @@
1
+ import { Equal, Not } from 'typeorm'
2
+
3
+ import {
4
+ ArrivalNotice,
5
+ ORDER_STATUS,
6
+ ORDER_TYPES,
7
+ OrderInventory,
8
+ OrderVas,
9
+ ReleaseGood,
10
+ VasOrder
11
+ } from '@things-factory/sales-base'
12
+ import { getRepository } from '@things-factory/shell'
13
+ import { Inventory } from '@things-factory/warehouse-base'
14
+
15
+ import { WORKSHEET_TYPE } from '../../../constants'
16
+ import { Worksheet, WorksheetDetail } from '../../../entities'
17
+ import { fetchExecutingWorksheet } from '../../../utils'
18
+
19
+ export const vasWorksheetResolver = {
20
+ async vasWorksheet(_: any, { orderNo, orderType }, context: ResolverContext) {
21
+ const { domain } = context.state
22
+ let refOrder: ArrivalNotice | ReleaseGood | VasOrder
23
+ if (orderType === ORDER_TYPES.ARRIVAL_NOTICE) {
24
+ refOrder = await getRepository(ArrivalNotice).findOne({
25
+ where: { domain: { id: domain.id }, name: orderNo, status: Not(Equal(ORDER_STATUS.DONE)) },
26
+ relations: ['bizplace']
27
+ })
28
+ } else if (orderType === ORDER_TYPES.RELEASE_OF_GOODS) {
29
+ refOrder = await getRepository(ReleaseGood).findOne({
30
+ where: { domain: { id: domain.id }, name: orderNo, status: Not(Equal(ORDER_STATUS.DONE)) },
31
+ relations: ['bizplace']
32
+ })
33
+ } else if (orderType === ORDER_TYPES.VAS_ORDER) {
34
+ refOrder = await getRepository(VasOrder).findOne({
35
+ where: { domain: { id: domain.id }, name: orderNo, status: Not(Equal(ORDER_STATUS.DONE)) },
36
+ relations: ['bizplace']
37
+ })
38
+ }
39
+
40
+ if (!refOrder) throw new Error(`Couldn't find VAS worksheet by order no (${orderNo})`)
41
+
42
+ const worksheet: Worksheet = await fetchExecutingWorksheet(
43
+ domain,
44
+ refOrder.bizplace,
45
+ [
46
+ 'worksheetDetails',
47
+ 'worksheetDetails.targetVas',
48
+ 'worksheetDetails.targetVas.vas',
49
+ 'worksheetDetails.targetVas.inventory',
50
+ 'worksheetDetails.targetVas.targetProduct',
51
+ 'worksheetDetails.targetVas.inventory.location',
52
+ 'creator',
53
+ 'updater'
54
+ ],
55
+ WORKSHEET_TYPE.VAS,
56
+ refOrder
57
+ )
58
+
59
+ if (orderType === ORDER_TYPES.RELEASE_OF_GOODS) {
60
+ for (let wsd of worksheet.worksheetDetails) {
61
+ const inventory: Inventory = wsd.targetVas.inventory
62
+ const orderInv: OrderInventory = await getRepository(OrderInventory).findOne({
63
+ where: { domain: { id: domain.id }, releaseGood: { id: refOrder.id }, inventory: { id: inventory.id } }
64
+ })
65
+
66
+ wsd.targetInventory = orderInv
67
+ }
68
+ }
69
+
70
+ return {
71
+ worksheetInfo: {
72
+ bizplaceName: refOrder.bizplace.name,
73
+ //@ts-ignore
74
+ containerNo: refOrder?.containerNo,
75
+ startedAt: worksheet.startedAt
76
+ },
77
+ worksheetDetailInfos: worksheet.worksheetDetails
78
+ .sort((a: WorksheetDetail, b: WorksheetDetail) => a.seq - b.seq)
79
+ .map((wsd: WorksheetDetail) => {
80
+ const targetVas: OrderVas = wsd.targetVas
81
+ return {
82
+ name: wsd.name,
83
+ seq: wsd.seq,
84
+ status: wsd.status,
85
+ issue: wsd.issue,
86
+ relatedOrderInv: wsd.targetInventory,
87
+ batchId: targetVas?.batchId,
88
+ targetName: targetVas?.name,
89
+ vas: targetVas?.vas,
90
+ set: targetVas?.set,
91
+ inventory: targetVas?.inventory,
92
+ locationInv: targetVas?.inventory?.location?.name,
93
+ targetType: targetVas?.targetType,
94
+ targetBatchId: targetVas?.targetBatchId,
95
+ targetProduct: targetVas?.targetProduct,
96
+ otherTarget: targetVas?.otherTarget,
97
+ qty: targetVas?.qty,
98
+ //@ts-ignore
99
+ weight: targetVas?.weight,
100
+ uomValue: targetVas?.uomValue,
101
+ operationGuide: targetVas?.operationGuide,
102
+ description: wsd.description,
103
+ remark: targetVas?.remark,
104
+ actualQty: targetVas?.actualQty,
105
+ actualUomValue: targetVas?.actualUomValue
106
+ }
107
+ })
108
+ }
109
+ }
110
+ }
@@ -0,0 +1,43 @@
1
+ import { EntityManager, FindOneOptions, Repository } from 'typeorm'
2
+
3
+ import { ArrivalNotice, ReleaseGood } from '@things-factory/sales-base'
4
+ import { Domain } from '@things-factory/shell'
5
+
6
+ import { WORKSHEET_TYPE } from '../../../constants'
7
+ import { Worksheet } from '../../../entities'
8
+
9
+ export const worksheetByOrderNoResolver = {
10
+ async worksheetByOrderNo(
11
+ _: any,
12
+ { orderType, orderNo }: { orderType: string; orderNo: string },
13
+ context: any
14
+ ): Promise<Worksheet> {
15
+ const { tx, domain } = context.state
16
+ return await worksheetByOrderNo(domain, orderNo, orderType, tx)
17
+ }
18
+ }
19
+
20
+ export async function worksheetByOrderNo(
21
+ domain: Domain,
22
+ orderNo: string,
23
+ type: string,
24
+ tx: EntityManager
25
+ ): Promise<Worksheet> {
26
+ let findOption: FindOneOptions<Worksheet> = {
27
+ where: { domain: { id: domain.id }, type },
28
+ relations: ['worksheetDetails']
29
+ }
30
+
31
+ if (type === WORKSHEET_TYPE.UNLOADING || type === WORKSHEET_TYPE.PUTAWAY) {
32
+ const ganRepo: Repository<ArrivalNotice> = tx.getRepository(ArrivalNotice)
33
+ findOption.where['arrivalNotice'] = await ganRepo.findOneBy({ domain: { id: domain.id }, name: orderNo })
34
+ ;(findOption.relations as string[]).push('worksheetDetails.targetProduct')
35
+ } else if (type === WORKSHEET_TYPE.PICKING || type === WORKSHEET_TYPE.LOADING) {
36
+ const roRepo: Repository<ReleaseGood> = tx.getRepository(ReleaseGood)
37
+ findOption.where['releaseGood'] = await roRepo.findOneBy({ domain: { id: domain.id }, name: orderNo })
38
+ ;(findOption.relations as string[]).push('worksheetDetails.targetInventory')
39
+ }
40
+
41
+ const wsRepo: Repository<Worksheet> = tx.getRepository(Worksheet)
42
+ return await wsRepo.findOne(findOption)
43
+ }
@@ -0,0 +1,46 @@
1
+ import { FindManyOptions } from 'typeorm'
2
+
3
+ import { getRepository } from '@things-factory/shell'
4
+
5
+ import { Worksheet, WorksheetDetail } from '../../../entities'
6
+
7
+ export const worksheetWithPaginationResolver = {
8
+ async worksheetWithPagination(
9
+ _: any,
10
+ { name, pagination }: { name: string; pagination?: { page: number; limit: number } },
11
+ context: any
12
+ ): Promise<{ worksheet: Worksheet; worksheetDetails: WorksheetDetail[]; total: number }> {
13
+ const { domain } = context.state
14
+ const worksheet: Worksheet = await getRepository(Worksheet).findOne({
15
+ where: { domain: { id: domain.id }, name },
16
+ relations: ['bizplace', 'arrivalNotice', 'releaseGood', 'inventoryCheck']
17
+ })
18
+
19
+ let findManyOptions: FindManyOptions<WorksheetDetail> = {
20
+ where: { domain: { id: domain.id }, worksheet: { id: worksheet.id } },
21
+ relations: [
22
+ 'targetInventory',
23
+ 'targetInventory.originLocation',
24
+ 'targetInventory.inspectedLocation',
25
+ 'targetInventory.inventory',
26
+ 'targetInventory.inventory.location',
27
+ 'targetInventory.inventory.product'
28
+ ]
29
+ }
30
+
31
+ if (pagination?.page && pagination?.limit) {
32
+ const { page, limit }: { page: number; limit: number } = pagination
33
+ const offset: number = (page - 1) * limit
34
+ findManyOptions.skip = offset
35
+ findManyOptions.take = limit
36
+ }
37
+
38
+ const [worksheetDetails, total] = await getRepository(WorksheetDetail).findAndCount(findManyOptions)
39
+
40
+ return {
41
+ worksheet,
42
+ worksheetDetails,
43
+ total
44
+ }
45
+ }
46
+ }
@@ -0,0 +1,330 @@
1
+ import { Equal, Not } from 'typeorm'
2
+
3
+ import { MarketplaceOrder, MarketplaceOrderShipping } from '@things-factory/marketplace-base'
4
+ import { ORDER_INVENTORY_STATUS, OrderInventory, OrderProduct, OrderVas } from '@things-factory/sales-base'
5
+ import { Setting } from '@things-factory/setting-base'
6
+ import { getRepository } from '@things-factory/shell'
7
+ import { Inventory, INVENTORY_STATUS, InventoryHistory } from '@things-factory/warehouse-base'
8
+
9
+ import { WORKSHEET_TYPE } from '../../../constants'
10
+ import { Worksheet, WorksheetDetail } from '../../../entities'
11
+
12
+ interface WorksheetInterface extends Worksheet {
13
+ orderProducts: OrderProduct[]
14
+ orderInventories: OrderInventory[]
15
+ orderVass: OrderVas[]
16
+ marketplaceOrder: MarketplaceOrder
17
+ }
18
+
19
+ export const worksheetResolver = {
20
+ async worksheet(_: any, { name }, context: ResolverContext) {
21
+ const { domain } = context.state
22
+ let worksheet: WorksheetInterface
23
+ worksheet = (await getRepository(Worksheet).findOne({
24
+ where: {
25
+ domain: { id: domain.id },
26
+ name
27
+ },
28
+ relations: [
29
+ 'domain',
30
+ 'bizplace',
31
+ 'bizplace.domain',
32
+ 'bufferLocation',
33
+ 'bufferLocation.warehouse',
34
+ 'arrivalNotice',
35
+ 'arrivalNotice.releaseGood',
36
+ 'arrivalNotice.supplier',
37
+ 'releaseGood',
38
+ 'releaseGood.arrivalNotice',
39
+ 'releaseGood.shippingOrder',
40
+ 'releaseGood.deliverTo',
41
+ 'releaseGood.deliverTo.bizplace',
42
+ 'releaseGood.manifest',
43
+ 'returnOrder',
44
+ 'inventoryCheck',
45
+ 'vasOrder',
46
+ 'assignee',
47
+ 'worksheetDetails',
48
+ 'worksheetDetails.toLocation',
49
+ 'worksheetDetails.targetProduct',
50
+ 'worksheetDetails.targetProduct.product',
51
+ 'worksheetDetails.targetVas',
52
+ 'worksheetDetails.targetVas.vas',
53
+ 'worksheetDetails.targetVas.inventory',
54
+ 'worksheetDetails.targetVas.inventory.location',
55
+ 'worksheetDetails.targetVas.targetProduct',
56
+ 'worksheetDetails.targetInventory',
57
+ 'worksheetDetails.targetInventory.releaseGood',
58
+ 'worksheetDetails.targetInventory.product',
59
+ 'worksheetDetails.targetInventory.inventory',
60
+ 'worksheetDetails.targetInventory.inventory.product',
61
+ 'worksheetDetails.targetInventory.inventory.warehouse',
62
+ 'worksheetDetails.targetInventory.inventory.location',
63
+ 'worksheetDetails.targetInventory.inspectedLocation',
64
+ 'creator',
65
+ 'updater'
66
+ ]
67
+ })) as WorksheetInterface
68
+
69
+ if (!worksheet) {
70
+ worksheet = (await getRepository(Worksheet).findOne({
71
+ where: {
72
+ domain: { id: domain.id },
73
+ arrivalNotice: { id: name } /* CONFIRMME regarding TYPEORM - name means id ? */
74
+ },
75
+ relations: [
76
+ 'domain',
77
+ 'bizplace',
78
+ 'bizplace.domain',
79
+ 'worksheetDetails',
80
+ 'worksheetDetails.targetProduct',
81
+ 'worksheetDetails.targetProduct.product',
82
+ 'worksheetDetails.targetInventory',
83
+ 'worksheetDetails.targetInventory.releaseGood',
84
+ 'worksheetDetails.targetInventory.product',
85
+ 'worksheetDetails.targetInventory.inventory',
86
+ 'worksheetDetails.targetInventory.inventory.product',
87
+ 'worksheetDetails.targetInventory.inventory.warehouse',
88
+ 'worksheetDetails.targetInventory.inventory.location',
89
+ 'worksheetDetails.targetInventory.inspectedLocation',
90
+ 'creator',
91
+ 'updater'
92
+ ]
93
+ })) as WorksheetInterface
94
+ }
95
+
96
+ let pWorksheetPickingItemSorting = getRepository(Setting).findOne({
97
+ where: { domain: { id: domain.id }, category: 'location', name: 'rule-for-picking-product' }
98
+ })
99
+
100
+ if (worksheet?.arrivalNotice?.id) {
101
+ worksheet.orderProducts = await getRepository(OrderProduct).find({
102
+ where: {
103
+ domain: { id: domain.id },
104
+ bizplace: { id: worksheet.bizplace.id },
105
+ arrivalNotice: { id: worksheet.arrivalNotice.id }
106
+ }
107
+ })
108
+
109
+ worksheet.orderVass = await getRepository(OrderVas).find({
110
+ where: {
111
+ domain: { id: domain.id },
112
+ bizplace: { id: worksheet.bizplace.id },
113
+ arrivalNotice: { id: worksheet.arrivalNotice.id }
114
+ },
115
+ relations: ['targetProduct']
116
+ })
117
+
118
+ // update inventory data >> unloaded inventory history data
119
+ if (
120
+ worksheet.type === WORKSHEET_TYPE.PUTAWAY &&
121
+ worksheet.worksheetDetails.every(wsd => wsd.targetInventory.inventory)
122
+ ) {
123
+ worksheet.worksheetDetails = await Promise.all(
124
+ worksheet.worksheetDetails.map(async (wsd: WorksheetDetail) => {
125
+ let inventory: Inventory = wsd.targetInventory.inventory
126
+
127
+ let foundHistory: InventoryHistory = await getRepository(InventoryHistory).findOne({
128
+ where: [
129
+ {
130
+ inventory: { id: inventory.id },
131
+ refOrderId: worksheet.arrivalNotice.id,
132
+ status: INVENTORY_STATUS.UNLOADED
133
+ },
134
+ {
135
+ inventory: { id: inventory.id },
136
+ refOrderId: worksheet.arrivalNotice.id,
137
+ status: INVENTORY_STATUS.PARTIALLY_UNLOADED
138
+ },
139
+ {
140
+ inventory: { id: inventory.id },
141
+ refOrderId: worksheet.arrivalNotice.id,
142
+ status: INVENTORY_STATUS.CHECKED
143
+ },
144
+ {
145
+ inventory: { id: inventory.id },
146
+ refOrderId: worksheet.arrivalNotice.id,
147
+ status: INVENTORY_STATUS.STORED
148
+ }
149
+ ],
150
+ relations: ['location', 'product'],
151
+ order: { seq: 'DESC' }
152
+ })
153
+
154
+ wsd.targetInventory.inventory = {
155
+ ...inventory,
156
+ qty: foundHistory?.qty || foundHistory?.openingQty || 0,
157
+ uomValue: foundHistory?.uomValue || foundHistory?.openingUomValue || 0,
158
+ location: foundHistory?.location,
159
+ product: foundHistory?.product,
160
+ cartonId: foundHistory?.cartonId,
161
+ batchId: foundHistory?.batchId,
162
+ batchIdRef: foundHistory?.batchIdRef,
163
+ packingType: foundHistory?.packingType,
164
+ packingSize: foundHistory?.packingSize,
165
+ uom: foundHistory?.uom
166
+ }
167
+
168
+ return wsd
169
+ })
170
+ )
171
+ }
172
+ }
173
+
174
+ if (worksheet.type === WORKSHEET_TYPE.BATCH_PICKING) {
175
+ let qbOrderInventories = getRepository(OrderInventory)
176
+ .createQueryBuilder('oi')
177
+ .leftJoinAndSelect('oi.releaseGood', 'releaseGood')
178
+ .leftJoinAndSelect('oi.inventory', 'inventory')
179
+ .leftJoinAndSelect('oi.product', 'product')
180
+ .leftJoinAndSelect('oi.orderProduct', 'orderProduct')
181
+ .leftJoinAndSelect('inventory.location', 'location')
182
+ .leftJoinAndSelect('oi.bizplace', 'bizplace')
183
+ .where('"oi"."domain_id" = :domain')
184
+ .andWhere('"oi"."bizplace_id" = :bizplace')
185
+ .andWhere('"oi"."ref_worksheet_id" = :refWorksheetId')
186
+ .setParameters({
187
+ domain: domain.id,
188
+ bizplace: worksheet.bizplace.id,
189
+ refWorksheetId: worksheet.id
190
+ })
191
+
192
+ let sortingSetting: Setting = await pWorksheetPickingItemSorting
193
+ if (sortingSetting?.value) {
194
+ let settingValue = JSON.parse(sortingSetting.value)
195
+ for (const key in settingValue) {
196
+ qbOrderInventories.addOrderBy(`location.${key}`, settingValue[key] == 'ASC' ? 'ASC' : 'DESC')
197
+ }
198
+ }
199
+
200
+ qbOrderInventories.addOrderBy(`product.name`, 'ASC')
201
+
202
+ let orderInventories: OrderInventory[] = await qbOrderInventories.getMany()
203
+ worksheet.orderInventories = orderInventories
204
+ }
205
+
206
+ if (worksheet?.releaseGood?.id) {
207
+ let qbOrderInventories = getRepository(OrderInventory)
208
+ .createQueryBuilder('oi')
209
+ .leftJoinAndSelect('oi.releaseGood', 'releaseGood')
210
+ .leftJoinAndSelect('oi.inventory', 'inventory')
211
+ .leftJoinAndSelect('oi.product', 'product')
212
+ .leftJoinAndSelect('oi.orderProduct', 'orderProduct')
213
+ .leftJoinAndSelect('inventory.location', 'location')
214
+ .leftJoinAndSelect('oi.bizplace', 'bizplace')
215
+ .where('"oi"."domain_id" = :domain')
216
+ .andWhere('"oi"."bizplace_id" = :bizplace')
217
+ .andWhere('"oi"."release_good_id" = :releaseGood')
218
+ .andWhere('"oi"."status" NOT IN (:...statuses)')
219
+ .setParameters({
220
+ domain: domain.id,
221
+ bizplace: worksheet.bizplace.id,
222
+ releaseGood: worksheet.releaseGood.id,
223
+ statuses: [ORDER_INVENTORY_STATUS.CANCELLED, ORDER_INVENTORY_STATUS.REPLACED]
224
+ })
225
+
226
+ let sortingSetting: Setting = await pWorksheetPickingItemSorting
227
+ if (sortingSetting?.value) {
228
+ let settingValue = JSON.parse(sortingSetting.value)
229
+ for (const key in settingValue) {
230
+ qbOrderInventories.addOrderBy(`location.${key}`, settingValue[key] == 'ASC' ? 'ASC' : 'DESC')
231
+ }
232
+ }
233
+
234
+ qbOrderInventories.addOrderBy(`product.name`, 'ASC')
235
+
236
+ let orderInventories: OrderInventory[] = await qbOrderInventories.getMany()
237
+ worksheet.orderInventories = orderInventories
238
+
239
+ if (worksheet.releaseGood.type == 'b2c') {
240
+ worksheet.marketplaceOrder = await getRepository(MarketplaceOrder).findOne({
241
+ where: { orderNo: worksheet.releaseGood.refNo },
242
+ relations: ['marketplaceOrderItems', 'marketplaceStore']
243
+ })
244
+
245
+ if (worksheet.marketplaceOrder) {
246
+ let marketplaceOrderShipping: MarketplaceOrderShipping
247
+ if (worksheet.marketplaceOrder.isSplitted) {
248
+ marketplaceOrderShipping = await getRepository(MarketplaceOrderShipping).findOne({
249
+ where: { subOrderNoRef: worksheet.releaseGood.refNo2 }
250
+ })
251
+ } else {
252
+ marketplaceOrderShipping = await getRepository(MarketplaceOrderShipping).findOne({
253
+ where: { orderNoRef: worksheet.releaseGood.refNo }
254
+ })
255
+ }
256
+
257
+ worksheet.marketplaceOrder.trackingNo = marketplaceOrderShipping.ownTrackingNo
258
+ ? marketplaceOrderShipping.ownTrackingNo
259
+ : marketplaceOrderShipping.trackingNo
260
+ worksheet.marketplaceOrder.shippingProvider = marketplaceOrderShipping.ownTransporter
261
+ ? marketplaceOrderShipping.ownTransporter
262
+ : marketplaceOrderShipping.transporter
263
+ }
264
+ }
265
+
266
+ worksheet.orderVass = await getRepository(OrderVas).find({
267
+ where: {
268
+ domain: { id: domain.id },
269
+ bizplace: { id: worksheet.bizplace.id },
270
+ releaseGood: { id: worksheet.releaseGood.id }
271
+ },
272
+ relations: ['targetProduct']
273
+ })
274
+ }
275
+
276
+ if (worksheet.orderInventories) {
277
+ worksheet.worksheetDetails.sort(function (a, b) {
278
+ return (
279
+ worksheet.orderInventories.map(oi => oi.id).indexOf(a.targetInventory.id) -
280
+ worksheet.orderInventories.map(oi => oi.id).indexOf(b.targetInventory.id)
281
+ )
282
+ })
283
+ }
284
+
285
+ if (worksheet?.returnOrder?.id) {
286
+ worksheet.orderInventories = await getRepository(OrderInventory).find({
287
+ where: {
288
+ domain: { id: domain.id },
289
+ bizplace: { id: worksheet.bizplace.id },
290
+ returnOrder: { id: worksheet.returnOrder.id },
291
+ status: Not(Equal(ORDER_INVENTORY_STATUS.CANCELLED))
292
+ },
293
+ relations: ['product', 'inventory', 'inventory.location']
294
+ })
295
+
296
+ worksheet.orderVass = await getRepository(OrderVas).find({
297
+ where: {
298
+ domain: { id: domain.id },
299
+ bizplace: { id: worksheet.bizplace.id },
300
+ returnOrder: { id: worksheet.returnOrder.id }
301
+ },
302
+ relations: ['targetProduct']
303
+ })
304
+ }
305
+
306
+ if (worksheet?.inventoryCheck?.id) {
307
+ worksheet.orderInventories = await getRepository(OrderInventory).find({
308
+ where: {
309
+ domain: { id: domain.id },
310
+ bizplace: { id: worksheet.bizplace.id },
311
+ inventoryCheck: { id: worksheet.inventoryCheck.id }
312
+ },
313
+ relations: ['product', 'inventory', 'inventory.location']
314
+ })
315
+ }
316
+
317
+ if (worksheet?.vasOrder?.id) {
318
+ worksheet.orderVass = await getRepository(OrderVas).find({
319
+ where: {
320
+ domain: { id: domain.id },
321
+ bizplace: { id: worksheet.bizplace.id },
322
+ vasOrder: { id: worksheet.vasOrder.id }
323
+ },
324
+ relations: ['targetProduct']
325
+ })
326
+ }
327
+
328
+ return worksheet
329
+ }
330
+ }