@things-factory/worksheet-base 5.0.12 → 6.0.0-alpha.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.
- package/dist-server/controllers/ecommerce/sellercraft-controller.js +225 -191
- package/dist-server/controllers/ecommerce/sellercraft-controller.js.map +1 -1
- package/dist-server/controllers/inbound/unloading-returning-worksheet-controller.js +2 -2
- package/dist-server/controllers/inbound/unloading-returning-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/inbound/unloading-worksheet-controller.js +28 -17
- package/dist-server/controllers/inbound/unloading-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/inspect/cycle-count-worksheet-controller.js +1 -1
- package/dist-server/controllers/inspect/cycle-count-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/packing-worksheet-controller.js +17 -3
- package/dist-server/controllers/outbound/packing-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/picking-worksheet-controller.js +221 -144
- package/dist-server/controllers/outbound/picking-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/returning-worksheet-controller.js +16 -0
- package/dist-server/controllers/outbound/returning-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js +8 -8
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/render-elccl-grn.js +21 -16
- package/dist-server/controllers/render-elccl-grn.js.map +1 -1
- package/dist-server/controllers/render-fm-grn.js +43 -26
- package/dist-server/controllers/render-fm-grn.js.map +1 -1
- package/dist-server/controllers/render-grn.js +42 -28
- package/dist-server/controllers/render-grn.js.map +1 -1
- package/dist-server/controllers/render-invoices.js +4 -5
- package/dist-server/controllers/render-invoices.js.map +1 -1
- package/dist-server/controllers/render-job-sheet.js +19 -19
- package/dist-server/controllers/render-job-sheet.js.map +1 -1
- package/dist-server/controllers/render-kimeda-grn.js +38 -23
- package/dist-server/controllers/render-kimeda-grn.js.map +1 -1
- package/dist-server/controllers/render-manifest.js +8 -9
- package/dist-server/controllers/render-manifest.js.map +1 -1
- package/dist-server/controllers/render-manual-do.js +15 -15
- package/dist-server/controllers/render-manual-do.js.map +1 -1
- package/dist-server/controllers/render-orientage-do.js +74 -28
- package/dist-server/controllers/render-orientage-do.js.map +1 -1
- package/dist-server/controllers/render-orientage-grn.js +25 -15
- package/dist-server/controllers/render-orientage-grn.js.map +1 -1
- package/dist-server/controllers/render-po.js +28 -19
- package/dist-server/controllers/render-po.js.map +1 -1
- package/dist-server/controllers/render-ro-do.js +139 -105
- package/dist-server/controllers/render-ro-do.js.map +1 -1
- package/dist-server/controllers/render-seebuu-grn.js +29 -19
- package/dist-server/controllers/render-seebuu-grn.js.map +1 -1
- package/dist-server/controllers/vas/vas-worksheet-controller.js +5 -5
- package/dist-server/controllers/vas/vas-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/worksheet-controller.js +75 -25
- package/dist-server/controllers/worksheet-controller.js.map +1 -1
- package/dist-server/entities/warehouse-bizplace-onhand-inventory.js +2 -1
- package/dist-server/entities/warehouse-bizplace-onhand-inventory.js.map +1 -1
- package/dist-server/entities/worksheet-detail.js +14 -12
- package/dist-server/entities/worksheet-detail.js.map +1 -1
- package/dist-server/entities/worksheet-movement.js +1 -2
- package/dist-server/entities/worksheet-movement.js.map +1 -1
- package/dist-server/entities/worksheet.js +13 -13
- package/dist-server/entities/worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/pallet/pallet-outbound.js +1 -1
- package/dist-server/graphql/resolvers/pallet/pallet-outbound.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/batch-picking-worksheet.js +6 -6
- package/dist-server/graphql/resolvers/worksheet/batch-picking-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cancel-draft-release-order.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/cancel-draft-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/check-inventory-release.js +6 -5
- package/dist-server/graphql/resolvers/worksheet/check-inventory-release.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/check-stock-take-current-location.js +8 -8
- package/dist-server/graphql/resolvers/worksheet/check-stock-take-current-location.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js +82 -80
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/create-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cross-dock-picking.js +5 -4
- package/dist-server/graphql/resolvers/worksheet/cross-dock-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cycle-count-adjustment.js +5 -5
- package/dist-server/graphql/resolvers/worksheet/cycle-count-adjustment.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cycle-count-worksheet.js +5 -4
- package/dist-server/graphql/resolvers/worksheet/cycle-count-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/delete-worksheet.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/delete-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/delivery-order-by-worksheet.js +83 -52
- package/dist-server/graphql/resolvers/worksheet/delivery-order-by-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/fetch-delivery-order-ro.js +169 -0
- package/dist-server/graphql/resolvers/worksheet/fetch-delivery-order-ro.js.map +1 -0
- package/dist-server/graphql/resolvers/worksheet/fetch-sellercraft-document.js +67 -0
- package/dist-server/graphql/resolvers/worksheet/fetch-sellercraft-document.js.map +1 -0
- package/dist-server/graphql/resolvers/worksheet/find-release-orders-by-task-no.js +1 -34
- package/dist-server/graphql/resolvers/worksheet/find-release-orders-by-task-no.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/find-release-orders-by-worksheet-no.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js +70 -0
- package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js.map +1 -0
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-arrival-notice-worksheet.js +34 -3
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-arrival-notice-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-batch-picking-worksheet.js +4 -4
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-batch-picking-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-cycle-count-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-multiple-release-good-worksheet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-multiple-release-good-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-return-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-putaway-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-release-good-worksheet.js +14 -10
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-release-good-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-return-order-worksheet.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-return-order-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-vas-order-worksheet.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/generate-worksheet/generate-vas-order-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/having-vas.js +7 -7
- package/dist-server/graphql/resolvers/worksheet/having-vas.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/index.js +5 -3
- package/dist-server/graphql/resolvers/worksheet/index.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/activate-cycle-count.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/add-extra-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/check-missing-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/complete-inspection.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/inspecting.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/relocate-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inspecting/undo-inspection.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js +18 -9
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loaded-inventories.js +6 -5
- package/dist-server/graphql/resolvers/worksheet/loaded-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/activate-loading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/complete-loading.js +14 -14
- package/dist-server/graphql/resolvers/worksheet/loading/complete-loading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/loading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/undo-loading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading-worksheet.js +11 -10
- package/dist-server/graphql/resolvers/worksheet/loading-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/not-tally-target-inventories.js +5 -4
- package/dist-server/graphql/resolvers/worksheet/not-tally-target-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/activate-packing.js +3 -4
- package/dist-server/graphql/resolvers/worksheet/packing/activate-packing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/complete-packing.js +2 -2
- package/dist-server/graphql/resolvers/worksheet/packing/complete-packing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/packing.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/packing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/scan-product-packing.js +16 -11
- package/dist-server/graphql/resolvers/worksheet/packing/scan-product-packing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing/undo-serial-number-packing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing-worksheet.js +96 -22
- package/dist-server/graphql/resolvers/worksheet/packing-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/palletizing-pallets.js +5 -5
- package/dist-server/graphql/resolvers/worksheet/palletizing-pallets.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/pending-cancellation-release-order.js +93 -81
- package/dist-server/graphql/resolvers/worksheet/pending-cancellation-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/activate-batch-picking.js +0 -19
- package/dist-server/graphql/resolvers/worksheet/picking/activate-batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/activate-picking.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/activate-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/assign-picking-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/assign-picking-worker.js +11 -5
- package/dist-server/graphql/resolvers/worksheet/picking/assign-picking-worker.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js +10 -4
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js +34 -38
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/fetch-and-assign-picking-task.js +46 -35
- package/dist-server/graphql/resolvers/worksheet/picking/fetch-and-assign-picking-task.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/my-picking-assignment-status.js +7 -2
- package/dist-server/graphql/resolvers/worksheet/picking/my-picking-assignment-status.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/picking-assignment-status-by-user.js +33 -16
- package/dist-server/graphql/resolvers/worksheet/picking/picking-assignment-status-by-user.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/scan-product-batch-picking.js +4 -4
- package/dist-server/graphql/resolvers/worksheet/picking/scan-product-batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/scan-product-picking.js +5 -8
- package/dist-server/graphql/resolvers/worksheet/picking/scan-product-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/seal-tote.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/undo-picking-assignment.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/undo-serial-number-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking-worksheet.js +6 -5
- package/dist-server/graphql/resolvers/worksheet/picking-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/proceed-extra-products.js +10 -8
- package/dist-server/graphql/resolvers/worksheet/proceed-extra-products.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway/activate-putaway.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway/complete-putaway.js +4 -3
- package/dist-server/graphql/resolvers/worksheet/putaway/complete-putaway.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway/putaway.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway/undo-putaway.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-return/activate-putaway-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-return/complete-putaway-return.js +2 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-return/complete-putaway-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-return/putaway-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-return/undo-putaway-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-returning-worksheet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/putaway-returning-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/putaway-worksheet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/putaway-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/recommend-putway-location.js +16 -11
- package/dist-server/graphql/resolvers/worksheet/recommend-putway-location.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/reject-cancellation-release-order.js +139 -149
- package/dist-server/graphql/resolvers/worksheet/reject-cancellation-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/relocate-pallet.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/relocate-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/replace-picking-pallets.js +2 -2
- package/dist-server/graphql/resolvers/worksheet/replace-picking-pallets.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/return-worksheet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/return-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/returning/activate-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/returning/complete-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/returning/returning.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting/activate-sorting.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting/complete-order-sorting.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting/complete-worksheet-sorting.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting/scan-product-sorting.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting/sorting-product.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/sorting-worksheet.js +4 -4
- package/dist-server/graphql/resolvers/worksheet/sorting-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/transfer.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories-by-reusable-pallet.js +8 -7
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories-by-reusable-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories.js +9 -8
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/activate-unloading.js +4 -2
- package/dist-server/graphql/resolvers/worksheet/unloading/activate-unloading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/complete-product-scan-unload.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/complete-unloading-partially.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/complete-unloading.js +6 -2
- package/dist-server/graphql/resolvers/worksheet/unloading/complete-unloading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/scan-product-unload.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/scan-serial-number-unload.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/undo-serial-number-unload.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/undo-unloading.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading/unload.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading-return/activate-unloading-return.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading-return/complete-unload-return-partially.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading-return/complete-unload-returning.js +7 -3
- package/dist-server/graphql/resolvers/worksheet/unloading-return/complete-unload-returning.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading-return-worksheet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/unloading-return-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloading-worksheet.js +5 -5
- package/dist-server/graphql/resolvers/worksheet/unloading-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/update-worksheet.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/update-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/activate-vas.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/assign-vas-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/complete-vas.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/execute-vas.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/undo-vas-inventory.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas/undo-vas.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-candidates.js +13 -12
- package/dist-server/graphql/resolvers/worksheet/vas-candidates.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-inventories.js +7 -6
- package/dist-server/graphql/resolvers/worksheet/vas-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/common-utils.js +36 -18
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/common-utils.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/check-relabelable.js +10 -3
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/check-relabelable.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/complete-relabeling.js +3 -2
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/complete-relabeling.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/relabeling.js +11 -3
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/relabeling.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/relabeling/undo-relabeling.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/complete-repackaging.js +3 -2
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/complete-repackaging.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/repackaging.js +2 -2
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/repackaging.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/undo-repackaging.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repackaging/undo-repackaging.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repalletizing/complete-repalletizing.js +2 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repalletizing/complete-repalletizing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repalletizing/repalletizing.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repalletizing/repalletizing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/repalletizing/undo-repalletizing.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/unpacking/complete-unpacking.js +2 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/unpacking/complete-unpacking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/unpacking/unpacking.js +7 -7
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/unpacking/unpacking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-worksheet.js +11 -10
- package/dist-server/graphql/resolvers/worksheet/vas-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/worksheet-by-order-no.js +7 -4
- package/dist-server/graphql/resolvers/worksheet/worksheet-by-order-no.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/worksheet-with-pagination.js +5 -5
- package/dist-server/graphql/resolvers/worksheet/worksheet-with-pagination.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/worksheet.js +72 -42
- package/dist-server/graphql/resolvers/worksheet/worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/worksheets.js +42 -17
- package/dist-server/graphql/resolvers/worksheet/worksheets.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/check-progressing-pallet.js +3 -3
- package/dist-server/graphql/resolvers/worksheet-detail/check-progressing-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/create-worksheet-detail.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/create-worksheet-detail.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/delete-worksheet-detail.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/delete-worksheet-detail.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details-by-bulk.js +13 -10
- package/dist-server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details-by-bulk.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details.js +7 -5
- package/dist-server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-carton-id.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-pallet-id.js +3 -3
- package/dist-server/graphql/resolvers/worksheet-detail/generate-pallet-id.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-picking-worksheet-details.js +5 -2
- package/dist-server/graphql/resolvers/worksheet-detail/generate-picking-worksheet-details.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-release-good-worksheet-details.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/generate-release-good-worksheet-details.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/index.js +2 -1
- package/dist-server/graphql/resolvers/worksheet-detail/index.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.js +81 -0
- package/dist-server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.js.map +1 -0
- package/dist-server/graphql/resolvers/worksheet-detail/update-worksheet-detail.js +2 -2
- package/dist-server/graphql/resolvers/worksheet-detail/update-worksheet-detail.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-detail.js +2 -2
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-detail.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-details-by-product-group.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-details-by-product-group.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-details.js +2 -2
- package/dist-server/graphql/resolvers/worksheet-detail/worksheet-details.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/create-worksheet-movement.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/create-worksheet-movement.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/delete-worksheet-movement.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/update-worksheet-movement.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/update-worksheet-movement.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/worksheet-movement.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/worksheet-movement.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/worksheet-movements.js +1 -1
- package/dist-server/graphql/resolvers/worksheet-movement/worksheet-movements.js.map +1 -1
- package/dist-server/graphql/types/worksheet/batch-pick-worksheet-info.js +12 -0
- package/dist-server/graphql/types/worksheet/batch-pick-worksheet-info.js.map +1 -0
- package/dist-server/graphql/types/worksheet/delivery-order-info.js +3 -0
- package/dist-server/graphql/types/worksheet/delivery-order-info.js.map +1 -1
- package/dist-server/graphql/types/worksheet/delivery-order-ro.js +18 -0
- package/dist-server/graphql/types/worksheet/delivery-order-ro.js.map +1 -0
- package/dist-server/graphql/types/worksheet/index.js +26 -15
- package/dist-server/graphql/types/worksheet/index.js.map +1 -1
- package/dist-server/graphql/types/worksheet/multiple-release-good-worksheet.js +11 -0
- package/dist-server/graphql/types/worksheet/multiple-release-good-worksheet.js.map +1 -0
- package/dist-server/graphql/types/worksheet/sellercraft-document.js +11 -0
- package/dist-server/graphql/types/worksheet/sellercraft-document.js.map +1 -0
- package/dist-server/graphql/types/worksheet-detail/index.js +10 -0
- package/dist-server/graphql/types/worksheet-detail/index.js.map +1 -1
- package/dist-server/graphql/types/worksheet-detail/inventory-detail.js +1 -0
- package/dist-server/graphql/types/worksheet-detail/inventory-detail.js.map +1 -1
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/dist-server/utils/inventory-util.js +26 -20
- package/dist-server/utils/inventory-util.js.map +1 -1
- package/dist-server/utils/worksheet-util.js +8 -6
- package/dist-server/utils/worksheet-util.js.map +1 -1
- package/package.json +17 -17
- package/server/controllers/ecommerce/sellercraft-controller.ts +282 -223
- package/server/controllers/inbound/unloading-returning-worksheet-controller.ts +9 -17
- package/server/controllers/inbound/unloading-worksheet-controller.ts +55 -66
- package/server/controllers/inspect/cycle-count-worksheet-controller.ts +1 -1
- package/server/controllers/outbound/packing-worksheet-controller.ts +25 -4
- package/server/controllers/outbound/picking-worksheet-controller.ts +292 -172
- package/server/controllers/outbound/returning-worksheet-controller.ts +23 -0
- package/server/controllers/outbound/sorting-worksheet-controller.ts +20 -20
- package/server/controllers/render-elccl-grn.ts +16 -11
- package/server/controllers/render-fm-grn.ts +32 -14
- package/server/controllers/render-grn.ts +31 -16
- package/server/controllers/render-invoices.ts +3 -3
- package/server/controllers/render-job-sheet.ts +13 -11
- package/server/controllers/render-kimeda-grn.ts +28 -13
- package/server/controllers/render-manifest.ts +25 -24
- package/server/controllers/render-manual-do.ts +9 -10
- package/server/controllers/render-orientage-do.ts +79 -30
- package/server/controllers/render-orientage-grn.ts +30 -20
- package/server/controllers/render-po.ts +31 -20
- package/server/controllers/render-ro-do.ts +151 -124
- package/server/controllers/render-seebuu-grn.ts +21 -11
- package/server/controllers/vas/vas-worksheet-controller.ts +19 -20
- package/server/controllers/worksheet-controller.ts +97 -27
- package/server/entities/warehouse-bizplace-onhand-inventory.ts +2 -1
- package/server/entities/worksheet-detail.ts +9 -0
- package/server/graphql/resolvers/pallet/pallet-outbound.ts +5 -8
- package/server/graphql/resolvers/worksheet/batch-picking-worksheet.ts +8 -6
- package/server/graphql/resolvers/worksheet/cancel-draft-release-order.ts +4 -11
- package/server/graphql/resolvers/worksheet/check-inventory-release.ts +8 -7
- package/server/graphql/resolvers/worksheet/check-stock-take-current-location.ts +10 -8
- package/server/graphql/resolvers/worksheet/confirm-cancellation-release-order.ts +112 -138
- package/server/graphql/resolvers/worksheet/create-worksheet.ts +6 -8
- package/server/graphql/resolvers/worksheet/cross-dock-picking.ts +8 -7
- package/server/graphql/resolvers/worksheet/cycle-count-adjustment.ts +7 -7
- package/server/graphql/resolvers/worksheet/cycle-count-worksheet.ts +6 -6
- package/server/graphql/resolvers/worksheet/delete-worksheet.ts +5 -3
- package/server/graphql/resolvers/worksheet/delivery-order-by-worksheet.ts +87 -53
- package/server/graphql/resolvers/worksheet/fetch-delivery-order-ro.ts +190 -0
- package/server/graphql/resolvers/worksheet/fetch-sellercraft-document.ts +69 -0
- package/server/graphql/resolvers/worksheet/find-release-orders-by-task-no.ts +5 -45
- package/server/graphql/resolvers/worksheet/find-release-orders-by-worksheet-no.ts +5 -5
- package/server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts +80 -0
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-arrival-notice-worksheet.ts +45 -5
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-batch-picking-worksheet.ts +11 -10
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-cycle-count-worksheet.ts +1 -1
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-multiple-release-good-worksheet.ts +7 -14
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-return-worksheet.ts +10 -4
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-partial-putaway-worksheet.ts +10 -4
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-putaway-worksheet.ts +5 -3
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-release-good-worksheet.ts +25 -29
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-return-order-worksheet.ts +6 -4
- package/server/graphql/resolvers/worksheet/generate-worksheet/generate-vas-order-worksheet.ts +6 -4
- package/server/graphql/resolvers/worksheet/having-vas.ts +10 -8
- package/server/graphql/resolvers/worksheet/index.ts +7 -3
- package/server/graphql/resolvers/worksheet/inspecting/activate-cycle-count.ts +5 -3
- package/server/graphql/resolvers/worksheet/inspecting/add-extra-pallet.ts +4 -2
- package/server/graphql/resolvers/worksheet/inspecting/check-missing-pallet.ts +5 -3
- package/server/graphql/resolvers/worksheet/inspecting/complete-inspection.ts +5 -3
- package/server/graphql/resolvers/worksheet/inspecting/inspecting.ts +9 -3
- package/server/graphql/resolvers/worksheet/inspecting/relocate-pallet.ts +16 -4
- package/server/graphql/resolvers/worksheet/inspecting/undo-inspection.ts +5 -3
- package/server/graphql/resolvers/worksheet/inventories-by-pallet.ts +34 -17
- package/server/graphql/resolvers/worksheet/loaded-inventories.ts +7 -6
- package/server/graphql/resolvers/worksheet/loading/activate-loading.ts +5 -3
- package/server/graphql/resolvers/worksheet/loading/complete-loading.ts +16 -16
- package/server/graphql/resolvers/worksheet/loading/loading.ts +5 -3
- package/server/graphql/resolvers/worksheet/loading/undo-loading.ts +5 -3
- package/server/graphql/resolvers/worksheet/loading-worksheet.ts +11 -11
- package/server/graphql/resolvers/worksheet/not-tally-target-inventories.ts +6 -6
- package/server/graphql/resolvers/worksheet/packing/activate-packing.ts +14 -13
- package/server/graphql/resolvers/worksheet/packing/complete-packing.ts +4 -4
- package/server/graphql/resolvers/worksheet/packing/packing.ts +3 -3
- package/server/graphql/resolvers/worksheet/packing/scan-product-packing.ts +21 -17
- package/server/graphql/resolvers/worksheet/packing/undo-serial-number-packing.ts +2 -2
- package/server/graphql/resolvers/worksheet/packing-worksheet.ts +102 -24
- package/server/graphql/resolvers/worksheet/palletizing-pallets.ts +10 -8
- package/server/graphql/resolvers/worksheet/pending-cancellation-release-order.ts +107 -97
- package/server/graphql/resolvers/worksheet/picking/activate-batch-picking.ts +3 -30
- package/server/graphql/resolvers/worksheet/picking/activate-picking.ts +3 -3
- package/server/graphql/resolvers/worksheet/picking/assign-picking-inventories.ts +23 -4
- package/server/graphql/resolvers/worksheet/picking/assign-picking-worker.ts +25 -17
- package/server/graphql/resolvers/worksheet/picking/batch-picking.ts +4 -2
- package/server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts +15 -6
- package/server/graphql/resolvers/worksheet/picking/complete-picking.ts +37 -42
- package/server/graphql/resolvers/worksheet/picking/fetch-and-assign-picking-task.ts +52 -42
- package/server/graphql/resolvers/worksheet/picking/my-picking-assignment-status.ts +15 -6
- package/server/graphql/resolvers/worksheet/picking/picking-assignment-status-by-user.ts +49 -35
- package/server/graphql/resolvers/worksheet/picking/picking.ts +4 -2
- package/server/graphql/resolvers/worksheet/picking/scan-product-batch-picking.ts +11 -6
- package/server/graphql/resolvers/worksheet/picking/scan-product-picking.ts +10 -35
- package/server/graphql/resolvers/worksheet/picking/seal-tote.ts +2 -2
- package/server/graphql/resolvers/worksheet/picking/undo-picking-assignment.ts +9 -3
- package/server/graphql/resolvers/worksheet/picking/undo-serial-number-picking.ts +2 -2
- package/server/graphql/resolvers/worksheet/picking-worksheet.ts +11 -11
- package/server/graphql/resolvers/worksheet/proceed-extra-products.ts +13 -13
- package/server/graphql/resolvers/worksheet/putaway/activate-putaway.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway/complete-putaway.ts +6 -5
- package/server/graphql/resolvers/worksheet/putaway/putaway.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway/undo-putaway.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway-return/activate-putaway-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway-return/complete-putaway-return.ts +13 -6
- package/server/graphql/resolvers/worksheet/putaway-return/putaway-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway-return/undo-putaway-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/putaway-returning-worksheet.ts +4 -6
- package/server/graphql/resolvers/worksheet/putaway-worksheet.ts +4 -6
- package/server/graphql/resolvers/worksheet/recommend-putway-location.ts +20 -19
- package/server/graphql/resolvers/worksheet/reject-cancellation-release-order.ts +154 -220
- package/server/graphql/resolvers/worksheet/relocate-pallet.ts +6 -4
- package/server/graphql/resolvers/worksheet/replace-picking-pallets.ts +3 -7
- package/server/graphql/resolvers/worksheet/return-worksheet.ts +4 -6
- package/server/graphql/resolvers/worksheet/returning/activate-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/returning/complete-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/returning/returning.ts +5 -3
- package/server/graphql/resolvers/worksheet/sorting/activate-sorting.ts +5 -3
- package/server/graphql/resolvers/worksheet/sorting/complete-order-sorting.ts +7 -5
- package/server/graphql/resolvers/worksheet/sorting/complete-worksheet-sorting.ts +5 -3
- package/server/graphql/resolvers/worksheet/sorting/scan-product-sorting.ts +9 -3
- package/server/graphql/resolvers/worksheet/sorting/sorting-product.ts +9 -3
- package/server/graphql/resolvers/worksheet/sorting-worksheet.ts +5 -5
- package/server/graphql/resolvers/worksheet/transfer.ts +10 -12
- package/server/graphql/resolvers/worksheet/unloaded-inventories-by-reusable-pallet.ts +13 -7
- package/server/graphql/resolvers/worksheet/unloaded-inventories.ts +9 -9
- package/server/graphql/resolvers/worksheet/unloading/activate-unloading.ts +9 -5
- package/server/graphql/resolvers/worksheet/unloading/complete-product-scan-unload.ts +5 -3
- package/server/graphql/resolvers/worksheet/unloading/complete-unloading-partially.ts +5 -3
- package/server/graphql/resolvers/worksheet/unloading/complete-unloading.ts +8 -4
- package/server/graphql/resolvers/worksheet/unloading/scan-product-unload.ts +5 -3
- package/server/graphql/resolvers/worksheet/unloading/scan-serial-number-unload.ts +2 -2
- package/server/graphql/resolvers/worksheet/unloading/undo-serial-number-unload.ts +2 -2
- package/server/graphql/resolvers/worksheet/unloading/undo-unloading.ts +2 -2
- package/server/graphql/resolvers/worksheet/unloading/unload.ts +7 -7
- package/server/graphql/resolvers/worksheet/unloading-return/activate-unloading-return.ts +5 -3
- package/server/graphql/resolvers/worksheet/unloading-return/complete-unload-return-partially.ts +5 -3
- package/server/graphql/resolvers/worksheet/unloading-return/complete-unload-returning.ts +9 -5
- package/server/graphql/resolvers/worksheet/unloading-return-worksheet.ts +4 -6
- package/server/graphql/resolvers/worksheet/unloading-worksheet.ts +5 -7
- package/server/graphql/resolvers/worksheet/update-worksheet.ts +5 -5
- package/server/graphql/resolvers/worksheet/vas/activate-vas.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas/assign-vas-inventories.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas/complete-vas.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas/execute-vas.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas/undo-vas-inventory.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas/undo-vas.ts +5 -3
- package/server/graphql/resolvers/worksheet/vas-candidates.ts +20 -17
- package/server/graphql/resolvers/worksheet/vas-inventories.ts +9 -7
- package/server/graphql/resolvers/worksheet/vas-transactions/common-utils.ts +36 -18
- package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/check-relabelable.ts +12 -5
- package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/complete-relabeling.ts +6 -3
- package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/relabeling.ts +14 -6
- package/server/graphql/resolvers/worksheet/vas-transactions/relabeling/undo-relabeling.ts +5 -7
- package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/complete-repackaging.ts +3 -2
- package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/repackaging.ts +8 -5
- package/server/graphql/resolvers/worksheet/vas-transactions/repackaging/undo-repackaging.ts +6 -16
- package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/complete-repalletizing.ts +5 -2
- package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/repalletizing.ts +10 -8
- package/server/graphql/resolvers/worksheet/vas-transactions/repalletizing/undo-repalletizing.ts +3 -5
- package/server/graphql/resolvers/worksheet/vas-transactions/unpacking/complete-unpacking.ts +6 -6
- package/server/graphql/resolvers/worksheet/vas-transactions/unpacking/unpacking.ts +10 -13
- package/server/graphql/resolvers/worksheet/vas-worksheet.ts +13 -11
- package/server/graphql/resolvers/worksheet/worksheet-by-order-no.ts +13 -8
- package/server/graphql/resolvers/worksheet/worksheet-with-pagination.ts +7 -5
- package/server/graphql/resolvers/worksheet/worksheet.ts +86 -32
- package/server/graphql/resolvers/worksheet/worksheets.ts +60 -19
- package/server/graphql/resolvers/worksheet-detail/check-progressing-pallet.ts +7 -8
- package/server/graphql/resolvers/worksheet-detail/create-worksheet-detail.ts +4 -6
- package/server/graphql/resolvers/worksheet-detail/delete-worksheet-detail.ts +5 -6
- package/server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details-by-bulk.ts +13 -19
- package/server/graphql/resolvers/worksheet-detail/generate-batch-picking-worksheet-details.ts +19 -27
- package/server/graphql/resolvers/worksheet-detail/generate-carton-id.ts +2 -4
- package/server/graphql/resolvers/worksheet-detail/generate-pallet-id.ts +6 -6
- package/server/graphql/resolvers/worksheet-detail/generate-picking-worksheet-details.ts +7 -4
- package/server/graphql/resolvers/worksheet-detail/generate-release-good-worksheet-details.ts +3 -3
- package/server/graphql/resolvers/worksheet-detail/index.ts +3 -1
- package/server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.ts +164 -0
- package/server/graphql/resolvers/worksheet-detail/update-worksheet-detail.ts +8 -7
- package/server/graphql/resolvers/worksheet-detail/worksheet-detail.ts +6 -7
- package/server/graphql/resolvers/worksheet-detail/worksheet-details-by-product-group.ts +5 -5
- package/server/graphql/resolvers/worksheet-detail/worksheet-details.ts +6 -7
- package/server/graphql/resolvers/worksheet-movement/create-worksheet-movement.ts +4 -3
- package/server/graphql/resolvers/worksheet-movement/delete-worksheet-movement.ts +3 -2
- package/server/graphql/resolvers/worksheet-movement/update-worksheet-movement.ts +2 -4
- package/server/graphql/resolvers/worksheet-movement/worksheet-movement.ts +3 -6
- package/server/graphql/resolvers/worksheet-movement/worksheet-movements.ts +4 -4
- package/server/graphql/types/worksheet/batch-pick-worksheet-info.ts +9 -0
- package/server/graphql/types/worksheet/delivery-order-info.ts +3 -0
- package/server/graphql/types/worksheet/delivery-order-ro.ts +15 -0
- package/server/graphql/types/worksheet/index.ts +49 -38
- package/server/graphql/types/worksheet/multiple-release-good-worksheet.ts +8 -0
- package/server/graphql/types/worksheet/sellercraft-document.ts +8 -0
- package/server/graphql/types/worksheet-detail/index.ts +10 -0
- package/server/graphql/types/worksheet-detail/inventory-detail.ts +1 -0
- package/server/utils/inventory-util.ts +20 -14
- package/server/utils/worksheet-util.ts +10 -6
- package/dist-server/graphql/resolvers/worksheet/fetch-sellercraft-airway-bill.js +0 -25
- package/dist-server/graphql/resolvers/worksheet/fetch-sellercraft-airway-bill.js.map +0 -1
- package/dist-server/graphql/types/worksheet/airwaybill.js +0 -11
- package/dist-server/graphql/types/worksheet/airwaybill.js.map +0 -1
- package/server/graphql/resolvers/worksheet/fetch-sellercraft-airway-bill.ts +0 -30
- package/server/graphql/types/worksheet/airwaybill.ts +0 -7
|
@@ -2,18 +2,17 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.pendingCancellationReleaseOrder = void 0;
|
|
4
4
|
const typeorm_1 = require("typeorm");
|
|
5
|
-
const auth_base_1 = require("@things-factory/auth-base");
|
|
6
|
-
const notification_1 = require("@things-factory/notification");
|
|
7
5
|
const sales_base_1 = require("@things-factory/sales-base");
|
|
8
6
|
const entities_1 = require("../../../entities");
|
|
9
7
|
exports.pendingCancellationReleaseOrder = {
|
|
10
8
|
async pendingCancellationReleaseOrder(_, { name }, context) {
|
|
11
|
-
var _a;
|
|
12
9
|
const { tx, domain, user } = context.state;
|
|
13
10
|
const foundRO = await tx.getRepository(sales_base_1.ReleaseGood).findOne({
|
|
14
|
-
where: { domain, name },
|
|
11
|
+
where: { domain: { id: domain.id }, name },
|
|
15
12
|
relations: ['bizplace', 'orderInventories', 'orderVass']
|
|
16
13
|
});
|
|
14
|
+
if (foundRO.status === 'DONE')
|
|
15
|
+
throw new Error('Release good has been completed!');
|
|
17
16
|
if (!foundRO)
|
|
18
17
|
throw new Error(`Release good order doesn't exists.`);
|
|
19
18
|
let targetOIs = foundRO.orderInventories;
|
|
@@ -36,7 +35,8 @@ exports.pendingCancellationReleaseOrder = {
|
|
|
36
35
|
foundRO.status === sales_base_1.ORDER_STATUS.READY_TO_PICK ||
|
|
37
36
|
foundRO.status === sales_base_1.ORDER_STATUS.PENDING_WORKSHEET) {
|
|
38
37
|
pickingOIs = targetOIs
|
|
39
|
-
.filter((oi) => oi.status === sales_base_1.ORDER_INVENTORY_STATUS.
|
|
38
|
+
.filter((oi) => oi.status === sales_base_1.ORDER_INVENTORY_STATUS.ASSIGNED ||
|
|
39
|
+
oi.status === sales_base_1.ORDER_INVENTORY_STATUS.PICKING ||
|
|
40
40
|
oi.status === sales_base_1.ORDER_INVENTORY_STATUS.READY_TO_PICK ||
|
|
41
41
|
oi.status === sales_base_1.ORDER_INVENTORY_STATUS.PENDING_SPLIT ||
|
|
42
42
|
oi.status === sales_base_1.ORDER_INVENTORY_STATUS.PENDING_WORKSHEET)
|
|
@@ -58,94 +58,106 @@ exports.pendingCancellationReleaseOrder = {
|
|
|
58
58
|
});
|
|
59
59
|
await tx.getRepository(sales_base_1.OrderVas).save(foundOVs);
|
|
60
60
|
}
|
|
61
|
-
if (pickedOIs && pickedOIs.length) {
|
|
62
|
-
let pickedWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
63
|
-
where: {
|
|
64
|
-
domain,
|
|
65
|
-
targetInventory: (0, typeorm_1.In)(pickedOIs.map(oi => oi.id)),
|
|
66
|
-
status: sales_base_1.ORDER_INVENTORY_STATUS.DONE
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
pickedWSD = pickedWSD.map((wsd) => {
|
|
70
|
-
return Object.assign(Object.assign({}, wsd), { status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL, updater: user });
|
|
71
|
-
});
|
|
72
|
-
await tx.getRepository(entities_1.WorksheetDetail).save(pickedWSD);
|
|
73
|
-
let replacedWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
74
|
-
where: {
|
|
75
|
-
domain,
|
|
76
|
-
targetInventory: (0, typeorm_1.In)(pickedOIs.map(oi => oi.id)),
|
|
77
|
-
status: sales_base_1.ORDER_INVENTORY_STATUS.REPLACED
|
|
78
|
-
},
|
|
79
|
-
relations: ['targetInventory']
|
|
80
|
-
});
|
|
81
|
-
if (replacedWSD && replacedWSD.length) {
|
|
82
|
-
let replacedOI = replacedWSD.map((wsd) => wsd.targetInventory);
|
|
83
|
-
replacedOI = replacedOI.map((oi) => {
|
|
84
|
-
return Object.assign(Object.assign({}, oi), { status: sales_base_1.ORDER_INVENTORY_STATUS.REPLACED, updater: user });
|
|
85
|
-
});
|
|
86
|
-
await tx.getRepository(sales_base_1.OrderInventory).save(replacedOI);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
if (pickingOIs && pickingOIs.length) {
|
|
90
|
-
let pickingWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
91
|
-
where: { domain, targetInventory: (0, typeorm_1.In)(pickingOIs.map(oi => oi.id)) }
|
|
92
|
-
});
|
|
93
|
-
pickingWSD = pickingWSD.map((wsd) => {
|
|
94
|
-
return Object.assign(Object.assign({}, wsd), { status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL, updater: user });
|
|
95
|
-
});
|
|
96
|
-
await tx.getRepository(entities_1.WorksheetDetail).save(pickingWSD);
|
|
97
|
-
}
|
|
98
61
|
// find worksheet and update status to PENDING_CANCEL
|
|
99
|
-
let foundWS = await tx.getRepository(entities_1.Worksheet).
|
|
62
|
+
let foundWS = await tx.getRepository(entities_1.Worksheet).findOne({
|
|
100
63
|
where: {
|
|
101
|
-
domain,
|
|
64
|
+
domain: { id: domain.id },
|
|
102
65
|
releaseGood: foundRO
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
foundWS = foundWS.map((ws) => {
|
|
106
|
-
return Object.assign(Object.assign({}, ws), { status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL, updater: user });
|
|
66
|
+
},
|
|
67
|
+
order: { createdAt: 'DESC' }
|
|
107
68
|
});
|
|
108
|
-
|
|
69
|
+
if (foundWS) {
|
|
70
|
+
await tx.getRepository(entities_1.Worksheet).update({ id: foundWS.id }, {
|
|
71
|
+
status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL,
|
|
72
|
+
updater: user
|
|
73
|
+
});
|
|
74
|
+
if (pickedOIs && pickedOIs.length) {
|
|
75
|
+
let pickedWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
76
|
+
where: {
|
|
77
|
+
domain: { id: domain.id },
|
|
78
|
+
targetInventory: (0, typeorm_1.In)(pickedOIs.map(oi => oi.id)),
|
|
79
|
+
status: sales_base_1.ORDER_INVENTORY_STATUS.DONE,
|
|
80
|
+
worksheet: { id: foundWS.id }
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
pickedWSD = pickedWSD.map((wsd) => {
|
|
84
|
+
return Object.assign(Object.assign({}, wsd), { status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL, updater: user });
|
|
85
|
+
});
|
|
86
|
+
await tx.getRepository(entities_1.WorksheetDetail).save(pickedWSD);
|
|
87
|
+
let replacedWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
88
|
+
where: {
|
|
89
|
+
domain: { id: domain.id },
|
|
90
|
+
targetInventory: (0, typeorm_1.In)(pickedOIs.map(oi => oi.id)),
|
|
91
|
+
status: sales_base_1.ORDER_INVENTORY_STATUS.REPLACED,
|
|
92
|
+
worksheet: { id: foundWS.id }
|
|
93
|
+
},
|
|
94
|
+
relations: ['targetInventory']
|
|
95
|
+
});
|
|
96
|
+
if (replacedWSD && replacedWSD.length) {
|
|
97
|
+
let replacedOI = replacedWSD.map((wsd) => wsd.targetInventory);
|
|
98
|
+
replacedOI = replacedOI.map((oi) => {
|
|
99
|
+
return Object.assign(Object.assign({}, oi), { status: sales_base_1.ORDER_INVENTORY_STATUS.REPLACED, updater: user });
|
|
100
|
+
});
|
|
101
|
+
await tx.getRepository(sales_base_1.OrderInventory).save(replacedOI);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (pickingOIs && pickingOIs.length) {
|
|
105
|
+
let pickingWSD = await tx.getRepository(entities_1.WorksheetDetail).find({
|
|
106
|
+
where: {
|
|
107
|
+
domain: { id: domain.id },
|
|
108
|
+
targetInventory: (0, typeorm_1.In)(pickingOIs.map(oi => oi.id)),
|
|
109
|
+
worksheet: { id: foundWS.id }
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
pickingWSD = pickingWSD.map((wsd) => {
|
|
113
|
+
return Object.assign(Object.assign({}, wsd), { status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_CANCEL, updater: user });
|
|
114
|
+
});
|
|
115
|
+
await tx.getRepository(entities_1.WorksheetDetail).save(pickingWSD);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
109
118
|
// find DO and change status to pending cancel
|
|
110
119
|
let foundDO = await tx.getRepository(sales_base_1.DeliveryOrder).find({
|
|
111
|
-
where: { domain, releaseGood: foundRO }
|
|
120
|
+
where: { domain: { id: domain.id }, releaseGood: foundRO }
|
|
112
121
|
});
|
|
113
122
|
foundDO = foundDO.map((deliveryOrder) => {
|
|
114
123
|
return Object.assign(Object.assign({}, deliveryOrder), { status: sales_base_1.ORDER_STATUS.PENDING_CANCEL, updater: user });
|
|
115
124
|
});
|
|
116
125
|
await tx.getRepository(sales_base_1.DeliveryOrder).save(foundDO);
|
|
117
126
|
await tx.getRepository(sales_base_1.ReleaseGood).save(Object.assign(Object.assign({}, foundRO), { status: sales_base_1.ORDER_STATUS.PENDING_CANCEL, updater: user }));
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
})
|
|
134
|
-
|
|
135
|
-
//
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
127
|
+
/**
|
|
128
|
+
* @notes Temporary off sendNotification due to suspect of causing wms down
|
|
129
|
+
*/
|
|
130
|
+
// // notification logics
|
|
131
|
+
// // get Office Admin Users
|
|
132
|
+
// const users: any[] = await tx
|
|
133
|
+
// .getRepository('users_roles')
|
|
134
|
+
// .createQueryBuilder('ur')
|
|
135
|
+
// .select('ur.users_id', 'id')
|
|
136
|
+
// .where(qb => {
|
|
137
|
+
// const subQuery = qb
|
|
138
|
+
// .subQuery()
|
|
139
|
+
// .select('role.id')
|
|
140
|
+
// .from(Role, 'role')
|
|
141
|
+
// .where("role.name = 'Office Admin'")
|
|
142
|
+
// .andWhere('role.domain_id = :domain', { domain: domain.id })
|
|
143
|
+
// .getQuery()
|
|
144
|
+
// return 'ur.roles_id IN ' + subQuery
|
|
145
|
+
// })
|
|
146
|
+
// .getRawMany()
|
|
147
|
+
// // send notification to Office Admin Users
|
|
148
|
+
// if (users?.length && context.header?.referer) {
|
|
149
|
+
// const receivers: any[] = users.map(user => user.id)
|
|
150
|
+
// const msg = {
|
|
151
|
+
// title: `${foundRO.name} cancellation`,
|
|
152
|
+
// body: `${customerBizplace.name} is requesting to cancel order`,
|
|
153
|
+
// url: context.header.referer,
|
|
154
|
+
// data: { url: context.header.referer }
|
|
155
|
+
// }
|
|
156
|
+
// await sendNotification({
|
|
157
|
+
// receivers,
|
|
158
|
+
// message: { ...msg }
|
|
159
|
+
// })
|
|
160
|
+
// }
|
|
149
161
|
return;
|
|
150
162
|
}
|
|
151
163
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pending-cancellation-release-order.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/pending-cancellation-release-order.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager, In } from 'typeorm'\n\nimport { Role, User } from '@things-factory/auth-base'\nimport { Bizplace } from '@things-factory/biz-base'\nimport { sendNotification } from '@things-factory/notification'\nimport {\n DeliveryOrder,\n ORDER_INVENTORY_STATUS,\n ORDER_STATUS,\n ORDER_VAS_STATUS,\n OrderInventory,\n OrderVas,\n ReleaseGood\n} from '@things-factory/sales-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { Worksheet, WorksheetDetail } from '../../../entities'\n\nexport const pendingCancellationReleaseOrder = {\n async pendingCancellationReleaseOrder(_: any, { name }, context: any) {\n const { tx, domain, user }: { tx: EntityManager; domain: Domain; user: User } = context.state\n const foundRO: ReleaseGood = await tx.getRepository(ReleaseGood).findOne({\n where: { domain, name },\n relations: ['bizplace', 'orderInventories', 'orderVass']\n })\n\n if (!foundRO) throw new Error(`Release good order doesn't exists.`)\n let targetOIs: OrderInventory[] = foundRO.orderInventories\n let foundOVs: OrderVas[] = foundRO.orderVass\n let customerBizplace: Bizplace = foundRO.bizplace\n let pickedOIs: OrderInventory[]\n let pickingOIs: OrderInventory[]\n\n // 1. Check RO status\n if (\n foundRO.status === ORDER_STATUS.LOADING ||\n foundRO.status === ORDER_STATUS.PACKING ||\n foundRO.status === ORDER_STATUS.SORTING\n ) {\n // 1a. Case 1: RO is done or loading, pending cancel order, worksheet, worksheet detail, order inventory\n // update status of order inventory to PENDING_CANCEL\n pickedOIs = targetOIs.map((orderInv: OrderInventory) => {\n return {\n ...orderInv,\n status: ORDER_INVENTORY_STATUS.PENDING_REVERSE,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickedOIs)\n } else if (\n foundRO.status === ORDER_STATUS.PICKING ||\n foundRO.status === ORDER_STATUS.READY_TO_PICK ||\n foundRO.status === ORDER_STATUS.PENDING_WORKSHEET\n ) {\n pickingOIs = targetOIs\n .filter(\n (oi: OrderInventory) =>\n oi.status === ORDER_INVENTORY_STATUS.PICKING ||\n oi.status === ORDER_INVENTORY_STATUS.READY_TO_PICK ||\n oi.status === ORDER_INVENTORY_STATUS.PENDING_SPLIT ||\n oi.status === ORDER_INVENTORY_STATUS.PENDING_WORKSHEET\n )\n .map((targetOI: OrderInventory) => {\n return {\n ...targetOI,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickingOIs)\n\n pickedOIs = targetOIs\n .filter((pickedOI: OrderInventory) => pickedOI.status === ORDER_INVENTORY_STATUS.PICKED)\n .map((targetOI: OrderInventory) => {\n return {\n ...targetOI,\n status: ORDER_INVENTORY_STATUS.PENDING_REVERSE,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickedOIs)\n }\n\n // update status of order vass to PENDING_CANCEL\n if (foundOVs && foundOVs.length) {\n foundOVs = foundOVs.map((orderVas: OrderVas) => {\n return {\n ...orderVas,\n status: ORDER_VAS_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(OrderVas).save(foundOVs)\n }\n\n if (pickedOIs && pickedOIs.length) {\n let pickedWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: {\n domain,\n targetInventory: In(pickedOIs.map(oi => oi.id)),\n status: ORDER_INVENTORY_STATUS.DONE\n }\n })\n\n pickedWSD = pickedWSD.map((wsd: WorksheetDetail) => {\n return {\n ...wsd,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(WorksheetDetail).save(pickedWSD)\n\n let replacedWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: {\n domain,\n targetInventory: In(pickedOIs.map(oi => oi.id)),\n status: ORDER_INVENTORY_STATUS.REPLACED\n },\n relations: ['targetInventory']\n })\n\n if (replacedWSD && replacedWSD.length) {\n let replacedOI: OrderInventory[] = replacedWSD.map((wsd: WorksheetDetail) => wsd.targetInventory)\n replacedOI = replacedOI.map((oi: OrderInventory) => {\n return {\n ...oi,\n status: ORDER_INVENTORY_STATUS.REPLACED,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(replacedOI)\n }\n }\n\n if (pickingOIs && pickingOIs.length) {\n let pickingWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: { domain, targetInventory: In(pickingOIs.map(oi => oi.id)) }\n })\n\n pickingWSD = pickingWSD.map((wsd: WorksheetDetail) => {\n return {\n ...wsd,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(WorksheetDetail).save(pickingWSD)\n }\n\n // find worksheet and update status to PENDING_CANCEL\n let foundWS: Worksheet[] = await tx.getRepository(Worksheet).find({\n where: {\n domain,\n releaseGood: foundRO\n }\n })\n\n foundWS = foundWS.map((ws: Worksheet) => {\n return {\n ...ws,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(Worksheet).save(foundWS)\n\n // find DO and change status to pending cancel\n let foundDO: DeliveryOrder[] = await tx.getRepository(DeliveryOrder).find({\n where: { domain, releaseGood: foundRO }\n })\n\n foundDO = foundDO.map((deliveryOrder: DeliveryOrder) => {\n return {\n ...deliveryOrder,\n status: ORDER_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(DeliveryOrder).save(foundDO)\n\n await tx.getRepository(ReleaseGood).save({\n ...foundRO,\n status: ORDER_STATUS.PENDING_CANCEL,\n updater: user\n })\n\n // notification logics\n // get Office Admin Users\n const users: any[] = await tx\n .getRepository('users_roles')\n .createQueryBuilder('ur')\n .select('ur.users_id', 'id')\n .where(qb => {\n const subQuery = qb\n .subQuery()\n .select('role.id')\n .from(Role, 'role')\n .where(\"role.name = 'Office Admin'\")\n .andWhere('role.domain_id = :domain', { domain: domain.id })\n .getQuery()\n return 'ur.roles_id IN ' + subQuery\n })\n .getRawMany()\n\n // send notification to Office Admin Users\n if (users?.length && context.header?.referer) {\n const receivers: any[] = users.map(user => user.id)\n const msg = {\n title: `${foundRO.name} cancellation`,\n body: `${customerBizplace.name} is requesting to cancel order`,\n url: context.header.referer,\n data: { url: context.header.referer }\n }\n\n await sendNotification({\n receivers,\n message: { ...msg }\n })\n }\n\n return\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"pending-cancellation-release-order.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/pending-cancellation-release-order.ts"],"names":[],"mappings":"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","sourcesContent":["import { In } from 'typeorm'\n\nimport { Bizplace } from '@things-factory/biz-base'\nimport {\n DeliveryOrder,\n ORDER_INVENTORY_STATUS,\n ORDER_STATUS,\n ORDER_VAS_STATUS,\n OrderInventory,\n OrderVas,\n ReleaseGood\n} from '@things-factory/sales-base'\n\nimport { Worksheet, WorksheetDetail } from '../../../entities'\n\nexport const pendingCancellationReleaseOrder = {\n async pendingCancellationReleaseOrder(_: any, { name }, context: ResolverContext) {\n const { tx, domain, user } = context.state\n const foundRO: ReleaseGood = await tx.getRepository(ReleaseGood).findOne({\n where: { domain: { id: domain.id }, name },\n relations: ['bizplace', 'orderInventories', 'orderVass']\n })\n\n if (foundRO.status === 'DONE') throw new Error('Release good has been completed!')\n if (!foundRO) throw new Error(`Release good order doesn't exists.`)\n let targetOIs: OrderInventory[] = foundRO.orderInventories\n let foundOVs: OrderVas[] = foundRO.orderVass\n let customerBizplace: Bizplace = foundRO.bizplace\n let pickedOIs: OrderInventory[]\n let pickingOIs: OrderInventory[]\n\n // 1. Check RO status\n if (\n foundRO.status === ORDER_STATUS.LOADING ||\n foundRO.status === ORDER_STATUS.PACKING ||\n foundRO.status === ORDER_STATUS.SORTING\n ) {\n // 1a. Case 1: RO is done or loading, pending cancel order, worksheet, worksheet detail, order inventory\n // update status of order inventory to PENDING_CANCEL\n pickedOIs = targetOIs.map((orderInv: OrderInventory) => {\n return {\n ...orderInv,\n status: ORDER_INVENTORY_STATUS.PENDING_REVERSE,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickedOIs)\n } else if (\n foundRO.status === ORDER_STATUS.PICKING ||\n foundRO.status === ORDER_STATUS.READY_TO_PICK ||\n foundRO.status === ORDER_STATUS.PENDING_WORKSHEET\n ) {\n pickingOIs = targetOIs\n .filter(\n (oi: OrderInventory) =>\n oi.status === ORDER_INVENTORY_STATUS.ASSIGNED ||\n oi.status === ORDER_INVENTORY_STATUS.PICKING ||\n oi.status === ORDER_INVENTORY_STATUS.READY_TO_PICK ||\n oi.status === ORDER_INVENTORY_STATUS.PENDING_SPLIT ||\n oi.status === ORDER_INVENTORY_STATUS.PENDING_WORKSHEET\n )\n .map((targetOI: OrderInventory) => {\n return {\n ...targetOI,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickingOIs)\n\n pickedOIs = targetOIs\n .filter((pickedOI: OrderInventory) => pickedOI.status === ORDER_INVENTORY_STATUS.PICKED)\n .map((targetOI: OrderInventory) => {\n return {\n ...targetOI,\n status: ORDER_INVENTORY_STATUS.PENDING_REVERSE,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(pickedOIs)\n }\n\n // update status of order vass to PENDING_CANCEL\n if (foundOVs && foundOVs.length) {\n foundOVs = foundOVs.map((orderVas: OrderVas) => {\n return {\n ...orderVas,\n status: ORDER_VAS_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(OrderVas).save(foundOVs)\n }\n\n // find worksheet and update status to PENDING_CANCEL\n let foundWS: Worksheet = await tx.getRepository(Worksheet).findOne({\n where: {\n domain: { id: domain.id },\n releaseGood: foundRO\n },\n order: { createdAt: 'DESC' }\n })\n\n if (foundWS) {\n await tx.getRepository(Worksheet).update(\n { id: foundWS.id },\n {\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n )\n\n if (pickedOIs && pickedOIs.length) {\n let pickedWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: {\n domain: { id: domain.id },\n targetInventory: In(pickedOIs.map(oi => oi.id)),\n status: ORDER_INVENTORY_STATUS.DONE,\n worksheet: { id: foundWS.id }\n }\n })\n\n pickedWSD = pickedWSD.map((wsd: WorksheetDetail) => {\n return {\n ...wsd,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(WorksheetDetail).save(pickedWSD)\n\n let replacedWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: {\n domain: { id: domain.id },\n targetInventory: In(pickedOIs.map(oi => oi.id)),\n status: ORDER_INVENTORY_STATUS.REPLACED,\n worksheet: { id: foundWS.id }\n },\n relations: ['targetInventory']\n })\n\n if (replacedWSD && replacedWSD.length) {\n let replacedOI: OrderInventory[] = replacedWSD.map((wsd: WorksheetDetail) => wsd.targetInventory)\n replacedOI = replacedOI.map((oi: OrderInventory) => {\n return {\n ...oi,\n status: ORDER_INVENTORY_STATUS.REPLACED,\n updater: user\n }\n })\n await tx.getRepository(OrderInventory).save(replacedOI)\n }\n }\n\n if (pickingOIs && pickingOIs.length) {\n let pickingWSD: WorksheetDetail[] = await tx.getRepository(WorksheetDetail).find({\n where: {\n domain: { id: domain.id },\n targetInventory: In(pickingOIs.map(oi => oi.id)),\n worksheet: { id: foundWS.id }\n }\n })\n\n pickingWSD = pickingWSD.map((wsd: WorksheetDetail) => {\n return {\n ...wsd,\n status: ORDER_INVENTORY_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(WorksheetDetail).save(pickingWSD)\n }\n }\n\n // find DO and change status to pending cancel\n let foundDO: DeliveryOrder[] = await tx.getRepository(DeliveryOrder).find({\n where: { domain: { id: domain.id }, releaseGood: foundRO }\n })\n\n foundDO = foundDO.map((deliveryOrder: DeliveryOrder) => {\n return {\n ...deliveryOrder,\n status: ORDER_STATUS.PENDING_CANCEL,\n updater: user\n }\n })\n await tx.getRepository(DeliveryOrder).save(foundDO)\n\n await tx.getRepository(ReleaseGood).save({\n ...foundRO,\n status: ORDER_STATUS.PENDING_CANCEL,\n updater: user\n })\n\n /**\n * @notes Temporary off sendNotification due to suspect of causing wms down\n */\n // // notification logics\n // // get Office Admin Users\n // const users: any[] = await tx\n // .getRepository('users_roles')\n // .createQueryBuilder('ur')\n // .select('ur.users_id', 'id')\n // .where(qb => {\n // const subQuery = qb\n // .subQuery()\n // .select('role.id')\n // .from(Role, 'role')\n // .where(\"role.name = 'Office Admin'\")\n // .andWhere('role.domain_id = :domain', { domain: domain.id })\n // .getQuery()\n // return 'ur.roles_id IN ' + subQuery\n // })\n // .getRawMany()\n\n // // send notification to Office Admin Users\n // if (users?.length && context.header?.referer) {\n // const receivers: any[] = users.map(user => user.id)\n // const msg = {\n // title: `${foundRO.name} cancellation`,\n // body: `${customerBizplace.name} is requesting to cancel order`,\n // url: context.header.referer,\n // data: { url: context.header.referer }\n // }\n\n // await sendNotification({\n // receivers,\n // message: { ...msg }\n // })\n // }\n\n return\n }\n}\n"]}
|
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.activateBatchPicking = exports.activateBatchPickingResolver = void 0;
|
|
4
4
|
const integration_marketplace_1 = require("@things-factory/integration-marketplace");
|
|
5
|
-
const integration_sellercraft_1 = require("@things-factory/integration-sellercraft");
|
|
6
5
|
const controllers_1 = require("../../../../controllers");
|
|
7
6
|
exports.activateBatchPickingResolver = {
|
|
8
7
|
async activateBatchPicking(_, { worksheetNo }, context) {
|
|
@@ -15,24 +14,6 @@ async function activateBatchPicking(tx, domain, user, worksheetNo) {
|
|
|
15
14
|
const worksheet = await worksheetController.activateBatchPicking(worksheetNo);
|
|
16
15
|
const worksheetDetails = worksheet.worksheetDetails;
|
|
17
16
|
const companyDomain = worksheet === null || worksheet === void 0 ? void 0 : worksheet.bizplace.company.domain;
|
|
18
|
-
const sellercraft = await tx
|
|
19
|
-
.getRepository(integration_sellercraft_1.Sellercraft)
|
|
20
|
-
.findOne({ domain: worksheet.bizplace.domain, status: integration_sellercraft_1.SellercraftStatus.ACTIVE });
|
|
21
|
-
if (sellercraft) {
|
|
22
|
-
const releaseGoods = worksheetDetails.map(worksheetDetail => worksheetDetail.targetInventory && worksheetDetail.targetInventory.releaseGood);
|
|
23
|
-
const uniqueReleaseGoods = [];
|
|
24
|
-
const map = new Map();
|
|
25
|
-
for (const releaseGood of releaseGoods) {
|
|
26
|
-
if (!map.has(releaseGood.id)) {
|
|
27
|
-
map.set(releaseGood.id, true);
|
|
28
|
-
uniqueReleaseGoods.push(Object.assign({}, releaseGood));
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
await Promise.all(uniqueReleaseGoods.map(async (releaseGood) => {
|
|
32
|
-
const sellercraftCtrl = new controllers_1.SellercraftController(tx, domain, user);
|
|
33
|
-
await sellercraftCtrl.initiateOrderShipment(sellercraft, releaseGood);
|
|
34
|
-
}));
|
|
35
|
-
}
|
|
36
17
|
// find for any existing marketplace store connections
|
|
37
18
|
const marketplaceStores = await tx.getRepository(integration_marketplace_1.MarketplaceStore).find({
|
|
38
19
|
where: { domain: companyDomain, status: 'ACTIVE', isAutoUpdateStockQty: true },
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"activate-batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/activate-batch-picking.ts"],"names":[],"mappings":";;;AAGA,qFAA0E;
|
|
1
|
+
{"version":3,"file":"activate-batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/activate-batch-picking.ts"],"names":[],"mappings":";;;AAGA,qFAA0E;AAG1E,yDAAyF;AAG5E,QAAA,4BAA4B,GAAG;IAC1C,KAAK,CAAC,oBAAoB,CAAC,CAAM,EAAE,EAAE,WAAW,EAAE,EAAE,OAAwB;QAC1E,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAC1C,OAAO,MAAM,oBAAoB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,CAAC,CAAA;IAClE,CAAC;CACF,CAAA;AAEM,KAAK,UAAU,oBAAoB,CACxC,EAAiB,EACjB,MAAc,EACd,IAAU,EACV,WAAmB;IAEnB,MAAM,mBAAmB,GAA+B,IAAI,wCAA0B,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;IACxG,MAAM,SAAS,GAAG,MAAM,mBAAmB,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAA;IAC7E,MAAM,gBAAgB,GAAG,SAAS,CAAC,gBAAgB,CAAA;IACnD,MAAM,aAAa,GAAW,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAA;IAEhE,sDAAsD;IACtD,MAAM,iBAAiB,GAAuB,MAAM,EAAE,CAAC,aAAa,CAAC,0CAAgB,CAAC,CAAC,IAAI,CAAC;QAC1F,KAAK,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,oBAAoB,EAAE,IAAI,EAAE;QAC9E,SAAS,EAAE,CAAC,yBAAyB,CAAC;KACvC,CAAC,CAAA;IAEF,IAAI,CAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,MAAM,KAAI,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,oBAAoB,CAAC,EAAE;QAC5F,IAAI,gBAAgB,GAAU,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;QAC9E,MAAM,aAAa,GAAwB,IAAI,iCAAmB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;QACpF,MAAM,aAAa,CAAC,2BAA2B,CAAC,iBAAiB,EAAE,gBAAgB,EAAE,aAAa,CAAC,CAAA;KACpG;IACD,OAAO,SAAS,CAAA;AAClB,CAAC;AAvBD,oDAuBC","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { MarketplaceStore } from '@things-factory/integration-marketplace'\nimport { Domain } from '@things-factory/shell'\n\nimport { EcommerceController, PickingWorksheetController } from '../../../../controllers'\nimport { Worksheet } from '../../../../entities'\n\nexport const activateBatchPickingResolver = {\n async activateBatchPicking(_: any, { worksheetNo }, context: ResolverContext) {\n const { tx, domain, user } = context.state\n return await activateBatchPicking(tx, domain, user, worksheetNo)\n }\n}\n\nexport async function activateBatchPicking(\n tx: EntityManager,\n domain: Domain,\n user: User,\n worksheetNo: string\n): Promise<Worksheet> {\n const worksheetController: PickingWorksheetController = new PickingWorksheetController(tx, domain, user)\n const worksheet = await worksheetController.activateBatchPicking(worksheetNo)\n const worksheetDetails = worksheet.worksheetDetails\n const companyDomain: Domain = worksheet?.bizplace.company.domain\n\n // find for any existing marketplace store connections\n const marketplaceStores: MarketplaceStore[] = await tx.getRepository(MarketplaceStore).find({\n where: { domain: companyDomain, status: 'ACTIVE', isAutoUpdateStockQty: true },\n relations: ['marketplaceDistributors']\n })\n\n if (marketplaceStores?.length && marketplaceStores.some(store => store.isAutoUpdateStockQty)) {\n let orderInventories: any[] = worksheetDetails.map(wsd => wsd.targetInventory)\n const ecommerceCtrl: EcommerceController = new EcommerceController(tx, domain, user)\n await ecommerceCtrl.updateProductVariationStock(marketplaceStores, orderInventories, companyDomain)\n }\n return worksheet\n}\n"]}
|
|
@@ -25,7 +25,7 @@ async function activatePicking(tx, domain, user, worksheetNo) {
|
|
|
25
25
|
if (releaseGood.type === 'b2c') {
|
|
26
26
|
const sellercraft = await tx
|
|
27
27
|
.getRepository(integration_sellercraft_1.Sellercraft)
|
|
28
|
-
.
|
|
28
|
+
.findOneBy({ domain: worksheet.bizplace.domain, status: integration_sellercraft_1.SellercraftStatus.ACTIVE });
|
|
29
29
|
if ((marketplaceStores === null || marketplaceStores === void 0 ? void 0 : marketplaceStores.length) && !sellercraft) {
|
|
30
30
|
if (marketplaceStores.some(store => store.isAutoUpdateStockQty)) {
|
|
31
31
|
const worksheetDetails = worksheet.worksheetDetails;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"activate-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/activate-picking.ts"],"names":[],"mappings":";;;AAGA,qFAA0E;AAC1E,qFAAwF;AACxF,uEAAmE;AACnE,2DAAsE;AAGtE,yDAAyF;AAG5E,QAAA,uBAAuB,GAAG;IACrC,KAAK,CAAC,eAAe,CAAC,CAAM,EAAE,EAAE,WAAW,EAAE,EAAE,
|
|
1
|
+
{"version":3,"file":"activate-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/activate-picking.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { MarketplaceStore } from '@things-factory/integration-marketplace'\nimport { Sellercraft, SellercraftStatus } from '@things-factory/integration-sellercraft'\nimport { MarketplaceOrder } from '@things-factory/marketplace-base'\nimport { ORDER_STATUS, ReleaseGood } from '@things-factory/sales-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { EcommerceController, PickingWorksheetController } from '../../../../controllers'\nimport { Worksheet } from '../../../../entities'\n\nexport const activatePickingResolver = {\n async activatePicking(_: any, { worksheetNo }, context: ResolverContext) {\n const { tx, domain, user } = context.state\n return await activatePicking(tx, domain, user, worksheetNo)\n }\n}\n\nexport async function activatePicking(\n tx: EntityManager,\n domain: Domain,\n user: User,\n worksheetNo: string\n): Promise<Worksheet> {\n const worksheetController: PickingWorksheetController = new PickingWorksheetController(tx, domain, user)\n const worksheet = await worksheetController.activatePicking(worksheetNo)\n const companyDomain: Domain = worksheet?.bizplace.company.domain\n\n // find for any existing marketplace store connections\n const marketplaceStores: MarketplaceStore[] = await tx.getRepository(MarketplaceStore).find({\n where: { domain: companyDomain, status: 'ACTIVE', isAutoUpdateStockQty: true },\n relations: ['marketplaceDistributors']\n })\n\n let releaseGood: ReleaseGood = worksheet.releaseGood\n\n if (releaseGood.type === 'b2c') {\n const sellercraft: Sellercraft = await tx\n .getRepository(Sellercraft)\n .findOneBy({ domain: worksheet.bizplace.domain, status: SellercraftStatus.ACTIVE })\n\n if (marketplaceStores?.length && !sellercraft) {\n if (marketplaceStores.some(store => store.isAutoUpdateStockQty)) {\n const worksheetDetails = worksheet.worksheetDetails\n let orderInventories: any[] = worksheetDetails.map(wsd => wsd.targetInventory)\n const ecommerceCtrl: EcommerceController = new EcommerceController(tx, domain, user)\n await ecommerceCtrl.updateProductVariationStock(marketplaceStores, orderInventories, companyDomain)\n }\n\n const marketplaceOrder: MarketplaceOrder = await tx.getRepository(MarketplaceOrder).findOne({\n where: { orderNo: releaseGood.refNo, domain: companyDomain },\n relations: ['marketplaceStore']\n })\n\n if (marketplaceOrder) {\n const marketplaceStore: MarketplaceStore = marketplaceOrder.marketplaceStore\n\n if (marketplaceStore.isAutoUpdateShipment) {\n const ecommerceCtrl: EcommerceController = new EcommerceController(tx, domain, user)\n await ecommerceCtrl.createOrderComment(marketplaceStore, marketplaceOrder, ORDER_STATUS.PICKING)\n }\n }\n }\n }\n\n return worksheet\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assign-picking-inventories.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/assign-picking-inventories.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"assign-picking-inventories.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/assign-picking-inventories.ts"],"names":[],"mappings":";;;AAKA,yDAAoE;AAGvD,QAAA,gCAAgC,GAAG;IAC9C,KAAK,CAAC,wBAAwB,CAC5B,CAAM,EACN,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,EAAE,gBAAgB,EAAE,EAC/E,OAAY;QAEZ,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAC1C,MAAM,wBAAwB,CAC5B,EAAE,EACF,MAAM,EACN,IAAI,EACJ,WAAW,EACX,OAAO,EACP,SAAS,EACT,WAAW,EACX,WAAW,EACX,gBAAgB,CACjB,CAAA;IACH,CAAC;CACF,CAAA;AAEM,KAAK,UAAU,wBAAwB,CAC5C,EAAiB,EACjB,MAAc,EACd,IAAU,EACV,WAAmB,EACnB,OAAe,EACf,SAAiB,EACjB,WAAmB,EACnB,WAAmB,EACnB,gBAA4C;IAE5C,MAAM,mBAAmB,GAA+B,IAAI,wCAA0B,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;IACxG,MAAM,mBAAmB,CAAC,wBAAwB,CAChD,WAAW,EACX,OAAO,EACP,SAAS,EACT,WAAW,EACX,WAAW,EACX,gBAAgB,CACjB,CAAA;AACH,CAAC;AApBD,4DAoBC","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { PickingWorksheetController } from '../../../../controllers'\nimport { WorksheetDetail } from '../../../../entities'\n\nexport const assignPickingInventoriesResolver = {\n async assignPickingInventories(\n _: any,\n { worksheetNo, batchId, productId, packingType, packingSize, worksheetDetails },\n context: any\n ): Promise<void> {\n const { tx, domain, user } = context.state\n await assignPickingInventories(\n tx,\n domain,\n user,\n worksheetNo,\n batchId,\n productId,\n packingType,\n packingSize,\n worksheetDetails\n )\n }\n}\n\nexport async function assignPickingInventories(\n tx: EntityManager,\n domain: Domain,\n user: User,\n worksheetNo: string,\n batchId: string,\n productId: string,\n packingType: string,\n packingSize: number,\n worksheetDetails: Partial<WorksheetDetail>[]\n): Promise<void> {\n const worksheetController: PickingWorksheetController = new PickingWorksheetController(tx, domain, user)\n await worksheetController.assignPickingInventories(\n worksheetNo,\n batchId,\n productId,\n packingType,\n packingSize,\n worksheetDetails\n )\n}\n"]}
|
|
@@ -1,23 +1,29 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.assignPickingWorkerResolver = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
4
5
|
const auth_base_1 = require("@things-factory/auth-base");
|
|
5
6
|
const constants_1 = require("../../../../constants");
|
|
6
7
|
const entities_1 = require("../../../../entities");
|
|
7
8
|
exports.assignPickingWorkerResolver = {
|
|
8
9
|
async assignPickingWorker(_parentObj, { worksheetId, userId }, context) {
|
|
9
10
|
const { tx, domain } = context.state;
|
|
10
|
-
const assignee = await tx.getRepository(auth_base_1.User).findOne(
|
|
11
|
+
const assignee = await tx.getRepository(auth_base_1.User).findOne({
|
|
12
|
+
where: { id: userId },
|
|
13
|
+
relations: ['domains']
|
|
14
|
+
});
|
|
11
15
|
if (((assignee === null || assignee === void 0 ? void 0 : assignee.domains) || []).every((userDomain) => userDomain.id !== domain.id))
|
|
12
16
|
throw new Error('Target user is not belong to current domain');
|
|
13
17
|
if (!assignee)
|
|
14
18
|
throw new Error('failed to find target user');
|
|
15
19
|
await Promise.all(worksheetId.map(async (worksheetId) => {
|
|
16
20
|
const worksheet = await tx.getRepository(entities_1.Worksheet).findOne({
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
+
where: {
|
|
22
|
+
id: worksheetId,
|
|
23
|
+
type: (0, typeorm_1.In)([constants_1.WORKSHEET_TYPE.BATCH_PICKING, constants_1.WORKSHEET_TYPE.PICKING])
|
|
24
|
+
}
|
|
25
|
+
/* CONFIRMME regarding TYPEORM */
|
|
26
|
+
});
|
|
21
27
|
if (!worksheet)
|
|
22
28
|
throw new Error('failed to find target picking worksheet');
|
|
23
29
|
if (worksheet.status !== constants_1.WORKSHEET_STATUS.DEACTIVATED)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assign-picking-worker.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/assign-picking-worker.ts"],"names":[],"mappings":";;;AAAA,yDAAgD;AAGhD,qDAAwE;AACxE,mDAAgD;AAEnC,QAAA,2BAA2B,GAAG;IACzC,KAAK,CAAC,mBAAmB,CACvB,UAAgB,EAChB,EAAE,WAAW,EAAE,MAAM,EAA6C,EAClE,OAAY;QAEZ,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"assign-picking-worker.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/assign-picking-worker.ts"],"names":[],"mappings":";;;AAAA,qCAA4B;AAE5B,yDAAgD;AAGhD,qDAAwE;AACxE,mDAAgD;AAEnC,QAAA,2BAA2B,GAAG;IACzC,KAAK,CAAC,mBAAmB,CACvB,UAAgB,EAChB,EAAE,WAAW,EAAE,MAAM,EAA6C,EAClE,OAAY;QAEZ,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QACpC,MAAM,QAAQ,GAAS,MAAM,EAAE,CAAC,aAAa,CAAC,gBAAI,CAAC,CAAC,OAAO,CAAC;YAC1D,KAAK,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE;YACrB,SAAS,EAAE,CAAC,SAAS,CAAC;SACvB,CAAC,CAAA;QACF,IAAI,CAAC,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,KAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,UAAkB,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,KAAK,MAAM,CAAC,EAAE,CAAC;YACtF,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;QAEhE,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;QAE5D,MAAM,OAAO,CAAC,GAAG,CACf,WAAW,CAAC,GAAG,CAAC,KAAK,EAAC,WAAW,EAAC,EAAE;YAClC,MAAM,SAAS,GAAc,MAAM,EAAE,CAAC,aAAa,CAAC,oBAAS,CAAC,CAAC,OAAO,CAAC;gBACrE,KAAK,EAAE;oBACL,EAAE,EAAE,WAAW;oBACf,IAAI,EAAE,IAAA,YAAE,EAAC,CAAC,0BAAc,CAAC,aAAa,EAAE,0BAAc,CAAC,OAAO,CAAC,CAAC;iBACjE;gBACD,iCAAiC;aAClC,CAAC,CAAA;YAEF,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAA;YAC1E,IAAI,SAAS,CAAC,MAAM,KAAK,4BAAgB,CAAC,WAAW;gBACnD,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAA;YAE7E,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAA;YAC7B,MAAM,EAAE,CAAC,aAAa,CAAC,oBAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACnD,CAAC,CAAC,CACH,CAAA;IACH,CAAC;CACF,CAAA","sourcesContent":["import { In } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../../constants'\nimport { Worksheet } from '../../../../entities'\n\nexport const assignPickingWorkerResolver = {\n async assignPickingWorker(\n _parentObj: void,\n { worksheetId, userId }: { worksheetId: [string]; userId: string },\n context: any\n ): Promise<void> {\n const { tx, domain } = context.state\n const assignee: User = await tx.getRepository(User).findOne({\n where: { id: userId },\n relations: ['domains']\n })\n if ((assignee?.domains || []).every((userDomain: Domain) => userDomain.id !== domain.id))\n throw new Error('Target user is not belong to current domain')\n\n if (!assignee) throw new Error('failed to find target user')\n\n await Promise.all(\n worksheetId.map(async worksheetId => {\n const worksheet: Worksheet = await tx.getRepository(Worksheet).findOne({\n where: {\n id: worksheetId,\n type: In([WORKSHEET_TYPE.BATCH_PICKING, WORKSHEET_TYPE.PICKING])\n }\n /* CONFIRMME regarding TYPEORM */\n })\n\n if (!worksheet) throw new Error('failed to find target picking worksheet')\n if (worksheet.status !== WORKSHEET_STATUS.DEACTIVATED)\n throw new Error(`current status of worksheet is not able to assign worker`)\n\n worksheet.assignee = assignee\n await tx.getRepository(Worksheet).save(worksheet)\n })\n )\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/batch-picking.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/batch-picking.ts"],"names":[],"mappings":";;;AAKA,yDAAoE;AAEvD,QAAA,oBAAoB,GAAG;IAClC,KAAK,CAAC,YAAY,CAChB,CAAM,EACN,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,UAAU,EAAE,EAC9E,OAAY;QAEZ,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAC1C,MAAM,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,UAAU,CAAC,CAAA;IAClH,CAAC;CACF,CAAA;AAEM,KAAK,UAAU,YAAY,CAChC,EAAiB,EACjB,MAAc,EACd,IAAU,EACV,MAAc,EACd,aAAqB,EACrB,QAAgB,EAChB,YAAoB,EACpB,eAAuB,EACvB,UAAkB;IAElB,MAAM,mBAAmB,GAA+B,IAAI,wCAA0B,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;IACxG,MAAM,mBAAmB,CAAC,YAAY,CAAC,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,UAAU,CAAC,CAAA;AACpH,CAAC;AAbD,oCAaC","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { PickingWorksheetController } from '../../../../controllers'\n\nexport const batchPickingResolver = {\n async batchPicking(\n _: any,\n { taskNo, worksheetType, palletId, locationName, binLocationName, releaseQty },\n context: any\n ) {\n const { tx, domain, user } = context.state\n await batchPicking(tx, domain, user, taskNo, worksheetType, palletId, locationName, binLocationName, releaseQty)\n }\n}\n\nexport async function batchPicking(\n tx: EntityManager,\n domain: Domain,\n user: User,\n taskNo: string,\n worksheetType: string,\n palletId: string,\n locationName: string,\n binLocationName: string,\n releaseQty: number\n) {\n const worksheetController: PickingWorksheetController = new PickingWorksheetController(tx, domain, user)\n await worksheetController.batchPicking(taskNo, worksheetType, palletId, locationName, binLocationName, releaseQty)\n}\n"]}
|
|
@@ -24,10 +24,12 @@ async function completeBatchPicking(tx, domain, user, taskNo) {
|
|
|
24
24
|
const pickingWSCtrl = new controllers_1.PickingWorksheetController(tx, domain, user);
|
|
25
25
|
const worksheet = await pickingWSCtrl.completeBatchPicking(taskNo);
|
|
26
26
|
const worksheetDetails = worksheet.worksheetDetails;
|
|
27
|
-
const targetInventories = worksheetDetails
|
|
27
|
+
const targetInventories = worksheetDetails
|
|
28
|
+
.filter(wsd => wsd.status != 'MISSING')
|
|
29
|
+
.map((wsd) => wsd.targetInventory);
|
|
28
30
|
const sellercraft = await tx
|
|
29
31
|
.getRepository(integration_sellercraft_1.Sellercraft)
|
|
30
|
-
.
|
|
32
|
+
.findOneBy({ domain: worksheet.bizplace.domain, status: integration_sellercraft_1.SellercraftStatus.ACTIVE });
|
|
31
33
|
if (sellercraft) {
|
|
32
34
|
const releaseGoods = worksheetDetails.map(worksheetDetail => worksheetDetail.targetInventory && worksheetDetail.targetInventory.releaseGood);
|
|
33
35
|
const uniqueReleaseGoods = [];
|
|
@@ -46,9 +48,13 @@ async function completeBatchPicking(tx, domain, user, taskNo) {
|
|
|
46
48
|
});
|
|
47
49
|
if (!(foundReleaseGood === null || foundReleaseGood === void 0 ? void 0 : foundReleaseGood.packageId)) {
|
|
48
50
|
foundReleaseGood = await sellercraftCtrl.packOrder(sellercraft, foundReleaseGood);
|
|
51
|
+
if (foundReleaseGood === null || foundReleaseGood === void 0 ? void 0 : foundReleaseGood.packageId) {
|
|
52
|
+
await tx
|
|
53
|
+
.getRepository(sales_base_1.ReleaseGood)
|
|
54
|
+
.update({ id: foundReleaseGood.id }, { packageId: foundReleaseGood.packageId, updater: foundReleaseGood.updater });
|
|
55
|
+
}
|
|
49
56
|
}
|
|
50
|
-
|
|
51
|
-
await sellercraftCtrl.initiateOrderDocument(sellercraft, foundReleaseGood);
|
|
57
|
+
sellercraftCtrl.initiateOrderShipment(sellercraft, foundReleaseGood);
|
|
52
58
|
}));
|
|
53
59
|
}
|
|
54
60
|
const pickPackTargetInventories = targetInventories
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"complete-batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts"],"names":[],"mappings":";;;AAGA,uDAAkE;AAClE,qFAAwF;AACxF,2DAAwE;AAGxE,0DAKiC;AACjC,uFAAkF;AAGrE,QAAA,4BAA4B,GAAG;IAC1C,KAAK,CAAC,oBAAoB,CAAC,CAAM,EAAE,EAAE,MAAM,EAAE,EAAE,
|
|
1
|
+
{"version":3,"file":"complete-batch-picking.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts"],"names":[],"mappings":"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","sourcesContent":["import { EntityManager } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Bizplace, getMyBizplace } from '@things-factory/biz-base'\nimport { Sellercraft, SellercraftStatus } from '@things-factory/integration-sellercraft'\nimport { OrderInventory, ReleaseGood } from '@things-factory/sales-base'\nimport { Domain } from '@things-factory/shell'\n\nimport {\n PackingWorksheetController,\n PickingWorksheetController,\n SellercraftController,\n SortingWorksheetController\n} from '../../../../controllers/'\nimport { WorksheetController } from '../../../../controllers/worksheet-controller'\nimport { Worksheet, WorksheetDetail } from '../../../../entities'\n\nexport const completeBatchPickingResolver = {\n async completeBatchPicking(_: any, { taskNo }, context: ResolverContext) {\n const { tx, domain, user } = context.state\n\n await completeBatchPicking(tx, domain, user, taskNo)\n\n const bizplace: Bizplace = await getMyBizplace(domain, user)\n const worksheetController: WorksheetController = new WorksheetController(tx, domain, user)\n await worksheetController.notifyToCustomer(bizplace, {\n title: `Picking has been completed (${bizplace.name}, ${taskNo})`,\n body: `Items now are ready for sorting`,\n url: context.header.referer,\n data: { url: context.header.referer }\n })\n }\n}\n\nexport async function completeBatchPicking(\n tx: EntityManager,\n domain: Domain,\n user: User,\n taskNo: string\n): Promise<void> {\n const pickingWSCtrl: PickingWorksheetController = new PickingWorksheetController(tx, domain, user)\n const worksheet = await pickingWSCtrl.completeBatchPicking(taskNo)\n\n const worksheetDetails: WorksheetDetail[] = worksheet.worksheetDetails\n const targetInventories: OrderInventory[] = worksheetDetails\n .filter(wsd => wsd.status != 'MISSING')\n .map((wsd: WorksheetDetail) => wsd.targetInventory)\n\n const sellercraft: Sellercraft = await tx\n .getRepository(Sellercraft)\n .findOneBy({ domain: worksheet.bizplace.domain, status: SellercraftStatus.ACTIVE })\n\n if (sellercraft) {\n const releaseGoods: ReleaseGood[] = worksheetDetails.map(\n worksheetDetail => worksheetDetail.targetInventory && worksheetDetail.targetInventory.releaseGood\n )\n const uniqueReleaseGoods: ReleaseGood[] = []\n const map = new Map()\n for (const releaseGood of releaseGoods) {\n if (!map.has(releaseGood.id)) {\n map.set(releaseGood.id, true)\n uniqueReleaseGoods.push({ ...releaseGood })\n }\n }\n\n await Promise.all(\n uniqueReleaseGoods.map(async releaseGood => {\n const sellercraftCtrl: SellercraftController = new SellercraftController(tx, domain, user)\n\n let foundReleaseGood: ReleaseGood = await tx.getRepository(ReleaseGood).findOne({\n where: { id: releaseGood.id },\n relations: ['orderProducts', 'orderProducts.product', 'orderProducts.product.productDetails']\n })\n\n if (!foundReleaseGood?.packageId) {\n foundReleaseGood = await sellercraftCtrl.packOrder(sellercraft, foundReleaseGood)\n if (foundReleaseGood?.packageId) {\n await tx\n .getRepository(ReleaseGood)\n .update(\n { id: foundReleaseGood.id },\n { packageId: foundReleaseGood.packageId, updater: foundReleaseGood.updater }\n )\n }\n }\n\n sellercraftCtrl.initiateOrderShipment(sellercraft, foundReleaseGood)\n })\n )\n }\n\n const pickPackTargetInventories: OrderInventory[] = targetInventories\n .filter(targetInventory => targetInventory.releaseGood.packingOption)\n .map((pickPackTargetInventory: OrderInventory) => {\n return pickPackTargetInventory\n })\n\n const pickSortTargetInventories: OrderInventory[] = targetInventories\n .filter(targetInventory => !targetInventory.releaseGood.packingOption)\n .map((pickSortTargetInventory: OrderInventory) => {\n return pickSortTargetInventory\n })\n\n if (pickPackTargetInventories?.length) {\n // pull out all unique RO\n const roNoList: string[] = pickPackTargetInventories.map((oi: OrderInventory) => oi.releaseGood.name)\n let uniqueRoNo: string[] = []\n roNoList.forEach(roNo => {\n if (!uniqueRoNo.includes(roNo)) {\n uniqueRoNo.push(roNo)\n }\n })\n\n // loop to generate packing worksheet\n for (var i: number = 0; i < uniqueRoNo.length; i++) {\n const releaseGoodNo: string = uniqueRoNo[i]\n const packingWSCtrl: PackingWorksheetController = new PackingWorksheetController(tx, domain, user)\n await packingWSCtrl.generatePackingWorksheet(releaseGoodNo)\n }\n }\n\n if (pickSortTargetInventories?.length) {\n const sortingWSCtrl: SortingWorksheetController = new SortingWorksheetController(tx, domain, user)\n const sortingWorksheet: Worksheet = await sortingWSCtrl.generateSortingWorksheet(\n worksheet,\n pickSortTargetInventories\n )\n\n await sortingWSCtrl.activateSorting(sortingWorksheet.name, sortingWorksheet.worksheetDetails)\n }\n}\n"]}
|