@things-factory/worksheet-base 8.0.0-beta.9 → 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,206 @@
1
+ import {
2
+ ORDER_INVENTORY_STATUS,
3
+ ORDER_PRODUCT_STATUS,
4
+ ORDER_TYPES,
5
+ OrderInventory,
6
+ OrderNoGenerator,
7
+ OrderProduct
8
+ } from '@things-factory/sales-base'
9
+ import { Setting } from '@things-factory/setting-base'
10
+ import { getRepository } from '@things-factory/shell'
11
+ import { Inventory } from '@things-factory/warehouse-base'
12
+
13
+ import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../constants'
14
+ import { Worksheet, WorksheetDetail } from '../../../entities'
15
+ import { inventoriesByStrategy, WorksheetNoGenerator } from '../../../utils'
16
+
17
+ export const generateBatchPickingWorksheetDetailsByBulkResolver = {
18
+ async generateBatchPickingWorksheetDetailsByBulk(
19
+ _: any,
20
+ { worksheetId, bizplaceId, selectedItems },
21
+ context: ResolverContext
22
+ ): Promise<Boolean> {
23
+ const { tx, user, domain } = context.state
24
+
25
+ try {
26
+ let worksheet: Worksheet = await tx.getRepository(Worksheet).findOne({
27
+ where: { id: worksheetId },
28
+ relations: [
29
+ 'releaseGood',
30
+ 'worksheetDetails',
31
+ 'worksheetDetails.targetInventory',
32
+ 'worksheetDetails.targetInventory.inventory',
33
+ 'worksheetDetails.targetInventory.product'
34
+ ]
35
+ })
36
+
37
+ // Only proceed if worksheet status IS "DEACTIVATED"
38
+ if (worksheet.status != WORKSHEET_STATUS.DEACTIVATED) {
39
+ return true
40
+ }
41
+
42
+ await getRepository(Worksheet).update(
43
+ { domain: { id: domain.id }, id: worksheetId },
44
+ {
45
+ status: WORKSHEET_STATUS.PROCESSING,
46
+ updater: user,
47
+ updatedAt: new Date()
48
+ }
49
+ )
50
+
51
+ const inventoryAssignmentSetting: Setting = await tx.getRepository(Setting).findOne({
52
+ where: { domain: { id: domain.id }, name: 'rule-for-inventory-assignment' }
53
+ })
54
+
55
+ await Promise.all(
56
+ selectedItems.map(async (oi: OrderInventory & { pickingStrategy: string }) => {
57
+ try {
58
+ let pOrderInventories = tx.getRepository(OrderInventory).find({
59
+ where: {
60
+ refWorksheetId: worksheet.id,
61
+ product: { id: oi.productId },
62
+ batchId: oi.batchId,
63
+ packingType: oi.packingType,
64
+ packingSize: oi.packingSize,
65
+ status: ORDER_INVENTORY_STATUS.PENDING_SPLIT
66
+ },
67
+ relations: ['product', 'releaseGood', 'bizplace', 'orderProduct'],
68
+ order: {
69
+ releaseQty: 'DESC'
70
+ }
71
+ })
72
+
73
+ let pInventoryList = inventoriesByStrategy(
74
+ {
75
+ ...oi,
76
+ worksheetId: worksheet.id,
77
+ bizplaceId,
78
+ locationSortingRules: inventoryAssignmentSetting ? JSON.parse(inventoryAssignmentSetting.value) : false
79
+ } as any,
80
+ domain,
81
+ tx
82
+ )
83
+
84
+ let idx = 0
85
+ let [orderInventories, inventoryList] = await Promise.all([pOrderInventories, pInventoryList])
86
+
87
+ for (let oiIdx = 0; oiIdx < orderInventories.length; oiIdx++) {
88
+ const orderInventory: OrderInventory = orderInventories[oiIdx]
89
+
90
+ let { releaseQty, releaseUomValue } = orderInventory
91
+
92
+ while (releaseQty > 0 && idx < inventoryList.items.length) {
93
+ let targetInventory: Inventory = await tx
94
+ .getRepository(Inventory)
95
+ .findOne({ where: { id: inventoryList.items[idx].id } })
96
+
97
+ let inventoryAvailableQty = targetInventory.qty - (targetInventory?.lockedQty || 0)
98
+ let inventoryAvailableUomValue = targetInventory.uomValue - (targetInventory?.lockedUomValue || 0)
99
+
100
+ if (inventoryAvailableQty > 0) {
101
+ let allocatedQty = 0,
102
+ allocatedUomValue = 0
103
+ if (inventoryAvailableQty < releaseQty) {
104
+ idx = idx + 1
105
+ allocatedQty = inventoryAvailableQty
106
+ allocatedUomValue = inventoryAvailableUomValue
107
+ } else {
108
+ allocatedQty = releaseQty
109
+ allocatedUomValue = releaseUomValue
110
+ }
111
+
112
+ releaseQty = releaseQty - allocatedQty
113
+ releaseUomValue = releaseUomValue - allocatedUomValue
114
+
115
+ //// Update inventory locked quantity
116
+ let qbInv = tx
117
+ .getRepository(Inventory)
118
+ .createQueryBuilder('inv')
119
+ .update(Inventory)
120
+ .set({
121
+ lockedUomValue: () => `COALESCE(locked_uom_value,0) + ${allocatedUomValue}`,
122
+ lockedQty: () => `COALESCE(locked_qty,0) + ${allocatedQty}`
123
+ })
124
+ .where('id = :id', { id: targetInventory.id })
125
+ await qbInv.execute()
126
+
127
+ // update order product status to ASSIGNED
128
+ await tx.getRepository(OrderProduct).update({ id: orderInventory.orderProduct.id }, {
129
+ status: ORDER_PRODUCT_STATUS.ASSIGNED as string,
130
+ updater: user
131
+ } as any)
132
+
133
+ // Create new order inventory with status -> READY_TO_PICK, type -> RELEASE_OF_GOODS
134
+ let newTargetInventory: OrderInventory = new OrderInventory()
135
+ //@ts-ignore
136
+ newTargetInventory = {
137
+ domain: domain,
138
+ bizplace: orderInventory.bizplace,
139
+ name: OrderNoGenerator.orderInventory(),
140
+ releaseGood: orderInventory.releaseGood,
141
+ batchId: orderInventory.batchId,
142
+ status: ORDER_INVENTORY_STATUS.READY_TO_PICK,
143
+ type: ORDER_TYPES.RELEASE_OF_GOODS,
144
+ refWorksheetId: orderInventory.refWorksheetId,
145
+ product: orderInventory.product,
146
+ packingType: orderInventory.packingType,
147
+ //@ts-ignore
148
+ packingSize: parseFloat(orderInventory.packingSize),
149
+ creator: user,
150
+ inventory: targetInventory,
151
+ releaseQty: allocatedQty,
152
+ releaseUomValue: allocatedUomValue,
153
+ uom: orderInventory.uom,
154
+ orderProduct: orderInventory.orderProduct
155
+ }
156
+ newTargetInventory = await tx.getRepository(OrderInventory).save(newTargetInventory)
157
+
158
+ // Generate Worksheet Detail with status -> DEACTIVATED, type -> BATCH_PICKING
159
+ let newWorksheetDetail: WorksheetDetail = new WorksheetDetail()
160
+ newWorksheetDetail = {
161
+ ...newWorksheetDetail,
162
+ domain: domain,
163
+ worksheet: worksheet,
164
+ bizplace: orderInventory.bizplace,
165
+ name: WorksheetNoGenerator.batchPickingDetail(),
166
+ targetInventory: newTargetInventory,
167
+ targetProduct: newTargetInventory.orderProduct,
168
+ type: WORKSHEET_TYPE.BATCH_PICKING,
169
+ status: WORKSHEET_STATUS.DEACTIVATED,
170
+ creator: user
171
+ }
172
+ await tx.getRepository(WorksheetDetail).save(newWorksheetDetail)
173
+ } else {
174
+ idx = idx + 1
175
+ }
176
+ }
177
+
178
+ //Update Current Order Inventory status -> COMPLETE_SPLIT
179
+ await tx.getRepository(OrderInventory).update({ id: orderInventory.id }, {
180
+ status: ORDER_INVENTORY_STATUS.COMPLETE_SPLIT,
181
+ updater: user,
182
+ updatedAt: new Date()
183
+ } as any)
184
+ }
185
+ return { orderInventory: oi, status: 'success', message: null }
186
+ } catch (error) {
187
+ return { orderInventory: oi, status: 'error', message: error }
188
+ }
189
+ })
190
+ )
191
+
192
+ return true
193
+ } catch (error) {
194
+ throw error
195
+ } finally {
196
+ await getRepository(Worksheet).update(
197
+ { domain: { id: domain.id }, id: worksheetId },
198
+ {
199
+ status: WORKSHEET_STATUS.DEACTIVATED,
200
+ updater: user,
201
+ updatedAt: new Date()
202
+ }
203
+ )
204
+ }
205
+ }
206
+ }
@@ -0,0 +1,165 @@
1
+ import { Product } from '@things-factory/product-base'
2
+ import {
3
+ ORDER_INVENTORY_STATUS,
4
+ ORDER_PRODUCT_STATUS,
5
+ OrderInventory,
6
+ OrderNoGenerator,
7
+ OrderProduct
8
+ } from '@things-factory/sales-base'
9
+ import { Inventory } from '@things-factory/warehouse-base'
10
+
11
+ import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../constants'
12
+ import { Worksheet, WorksheetDetail } from '../../../entities'
13
+ import { WorksheetNoGenerator } from '../../../utils'
14
+
15
+ export const generateBatchPickingWorksheetDetailsResolver = {
16
+ async generateBatchPickingWorksheetDetails(
17
+ _: any,
18
+ { worksheetNo, batchId, productId, packingType, worksheetDetails },
19
+ context: ResolverContext
20
+ ): Promise<void> {
21
+ const { tx, user, domain } = context.state
22
+
23
+ // 1. Find Related Worksheet
24
+ const worksheet: Worksheet = await tx.getRepository(Worksheet).findOne({
25
+ where: { name: worksheetNo, domain: { id: domain.id } },
26
+ relations: [
27
+ 'worksheetDetails',
28
+ 'worksheetDetails.targetInventory',
29
+ 'worksheetDetails.targetInventory.inventory',
30
+ 'worksheetDetails.targetInventory.product'
31
+ ]
32
+ })
33
+
34
+ // Only proceed if worksheet status IS "DEACTIVATED"
35
+ if (worksheet.status != WORKSHEET_STATUS.DEACTIVATED) {
36
+ return
37
+ }
38
+
39
+ // 2. Find all existing order inventory that is related to the product
40
+ let prevOrdInvs: OrderInventory[] = await tx.getRepository(OrderInventory).find({
41
+ where: {
42
+ domain: { id: domain.id },
43
+ refWorksheetId: worksheet.id,
44
+ product: { id: productId },
45
+ batchId,
46
+ packingType,
47
+ status: ORDER_INVENTORY_STATUS.PENDING_SPLIT
48
+ },
49
+ relations: ['releaseGood', 'bizplace', 'orderProduct']
50
+ })
51
+
52
+ // Sort all release qty from highest to lowest
53
+ prevOrdInvs = prevOrdInvs.sort(function (a, b) {
54
+ return b.releaseQty - a.releaseQty
55
+ })
56
+
57
+ const selectedOrdInvs: OrderInventory[] = worksheetDetails
58
+ .map((wsd: any) => wsd.targetInventory)
59
+ .sort(function (a, b) {
60
+ return b.releaseQty - a.releaseQty
61
+ })
62
+
63
+ let j = 0
64
+
65
+ for (var i: number = 0; i < prevOrdInvs.length; i++) {
66
+ let prevOrdInv: OrderInventory = prevOrdInvs[i] //PENDING_SPLIT
67
+ let requiredQty: number = prevOrdInv.releaseQty
68
+ let requiredUomValue: number = prevOrdInv.releaseUomValue
69
+
70
+ while (j < selectedOrdInvs.length && requiredQty > 0) {
71
+ let selectedOrdInv: any = selectedOrdInvs[j]
72
+ let remainingQty: number = selectedOrdInv.releaseQty
73
+ let remainingUomValue: number = selectedOrdInv.releaseUomValue
74
+
75
+ if (remainingQty == 0) {
76
+ j = j + 1
77
+ continue
78
+ }
79
+
80
+ // Create new order inventory with new status -> READY_TO_PICK
81
+ let newTargetInventory: OrderInventory = new OrderInventory()
82
+ newTargetInventory.domain = domain
83
+ newTargetInventory.bizplace = prevOrdInv.bizplace
84
+ newTargetInventory.name = OrderNoGenerator.orderInventory()
85
+ newTargetInventory.releaseGood = prevOrdInv.releaseGood
86
+ newTargetInventory.batchId = prevOrdInv.batchId
87
+ newTargetInventory.status = ORDER_INVENTORY_STATUS.READY_TO_PICK
88
+ newTargetInventory.type = selectedOrdInv.type
89
+ newTargetInventory.refWorksheetId = prevOrdInv.refWorksheetId
90
+ newTargetInventory.product = await tx.getRepository(Product).findOne(productId)
91
+ newTargetInventory.packingType = prevOrdInv.packingType
92
+ //@ts-ignore
93
+ newTargetInventory.packingSize = parseFloat(prevOrdInv.packingSize)
94
+ newTargetInventory.creator = user
95
+ newTargetInventory.uom = selectedOrdInv.uom
96
+ newTargetInventory.orderProduct = prevOrdInv.orderProduct
97
+
98
+ let inventory: Inventory = await tx.getRepository(Inventory).findOne(selectedOrdInv.inventory.id)
99
+
100
+ const currentLockedQty: number = inventory.lockedQty
101
+ const currentLockedUomValue: number = inventory.lockedUomValue
102
+
103
+ // Negative means fulfilled, positive mean current inventory is insufficient to fulfil all qty
104
+ const fulfiledQty: number = requiredQty - remainingQty // 2 - 5 || 2 - 2 || 2 - 1
105
+ const fulfiledUomValue: number = Math.round((requiredUomValue - remainingUomValue) * 100) / 100
106
+
107
+ newTargetInventory.inventory = inventory
108
+ newTargetInventory.releaseQty = fulfiledQty <= 0 ? requiredQty : remainingQty
109
+ newTargetInventory.releaseUomValue = fulfiledUomValue <= 0 ? requiredUomValue : remainingUomValue
110
+ newTargetInventory = await tx.getRepository(OrderInventory).save(newTargetInventory)
111
+
112
+ remainingQty = remainingQty - requiredQty
113
+ remainingUomValue = Math.round((remainingUomValue - requiredUomValue) * 100) / 100
114
+
115
+ requiredQty = fulfiledQty <= 0 ? 0 : fulfiledQty
116
+ requiredUomValue = fulfiledUomValue <= 0 ? 0 : fulfiledUomValue
117
+
118
+ await tx.getRepository(Inventory).update({ domain, id: inventory.id }, {
119
+ lockedQty: Boolean(currentLockedQty)
120
+ ? newTargetInventory.releaseQty + currentLockedQty
121
+ : newTargetInventory.releaseQty,
122
+ lockedUomValue: Boolean(currentLockedUomValue)
123
+ ? Math.round((newTargetInventory.releaseUomValue + currentLockedUomValue) * 100) / 100
124
+ : newTargetInventory.releaseUomValue,
125
+ updater: user,
126
+ updatedAt: new Date()
127
+ } as any)
128
+
129
+ // update order product status to ASSIGNED
130
+ await tx
131
+ .getRepository(OrderProduct)
132
+ .update(prevOrdInv.orderProduct, { status: ORDER_PRODUCT_STATUS.ASSIGNED, updater: user } as any)
133
+
134
+ // Generate Worksheet Detail
135
+ let newWorksheetDetail: WorksheetDetail = new WorksheetDetail()
136
+ newWorksheetDetail = {
137
+ ...newWorksheetDetail,
138
+ domain: domain,
139
+ worksheet: worksheet,
140
+ bizplace: prevOrdInv.bizplace,
141
+ name: WorksheetNoGenerator.batchPickingDetail(),
142
+ targetInventory: newTargetInventory,
143
+ targetProduct: prevOrdInv.orderProduct,
144
+ type: WORKSHEET_TYPE.BATCH_PICKING,
145
+ status: WORKSHEET_STATUS.DEACTIVATED,
146
+ creator: user
147
+ }
148
+ await tx.getRepository(WorksheetDetail).save(newWorksheetDetail)
149
+
150
+ selectedOrdInv.releaseQty = remainingQty <= 0 ? 0 : remainingQty
151
+ selectedOrdInv.releaseUomValue = remainingUomValue <= 0 ? 0 : remainingUomValue
152
+
153
+ // insufficient qty for current order inventory, use the next inventory qty
154
+ if (selectedOrdInv.releaseQty == 0) {
155
+ j = j + 1
156
+ }
157
+ }
158
+ await tx.getRepository(OrderInventory).update({ id: prevOrdInvs[i].id }, {
159
+ status: ORDER_INVENTORY_STATUS.COMPLETE_SPLIT,
160
+ updater: user,
161
+ updatedAt: new Date()
162
+ } as any)
163
+ }
164
+ }
165
+ }
@@ -0,0 +1,26 @@
1
+ import { generateId } from '@things-factory/id-rule-base'
2
+
3
+ export const generateCartonIdResolver = {
4
+ async generateCartonId(_: any, { printQty, type }, context: ResolverContext) {
5
+ const { tx, domain } = context.state
6
+ // 1. get and set the date
7
+ const today = new Date()
8
+ const year = today.getFullYear()
9
+ const month = today.getMonth()
10
+ const day = today.getDate()
11
+
12
+ const yy = String(year).substr(String(year).length - 2)
13
+ const mm = String(month + 1).padStart(2, '0')
14
+ const dd = String(day).padStart(2, '0')
15
+
16
+ const date = yy + mm + dd
17
+ let results = []
18
+
19
+ for (let i = 0; i < printQty; i++) {
20
+ const generatedPalletId = await generateId({ domain, type, seed: { date: date } })
21
+ results.push({ cartonId: generatedPalletId })
22
+ }
23
+
24
+ return results
25
+ }
26
+ }
@@ -0,0 +1,94 @@
1
+ import { In } from 'typeorm'
2
+
3
+ import { generateId } from '@things-factory/id-rule-base'
4
+
5
+ import { WorksheetDetail } from '../../../entities'
6
+
7
+ export const generatePalletIdResolver = {
8
+ async generatePalletId(_: any, { targets, type }, context: ResolverContext) {
9
+ const { tx, domain } = context.state
10
+ // 1. get date in yymmdd format
11
+ const date = new Date().toJSON().slice(0, 10).replace(/-/g, '').slice(2, 8)
12
+ let results = []
13
+
14
+ // 2. get worksheet details
15
+ const foundWorksheetDetails: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({
16
+ where: {
17
+ domain: { id: domain.id },
18
+ id: In(targets.map(target => target.id))
19
+ },
20
+ relations: [
21
+ 'domain',
22
+ 'bizplace',
23
+ 'worksheet',
24
+ 'worker',
25
+ 'targetProduct',
26
+ 'targetProduct.arrivalNotice',
27
+ 'targetProduct.arrivalNotice.purchaseOrder',
28
+ 'targetProduct.product',
29
+ 'targetInventory',
30
+ 'targetInventory.product',
31
+ 'targetVas',
32
+ 'targetVas.targetProduct'
33
+ ]
34
+ })
35
+
36
+ // 3. from worksheet detail get product name, product type, batchid, packing type, bizplace
37
+ if (!foundWorksheetDetails?.length) throw new Error('Unable to find worksheet details')
38
+ else {
39
+ for (let i = 0; i < foundWorksheetDetails.length; i++) {
40
+ let foundWSD = foundWorksheetDetails[i]
41
+ for (let idx = 0; idx < targets.length; idx++) {
42
+ if (foundWSD.id === targets[idx].id) {
43
+ // 4. generate pallet id based on print qty > call generateId resolver
44
+ for (let i = 0; i < targets[idx].printQty; i++) {
45
+ let result: any = {}
46
+ // 5. map all data to be returned
47
+ if (foundWSD.targetProduct) {
48
+ result = {
49
+ ...foundWSD.targetProduct,
50
+ bizplace: foundWSD.bizplace,
51
+ orderProductRemark: foundWSD.targetProduct.remark,
52
+ purchaseOrderNo: foundWSD.targetProduct.arrivalNotice?.purchaseOrder?.name || '',
53
+ arrivalNoticeRefNo: foundWSD.targetProduct.arrivalNotice?.refNo || '',
54
+ arrivalNoticeNo: foundWSD.targetProduct.arrivalNotice?.name || ''
55
+ }
56
+ } else if (foundWSD.targetInventory) {
57
+ result = {
58
+ ...foundWSD.targetInventory,
59
+ bizplace: foundWSD.bizplace,
60
+ orderProductRemark: '',
61
+ purchaseOrderNo: '',
62
+ arrivalNoticeRefNo: ''
63
+ }
64
+ } else if (foundWSD.targetVas) {
65
+ result = {
66
+ ...foundWSD.targetVas,
67
+ bizplace: foundWSD.bizplace,
68
+ batchId: foundWSD.targetVas.targetBatchId,
69
+ orderProductRemark: '',
70
+ purchaseOrderNo: '',
71
+ arrivalNoticeRefNo: ''
72
+ }
73
+ }
74
+
75
+ results.push({
76
+ ...result,
77
+ palletId: await generateId({
78
+ domain,
79
+ type,
80
+ seed: {
81
+ batchId: result.batchId || '',
82
+ date
83
+ }
84
+ })
85
+ })
86
+ }
87
+ }
88
+ }
89
+ }
90
+ }
91
+
92
+ return results
93
+ }
94
+ }