@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,37 @@
1
+ import { In, Repository } from 'typeorm'
2
+
3
+ import { ORDER_INVENTORY_STATUS, ORDER_TYPES, OrderInventory } from '@things-factory/sales-base'
4
+ import { getRepository } from '@things-factory/shell'
5
+ import { Inventory } from '@things-factory/warehouse-base'
6
+
7
+ export const checkInventoryReleaseResolver = {
8
+ async checkInventoryRelease(_: any, { palletId }, context: ResolverContext) {
9
+ const { domain } = context.state
10
+ const invRepo: Repository<Inventory> = getRepository(Inventory)
11
+ const oiRepo: Repository<OrderInventory> = getRepository(OrderInventory)
12
+
13
+ const inventory: Inventory = await invRepo.findOne({
14
+ where: { domain: { id: domain.id }, palletId },
15
+ relations: ['bizplace']
16
+ })
17
+
18
+ const oiStatuses: string[] = [
19
+ ORDER_INVENTORY_STATUS.PENDING,
20
+ ORDER_INVENTORY_STATUS.PENDING_RECEIVE,
21
+ ORDER_INVENTORY_STATUS.READY_TO_PICK,
22
+ ORDER_INVENTORY_STATUS.PICKING,
23
+ ORDER_INVENTORY_STATUS.PENDING_CANCEL
24
+ ]
25
+
26
+ const orderInventories: OrderInventory[] = await oiRepo.find({
27
+ where: {
28
+ domain: { id: domain.id },
29
+ inventory: { id: inventory.id },
30
+ type: ORDER_TYPES.RELEASE_OF_GOODS,
31
+ status: In(oiStatuses)
32
+ }
33
+ })
34
+
35
+ return Boolean(orderInventories?.length > 0)
36
+ }
37
+ }
@@ -0,0 +1,63 @@
1
+ import { Repository } from 'typeorm'
2
+
3
+ import { InventoryCheck, OrderInventory } from '@things-factory/sales-base'
4
+ import { getRepository } from '@things-factory/shell'
5
+ import { Inventory } from '@things-factory/warehouse-base'
6
+
7
+ import { WorksheetDetail } from '../../../entities'
8
+
9
+ export const checkStockTakeCurrentLocationResolver = {
10
+ async checkStockTakeCurrentLocation(_: any, { palletId, cycleCountNo }, context: ResolverContext) {
11
+ const { domain } = context.state
12
+ const invRepo: Repository<Inventory> = getRepository(Inventory)
13
+ const worksheetDetailRepo: Repository<WorksheetDetail> = getRepository(WorksheetDetail)
14
+ const inventoryCheckRepo: Repository<InventoryCheck> = getRepository(InventoryCheck)
15
+
16
+ const inventory: Inventory = await invRepo.findOne({
17
+ where: { domain: { id: domain.id }, palletId },
18
+ relations: ['bizplace']
19
+ })
20
+
21
+ const cycleCount: InventoryCheck = await inventoryCheckRepo.findOne({
22
+ where: { domain: { id: domain.id }, name: cycleCountNo },
23
+ relations: [
24
+ 'orderInventories',
25
+ 'orderInventories.inventory',
26
+ 'orderInventories.inventory.location',
27
+ 'orderInventories.inventory.product'
28
+ ]
29
+ })
30
+
31
+ const orderInventories: OrderInventory[] = cycleCount.orderInventories
32
+
33
+ const foundInventory: Inventory = orderInventories.find(
34
+ (oi: OrderInventory) => oi.inventory.palletId === inventory.palletId
35
+ ).inventory
36
+
37
+ const foundWSD: any[] = await Promise.all(
38
+ orderInventories
39
+ .filter((oi: OrderInventory) => oi.inventory.palletId === inventory.palletId)
40
+ .map(async (oi: OrderInventory) => {
41
+ const matchingWSD = await worksheetDetailRepo.findOne({
42
+ where: { domain: { id: domain.id }, targetInventory: { id: oi.id } }
43
+ })
44
+
45
+ return matchingWSD
46
+ })
47
+ )
48
+
49
+ if (!foundInventory) throw new Error(`${inventory.palletId} is not in cycle count worksheet`)
50
+
51
+ return {
52
+ worksheetDetailName: foundWSD[0].name,
53
+ currentLocation: foundInventory.location.name,
54
+ palletId: foundInventory.palletId,
55
+ batchId: foundInventory.batchId,
56
+ qty: foundInventory.qty,
57
+ uomValue: foundInventory.uomValue,
58
+ uom: foundInventory.uom,
59
+ productName: foundInventory.product.name,
60
+ productDescription: foundInventory.product.description
61
+ }
62
+ }
63
+ }
@@ -0,0 +1,213 @@
1
+ import { In } from 'typeorm'
2
+
3
+ import {
4
+ DeliveryOrder,
5
+ ORDER_INVENTORY_STATUS,
6
+ ORDER_STATUS,
7
+ ORDER_VAS_STATUS,
8
+ OrderInventory,
9
+ OrderVas,
10
+ ReleaseGood
11
+ } from '@things-factory/sales-base'
12
+ import { Inventory, INVENTORY_STATUS, INVENTORY_TRANSACTION_TYPE, Location } from '@things-factory/warehouse-base'
13
+
14
+ import { Worksheet, WorksheetDetail } from '../../../entities'
15
+ import { generateInventoryHistory } from '../../../utils'
16
+
17
+ export const confirmCancellationReleaseOrder = {
18
+ async confirmCancellationReleaseOrder(_: any, { name }, context: ResolverContext) {
19
+ const { tx, domain, user } = context.state
20
+ let releaseGood: ReleaseGood = await tx.getRepository(ReleaseGood).findOne({
21
+ where: { domain: { id: domain.id }, name, status: ORDER_STATUS.PENDING_CANCEL },
22
+ relations: [
23
+ 'bizplace',
24
+ 'orderInventories',
25
+ 'orderInventories.inventory',
26
+ 'orderInventories.inventory.location',
27
+ 'orderVass'
28
+ ]
29
+ })
30
+
31
+ if (!releaseGood) throw new Error(`Release good order doesn't exists.`)
32
+ let targetOIs: OrderInventory[] = releaseGood.orderInventories
33
+ let foundOVs: OrderVas[] = releaseGood.orderVass
34
+
35
+ // 1. Check Order Inventory status
36
+ // 1a. separate into three groups, group 1: pending cancel, group 2: picked, group 3: replaced
37
+ let cancelOIs: OrderInventory[] = _filterOrderInventoriesByStatus(targetOIs, ORDER_INVENTORY_STATUS.PENDING_CANCEL)
38
+ let pickedOIs: OrderInventory[] = _filterOrderInventoriesByStatus(targetOIs, ORDER_INVENTORY_STATUS.PENDING_REVERSE)
39
+ let replacedOIs: OrderInventory[] = _filterOrderInventoriesByStatus(targetOIs, ORDER_INVENTORY_STATUS.REPLACED)
40
+
41
+ if (pickedOIs && pickedOIs.length) {
42
+ await Promise.all(
43
+ pickedOIs.map(async (orderInventory: OrderInventory) => {
44
+ let inventory: Inventory = orderInventory.inventory
45
+ let location: Location = inventory?.location
46
+
47
+ if (inventory && inventory.id) {
48
+ await tx
49
+ .createQueryBuilder()
50
+ .update(Inventory)
51
+ .set({
52
+ qty: () => `COALESCE("qty", 0) + ${orderInventory.releaseQty}`,
53
+ uomValue: () => `COALESCE("uom_value", 0) + ${orderInventory.releaseUomValue}`,
54
+ status: INVENTORY_STATUS.STORED,
55
+ updater: user
56
+ } as any)
57
+ .where('id = :id', { id: inventory.id })
58
+ .execute()
59
+
60
+ await generateInventoryHistory(
61
+ inventory,
62
+ releaseGood,
63
+ INVENTORY_TRANSACTION_TYPE.CANCEL_ORDER,
64
+ orderInventory.releaseQty,
65
+ orderInventory.releaseUomValue,
66
+ user,
67
+ tx
68
+ )
69
+ }
70
+
71
+ return orderInventory
72
+ })
73
+ )
74
+
75
+ await tx
76
+ .getRepository(OrderInventory)
77
+ //@ts-ignore
78
+ .update(pickedOIs, { status: ORDER_INVENTORY_STATUS.CANCELLED, updater: user } as any)
79
+ }
80
+
81
+ // change status to cancelled for order inventory that has not executed yet and remove locked qty
82
+ if (cancelOIs && cancelOIs.length) {
83
+ await Promise.all(
84
+ cancelOIs.map(async (orderInventory: OrderInventory) => {
85
+ let inventory: Inventory = orderInventory.inventory
86
+
87
+ if (inventory && inventory.id) {
88
+ await tx
89
+ .createQueryBuilder()
90
+ .update(Inventory)
91
+ .set({
92
+ lockedQty: () => `COALESCE("locked_qty", 0) - ${orderInventory.releaseQty}`,
93
+ lockedUomValue: () => `COALESCE("locked_uom_value", 0) - ${orderInventory.releaseUomValue}`,
94
+ updater: user
95
+ } as any)
96
+ .where('id = :id', { id: inventory.id })
97
+ .execute()
98
+
99
+ // @ChrisLim-git commented for further review as it causes qty to add into inventory
100
+ // await tx
101
+ // .createQueryBuilder()
102
+ // .update(Inventory)
103
+ // .set({
104
+ // qty: () => `COALESCE("qty", 0) + ${orderInventory.releaseQty}`,
105
+ // uomValue: () => `COALESCE("uom_value", 0) + ${orderInventory.releaseUomValue}`,
106
+ // status: INVENTORY_STATUS.STORED,
107
+ // updater: user
108
+ // })
109
+ // .where('id = :id', { id: inventory.id })
110
+ // .execute()
111
+ }
112
+
113
+ return orderInventory
114
+ })
115
+ )
116
+
117
+ await tx
118
+ .getRepository(OrderInventory)
119
+ //@ts-ignore
120
+ .update(cancelOIs, { status: ORDER_INVENTORY_STATUS.CANCELLED, updater: user } as any)
121
+ }
122
+
123
+ if (replacedOIs && replacedOIs.length) {
124
+ await tx
125
+ .getRepository(OrderInventory)
126
+ //@ts-ignore
127
+ .update(replacedOIs, { status: ORDER_INVENTORY_STATUS.CANCELLED, updater: user } as any)
128
+ }
129
+
130
+ if (foundOVs && foundOVs?.length) {
131
+ // update status of order vass to CANCELLED
132
+ foundOVs = foundOVs.map((orderVas: OrderVas) => {
133
+ return {
134
+ ...orderVas,
135
+ status: ORDER_VAS_STATUS.CANCELLED,
136
+ updater: user
137
+ }
138
+ })
139
+ await tx.getRepository(OrderVas).save(foundOVs)
140
+ }
141
+
142
+ // find worksheet and update status to CANCELLED
143
+ let foundWS: Worksheet[] = await tx
144
+ .getRepository(Worksheet)
145
+ .find({ where: { domain: { id: domain.id }, releaseGood: { id: releaseGood.id } } })
146
+
147
+ foundWS = foundWS.map((ws: Worksheet) => {
148
+ return {
149
+ ...ws,
150
+ status: ORDER_STATUS.CANCELLED,
151
+ updater: user
152
+ }
153
+ })
154
+ await tx.getRepository(Worksheet).save(foundWS)
155
+
156
+ // find worksheet detail and update status to CANCELLED
157
+ let foundWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({
158
+ where: {
159
+ domain: { id: domain.id },
160
+ targetInventory: { id: In(targetOIs.map((oi: OrderInventory) => oi.id)) }
161
+ }
162
+ })
163
+
164
+ if (foundWSD && foundWSD?.length) {
165
+ foundWSD = foundWSD.map((wsd: WorksheetDetail) => {
166
+ return {
167
+ ...wsd,
168
+ status: ORDER_STATUS.CANCELLED,
169
+ updater: user
170
+ }
171
+ })
172
+ await tx.getRepository(WorksheetDetail).save(foundWSD)
173
+ }
174
+
175
+ // find DO and change status to pending cancel
176
+ let foundDO: DeliveryOrder[] = await tx.getRepository(DeliveryOrder).find({
177
+ where: { domain: { id: domain.id }, releaseGood: { id: releaseGood.id }, status: ORDER_STATUS.PENDING_CANCEL },
178
+ relations: ['transportVehicle']
179
+ })
180
+
181
+ if (foundDO && foundDO?.length) {
182
+ foundDO = foundDO.map((deliveryOrder: DeliveryOrder) => {
183
+ return {
184
+ ...deliveryOrder,
185
+ status: ORDER_STATUS.CANCELLED,
186
+ updater: user
187
+ }
188
+ })
189
+ await tx.getRepository(DeliveryOrder).save(foundDO)
190
+ }
191
+
192
+ releaseGood.status = ORDER_STATUS.CANCELLED
193
+ releaseGood.updater = user
194
+ await tx.getRepository(ReleaseGood).save(releaseGood)
195
+
196
+ return
197
+ }
198
+ }
199
+
200
+ function _filterOrderInventoriesByStatus(orderInventories: OrderInventory[], status: string): OrderInventory[] {
201
+ return orderInventories
202
+ .filter((oi: OrderInventory) => oi.status === status)
203
+ .reduce((acc, oi) => {
204
+ let existingInvIdx = !oi.inventory ? -1 : acc.findIndex(i => i.inventory?.id == oi.inventory?.id)
205
+ if (existingInvIdx >= 0) {
206
+ acc[existingInvIdx].releaseQty += oi.releaseQty
207
+ acc[existingInvIdx].releaseUomValue += oi.releaseQty
208
+ } else {
209
+ acc.push(oi)
210
+ }
211
+ return acc
212
+ }, [])
213
+ }
@@ -0,0 +1,21 @@
1
+ import { EntityManager } from 'typeorm'
2
+
3
+ import { User } from '@things-factory/auth-base'
4
+ import { Bizplace } from '@things-factory/biz-base'
5
+ import { Domain } from '@things-factory/shell'
6
+
7
+ import { Worksheet } from '../../../entities'
8
+
9
+ export const createWorksheet = {
10
+ async createWorksheet(_: any, { worksheet }, context: ResolverContext) {
11
+ const { tx, domain, bizplace, user } = context.state
12
+
13
+ return await tx.getRepository(Worksheet).save({
14
+ ...worksheet,
15
+ domain: domain,
16
+ bizplace: bizplace[0],
17
+ creator: user,
18
+ updater: user
19
+ })
20
+ }
21
+ }
@@ -0,0 +1,173 @@
1
+ import { EntityManager, In, SelectQueryBuilder } from 'typeorm'
2
+
3
+ import { Bizplace } from '@things-factory/biz-base'
4
+ import { OrderInventory, OrderNoGenerator, ReleaseGood } from '@things-factory/sales-base'
5
+ import { Inventory, INVENTORY_STATUS } from '@things-factory/warehouse-base'
6
+
7
+ import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../constants'
8
+ import { WorksheetController } from '../../../controllers/worksheet-controller'
9
+ import { Worksheet, WorksheetDetail } from '../../../entities'
10
+ import { picking } from './picking/picking'
11
+
12
+ export const crossDockPickingResolver = {
13
+ async crossDockPicking(
14
+ _: any,
15
+ {
16
+ worksheetDetailName,
17
+ worksheetType,
18
+ palletId,
19
+ releaseQty
20
+ }: { worksheetDetailName: string; worksheetType: string; palletId: string; releaseQty: number },
21
+ context: any
22
+ ): Promise<void> {
23
+ const { tx, domain, user } = context.state
24
+ const wsd: WorksheetDetail = await tx.getRepository(WorksheetDetail).findOne({
25
+ where: { domain: { id: domain.id }, name: worksheetDetailName },
26
+ relations: [
27
+ 'targetInventory',
28
+ 'targetInventory.domain',
29
+ 'targetInventory.bizplace',
30
+ 'targetInventory.releaseGood',
31
+ 'targetInventory.product',
32
+ 'worksheet',
33
+ 'worksheet.releaseGood',
34
+ 'worksheet.releaseGood.arrivalNotice'
35
+ ]
36
+ })
37
+
38
+ if (!wsd) throw new Error(`Failed to find picking worksheet detail by passed worksheet detail name`)
39
+ const worksheet: Worksheet = wsd.worksheet
40
+ const releaseGood: ReleaseGood = worksheet.releaseGood
41
+
42
+ let targetInv: OrderInventory = wsd.targetInventory
43
+ const bizplace: Bizplace = targetInv.bizplace
44
+ let inventory: Inventory = await tx.getRepository(Inventory).findOne({
45
+ where: {
46
+ domain: { id: domain.id },
47
+ bizplace: { id: bizplace.id },
48
+ palletId,
49
+ status: In([INVENTORY_STATUS.STORED, INVENTORY_STATUS.PARTIALLY_UNLOADED, INVENTORY_STATUS.UNLOADED])
50
+ },
51
+ relations: ['product', 'location']
52
+ })
53
+
54
+ if (!inventory) throw new Error(`Failed to find inventory by passed pallet ID (${palletId})`)
55
+ const hasSameCondition: boolean =
56
+ inventory.batchId === targetInv.batchId &&
57
+ inventory.product.id === targetInv.product.id &&
58
+ inventory.packingType === targetInv.packingType
59
+ if (!hasSameCondition) throw new Error(`Pallet (${palletId}) doesn't have same condition compared with order has`)
60
+ if (inventory.qty < releaseQty) throw new Error(`Release qty is bigger than what pallet has`)
61
+ if (targetInv.releaseQty < releaseQty) throw new Error(`Release qty is bigger than required qty`)
62
+
63
+ const unitUomValue: number = inventory.uomValue / inventory.qty
64
+ const releaseUomValue: number = releaseQty * unitUomValue
65
+ const remainQty: number = targetInv.releaseQty - releaseQty
66
+ const remainUomValue: number = targetInv.releaseUomValue - releaseUomValue
67
+
68
+ const originWSD: WorksheetDetail = await fetchOriginalWSD(
69
+ tx,
70
+ domain.id,
71
+ releaseGood.id,
72
+ targetInv.batchId,
73
+ targetInv.packingType,
74
+ targetInv.product.id,
75
+ inventory.id
76
+ )
77
+
78
+ if (!originWSD) {
79
+ // Update target inventory information
80
+ // 1. update release amount
81
+ // 2. assign inventory
82
+ targetInv.releaseQty = releaseQty
83
+ targetInv.releaseUomValue = releaseUomValue
84
+
85
+ targetInv.inventory = inventory
86
+ targetInv = await tx.getRepository(OrderInventory).save(targetInv)
87
+
88
+ if (remainQty > 0 || remainUomValue > 0) {
89
+ // Need to create order inventory and worksheet detail without inventory assignment
90
+ let targetInventory: OrderInventory = tx.getRepository(OrderInventory).create(targetInv)
91
+ //@ts-ignore
92
+ delete targetInventory.id
93
+ targetInventory.name = OrderNoGenerator.orderInventory()
94
+ targetInventory.releaseQty = remainQty
95
+ targetInventory.releaseUomValue = remainUomValue
96
+ targetInventory.inventory = null
97
+ targetInventory.creator = user
98
+ targetInventory.updater = user
99
+ targetInventory = await tx.getRepository(OrderInventory).save(targetInventory)
100
+
101
+ const worksheetController: WorksheetController = new WorksheetController(tx, domain, user)
102
+ await worksheetController.createWorksheetDetails(worksheet, WORKSHEET_TYPE.PICKING, [targetInventory], {
103
+ status: WORKSHEET_STATUS.EXECUTING
104
+ })
105
+ }
106
+ } else {
107
+ let { targetInventory: originOrdInv } = await tx.getRepository(WorksheetDetail).findOne({
108
+ where: { id: originWSD.id },
109
+ relations: ['targetInventory']
110
+ })
111
+ originOrdInv.releaseQty += releaseQty
112
+ originOrdInv.releaseUomValue += releaseUomValue
113
+ originOrdInv.updater = user
114
+ await tx.getRepository(OrderInventory).save(originOrdInv)
115
+
116
+ targetInv.releaseQty -= releaseQty
117
+ targetInv.releaseUomValue -= releaseUomValue
118
+ targetInv.updater = user
119
+
120
+ if (targetInv.releaseQty === 0 || targetInv.releaseUomValue === 0) {
121
+ // Delete worksheet detail
122
+ await tx.getRepository(WorksheetDetail).delete(wsd.id)
123
+ // Delete order inventory
124
+ await tx.getRepository(OrderInventory).delete(targetInv.id)
125
+ } else {
126
+ await tx.getRepository(OrderInventory).save(targetInv)
127
+ }
128
+ }
129
+
130
+ await picking(
131
+ tx,
132
+ domain,
133
+ user,
134
+ worksheetDetailName,
135
+ worksheetType,
136
+ inventory.palletId,
137
+ inventory.location.name,
138
+ releaseQty
139
+ )
140
+ }
141
+ }
142
+
143
+ export async function fetchOriginalWSD(
144
+ tx: EntityManager,
145
+ domainId: string,
146
+ releaseGoodId: string,
147
+ batchId: string,
148
+ packingType: string,
149
+ productId: string,
150
+ inventoryId: string
151
+ ): Promise<WorksheetDetail> {
152
+ let qb: SelectQueryBuilder<WorksheetDetail> = tx.createQueryBuilder(WorksheetDetail, 'wsd')
153
+ return qb
154
+ .leftJoin(OrderInventory, 'oi', 'wsd.target_inventory_id = oi.id')
155
+ .leftJoin(Inventory, 'inv', 'oi.inventory_id = inv.id')
156
+ .andWhere('wsd.domain_id = :domainId')
157
+ .andWhere('wsd.status = :status')
158
+ .andWhere('oi.release_good_id = :releaseGoodId')
159
+ .andWhere('oi.batch_id = :batchId')
160
+ .andWhere('oi.packing_type = :packingType')
161
+ .andWhere('oi.product_id = :productId')
162
+ .andWhere('inv.id = :inventoryId')
163
+ .setParameters({
164
+ domainId,
165
+ status: WORKSHEET_STATUS.DONE,
166
+ releaseGoodId,
167
+ batchId,
168
+ packingType,
169
+ productId,
170
+ inventoryId
171
+ })
172
+ .getOne()
173
+ }