@things-factory/operato-hub 4.3.670 → 4.3.671

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (531) hide show
  1. package/config.development.js +20 -12
  2. package/openapi/v1/inbound.yaml +12 -1
  3. package/openapi/v1/outbound.yaml +11 -1
  4. package/openapi/v1/upload-attachments.yaml +83 -0
  5. package/package.json +45 -45
  6. package/server/routers/api/restful-apis/v1/middlewares/validation-middleware.ts +95 -0
  7. package/server/routers/api/restful-apis/v1/utils/params.ts +7 -3
  8. package/server/routers/api/restful-apis/v1/warehouse/add-inbound-order.ts +22 -2
  9. package/server/routers/api/restful-apis/v1/warehouse/add-release-order.ts +23 -2
  10. package/server/routers/api/restful-apis/v1/warehouse/index.ts +2 -1
  11. package/server/routers/api/restful-apis/v1/warehouse/upload-attachments.ts +113 -0
  12. package/dist-server/controllers/bizplace-initializer/codes.js +0 -21
  13. package/dist-server/controllers/bizplace-initializer/codes.js.map +0 -1
  14. package/dist-server/controllers/bizplace-initializer/dataset/codes.js +0 -403
  15. package/dist-server/controllers/bizplace-initializer/dataset/codes.js.map +0 -1
  16. package/dist-server/controllers/bizplace-initializer/dataset/groups.js +0 -24
  17. package/dist-server/controllers/bizplace-initializer/dataset/groups.js.map +0 -1
  18. package/dist-server/controllers/bizplace-initializer/dataset/index.js +0 -22
  19. package/dist-server/controllers/bizplace-initializer/dataset/index.js.map +0 -1
  20. package/dist-server/controllers/bizplace-initializer/dataset/menus.js +0 -504
  21. package/dist-server/controllers/bizplace-initializer/dataset/menus.js.map +0 -1
  22. package/dist-server/controllers/bizplace-initializer/dataset/roles-privileges.js +0 -406
  23. package/dist-server/controllers/bizplace-initializer/dataset/roles-privileges.js.map +0 -1
  24. package/dist-server/controllers/bizplace-initializer/dataset/settings.js +0 -112
  25. package/dist-server/controllers/bizplace-initializer/dataset/settings.js.map +0 -1
  26. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain-roles.js +0 -26
  27. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain-roles.js.map +0 -1
  28. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain.js +0 -43
  29. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain.js.map +0 -1
  30. package/dist-server/controllers/bizplace-initializer/groups.js +0 -18
  31. package/dist-server/controllers/bizplace-initializer/groups.js.map +0 -1
  32. package/dist-server/controllers/bizplace-initializer/index.js +0 -22
  33. package/dist-server/controllers/bizplace-initializer/index.js.map +0 -1
  34. package/dist-server/controllers/bizplace-initializer/menus.js +0 -28
  35. package/dist-server/controllers/bizplace-initializer/menus.js.map +0 -1
  36. package/dist-server/controllers/bizplace-initializer/settings.js +0 -16
  37. package/dist-server/controllers/bizplace-initializer/settings.js.map +0 -1
  38. package/dist-server/controllers/company-initializer/business-register.js +0 -48
  39. package/dist-server/controllers/company-initializer/business-register.js.map +0 -1
  40. package/dist-server/controllers/company-initializer/codes.js +0 -137
  41. package/dist-server/controllers/company-initializer/codes.js.map +0 -1
  42. package/dist-server/controllers/company-initializer/generate-company-roles.js +0 -117
  43. package/dist-server/controllers/company-initializer/generate-company-roles.js.map +0 -1
  44. package/dist-server/controllers/company-initializer/index.js +0 -23
  45. package/dist-server/controllers/company-initializer/index.js.map +0 -1
  46. package/dist-server/controllers/company-initializer/menus.js +0 -348
  47. package/dist-server/controllers/company-initializer/menus.js.map +0 -1
  48. package/dist-server/controllers/company-initializer/settings.js +0 -36
  49. package/dist-server/controllers/company-initializer/settings.js.map +0 -1
  50. package/dist-server/controllers/company-initializer/transporter.js +0 -18
  51. package/dist-server/controllers/company-initializer/transporter.js.map +0 -1
  52. package/dist-server/controllers/index.js +0 -1
  53. package/dist-server/controllers/index.js.map +0 -1
  54. package/dist-server/controllers/invitation.js +0 -118
  55. package/dist-server/controllers/invitation.js.map +0 -1
  56. package/dist-server/controllers/utils/make-invitation-token.js +0 -12
  57. package/dist-server/controllers/utils/make-invitation-token.js.map +0 -1
  58. package/dist-server/controllers/utils/save-invitation-token.js +0 -13
  59. package/dist-server/controllers/utils/save-invitation-token.js.map +0 -1
  60. package/dist-server/entities/email-attachment.js +0 -81
  61. package/dist-server/entities/email-attachment.js.map +0 -1
  62. package/dist-server/entities/email-recipient.js +0 -69
  63. package/dist-server/entities/email-recipient.js.map +0 -1
  64. package/dist-server/entities/email.js +0 -98
  65. package/dist-server/entities/email.js.map +0 -1
  66. package/dist-server/entities/index.js +0 -11
  67. package/dist-server/entities/index.js.map +0 -1
  68. package/dist-server/errors/index.js +0 -18
  69. package/dist-server/errors/index.js.map +0 -1
  70. package/dist-server/errors/validation-error.js +0 -14
  71. package/dist-server/errors/validation-error.js.map +0 -1
  72. package/dist-server/graphql/index.js +0 -33
  73. package/dist-server/graphql/index.js.map +0 -1
  74. package/dist-server/graphql/resolvers/email/index.js +0 -6
  75. package/dist-server/graphql/resolvers/email/index.js.map +0 -1
  76. package/dist-server/graphql/resolvers/email/send-emails.js +0 -263
  77. package/dist-server/graphql/resolvers/email/send-emails.js.map +0 -1
  78. package/dist-server/graphql/resolvers/generators/generate-bizplace.js +0 -39
  79. package/dist-server/graphql/resolvers/generators/generate-bizplace.js.map +0 -1
  80. package/dist-server/graphql/resolvers/generators/generate-company.js +0 -62
  81. package/dist-server/graphql/resolvers/generators/generate-company.js.map +0 -1
  82. package/dist-server/graphql/resolvers/generators/index.js +0 -8
  83. package/dist-server/graphql/resolvers/generators/index.js.map +0 -1
  84. package/dist-server/graphql/resolvers/generators/update-domain-extType.js +0 -45
  85. package/dist-server/graphql/resolvers/generators/update-domain-extType.js.map +0 -1
  86. package/dist-server/graphql/resolvers/index.js +0 -35
  87. package/dist-server/graphql/resolvers/index.js.map +0 -1
  88. package/dist-server/graphql/resolvers/invitations/index.js +0 -6
  89. package/dist-server/graphql/resolvers/invitations/index.js.map +0 -1
  90. package/dist-server/graphql/resolvers/invitations/partner-invitation.js +0 -52
  91. package/dist-server/graphql/resolvers/invitations/partner-invitation.js.map +0 -1
  92. package/dist-server/graphql/resolvers/oauth2/company-roles-by-scope.js +0 -30
  93. package/dist-server/graphql/resolvers/oauth2/company-roles-by-scope.js.map +0 -1
  94. package/dist-server/graphql/resolvers/oauth2/index.js +0 -6
  95. package/dist-server/graphql/resolvers/oauth2/index.js.map +0 -1
  96. package/dist-server/graphql/resolvers/reports/admiral-asn-report.js +0 -127
  97. package/dist-server/graphql/resolvers/reports/admiral-asn-report.js.map +0 -1
  98. package/dist-server/graphql/resolvers/reports/asn-report.js +0 -126
  99. package/dist-server/graphql/resolvers/reports/asn-report.js.map +0 -1
  100. package/dist-server/graphql/resolvers/reports/custom/elccl/aging-report.js +0 -157
  101. package/dist-server/graphql/resolvers/reports/custom/elccl/aging-report.js.map +0 -1
  102. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-dispatch-report.js +0 -74
  103. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-dispatch-report.js.map +0 -1
  104. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-monthly-dispatch-report.js +0 -99
  105. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-monthly-dispatch-report.js.map +0 -1
  106. package/dist-server/graphql/resolvers/reports/custom/elccl/export-report.js +0 -156
  107. package/dist-server/graphql/resolvers/reports/custom/elccl/export-report.js.map +0 -1
  108. package/dist-server/graphql/resolvers/reports/custom/posmy/custom-posmy-aging-report.js +0 -131
  109. package/dist-server/graphql/resolvers/reports/custom/posmy/custom-posmy-aging-report.js.map +0 -1
  110. package/dist-server/graphql/resolvers/reports/custom/yltc/custom-yltc-inventory-report.js +0 -216
  111. package/dist-server/graphql/resolvers/reports/custom/yltc/custom-yltc-inventory-report.js.map +0 -1
  112. package/dist-server/graphql/resolvers/reports/inbound-order-details-report.js +0 -189
  113. package/dist-server/graphql/resolvers/reports/inbound-order-details-report.js.map +0 -1
  114. package/dist-server/graphql/resolvers/reports/index.js +0 -17
  115. package/dist-server/graphql/resolvers/reports/index.js.map +0 -1
  116. package/dist-server/graphql/resolvers/reports/outbound-order-details-report.js +0 -231
  117. package/dist-server/graphql/resolvers/reports/outbound-order-details-report.js.map +0 -1
  118. package/dist-server/graphql/resolvers/reports/receiving-report.js +0 -103
  119. package/dist-server/graphql/resolvers/reports/receiving-report.js.map +0 -1
  120. package/dist-server/graphql/resolvers/reports/shortage-report.js +0 -164
  121. package/dist-server/graphql/resolvers/reports/shortage-report.js.map +0 -1
  122. package/dist-server/graphql/resolvers/synchronization/auto-update-all-marketplace-product-variation-quantity.js +0 -187
  123. package/dist-server/graphql/resolvers/synchronization/auto-update-all-marketplace-product-variation-quantity.js.map +0 -1
  124. package/dist-server/graphql/resolvers/synchronization/create-dat-shipments.js +0 -58
  125. package/dist-server/graphql/resolvers/synchronization/create-dat-shipments.js.map +0 -1
  126. package/dist-server/graphql/resolvers/synchronization/fetch-sync-invoices.js +0 -41
  127. package/dist-server/graphql/resolvers/synchronization/fetch-sync-invoices.js.map +0 -1
  128. package/dist-server/graphql/resolvers/synchronization/fetch-sync-products.js +0 -79
  129. package/dist-server/graphql/resolvers/synchronization/fetch-sync-products.js.map +0 -1
  130. package/dist-server/graphql/resolvers/synchronization/fetch-sync-purchase-orders.js +0 -57
  131. package/dist-server/graphql/resolvers/synchronization/fetch-sync-purchase-orders.js.map +0 -1
  132. package/dist-server/graphql/resolvers/synchronization/get-lmd-awb.js +0 -34
  133. package/dist-server/graphql/resolvers/synchronization/get-lmd-awb.js.map +0 -1
  134. package/dist-server/graphql/resolvers/synchronization/index.js +0 -30
  135. package/dist-server/graphql/resolvers/synchronization/index.js.map +0 -1
  136. package/dist-server/graphql/resolvers/synchronization/mms-retry-create-lmd-parcels.js +0 -70
  137. package/dist-server/graphql/resolvers/synchronization/mms-retry-create-lmd-parcels.js.map +0 -1
  138. package/dist-server/graphql/resolvers/synchronization/powrup-get-airway-bill.js +0 -78
  139. package/dist-server/graphql/resolvers/synchronization/powrup-get-airway-bill.js.map +0 -1
  140. package/dist-server/graphql/resolvers/synchronization/powrup-get-tracking-no.js +0 -61
  141. package/dist-server/graphql/resolvers/synchronization/powrup-get-tracking-no.js.map +0 -1
  142. package/dist-server/graphql/resolvers/synchronization/powrup-initiate-shipment.js +0 -88
  143. package/dist-server/graphql/resolvers/synchronization/powrup-initiate-shipment.js.map +0 -1
  144. package/dist-server/graphql/resolvers/synchronization/powrup-pack-order.js +0 -185
  145. package/dist-server/graphql/resolvers/synchronization/powrup-pack-order.js.map +0 -1
  146. package/dist-server/graphql/resolvers/synchronization/refresh-lmd-access-token.js +0 -72
  147. package/dist-server/graphql/resolvers/synchronization/refresh-lmd-access-token.js.map +0 -1
  148. package/dist-server/graphql/resolvers/synchronization/retry-create-lmd-parcels.js +0 -96
  149. package/dist-server/graphql/resolvers/synchronization/retry-create-lmd-parcels.js.map +0 -1
  150. package/dist-server/graphql/resolvers/synchronization/sellercraft-initiate-shipment.js +0 -97
  151. package/dist-server/graphql/resolvers/synchronization/sellercraft-initiate-shipment.js.map +0 -1
  152. package/dist-server/graphql/resolvers/synchronization/sellercraft-pack-marketplace-order.js +0 -202
  153. package/dist-server/graphql/resolvers/synchronization/sellercraft-pack-marketplace-order.js.map +0 -1
  154. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-powrup.js +0 -32
  155. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-powrup.js.map +0 -1
  156. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-sellercraft.js +0 -35
  157. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-sellercraft.js.map +0 -1
  158. package/dist-server/graphql/resolvers/synchronization/sync-products-from-account.js +0 -32
  159. package/dist-server/graphql/resolvers/synchronization/sync-products-from-account.js.map +0 -1
  160. package/dist-server/graphql/resolvers/synchronization/sync-products-to-account.js +0 -53
  161. package/dist-server/graphql/resolvers/synchronization/sync-products-to-account.js.map +0 -1
  162. package/dist-server/graphql/resolvers/synchronization/sync-products-to-powrup.js +0 -100
  163. package/dist-server/graphql/resolvers/synchronization/sync-products-to-powrup.js.map +0 -1
  164. package/dist-server/graphql/resolvers/synchronization/sync-products-to-sellercraft.js +0 -142
  165. package/dist-server/graphql/resolvers/synchronization/sync-products-to-sellercraft.js.map +0 -1
  166. package/dist-server/graphql/resolvers/synchronization/versafleet-fetch-driver-runsheet.js +0 -45
  167. package/dist-server/graphql/resolvers/synchronization/versafleet-fetch-driver-runsheet.js.map +0 -1
  168. package/dist-server/graphql/resolvers/synchronization/webspert-initiate-shipment.js +0 -37
  169. package/dist-server/graphql/resolvers/synchronization/webspert-initiate-shipment.js.map +0 -1
  170. package/dist-server/graphql/resolvers/synchronization/webspert-pack-and-get.js +0 -66
  171. package/dist-server/graphql/resolvers/synchronization/webspert-pack-and-get.js.map +0 -1
  172. package/dist-server/graphql/resolvers/synchronization/webspert-update-stocks.js +0 -27
  173. package/dist-server/graphql/resolvers/synchronization/webspert-update-stocks.js.map +0 -1
  174. package/dist-server/graphql/types/generators/generate-bizplace-input.js +0 -17
  175. package/dist-server/graphql/types/generators/generate-bizplace-input.js.map +0 -1
  176. package/dist-server/graphql/types/generators/generate-company-input.js +0 -17
  177. package/dist-server/graphql/types/generators/generate-company-input.js.map +0 -1
  178. package/dist-server/graphql/types/generators/index.js +0 -13
  179. package/dist-server/graphql/types/generators/index.js.map +0 -1
  180. package/dist-server/graphql/types/generators/update-domain-type-input.js +0 -14
  181. package/dist-server/graphql/types/generators/update-domain-type-input.js.map +0 -1
  182. package/dist-server/graphql/types/index.js +0 -35
  183. package/dist-server/graphql/types/index.js.map +0 -1
  184. package/dist-server/graphql/types/invitations/index.js +0 -9
  185. package/dist-server/graphql/types/invitations/index.js.map +0 -1
  186. package/dist-server/graphql/types/oauth2/company-role.js +0 -14
  187. package/dist-server/graphql/types/oauth2/company-role.js.map +0 -1
  188. package/dist-server/graphql/types/oauth2/index.js +0 -9
  189. package/dist-server/graphql/types/oauth2/index.js.map +0 -1
  190. package/dist-server/graphql/types/reports/admiral-asn-report-list.js +0 -14
  191. package/dist-server/graphql/types/reports/admiral-asn-report-list.js.map +0 -1
  192. package/dist-server/graphql/types/reports/admiral-asn-report.js +0 -21
  193. package/dist-server/graphql/types/reports/admiral-asn-report.js.map +0 -1
  194. package/dist-server/graphql/types/reports/asn-report-list.js +0 -14
  195. package/dist-server/graphql/types/reports/asn-report-list.js.map +0 -1
  196. package/dist-server/graphql/types/reports/asn-report.js +0 -21
  197. package/dist-server/graphql/types/reports/asn-report.js.map +0 -1
  198. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report-list.js +0 -14
  199. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report-list.js.map +0 -1
  200. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report.js +0 -31
  201. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report.js.map +0 -1
  202. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report-list.js +0 -14
  203. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report-list.js.map +0 -1
  204. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report.js +0 -26
  205. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report.js.map +0 -1
  206. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report-list.js +0 -14
  207. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report-list.js.map +0 -1
  208. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report.js +0 -31
  209. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report.js.map +0 -1
  210. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report-list.js +0 -13
  211. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report-list.js.map +0 -1
  212. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report.js +0 -28
  213. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report.js.map +0 -1
  214. package/dist-server/graphql/types/reports/custom/yltc/custom-yltc-inventory-report.js +0 -23
  215. package/dist-server/graphql/types/reports/custom/yltc/custom-yltc-inventory-report.js.map +0 -1
  216. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js +0 -14
  217. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js.map +0 -1
  218. package/dist-server/graphql/types/reports/inbound-order-details-report.js +0 -59
  219. package/dist-server/graphql/types/reports/inbound-order-details-report.js.map +0 -1
  220. package/dist-server/graphql/types/reports/index.js +0 -63
  221. package/dist-server/graphql/types/reports/index.js.map +0 -1
  222. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js +0 -14
  223. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js.map +0 -1
  224. package/dist-server/graphql/types/reports/outbound-order-details-report.js +0 -76
  225. package/dist-server/graphql/types/reports/outbound-order-details-report.js.map +0 -1
  226. package/dist-server/graphql/types/reports/receiving-report-list.js +0 -14
  227. package/dist-server/graphql/types/reports/receiving-report-list.js.map +0 -1
  228. package/dist-server/graphql/types/reports/receiving-report.js +0 -23
  229. package/dist-server/graphql/types/reports/receiving-report.js.map +0 -1
  230. package/dist-server/graphql/types/reports/shortage-report-list.js +0 -14
  231. package/dist-server/graphql/types/reports/shortage-report-list.js.map +0 -1
  232. package/dist-server/graphql/types/reports/shortage-report-type.js +0 -26
  233. package/dist-server/graphql/types/reports/shortage-report-type.js.map +0 -1
  234. package/dist-server/graphql/types/synchronization/index.js +0 -49
  235. package/dist-server/graphql/types/synchronization/index.js.map +0 -1
  236. package/dist-server/graphql/types/synchronization/sync-invoice-list.js +0 -14
  237. package/dist-server/graphql/types/synchronization/sync-invoice-list.js.map +0 -1
  238. package/dist-server/graphql/types/synchronization/sync-invoice-set.js +0 -44
  239. package/dist-server/graphql/types/synchronization/sync-invoice-set.js.map +0 -1
  240. package/dist-server/graphql/types/synchronization/sync-product-list.js +0 -14
  241. package/dist-server/graphql/types/synchronization/sync-product-list.js.map +0 -1
  242. package/dist-server/graphql/types/synchronization/sync-product-set.js +0 -14
  243. package/dist-server/graphql/types/synchronization/sync-product-set.js.map +0 -1
  244. package/dist-server/graphql/types/synchronization/sync-purchase-order-list.js +0 -14
  245. package/dist-server/graphql/types/synchronization/sync-purchase-order-list.js.map +0 -1
  246. package/dist-server/graphql/types/synchronization/sync-purchase-order-set.js +0 -34
  247. package/dist-server/graphql/types/synchronization/sync-purchase-order-set.js.map +0 -1
  248. package/dist-server/index.js +0 -43
  249. package/dist-server/index.js.map +0 -1
  250. package/dist-server/middlewares/business-middleware.js +0 -32
  251. package/dist-server/middlewares/business-middleware.js.map +0 -1
  252. package/dist-server/middlewares/index.js +0 -21
  253. package/dist-server/middlewares/index.js.map +0 -1
  254. package/dist-server/middlewares/store-middleware.js +0 -34
  255. package/dist-server/middlewares/store-middleware.js.map +0 -1
  256. package/dist-server/middlewares/warehouse-middleware.js +0 -33
  257. package/dist-server/middlewares/warehouse-middleware.js.map +0 -1
  258. package/dist-server/migrations/1597668478399-SeedBusinessDomain.js +0 -27
  259. package/dist-server/migrations/1597668478399-SeedBusinessDomain.js.map +0 -1
  260. package/dist-server/migrations/1597668478401-SeedBusinessRoles.js +0 -377
  261. package/dist-server/migrations/1597668478401-SeedBusinessRoles.js.map +0 -1
  262. package/dist-server/migrations/1608009991065-SeedUser.js +0 -53
  263. package/dist-server/migrations/1608009991065-SeedUser.js.map +0 -1
  264. package/dist-server/migrations/index.js +0 -12
  265. package/dist-server/migrations/index.js.map +0 -1
  266. package/dist-server/routers/api/index.js +0 -5
  267. package/dist-server/routers/api/index.js.map +0 -1
  268. package/dist-server/routers/api/restful-apis/unstable/add-contact-point.js +0 -76
  269. package/dist-server/routers/api/restful-apis/unstable/add-contact-point.js.map +0 -1
  270. package/dist-server/routers/api/restful-apis/unstable/add-draft-release-order.js +0 -174
  271. package/dist-server/routers/api/restful-apis/unstable/add-draft-release-order.js.map +0 -1
  272. package/dist-server/routers/api/restful-apis/unstable/add-inbound-order.js +0 -217
  273. package/dist-server/routers/api/restful-apis/unstable/add-inbound-order.js.map +0 -1
  274. package/dist-server/routers/api/restful-apis/unstable/add-marketplace-order.js +0 -144
  275. package/dist-server/routers/api/restful-apis/unstable/add-marketplace-order.js.map +0 -1
  276. package/dist-server/routers/api/restful-apis/unstable/add-products.js +0 -88
  277. package/dist-server/routers/api/restful-apis/unstable/add-products.js.map +0 -1
  278. package/dist-server/routers/api/restful-apis/unstable/add-release-order.js +0 -1080
  279. package/dist-server/routers/api/restful-apis/unstable/add-release-order.js.map +0 -1
  280. package/dist-server/routers/api/restful-apis/unstable/add-sales-invoice.js +0 -140
  281. package/dist-server/routers/api/restful-apis/unstable/add-sales-invoice.js.map +0 -1
  282. package/dist-server/routers/api/restful-apis/unstable/bizplace.js +0 -45
  283. package/dist-server/routers/api/restful-apis/unstable/bizplace.js.map +0 -1
  284. package/dist-server/routers/api/restful-apis/unstable/cancel-marketplace-order.js +0 -63
  285. package/dist-server/routers/api/restful-apis/unstable/cancel-marketplace-order.js.map +0 -1
  286. package/dist-server/routers/api/restful-apis/unstable/cancel-release-order.js +0 -82
  287. package/dist-server/routers/api/restful-apis/unstable/cancel-release-order.js.map +0 -1
  288. package/dist-server/routers/api/restful-apis/unstable/get-contact-point-list.js +0 -103
  289. package/dist-server/routers/api/restful-apis/unstable/get-contact-point-list.js.map +0 -1
  290. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-detail.js +0 -47
  291. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-detail.js.map +0 -1
  292. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-list.js +0 -124
  293. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-list.js.map +0 -1
  294. package/dist-server/routers/api/restful-apis/unstable/get-delivery-orders.js +0 -164
  295. package/dist-server/routers/api/restful-apis/unstable/get-delivery-orders.js.map +0 -1
  296. package/dist-server/routers/api/restful-apis/unstable/get-goods-received-notes.js +0 -120
  297. package/dist-server/routers/api/restful-apis/unstable/get-goods-received-notes.js.map +0 -1
  298. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-detail.js +0 -115
  299. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-detail.js.map +0 -1
  300. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-list.js +0 -125
  301. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-list.js.map +0 -1
  302. package/dist-server/routers/api/restful-apis/unstable/get-inventory-overall-product-group.js +0 -88
  303. package/dist-server/routers/api/restful-apis/unstable/get-inventory-overall-product-group.js.map +0 -1
  304. package/dist-server/routers/api/restful-apis/unstable/get-inventory-product-group.js +0 -95
  305. package/dist-server/routers/api/restful-apis/unstable/get-inventory-product-group.js.map +0 -1
  306. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-order-shipping-list.js +0 -146
  307. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-order-shipping-list.js.map +0 -1
  308. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-store-list.js +0 -79
  309. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-store-list.js.map +0 -1
  310. package/dist-server/routers/api/restful-apis/unstable/get-onhand-inventories.js +0 -110
  311. package/dist-server/routers/api/restful-apis/unstable/get-onhand-inventories.js.map +0 -1
  312. package/dist-server/routers/api/restful-apis/unstable/get-partners.js +0 -23
  313. package/dist-server/routers/api/restful-apis/unstable/get-partners.js.map +0 -1
  314. package/dist-server/routers/api/restful-apis/unstable/get-products.js +0 -214
  315. package/dist-server/routers/api/restful-apis/unstable/get-products.js.map +0 -1
  316. package/dist-server/routers/api/restful-apis/unstable/get-release-order-detail.js +0 -125
  317. package/dist-server/routers/api/restful-apis/unstable/get-release-order-detail.js.map +0 -1
  318. package/dist-server/routers/api/restful-apis/unstable/get-release-order-list.js +0 -195
  319. package/dist-server/routers/api/restful-apis/unstable/get-release-order-list.js.map +0 -1
  320. package/dist-server/routers/api/restful-apis/unstable/get-warehouses.js +0 -20
  321. package/dist-server/routers/api/restful-apis/unstable/get-warehouses.js.map +0 -1
  322. package/dist-server/routers/api/restful-apis/unstable/index.js +0 -35
  323. package/dist-server/routers/api/restful-apis/unstable/index.js.map +0 -1
  324. package/dist-server/routers/api/restful-apis/unstable/reject-inbound-order.js +0 -35
  325. package/dist-server/routers/api/restful-apis/unstable/reject-inbound-order.js.map +0 -1
  326. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-delivered.js +0 -45
  327. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-delivered.js.map +0 -1
  328. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-failed-delivery.js +0 -45
  329. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-failed-delivery.js.map +0 -1
  330. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-order.js +0 -93
  331. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-order.js.map +0 -1
  332. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-shipping-order.js +0 -88
  333. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-shipping-order.js.map +0 -1
  334. package/dist-server/routers/api/restful-apis/unstable/update-release-order-details.js +0 -82
  335. package/dist-server/routers/api/restful-apis/unstable/update-release-order-details.js.map +0 -1
  336. package/dist-server/routers/api/restful-apis/v1/company/add-contact-points.js +0 -105
  337. package/dist-server/routers/api/restful-apis/v1/company/add-contact-points.js.map +0 -1
  338. package/dist-server/routers/api/restful-apis/v1/company/add-products.js +0 -157
  339. package/dist-server/routers/api/restful-apis/v1/company/add-products.js.map +0 -1
  340. package/dist-server/routers/api/restful-apis/v1/company/get-bizplace-list.js +0 -49
  341. package/dist-server/routers/api/restful-apis/v1/company/get-bizplace-list.js.map +0 -1
  342. package/dist-server/routers/api/restful-apis/v1/company/get-contact-point-list.js +0 -62
  343. package/dist-server/routers/api/restful-apis/v1/company/get-contact-point-list.js.map +0 -1
  344. package/dist-server/routers/api/restful-apis/v1/company/get-partner-list.js +0 -88
  345. package/dist-server/routers/api/restful-apis/v1/company/get-partner-list.js.map +0 -1
  346. package/dist-server/routers/api/restful-apis/v1/company/get-product-by-skus.js +0 -95
  347. package/dist-server/routers/api/restful-apis/v1/company/get-product-by-skus.js.map +0 -1
  348. package/dist-server/routers/api/restful-apis/v1/company/get-product-list.js +0 -104
  349. package/dist-server/routers/api/restful-apis/v1/company/get-product-list.js.map +0 -1
  350. package/dist-server/routers/api/restful-apis/v1/company/get-webhook-details.js +0 -58
  351. package/dist-server/routers/api/restful-apis/v1/company/get-webhook-details.js.map +0 -1
  352. package/dist-server/routers/api/restful-apis/v1/company/index.js +0 -14
  353. package/dist-server/routers/api/restful-apis/v1/company/index.js.map +0 -1
  354. package/dist-server/routers/api/restful-apis/v1/company/upsert-product.js +0 -111
  355. package/dist-server/routers/api/restful-apis/v1/company/upsert-product.js.map +0 -1
  356. package/dist-server/routers/api/restful-apis/v1/company/upsert-products.js +0 -356
  357. package/dist-server/routers/api/restful-apis/v1/company/upsert-products.js.map +0 -1
  358. package/dist-server/routers/api/restful-apis/v1/company/upsert-webhooks.js +0 -146
  359. package/dist-server/routers/api/restful-apis/v1/company/upsert-webhooks.js.map +0 -1
  360. package/dist-server/routers/api/restful-apis/v1/index.js +0 -6
  361. package/dist-server/routers/api/restful-apis/v1/index.js.map +0 -1
  362. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-order.js +0 -254
  363. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-order.js.map +0 -1
  364. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-products.js +0 -78
  365. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-products.js.map +0 -1
  366. package/dist-server/routers/api/restful-apis/v1/marketplace/cancel-marketplace-order.js +0 -90
  367. package/dist-server/routers/api/restful-apis/v1/marketplace/cancel-marketplace-order.js.map +0 -1
  368. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-order-shipping-list.js +0 -138
  369. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-order-shipping-list.js.map +0 -1
  370. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-store-list.js +0 -51
  371. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-store-list.js.map +0 -1
  372. package/dist-server/routers/api/restful-apis/v1/marketplace/index.js +0 -11
  373. package/dist-server/routers/api/restful-apis/v1/marketplace/index.js.map +0 -1
  374. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-order-delivered.js +0 -62
  375. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-order-delivered.js.map +0 -1
  376. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-product.js +0 -76
  377. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-product.js.map +0 -1
  378. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-shipping-order.js +0 -40
  379. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-shipping-order.js.map +0 -1
  380. package/dist-server/routers/api/restful-apis/v1/middlewares/business-middleware.js +0 -70
  381. package/dist-server/routers/api/restful-apis/v1/middlewares/business-middleware.js.map +0 -1
  382. package/dist-server/routers/api/restful-apis/v1/middlewares/index.js +0 -40
  383. package/dist-server/routers/api/restful-apis/v1/middlewares/index.js.map +0 -1
  384. package/dist-server/routers/api/restful-apis/v1/middlewares/logging-middleware.js +0 -53
  385. package/dist-server/routers/api/restful-apis/v1/middlewares/logging-middleware.js.map +0 -1
  386. package/dist-server/routers/api/restful-apis/v1/middlewares/store-middleware.js +0 -32
  387. package/dist-server/routers/api/restful-apis/v1/middlewares/store-middleware.js.map +0 -1
  388. package/dist-server/routers/api/restful-apis/v1/middlewares/validation-middleware.js +0 -118
  389. package/dist-server/routers/api/restful-apis/v1/middlewares/validation-middleware.js.map +0 -1
  390. package/dist-server/routers/api/restful-apis/v1/middlewares/warehouse-middleware.js +0 -31
  391. package/dist-server/routers/api/restful-apis/v1/middlewares/warehouse-middleware.js.map +0 -1
  392. package/dist-server/routers/api/restful-apis/v1/utils/error-util.js +0 -71
  393. package/dist-server/routers/api/restful-apis/v1/utils/error-util.js.map +0 -1
  394. package/dist-server/routers/api/restful-apis/v1/utils/params.js +0 -1164
  395. package/dist-server/routers/api/restful-apis/v1/utils/params.js.map +0 -1
  396. package/dist-server/routers/api/restful-apis/v1/utils/validate-util.js +0 -68
  397. package/dist-server/routers/api/restful-apis/v1/utils/validate-util.js.map +0 -1
  398. package/dist-server/routers/api/restful-apis/v1/warehouse/add-inbound-order.js +0 -254
  399. package/dist-server/routers/api/restful-apis/v1/warehouse/add-inbound-order.js.map +0 -1
  400. package/dist-server/routers/api/restful-apis/v1/warehouse/add-release-order.js +0 -1091
  401. package/dist-server/routers/api/restful-apis/v1/warehouse/add-release-order.js.map +0 -1
  402. package/dist-server/routers/api/restful-apis/v1/warehouse/add-return-order.js +0 -325
  403. package/dist-server/routers/api/restful-apis/v1/warehouse/add-return-order.js.map +0 -1
  404. package/dist-server/routers/api/restful-apis/v1/warehouse/add-sales-invoice.js +0 -97
  405. package/dist-server/routers/api/restful-apis/v1/warehouse/add-sales-invoice.js.map +0 -1
  406. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-inbound-order.js +0 -199
  407. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-inbound-order.js.map +0 -1
  408. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-release-order.js +0 -197
  409. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-release-order.js.map +0 -1
  410. package/dist-server/routers/api/restful-apis/v1/warehouse/complete-delivery-order.js +0 -170
  411. package/dist-server/routers/api/restful-apis/v1/warehouse/complete-delivery-order.js.map +0 -1
  412. package/dist-server/routers/api/restful-apis/v1/warehouse/dispatch-delivery-order.js +0 -327
  413. package/dist-server/routers/api/restful-apis/v1/warehouse/dispatch-delivery-order.js.map +0 -1
  414. package/dist-server/routers/api/restful-apis/v1/warehouse/get-delivery-order-list.js +0 -223
  415. package/dist-server/routers/api/restful-apis/v1/warehouse/get-delivery-order-list.js.map +0 -1
  416. package/dist-server/routers/api/restful-apis/v1/warehouse/get-do-document.js +0 -65
  417. package/dist-server/routers/api/restful-apis/v1/warehouse/get-do-document.js.map +0 -1
  418. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-details.js +0 -144
  419. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-details.js.map +0 -1
  420. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-list.js +0 -305
  421. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-list.js.map +0 -1
  422. package/dist-server/routers/api/restful-apis/v1/warehouse/get-goods-received-note-list.js +0 -100
  423. package/dist-server/routers/api/restful-apis/v1/warehouse/get-goods-received-note-list.js.map +0 -1
  424. package/dist-server/routers/api/restful-apis/v1/warehouse/get-grn-document.js +0 -102
  425. package/dist-server/routers/api/restful-apis/v1/warehouse/get-grn-document.js.map +0 -1
  426. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-details.js +0 -179
  427. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-details.js.map +0 -1
  428. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-list.js +0 -96
  429. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-list.js.map +0 -1
  430. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-details.js +0 -146
  431. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-details.js.map +0 -1
  432. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-list.js +0 -214
  433. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-list.js.map +0 -1
  434. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-product-group-list.js +0 -90
  435. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-product-group-list.js.map +0 -1
  436. package/dist-server/routers/api/restful-apis/v1/warehouse/get-manifest-details.js +0 -138
  437. package/dist-server/routers/api/restful-apis/v1/warehouse/get-manifest-details.js.map +0 -1
  438. package/dist-server/routers/api/restful-apis/v1/warehouse/get-onhand-inventory-list.js +0 -106
  439. package/dist-server/routers/api/restful-apis/v1/warehouse/get-onhand-inventory-list.js.map +0 -1
  440. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-details.js +0 -278
  441. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-details.js.map +0 -1
  442. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-list.js +0 -142
  443. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-list.js.map +0 -1
  444. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-details.js +0 -106
  445. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-details.js.map +0 -1
  446. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-list.js +0 -63
  447. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-list.js.map +0 -1
  448. package/dist-server/routers/api/restful-apis/v1/warehouse/get-warehouse-bizplace-onhand-inventories.js +0 -68
  449. package/dist-server/routers/api/restful-apis/v1/warehouse/get-warehouse-bizplace-onhand-inventories.js.map +0 -1
  450. package/dist-server/routers/api/restful-apis/v1/warehouse/index.js +0 -32
  451. package/dist-server/routers/api/restful-apis/v1/warehouse/index.js.map +0 -1
  452. package/dist-server/routers/api/restful-apis/v1/warehouse/update-gan-to-arrived.js +0 -96
  453. package/dist-server/routers/api/restful-apis/v1/warehouse/update-gan-to-arrived.js.map +0 -1
  454. package/dist-server/routers/api/restful-apis/v1/warehouse/update-order-package-details.js +0 -46
  455. package/dist-server/routers/api/restful-apis/v1/warehouse/update-order-package-details.js.map +0 -1
  456. package/dist-server/routers/api/restful-apis/v1/warehouse/update-release-order-details.js +0 -70
  457. package/dist-server/routers/api/restful-apis/v1/warehouse/update-release-order-details.js.map +0 -1
  458. package/dist-server/routers/auth-invitation-router.js +0 -25
  459. package/dist-server/routers/auth-invitation-router.js.map +0 -1
  460. package/dist-server/routers/business/bizplace-register-router.js +0 -25
  461. package/dist-server/routers/business/bizplace-register-router.js.map +0 -1
  462. package/dist-server/routers/business/business-register-router.js +0 -31
  463. package/dist-server/routers/business/business-register-router.js.map +0 -1
  464. package/dist-server/routers/business/index.js +0 -20
  465. package/dist-server/routers/business/index.js.map +0 -1
  466. package/dist-server/routers/business/path-base-business-router.js +0 -21
  467. package/dist-server/routers/business/path-base-business-router.js.map +0 -1
  468. package/dist-server/routers/internal/apis/create-bizplace.js +0 -70
  469. package/dist-server/routers/internal/apis/create-bizplace.js.map +0 -1
  470. package/dist-server/routers/internal/apis/create-company.js +0 -77
  471. package/dist-server/routers/internal/apis/create-company.js.map +0 -1
  472. package/dist-server/routers/internal/apis/create-partner.js +0 -41
  473. package/dist-server/routers/internal/apis/create-partner.js.map +0 -1
  474. package/dist-server/routers/internal/apis/create-user.js +0 -23
  475. package/dist-server/routers/internal/apis/create-user.js.map +0 -1
  476. package/dist-server/routers/internal/apis/index.js +0 -37
  477. package/dist-server/routers/internal/apis/index.js.map +0 -1
  478. package/dist-server/routers/internal/apis/invite-user.js +0 -48
  479. package/dist-server/routers/internal/apis/invite-user.js.map +0 -1
  480. package/dist-server/routers/internal/apis/terminate-partner.js +0 -38
  481. package/dist-server/routers/internal/apis/terminate-partner.js.map +0 -1
  482. package/dist-server/routers/internal/apis/terminate-user.js +0 -53
  483. package/dist-server/routers/internal/apis/terminate-user.js.map +0 -1
  484. package/dist-server/routers/internal/apis/update-bizplace.js +0 -52
  485. package/dist-server/routers/internal/apis/update-bizplace.js.map +0 -1
  486. package/dist-server/routers/internal/apis/update-company.js +0 -55
  487. package/dist-server/routers/internal/apis/update-company.js.map +0 -1
  488. package/dist-server/routers/internal/apis/update-user.js +0 -33
  489. package/dist-server/routers/internal/apis/update-user.js.map +0 -1
  490. package/dist-server/routers/internal/index.js +0 -8
  491. package/dist-server/routers/internal/index.js.map +0 -1
  492. package/dist-server/routers/internal/middlewares/index.js +0 -20
  493. package/dist-server/routers/internal/middlewares/index.js.map +0 -1
  494. package/dist-server/routers/internal/middlewares/logging-middleware.js +0 -23
  495. package/dist-server/routers/internal/middlewares/logging-middleware.js.map +0 -1
  496. package/dist-server/routers/internal/middlewares/validation-middleware.js +0 -110
  497. package/dist-server/routers/internal/middlewares/validation-middleware.js.map +0 -1
  498. package/dist-server/routers/internal/powrup-router.js +0 -291
  499. package/dist-server/routers/internal/powrup-router.js.map +0 -1
  500. package/dist-server/routers/internal/sellercraft-router.js +0 -53
  501. package/dist-server/routers/internal/sellercraft-router.js.map +0 -1
  502. package/dist-server/routers/internal/utils/error-util.js +0 -71
  503. package/dist-server/routers/internal/utils/error-util.js.map +0 -1
  504. package/dist-server/routers/internal/utils/params.js +0 -153
  505. package/dist-server/routers/internal/utils/params.js.map +0 -1
  506. package/dist-server/routers/support-router.js +0 -386
  507. package/dist-server/routers/support-router.js.map +0 -1
  508. package/dist-server/routers/webhook-service/versafleet-router.js +0 -93
  509. package/dist-server/routers/webhook-service/versafleet-router.js.map +0 -1
  510. package/dist-server/routers/xilnex-router.js +0 -1103
  511. package/dist-server/routers/xilnex-router.js.map +0 -1
  512. package/dist-server/routes.js +0 -26
  513. package/dist-server/routes.js.map +0 -1
  514. package/dist-server/templates/account-unlock-email.js +0 -69
  515. package/dist-server/templates/account-unlock-email.js.map +0 -1
  516. package/dist-server/templates/invitation-email.js +0 -70
  517. package/dist-server/templates/invitation-email.js.map +0 -1
  518. package/dist-server/templates/reset-password-email.js +0 -66
  519. package/dist-server/templates/reset-password-email.js.map +0 -1
  520. package/dist-server/templates/verification-email.js +0 -70
  521. package/dist-server/templates/verification-email.js.map +0 -1
  522. package/dist-server/utils/build-map.js +0 -19
  523. package/dist-server/utils/build-map.js.map +0 -1
  524. package/dist-server/utils/get-warehouses.js +0 -113
  525. package/dist-server/utils/get-warehouses.js.map +0 -1
  526. package/dist-server/utils/index.js +0 -21
  527. package/dist-server/utils/index.js.map +0 -1
  528. package/dist-server/utils/order-no-generator.js +0 -11
  529. package/dist-server/utils/order-no-generator.js.map +0 -1
  530. package/dist-server/utils/report-query-util.js +0 -42
  531. package/dist-server/utils/report-query-util.js.map +0 -1
@@ -1,1080 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const typeorm_1 = require("typeorm");
4
- const uuid_1 = require("uuid");
5
- const api_1 = require("@things-factory/api");
6
- const biz_base_1 = require("@things-factory/biz-base");
7
- const env_1 = require("@things-factory/env");
8
- const geography_1 = require("@things-factory/geography");
9
- const id_rule_base_1 = require("@things-factory/id-rule-base");
10
- const integration_base_1 = require("@things-factory/integration-base");
11
- const integration_lmd_1 = require("@things-factory/integration-lmd");
12
- const integration_sellercraft_1 = require("@things-factory/integration-sellercraft");
13
- const marketplace_base_1 = require("@things-factory/marketplace-base");
14
- const product_base_1 = require("@things-factory/product-base");
15
- const sales_base_1 = require("@things-factory/sales-base");
16
- const setting_base_1 = require("@things-factory/setting-base");
17
- const warehouse_base_1 = require("@things-factory/warehouse-base");
18
- const index_1 = require("../../../../errors/index");
19
- const business_middleware_1 = require("../../../../middlewares/business-middleware");
20
- const warehouse_middleware_1 = require("../../../../middlewares/warehouse-middleware");
21
- const debug = require('debug')('things-factory:operato-hub:restful-api:unstable:add-release-order');
22
- const apiVersion = 'unstable';
23
- api_1.restfulApiRouter.post(`/${apiVersion}/warehouse/:warehouseId/add-release-order`, business_middleware_1.businessMiddleware, warehouse_middleware_1.warehouseMiddleware, async (context, next) => {
24
- return await (0, typeorm_1.getConnection)().transaction(async (tx) => {
25
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
26
- const { client, domain, user, application } = context.state;
27
- const { warehouseId: customerBizplaceId } = context.params;
28
- const { t } = context;
29
- const bodyReq = context.request.body;
30
- const requiredDraft = bodyReq.hasOwnProperty('requiredDraft') ? bodyReq.requiredDraft : true;
31
- let releaseGood;
32
- let massagedData = { orderProducts: [], combinedItems: [] };
33
- // const isAutoAssign: Boolean = bodyReq.hasOwnProperty('isAutoAssign') ? bodyReq.isAutoAssign : true
34
- try {
35
- if (!customerBizplaceId)
36
- context.throw(404, t('error.warehouse id not found'));
37
- if (typeof bodyReq === undefined || !((_a = Object.keys(bodyReq)) === null || _a === void 0 ? void 0 : _a.length)) {
38
- context.throw(400, t('error.invalid body request format'));
39
- }
40
- debug('post:/add-release-order request.body', bodyReq);
41
- await checkMandatoryKey(context, bodyReq);
42
- // get customer company's bizplace
43
- const custCompanyBizplace = await (0, biz_base_1.getCompanyBizplace)(null, null, customerBizplaceId, tx);
44
- const customerBizplace = await tx.getRepository(biz_base_1.Bizplace).findOne({
45
- where: { id: customerBizplaceId },
46
- relations: ['domain']
47
- });
48
- const worksheetPickingAssignment = await tx.getRepository(setting_base_1.Setting).findOne({
49
- where: { domain, category: 'id-rule', name: 'enable-worksheet-picking-activation-assignment' }
50
- });
51
- let newPhone1 = ((_b = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _b === void 0 ? void 0 : _b.phone1) ? bodyReq.deliverTo.phone1.replace(/\D/g, '') : null;
52
- let newPhone2 = ((_c = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _c === void 0 ? void 0 : _c.phone2) ? bodyReq.deliverTo.phone2.replace(/\D/g, '') : null;
53
- releaseGood = {
54
- domain,
55
- bizplace: customerBizplace,
56
- companyBizplace: custCompanyBizplace,
57
- courierOption: bodyReq.courierOption,
58
- codOption: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.codOption,
59
- collectionOrderNo: bodyReq.collectionOrderNo,
60
- exportOption: bodyReq.exportOption,
61
- ownTransport: bodyReq.ownTransport,
62
- packingOption: bodyReq.packingOption,
63
- refNo: bodyReq.refNo,
64
- refNo2: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.refNo2,
65
- refNo3: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.refNo3,
66
- refOrderId: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.refOrderId,
67
- releaseDate: bodyReq.releaseDate,
68
- type: bodyReq.type,
69
- marketplaceOrderStatus: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.marketplaceOrderStatus,
70
- remark: (bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.remark) || null,
71
- billingAddress: ((_d = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.billTo) === null || _d === void 0 ? void 0 : _d.billingAddress) || null,
72
- deliveryAddress1: ((_e = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _e === void 0 ? void 0 : _e.deliveryAddress1) || null,
73
- deliveryAddress2: ((_f = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _f === void 0 ? void 0 : _f.deliveryAddress2) || null,
74
- deliveryAddress3: ((_g = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _g === void 0 ? void 0 : _g.deliveryAddress3) || null,
75
- deliveryAddress4: ((_h = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _h === void 0 ? void 0 : _h.deliveryAddress4) || null,
76
- deliveryAddress5: ((_j = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _j === void 0 ? void 0 : _j.deliveryAddress5) || null,
77
- attentionTo: ((_k = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _k === void 0 ? void 0 : _k.attentionTo) || null,
78
- attentionCompany: ((_l = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _l === void 0 ? void 0 : _l.attentionCompany) || null,
79
- city: ((_m = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _m === void 0 ? void 0 : _m.city) || null,
80
- ward: ((_o = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _o === void 0 ? void 0 : _o.ward) || null,
81
- district: ((_p = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _p === void 0 ? void 0 : _p.district) || null,
82
- state: ((_q = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _q === void 0 ? void 0 : _q.state) || null,
83
- postalCode: ((_r = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _r === void 0 ? void 0 : _r.postalCode) || null,
84
- country: ((_s = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _s === void 0 ? void 0 : _s.country) || null,
85
- phone1: newPhone1,
86
- phone2: newPhone2,
87
- email: ((_t = bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.deliverTo) === null || _t === void 0 ? void 0 : _t.email) || null,
88
- transporter: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.transporter,
89
- trackingNo: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.trackingNo,
90
- airwayBill: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.airwayBill,
91
- invoice: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.invoice,
92
- packageId: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.packageId,
93
- storeName: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.storeName,
94
- storeId: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.storeId,
95
- routeId: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.routeId,
96
- stopId: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.stopId,
97
- source: (bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.source) == 'MMS' ? bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.source : application === null || application === void 0 ? void 0 : application.type,
98
- platformCode: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.platformCode,
99
- platformCountry: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.platformCountry,
100
- platformName: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.platformName,
101
- paidAmount: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.paidAmount,
102
- discountAmount: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.discountAmount,
103
- taxAmount: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.taxAmount,
104
- shippingFee: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.shippingFee,
105
- lmdOption: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.lmdOption,
106
- priorityDelivery: bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.priorityDelivery,
107
- assignedInventory: (worksheetPickingAssignment === null || worksheetPickingAssignment === void 0 ? void 0 : worksheetPickingAssignment.value) == 'true' ? false : true
108
- };
109
- // check existing order
110
- await checkExistingOrder(releaseGood, customerBizplace, bodyReq === null || bodyReq === void 0 ? void 0 : bodyReq.checkDuplicationValidation, context, tx);
111
- //massage data
112
- massagedData = await massageOrderItems(releaseGood, bodyReq.orderInventories, context);
113
- // validation
114
- let errorList = [];
115
- await Promise.all(massagedData.combinedItems.map(async (item) => {
116
- let itemList = await tx.query(`
117
- select wboi.* from warehouse_bizplace_onhand_inventories wboi
118
- left join (
119
- select i2.product_id, i2.domain_id, i2.bizplace_id, i2.packing_type, i2.packing_size, i2.uom, sum(i2.qty) as storage_qty, sum(i2.uom_value) as storage_uom_value from inventories i2
120
- inner join locations l2 on l2.id = i2.location_id
121
- where i2.domain_id = $1 and i2.bizplace_id = $2
122
- and i2.product_id = $3 and i2.packing_type= $4 and i2.packing_size= $5 and i2.uom = $6 and i2.status='STORED'
123
- and l2.type='STORAGE' group by i2.product_id, i2.domain_id, i2.bizplace_id, i2.packing_type, i2.packing_size, i2.uom
124
- ) storageInv on storageInv.product_id = wboi.product_id and storageInv.domain_id=wboi.domain_id and storageInv.bizplace_id=wboi.bizplace_id
125
- and storageInv.packing_type=wboi.packing_type and storageInv.packing_size=wboi.packing_size and storageInv.uom=wboi.uom
126
- where wboi."domain_id"= $1 and
127
- wboi."bizplace_id" = $2 and
128
- wboi."group_type" = 'SINGLE' and
129
- wboi."product_id" = $3 and
130
- wboi."packing_type" = $4 and
131
- wboi."packing_size" = $5 and
132
- wboi."uom" = $6 and
133
- (wboi."remain_qty" - wboi."transfer_qty" - coalesce(storageInv.storage_qty, 0)) >= $7 and
134
- (wboi."remain_uom_value" - wboi."transfer_uom_value" - coalesce(storageInv.storage_uom_value, 0)) >= $8
135
- `, [
136
- domain.id,
137
- customerBizplace.id,
138
- item.product.id,
139
- item.packingType,
140
- item.packingSize,
141
- item.uom,
142
- item.releaseQty,
143
- item.releaseUomValue
144
- ]);
145
- if (itemList.length <= 0) {
146
- errorList.push(JSON.stringify({
147
- code: 'insufficient stock',
148
- sku: item.product.sku,
149
- packingType: item.packingType,
150
- packingSize: item.packingSize,
151
- uom: item.uom,
152
- qty: item.releaseQty,
153
- uom_value: item.releaseUomValue
154
- }));
155
- }
156
- console.log();
157
- }));
158
- if (errorList.length > 0) {
159
- throw new index_1.ValidationError({
160
- errorCode: 'INSUFFICIENT_STOCK',
161
- message: 'insufficient stock',
162
- detail: errorList.join(', ')
163
- });
164
- }
165
- // assignment
166
- // console.time('assign')
167
- let assignedOrderProducts = await assignToInventory(releaseGood, massagedData.orderProducts, customerBizplace, context, tx, worksheetPickingAssignment);
168
- // console.timeEnd('assign')
169
- // create order
170
- // console.time('save')
171
- let result = await createReleaseGood(releaseGood, assignedOrderProducts, customerBizplace, context, tx, worksheetPickingAssignment);
172
- // console.timeEnd('save')
173
- let addReleaseGood = {
174
- id: result.id,
175
- name: result.name,
176
- refNo: result.refNo,
177
- refNo2: result.refNo2,
178
- refNo3: result.refNo3,
179
- refOrderId: result === null || result === void 0 ? void 0 : result.refOrderId,
180
- status: result.status,
181
- truckNo: result.truckNo,
182
- ownTransport: result.ownTransport,
183
- crossDocking: result.crossDocking,
184
- marketplaceOrderStatus: result.marketplaceOrderStatus,
185
- billingAddress: result.billingAddress,
186
- deliveryAddress1: result.deliveryAddress1,
187
- deliveryAddress2: result.deliveryAddress2,
188
- deliveryAddress3: result.deliveryAddress3,
189
- deliveryAddress4: result.deliveryAddress4,
190
- deliveryAddress5: result.deliveryAddress5,
191
- attentionTo: result.attentionTo,
192
- attentionCompany: result.attentionCompany,
193
- city: result.city,
194
- ward: result.ward,
195
- district: result.district,
196
- state: result.state,
197
- postalCode: result.postalCode,
198
- country: result.country,
199
- phone1: result.phone1,
200
- phone2: result.phone2,
201
- email: result.email,
202
- transporter: result.transporter,
203
- trackingNo: result.trackingNo,
204
- airwayBill: result.airwayBill,
205
- invoice: result.invoice,
206
- type: result.type,
207
- packageId: result.packageId,
208
- storeName: result.storeName,
209
- storeId: result.storeId,
210
- routeId: result.routeId,
211
- stopId: result.stopId,
212
- exportOption: result.exportOption,
213
- releaseDate: result.releaseDate,
214
- collectionOrderNo: result.collectionOrderNo,
215
- platformCode: result === null || result === void 0 ? void 0 : result.platformCode,
216
- platformCountry: result === null || result === void 0 ? void 0 : result.platformCountry,
217
- platformName: result === null || result === void 0 ? void 0 : result.platformName,
218
- paidAmount: result === null || result === void 0 ? void 0 : result.paidAmount,
219
- discountAmount: result === null || result === void 0 ? void 0 : result.discountAmount,
220
- taxAmount: result === null || result === void 0 ? void 0 : result.taxAmount,
221
- shippingFee: result === null || result === void 0 ? void 0 : result.shippingFee,
222
- priorityDelivery: result === null || result === void 0 ? void 0 : result.priorityDelivery,
223
- bizplace: { name: result.bizplace.name },
224
- domain: { name: result.domain.name },
225
- orderInventories: result.orderInventories
226
- };
227
- // return body
228
- context.body = { result: { addReleaseGood } };
229
- (0, integration_base_1.createPayloadLog)(customerBizplaceId, `/${apiVersion}/warehouse/:warehouseId/add-release-order`, bodyReq, context.body, context, integration_base_1.PayloadType.INGESTION);
230
- }
231
- catch (error) {
232
- (0, integration_base_1.createPayloadLog)(customerBizplaceId, `/${apiVersion}/warehouse/:warehouseId/add-release-order`, bodyReq, error, context, integration_base_1.PayloadType.INGESTION);
233
- if (error.errorCode) {
234
- if (error.errorCode == 'INSUFFICIENT_STOCK' && requiredDraft) {
235
- const result = await createDraftOrder(releaseGood, massagedData.orderProducts, context);
236
- let createdDraftOrder = {
237
- id: result.id,
238
- name: result.name,
239
- refNo: result.refNo,
240
- refNo2: result.refNo2,
241
- refNo3: result.refNo3,
242
- status: result.status,
243
- truckNo: result.truckNo,
244
- ownTransport: result.ownTransport,
245
- marketplaceOrderStatus: result.marketplaceOrderStatus,
246
- billingAddress: result.billingAddress,
247
- deliveryAddress1: result.deliveryAddress1,
248
- deliveryAddress2: result.deliveryAddress2,
249
- deliveryAddress3: result.deliveryAddress3,
250
- deliveryAddress4: result.deliveryAddress4,
251
- deliveryAddress5: result.deliveryAddress5,
252
- attentionTo: result.attentionTo,
253
- attentionCompany: result.attentionCompany,
254
- city: result.city,
255
- ward: result.ward,
256
- district: result.district,
257
- state: result.state,
258
- postalCode: result.postalCode,
259
- country: result.country,
260
- phone1: result.phone1,
261
- phone2: result.phone2,
262
- email: result.email,
263
- type: result.type,
264
- packageId: result.packageId,
265
- exportOption: result.exportOption,
266
- releaseDate: result.releaseDate,
267
- collectionOrderNo: result.collectionOrderNo,
268
- platformCode: result === null || result === void 0 ? void 0 : result.platformCode,
269
- platformCountry: result === null || result === void 0 ? void 0 : result.platformCountry,
270
- platformName: result === null || result === void 0 ? void 0 : result.platformName,
271
- discountAmount: result === null || result === void 0 ? void 0 : result.discountAmount,
272
- taxAmount: result === null || result === void 0 ? void 0 : result.taxAmount,
273
- shippingFee: result === null || result === void 0 ? void 0 : result.shippingFee,
274
- priorityDelivery: result === null || result === void 0 ? void 0 : result.priorityDelivery,
275
- bizplace: { name: result.bizplace.name },
276
- domain: { name: result.domain.name }
277
- };
278
- context.body = { result: { createdDraftOrder } };
279
- }
280
- else if (error.errorCode == 'EXISTING_ORDER') {
281
- context.body = {
282
- responseCode: 'E05',
283
- message: error.message,
284
- details: error.detail
285
- };
286
- }
287
- else {
288
- env_1.logger.error(`add-release-order: ${JSON.stringify(error)}`);
289
- context.throw(400, context.t(error));
290
- }
291
- }
292
- else {
293
- env_1.logger.error(`add-release-order: ${JSON.stringify(error)}`);
294
- context.throw(400, context.t(error));
295
- }
296
- }
297
- });
298
- });
299
- async function checkMandatoryKey(context, params) {
300
- let noparams = ['releaseDate', 'exportOption'].filter(param => !(param in params));
301
- if ('ownTransport' in params) {
302
- if (params.ownTransport == true) {
303
- if (!params.hasOwnProperty('collectionOrderNo')) {
304
- noparams.push('collectionOrderNo');
305
- }
306
- }
307
- }
308
- else {
309
- noparams.push('ownTransport');
310
- }
311
- if ('exportOption' in params) {
312
- if (params.exportOption === true) {
313
- if (params.exportOption.filter(record => !record.containerNo || !record.containerArrivalDate || !record.containerLeavingDate || !record.shipName).length) {
314
- noparams.push('exportOption');
315
- }
316
- }
317
- }
318
- if ('orderInventories' in params) {
319
- params.orderInventories.forEach((param, key) => {
320
- let noSubParams = [];
321
- if (!(param === null || param === void 0 ? void 0 : param.releaseQty))
322
- noSubParams.push('releaseQty');
323
- if (!(param === null || param === void 0 ? void 0 : param.product))
324
- noSubParams.push('product');
325
- if (noSubParams === null || noSubParams === void 0 ? void 0 : noSubParams.length)
326
- context.throw(400, context.t('error.required param x not found', { x: `${noSubParams.join(', ')}` }));
327
- });
328
- }
329
- else {
330
- noparams.push('orderInventories');
331
- }
332
- if (noparams === null || noparams === void 0 ? void 0 : noparams.length) {
333
- context.throw(400, context.t('error.required param x not found', { x: `${noparams.join(', ')}` }));
334
- }
335
- return params;
336
- }
337
- async function checkExistingOrder(releaseGood, bizplace, checkDuplicationValidation = true, context, tx) {
338
- const { domain, user } = context.state;
339
- const refNo = releaseGood.refNo;
340
- const refNo2 = releaseGood.refNo2;
341
- const refNo3 = releaseGood.refNo3;
342
- if (checkDuplicationValidation) {
343
- const foundDraftReleaseGood = await tx.getRepository(sales_base_1.DraftReleaseGood).findOne({
344
- where: {
345
- domain,
346
- bizplace: { id: bizplace.id },
347
- refNo: refNo || null,
348
- refNo2: refNo2 || null,
349
- refNo3: refNo3 || null,
350
- status: (0, typeorm_1.Not)((0, typeorm_1.In)([sales_base_1.DRAFT_RELEASE_ORDER_STATUS.CANCELLED]))
351
- }
352
- });
353
- if (foundDraftReleaseGood) {
354
- throw new index_1.ValidationError({
355
- errorCode: 'EXISTING_ORDER',
356
- message: 'existing draft release order found',
357
- detail: foundDraftReleaseGood.name
358
- });
359
- }
360
- const sellercraft = await tx
361
- .getRepository(integration_sellercraft_1.Sellercraft)
362
- .findOne({ domain: bizplace.domain, status: 'ACTIVE' });
363
- if (sellercraft) {
364
- const sellercraftCtrl = new sales_base_1.SellercraftController(tx, bizplace.domain, user);
365
- await sellercraftCtrl.checkExistingReleaseGood(sellercraft, releaseGood);
366
- }
367
- else {
368
- const foundReleaseGood = await tx.getRepository(sales_base_1.ReleaseGood).findOne({
369
- where: {
370
- domain: domain,
371
- bizplace: { id: bizplace.id },
372
- refNo,
373
- status: (0, typeorm_1.Not)((0, typeorm_1.In)([sales_base_1.ORDER_STATUS.CANCELLED, sales_base_1.ORDER_STATUS.PENDING_CANCEL]))
374
- },
375
- relations: ['bizplace', 'bizplace.domain', 'bizplace.company', 'bizplace.company.domain']
376
- });
377
- if (foundReleaseGood) {
378
- const customerCompanyDomain = foundReleaseGood.bizplace.company.domain;
379
- const marketplaceOrder = await tx.getRepository(marketplace_base_1.MarketplaceOrder).findOne({
380
- where: { orderNo: refNo, domain: customerCompanyDomain }
381
- });
382
- // Need to restructure the validation
383
- if (marketplaceOrder === null || marketplaceOrder === void 0 ? void 0 : marketplaceOrder.isSplitted) {
384
- const refNo2 = releaseGood.refNo2;
385
- const foundSplittedReleaseGood = await tx.getRepository(sales_base_1.ReleaseGood).findOne({
386
- where: {
387
- domain,
388
- refNo2,
389
- status: (0, typeorm_1.Not)((0, typeorm_1.In)([sales_base_1.ORDER_STATUS.CANCELLED, sales_base_1.ORDER_STATUS.PENDING_CANCEL]))
390
- },
391
- relations: ['bizplace', 'bizplace.domain', 'bizplace.company', 'bizplace.company.domain']
392
- });
393
- if (foundSplittedReleaseGood)
394
- throw new index_1.ValidationError({
395
- errorCode: 'EXISTING_ORDER',
396
- message: 'existing release order found',
397
- detail: foundSplittedReleaseGood.name
398
- });
399
- }
400
- else {
401
- throw new index_1.ValidationError({
402
- errorCode: 'EXISTING_ORDER',
403
- message: 'existing release order found',
404
- detail: foundReleaseGood.name
405
- });
406
- }
407
- }
408
- }
409
- }
410
- }
411
- async function createDraftOrder(releaseGood, orderProducts, context) {
412
- return await (0, typeorm_1.getConnection)().transaction(async (tx) => {
413
- return await (0, sales_base_1.createDraftReleaseGoodFunction)(null, releaseGood, orderProducts, null, [], context, tx);
414
- });
415
- }
416
- async function createReleaseGood(releaseGood, orderProducts, bizplace, context, tx, worksheetPickingAssignment) {
417
- try {
418
- const { domain, user } = context.state;
419
- const settingRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(setting_base_1.Setting)) || (0, typeorm_1.getRepository)(setting_base_1.Setting);
420
- const geoCountryRepo = (tx === null || tx === void 0 ? void 0 : tx.getRepository(geography_1.GeoCountry)) || (0, typeorm_1.getRepository)(geography_1.GeoCountry);
421
- if (orderProducts.length <= 0) {
422
- throw new index_1.ValidationError({
423
- errorCode: 'ITEM_NOT_FOUND',
424
- message: 'no order items found',
425
- detail: JSON.stringify(releaseGood)
426
- });
427
- }
428
- let newReleaseGood = new sales_base_1.ReleaseGood();
429
- // find RO number rule setting
430
- const roNoSetting = await settingRepo.findOne({
431
- where: {
432
- domain,
433
- name: sales_base_1.ORDER_NUMBER_SETTING_KEY.RO_NUMBER_RULE
434
- }
435
- });
436
- // standardise country
437
- let deliveryCountry = (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.country)
438
- ? await geoCountryRepo.findOne({
439
- where: [{ name: (0, typeorm_1.ILike)(releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.country) }, { description: (0, typeorm_1.ILike)(releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.country) }]
440
- })
441
- : null;
442
- let platformCountry = (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.platformCountry)
443
- ? await geoCountryRepo.findOne({
444
- where: [{ name: (0, typeorm_1.ILike)(releaseGood.platformCountry) }, { description: (0, typeorm_1.ILike)(releaseGood.platformCountry) }]
445
- })
446
- : null;
447
- // assign lmd
448
- let lmd = null;
449
- if (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.lmdOption) {
450
- lmd = await autoAssignLmd(domain, deliveryCountry === null || deliveryCountry === void 0 ? void 0 : deliveryCountry.id, releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.postalCode, bizplace);
451
- }
452
- let phoneNum = (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.phone1) ? releaseGood.phone1.replace(/[^\d]/g, '') : null;
453
- newReleaseGood = {
454
- name: roNoSetting
455
- ? await (0, id_rule_base_1.generateId)({ domain, type: sales_base_1.ORDER_NUMBER_RULE_TYPE.RO_NUMBER, seed: {} })
456
- : sales_base_1.OrderNoGenerator.releaseGood(),
457
- domain: domain,
458
- bizplace: bizplace,
459
- collectionOrderNo: releaseGood.collectionOrderNo,
460
- courierOption: releaseGood.courierOption,
461
- codOption: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.codOption,
462
- exportOption: releaseGood.exportOption,
463
- ownTransport: releaseGood.ownTransport,
464
- packingOption: releaseGood.packingOption,
465
- marketplaceOrderStatus: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.marketplaceOrderStatus) || null,
466
- billingAddress: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.billingAddress) || null,
467
- deliveryAddress1: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.deliveryAddress1) || null,
468
- deliveryAddress2: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.deliveryAddress2) || null,
469
- deliveryAddress3: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.deliveryAddress3) || null,
470
- deliveryAddress4: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.deliveryAddress4) || null,
471
- deliveryAddress5: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.deliveryAddress5) || null,
472
- attentionTo: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.attentionTo) || null,
473
- attentionCompany: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.attentionCompany) || null,
474
- city: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.city) || null,
475
- ward: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.ward) || null,
476
- district: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.district) || null,
477
- state: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.state) || null,
478
- postalCode: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.postalCode) || null,
479
- country: (deliveryCountry === null || deliveryCountry === void 0 ? void 0 : deliveryCountry.description) || (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.country) || null,
480
- phone1: phoneNum,
481
- phone2: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.phone2) || null,
482
- email: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.email) || null,
483
- transporter: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.transporter,
484
- trackingNo: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.trackingNo,
485
- airwayBill: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.airwayBill,
486
- invoice: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.invoice,
487
- refNo: releaseGood.refNo,
488
- refNo2: releaseGood.refNo2 || null,
489
- refNo3: releaseGood.refNo3 || null,
490
- refOrderId: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.refOrderId) || null,
491
- remark: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.remark) || null,
492
- releaseDate: releaseGood.releaseDate,
493
- truckNo: releaseGood.truckNo,
494
- type: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.type) ? releaseGood.type : 'b2b',
495
- status: sales_base_1.ORDER_STATUS.PENDING_WORKSHEET,
496
- storeName: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.storeName,
497
- storeId: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.storeId,
498
- routeId: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.routeId,
499
- stopId: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.stopId,
500
- packageId: (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.packageId) || null,
501
- noOfItems: orderProducts.length,
502
- source: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.source,
503
- platformCode: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.platformCode,
504
- platformCountry: (platformCountry === null || platformCountry === void 0 ? void 0 : platformCountry.description) || (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.platformCountry) || null,
505
- platformName: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.platformName,
506
- paidAmount: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.paidAmount,
507
- discountAmount: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.discountAmount,
508
- taxAmount: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.taxAmount,
509
- shippingFee: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.shippingFee,
510
- lmdOption: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.lmdOption,
511
- priorityDelivery: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.priorityDelivery,
512
- lastMileDelivery: lmd,
513
- creator: user,
514
- updater: user,
515
- acceptedBy: user,
516
- acceptedAt: new Date(),
517
- assignedInventory: (worksheetPickingAssignment === null || worksheetPickingAssignment === void 0 ? void 0 : worksheetPickingAssignment.value) == 'true' ? false : true,
518
- orderMethod: sales_base_1.ORDER_METHOD.SELECT_BY_PRODUCT,
519
- sourceData: releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.sourceData
520
- };
521
- let resultReleaseGood = await tx.getRepository(sales_base_1.ReleaseGood).save(newReleaseGood);
522
- let combinedOrderInventories = [];
523
- let savedOrderProducts = await Promise.all(orderProducts.map(async (orderProduct) => {
524
- let orderInventories = orderProduct.orderInventories;
525
- orderProduct = Object.assign(new sales_base_1.OrderProduct(), Object.assign(Object.assign({}, orderProduct), { name: (0, uuid_1.v4)(), domain: domain, bizplace: bizplace, releaseGood: resultReleaseGood, type: sales_base_1.ORDER_TYPES.RELEASE_OF_GOODS, status: sales_base_1.ORDER_PRODUCT_STATUS.ASSIGNED }));
526
- let newOrderProduct = await tx.getRepository(sales_base_1.OrderProduct).save(orderProduct);
527
- if ((worksheetPickingAssignment === null || worksheetPickingAssignment === void 0 ? void 0 : worksheetPickingAssignment.value) !== 'true') {
528
- for (let oiIdx = 0; oiIdx < orderInventories.length; oiIdx++) {
529
- let orderInventory = Object.assign(new sales_base_1.OrderInventory(), Object.assign(Object.assign({}, orderInventories[oiIdx]), { name: (0, uuid_1.v4)(), domain: domain, bizplace: bizplace, releaseGood: resultReleaseGood, type: sales_base_1.ORDER_TYPES.RELEASE_OF_GOODS, status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_WORKSHEET, orderProduct: newOrderProduct }));
530
- await tx.getRepository(sales_base_1.OrderInventory).save(orderInventory);
531
- combinedOrderInventories.push({
532
- product: { name: orderInventory.product.name, sku: orderInventory.product.sku },
533
- batchId: orderInventory.batchId,
534
- packingType: orderInventory.packingType,
535
- packingSize: orderInventory.packingSize,
536
- releaseQty: orderInventory.releaseQty,
537
- releaseUomValue: orderInventory.releaseUomValue
538
- });
539
- }
540
- }
541
- return newOrderProduct;
542
- }));
543
- newReleaseGood.orderProducts = savedOrderProducts;
544
- newReleaseGood.orderInventories = combinedOrderInventories;
545
- return newReleaseGood;
546
- }
547
- catch (error) {
548
- throw error;
549
- }
550
- }
551
- async function massageOrderItems(releaseGood, inputOrderProducts, context) {
552
- const { t } = context;
553
- try {
554
- let orderProducts = [];
555
- let errorList = [];
556
- let totalReleaseQty = 0;
557
- //combine any repeated skus
558
- inputOrderProducts = inputOrderProducts.reduce((acc, itm, idx) => {
559
- let { sku, refCode } = itm.product;
560
- let { packingType, packingSize, batchId, releaseQty, sellingPrice, paidAmount } = itm;
561
- if (!sku && !refCode) {
562
- errorList.push(JSON.stringify({
563
- code: 'INVALID_DATA',
564
- message: 'sku or refCode not found',
565
- sku: sku,
566
- refCode: refCode,
567
- packingType: packingType === null || packingType === void 0 ? void 0 : packingType.trim(),
568
- packingSize: packingSize,
569
- qty: releaseQty
570
- }));
571
- }
572
- if (releaseQty <= 0) {
573
- errorList.push(JSON.stringify({
574
- code: 'INVALID_DATA',
575
- message: 'negative stock request',
576
- sku: sku,
577
- refCode: refCode,
578
- packingType: packingType === null || packingType === void 0 ? void 0 : packingType.trim(),
579
- packingSize: packingSize,
580
- qty: releaseQty
581
- }));
582
- }
583
- let existingIndex = acc.findIndex(itm => (itm === null || itm === void 0 ? void 0 : itm.sku) == (sku === null || sku === void 0 ? void 0 : sku.trim()) &&
584
- (itm === null || itm === void 0 ? void 0 : itm.refCode) == (refCode === null || refCode === void 0 ? void 0 : refCode.trim()) &&
585
- (itm === null || itm === void 0 ? void 0 : itm.packingType) == (packingType === null || packingType === void 0 ? void 0 : packingType.trim()) &&
586
- (itm === null || itm === void 0 ? void 0 : itm.packingSize) == packingSize);
587
- if (existingIndex >= 0 && releaseQty > 0) {
588
- acc[existingIndex].releaseQty = acc[existingIndex].releaseQty + releaseQty;
589
- totalReleaseQty += releaseQty;
590
- }
591
- else {
592
- acc.push({
593
- sku: sku === null || sku === void 0 ? void 0 : sku.trim(),
594
- refCode: refCode === null || refCode === void 0 ? void 0 : refCode.trim(),
595
- packingType: packingType === null || packingType === void 0 ? void 0 : packingType.trim(),
596
- packingSize: packingSize,
597
- releaseQty: releaseQty,
598
- sellingPrice: sellingPrice,
599
- batchId: (batchId === null || batchId === void 0 ? void 0 : batchId.trim()) || '',
600
- paidAmount: paidAmount
601
- });
602
- totalReleaseQty += releaseQty;
603
- }
604
- return acc;
605
- }, []);
606
- if (errorList.length > 0) {
607
- throw new index_1.ValidationError({
608
- errorCode: 'INVALID_DATA',
609
- message: 'invalid data',
610
- detail: errorList.join(', ')
611
- });
612
- }
613
- let avgPaidAmount = (releaseGood === null || releaseGood === void 0 ? void 0 : releaseGood.paidAmount) ? releaseGood.paidAmount / totalReleaseQty : 0;
614
- //find customer sku in system
615
- await Promise.all(inputOrderProducts.map(async (inputOrderItem) => {
616
- const sku = inputOrderItem.sku;
617
- const refCode = inputOrderItem.refCode;
618
- const packingType = inputOrderItem.packingType;
619
- const packingSize = inputOrderItem.packingSize;
620
- const qb = (0, typeorm_1.getRepository)(product_base_1.ProductDetail)
621
- .createQueryBuilder('PD')
622
- .innerJoinAndSelect('PD.product', 'PROD')
623
- .where('PROD.bizplace_id = :bizplaceId', { bizplaceId: releaseGood.companyBizplace.id });
624
- if (!sku && !refCode) {
625
- context.throw(404, t('error.sku or refCode not found'));
626
- }
627
- if (refCode) {
628
- qb.andWhere('PD.ref_code = :refCode', { refCode });
629
- }
630
- if (sku) {
631
- qb.andWhere('PROD.sku = :sku', { sku });
632
- }
633
- if (packingType) {
634
- qb.andWhere('PD.packing_type = :packingType', { packingType });
635
- }
636
- if ((!packingType && !refCode) || !packingSize) {
637
- qb.andWhere('PD.is_default = :isDefault', { isDefault: true });
638
- }
639
- const productDetail = await qb.getOne();
640
- // order Product based on product detail
641
- if (productDetail) {
642
- let newOrderProduct = Object.assign({}, inputOrderItem);
643
- newOrderProduct = Object.assign(Object.assign({}, newOrderProduct), { product: productDetail.product, productDetail: productDetail, packingType: productDetail.packingType, packingSize: packingSize || productDetail.packingSize, uom: productDetail.uom, uomValue: productDetail.uomValue, refCode: inputOrderItem.refCode, releaseQty: inputOrderItem.releaseQty, releaseUomValue: inputOrderItem.releaseQty * (productDetail.uomValue || 1), packQty: 0, actualPackQty: 0, palletQty: 0, actualPalletQty: 0, type: 'RELEASE_OF_GOODS', status: sales_base_1.ORDER_PRODUCT_STATUS.ASSIGNED, batchId: (inputOrderItem === null || inputOrderItem === void 0 ? void 0 : inputOrderItem.batchId) || '', sellingPrice: (inputOrderItem === null || inputOrderItem === void 0 ? void 0 : inputOrderItem.sellingPrice)
644
- ? inputOrderItem.sellingPrice
645
- : avgPaidAmount * inputOrderItem.releaseQty, paidAmount: (inputOrderItem === null || inputOrderItem === void 0 ? void 0 : inputOrderItem.paidAmount)
646
- ? inputOrderItem.paidAmount
647
- : avgPaidAmount * inputOrderItem.releaseQty });
648
- newOrderProduct.orderInventories = [
649
- Object.assign(Object.assign({}, newOrderProduct), { packQty: 0, actualPackQty: 0, palletQty: 0, actualPalletQty: 0, type: 'RELEASE_OF_GOODS', status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_WORKSHEET })
650
- ];
651
- orderProducts.push(newOrderProduct);
652
- }
653
- if (!productDetail) {
654
- const qb = (0, typeorm_1.getRepository)(product_base_1.ProductBundle)
655
- .createQueryBuilder('PB')
656
- .innerJoinAndSelect('PB.productBundleSettings', 'PBS')
657
- .innerJoinAndSelect('PBS.productDetail', 'PBD')
658
- .innerJoinAndSelect('PBD.product', 'PROD')
659
- .where('PB.bizplace_id = :bizplaceId', { bizplaceId: releaseGood.companyBizplace.id });
660
- if (!sku && !refCode) {
661
- context.throw(404, t('error.sku or refCode not found'));
662
- }
663
- if (refCode) {
664
- qb.andWhere('PB.ref_code = :refCode', { refCode });
665
- }
666
- if (sku) {
667
- qb.andWhere('PB.sku = :sku', { sku });
668
- }
669
- if (packingType) {
670
- qb.andWhere('PB.packing_type = :packingType', { packingType });
671
- }
672
- const foundProductBundle = await qb.getOne();
673
- if (foundProductBundle) {
674
- let orderProduct;
675
- // to be further enhanced
676
- // let orderProduct = {
677
- // productBundle: foundProductBundle,
678
- // refCode,
679
- // packingType: foundProductBundle.packingType,
680
- // packingSize: packingSize || 1,
681
- // uom: inputOrderItem?.uom,
682
- // releaseQty: inputOrderItem.releaseQty,
683
- // releaseUomValue: inputOrderItem.releaseQty,
684
- // packQty: 0,
685
- // actualPackQty: 0,
686
- // palletQty: 0,
687
- // actualPalletQty: 0,
688
- // orderInventories: [],
689
- // type: 'RELEASE_OF_GOODS',
690
- // status: ORDER_PRODUCT_STATUS.ASSIGNED,
691
- // batchId: '-',
692
- // sellingPrice: inputOrderItem?.sellingPrice
693
- // ? inputOrderItem.sellingPrice
694
- // : avgPaidAmount * inputOrderItem.releaseQty,
695
- // paidAmount: inputOrderItem?.paidAmount
696
- // ? inputOrderItem.paidAmount
697
- // : avgPaidAmount * inputOrderItem.releaseQty
698
- // }
699
- const bundleProductSettings = foundProductBundle.productBundleSettings;
700
- bundleProductSettings.map(bundleProductSetting => {
701
- const productDetailBundle = bundleProductSetting.productDetail;
702
- let newOrderInventory = {
703
- product: productDetailBundle.product,
704
- productDetail: productDetailBundle,
705
- sku: productDetailBundle.product.sku,
706
- packingType: productDetailBundle.packingType,
707
- packingSize: productDetailBundle.packingSize,
708
- uom: productDetailBundle.uom,
709
- packQty: 0,
710
- actualPackQty: 0,
711
- palletQty: 0,
712
- actualPalletQty: 0,
713
- releaseQty: inputOrderItem.releaseQty * bundleProductSetting.bundleQty,
714
- releaseUomValue: inputOrderItem.releaseQty *
715
- bundleProductSetting.bundleQty *
716
- (productDetailBundle.uomValue <= 0 ? 1 : productDetailBundle.uomValue),
717
- type: 'RELEASE_OF_GOODS',
718
- status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_WORKSHEET
719
- };
720
- orderProduct = Object.assign(new sales_base_1.OrderProduct(), newOrderInventory);
721
- orderProduct = Object.assign(Object.assign({}, orderProduct), { refCode, packingType: foundProductBundle.packingType, packingSize: packingSize || 1, orderInventories: [], status: sales_base_1.ORDER_PRODUCT_STATUS.ASSIGNED, batchId: '-' });
722
- orderProduct.orderInventories.push(newOrderInventory);
723
- orderProducts.push(orderProduct);
724
- });
725
- }
726
- else {
727
- if (sku && refCode) {
728
- context.throw(404, t(`error.sku ${sku} and refCode ${refCode} not exist in product / bundle master`));
729
- }
730
- if (sku) {
731
- context.throw(404, t(`error.sku ${sku} not exist in product / bundle master`));
732
- }
733
- if (refCode) {
734
- context.throw(404, t(`error.refCode ${refCode} not exist in product / bundle master`));
735
- }
736
- }
737
- }
738
- }));
739
- //combine any repeated skus
740
- let combinedItems = orderProducts.reduce((acc, op, idx) => {
741
- let oi = (op === null || op === void 0 ? void 0 : op.orderInventories) || [];
742
- oi.forEach(itm => {
743
- let { sku, refCode } = itm.product;
744
- let { packingType, packingSize, batchId, releaseQty, product, productDetail, uom } = itm;
745
- if (!sku && !refCode) {
746
- context.throw(404, t('error.sku or refCode not found'));
747
- }
748
- let existingIndex = acc.findIndex(itm => (itm === null || itm === void 0 ? void 0 : itm.sku) == (sku === null || sku === void 0 ? void 0 : sku.trim()) &&
749
- (itm === null || itm === void 0 ? void 0 : itm.refCode) == (refCode === null || refCode === void 0 ? void 0 : refCode.trim()) &&
750
- (itm === null || itm === void 0 ? void 0 : itm.packingType) == (packingType === null || packingType === void 0 ? void 0 : packingType.trim()) &&
751
- (itm === null || itm === void 0 ? void 0 : itm.packingSize) == packingSize &&
752
- (itm === null || itm === void 0 ? void 0 : itm.batchId) == (batchId === null || batchId === void 0 ? void 0 : batchId.trim()) &&
753
- (itm === null || itm === void 0 ? void 0 : itm.uom) == (uom === null || uom === void 0 ? void 0 : uom.trim()));
754
- if (existingIndex >= 0 && releaseQty > 0) {
755
- acc[existingIndex].releaseQty = acc[existingIndex].releaseQty + releaseQty;
756
- acc[existingIndex].releaseUomValue =
757
- acc[existingIndex].releaseUomValue + releaseQty * (productDetail.uomValue <= 0 ? 1 : productDetail.uomValue);
758
- }
759
- else {
760
- let updateObj = {
761
- sku: sku === null || sku === void 0 ? void 0 : sku.trim(),
762
- packingType: packingType === null || packingType === void 0 ? void 0 : packingType.trim(),
763
- packingSize: packingSize,
764
- uom: uom === null || uom === void 0 ? void 0 : uom.trim(),
765
- releaseQty: releaseQty,
766
- releaseUomValue: releaseQty * (productDetail.uomValue <= 0 ? 1 : productDetail.uomValue),
767
- product,
768
- productDetail
769
- };
770
- if (refCode)
771
- updateObj['refCode'] = refCode.trim();
772
- updateObj['batchId'] = batchId ? batchId === null || batchId === void 0 ? void 0 : batchId.trim() : '';
773
- acc.push(updateObj);
774
- }
775
- });
776
- return acc;
777
- }, []);
778
- const mapJsonData = (releaseGood, orderProducts) => {
779
- let mapData = {
780
- refNo: releaseGood.refNo || null,
781
- refOrderItem: releaseGood.refOrderItem || null,
782
- orderProducts: orderProducts.map(itm => {
783
- return {
784
- releaseQty: itm.releaseQty,
785
- product: (itm === null || itm === void 0 ? void 0 : itm.product)
786
- ? {
787
- id: itm.product.id,
788
- sku: itm.product.sku
789
- }
790
- : null,
791
- productBundle: (itm === null || itm === void 0 ? void 0 : itm.productBundle)
792
- ? {
793
- id: itm.productBundle.id,
794
- sku: itm.productBundle.sku
795
- }
796
- : null,
797
- productDetail: (itm === null || itm === void 0 ? void 0 : itm.productDetail)
798
- ? {
799
- id: itm.productDetail.id,
800
- refCode: itm.productDetail.refCode,
801
- uom: itm.productDetail.uom,
802
- uomValue: itm.productDetail.uomValue,
803
- packingType: itm.productDetail.packingType
804
- }
805
- : null
806
- };
807
- })
808
- };
809
- releaseGood.sourceData = JSON.stringify(mapData);
810
- };
811
- mapJsonData(releaseGood, orderProducts);
812
- return { orderProducts, combinedItems };
813
- }
814
- catch (error) {
815
- throw error;
816
- }
817
- }
818
- async function assignToInventory(releaseGood, orderProducts, customerBizplace, context, tx, worksheetPickingAssignment) {
819
- const { client, domain, user } = context.state;
820
- const pickingProductSetting = await tx.getRepository(setting_base_1.Setting).findOne({
821
- where: { domain, name: 'rule-for-picking-product' }
822
- });
823
- for (let opIdx = 0; opIdx < orderProducts.length; opIdx++) {
824
- let orderProduct = orderProducts[opIdx];
825
- let assignedOrderInventories = [];
826
- const orderInventory = orderProduct.orderInventories[0];
827
- let sortings = [];
828
- if ((worksheetPickingAssignment === null || worksheetPickingAssignment === void 0 ? void 0 : worksheetPickingAssignment.value) !== 'true') {
829
- switch (orderInventory.product.pickingStrategy) {
830
- case 'LIFO':
831
- sortings.push({ name: 'iv.created_at', desc: true });
832
- if (pickingProductSetting === null || pickingProductSetting === void 0 ? void 0 : pickingProductSetting.value) {
833
- for (const [key, value] of Object.entries(JSON.parse(pickingProductSetting.value))) {
834
- sortings.push({ name: `loc.${key}`, desc: value == 'DESC' ? true : false });
835
- }
836
- }
837
- else {
838
- sortings.push({ name: 'loc.name', desc: false }, { name: 'iv.created_at', desc: false });
839
- }
840
- break;
841
- case 'FEFO':
842
- sortings.push({ name: 'iv.expiration_date', desc: false }, { name: 'iv.created_at', desc: false });
843
- if (pickingProductSetting === null || pickingProductSetting === void 0 ? void 0 : pickingProductSetting.value) {
844
- for (const [key, value] of Object.entries(JSON.parse(pickingProductSetting.value))) {
845
- sortings.push({ name: `loc.${key}`, desc: value == 'DESC' ? true : false });
846
- }
847
- }
848
- else {
849
- sortings.push({ name: 'loc.name', desc: false }, { name: 'iv.created_at', desc: false });
850
- }
851
- break;
852
- case 'FMFO':
853
- sortings.push({ name: 'iv.manufacture_date', desc: false }, { name: 'iv.created_at', desc: false });
854
- if (pickingProductSetting === null || pickingProductSetting === void 0 ? void 0 : pickingProductSetting.value) {
855
- for (const [key, value] of Object.entries(JSON.parse(pickingProductSetting.value))) {
856
- sortings.push({ name: `loc.${key}`, desc: value == 'DESC' ? true : false });
857
- }
858
- }
859
- else {
860
- sortings.push({ name: 'loc.name', desc: false }, { name: 'iv.created_at', desc: false });
861
- }
862
- break;
863
- case 'LOCATION':
864
- if (pickingProductSetting === null || pickingProductSetting === void 0 ? void 0 : pickingProductSetting.value) {
865
- for (const [key, value] of Object.entries(JSON.parse(pickingProductSetting.value))) {
866
- sortings.push({ name: `loc.${key}`, desc: value == 'DESC' ? true : false });
867
- }
868
- }
869
- else {
870
- sortings.push({ name: 'loc.name', desc: false }, { name: 'iv.created_at', desc: false });
871
- }
872
- break;
873
- //Every other case includes 'FIFO' will be applicable for this case
874
- default:
875
- sortings.push({ name: 'iv.created_at', desc: false });
876
- if (pickingProductSetting === null || pickingProductSetting === void 0 ? void 0 : pickingProductSetting.value) {
877
- for (const [key, value] of Object.entries(JSON.parse(pickingProductSetting.value))) {
878
- sortings.push({ name: `loc.${key}`, desc: value == 'DESC' ? true : false });
879
- }
880
- }
881
- else {
882
- sortings.push({ name: 'loc.name', desc: false });
883
- sortings.push({ name: 'iv.pallet_id', desc: false });
884
- }
885
- break;
886
- }
887
- let queryFilters = [];
888
- let queryStrings = queryFilters.reduce((acc, itm, idx, arr) => {
889
- acc.values.push(itm.filters);
890
- switch (itm === null || itm === void 0 ? void 0 : itm.operator) {
891
- case 'notin':
892
- case 'in':
893
- acc.query.push(`${itm.query} ${itm.operator == 'notin' ? 'NOT IN' : 'IN'} (${itm.filtes
894
- .map((itm, idx) => {
895
- return `$${acc.values.length + 1}`;
896
- })
897
- .join(',')})`);
898
- break;
899
- default:
900
- acc.query.push(`${itm.query} ${(itm === null || itm === void 0 ? void 0 : itm.operator) ? itm.operator : '='} $${acc.values.length + 1}`);
901
- break;
902
- }
903
- acc.query.push(`${itm.query} ${(itm === null || itm === void 0 ? void 0 : itm.operator) ? itm.operator : '='} $${acc.values.length + 1}`);
904
- }, {
905
- query: [],
906
- values: []
907
- });
908
- let sortQuery = sortings
909
- .map(itm => {
910
- return `${itm.name} ${itm.desc ? 'DESC' : 'ASC'}`;
911
- })
912
- .join(`,`);
913
- let params = [
914
- user.id,
915
- domain.id,
916
- customerBizplace.id,
917
- orderInventory.packingType,
918
- orderInventory.packingSize,
919
- orderInventory.product.id,
920
- warehouse_base_1.INVENTORY_STATUS.STORED,
921
- warehouse_base_1.LOCATION_TYPE.QUARANTINE,
922
- warehouse_base_1.LOCATION_TYPE.RESERVE,
923
- warehouse_base_1.LOCATION_TYPE.STORAGE
924
- ];
925
- if (orderInventory.batchId) {
926
- params.push(orderInventory.batchId);
927
- }
928
- params = [...params, ...queryStrings.values];
929
- let updatedInventories = await tx.getRepository(warehouse_base_1.Inventory).query(`
930
- update inventories tgt set locked_qty = coalesce(locked_qty,0) + src.reserve_qty,
931
- locked_uom_value = coalesce(locked_uom_value,0) + src.reserve_uom_value,
932
- updated_at = NOW(),
933
- updater_id = $1
934
- from (
935
- select "id", "pallet_id","carton_id", "batch_id", "batch_id_ref", "unit", "uom", "packing_type", "packing_size", "manufacture_year",
936
- "reserve_qty", (("uom_value"/"qty") * "reserve_qty") as "reserve_uom_value" from (
937
- select "sort_seq", "id", "pallet_id", "batch_id", "batch_id_ref", "unit", "uom", "packing_type", "packing_size", "manufacture_year", "carton_id", "uom_value", "locked_uom_value", "qty", "locked_qty", "created_at",
938
- "release_qty", "release_uom_value", lock_amount,
939
- case when "lock_amount" < 0 then "available_qty" else "available_qty" - "lock_amount" end as "reserve_qty"
940
- from (
941
- select *,
942
- (
943
- case when (qty - greatest(locked_qty, 0) - greatest(unassigned_qty, 0)) < 0 then 0
944
- else qty - greatest(locked_qty, 0) - greatest(unassigned_qty, 0) end
945
- ) as available_qty,
946
- sum(qty - locked_qty - release_qty - unassigned_qty) over (order by sort_seq asc rows between unbounded preceding and current row) as lock_amount
947
- from (
948
- SELECT 0 as sort_seq, null as id, null as pallet_id, null as batch_id, null as batch_id_ref,
949
- null as unit, '${orderInventory.uom}' as uom, '${orderInventory.packingType}' as packing_type, '${orderInventory.packingSize}' as packing_size,
950
- null as manufacture_year, null as carton_id, 0 as uom_value, 0 as locked_uom_value, 0 as qty, 0 as locked_qty, 0 as unassigned_uom_value, 0 as unassigned_qty, null as created_at,
951
- '${orderInventory.releaseQty}' as release_qty, '${orderInventory.releaseUomValue}' as release_uom_value
952
- UNION
953
- (
954
- SELECT ROW_NUMBER() OVER(PARTITION BY iv.domain_id ORDER BY wiar.rank ${sortQuery ? ', ' + sortQuery : ''}) as sort_seq,
955
- iv.id, iv.pallet_id, iv.batch_id, iv.batch_id_ref,
956
- iv.unit, iv.uom, iv.packing_type, iv.packing_size,
957
- iv.manufacture_year, iv.carton_id, iv.uom_value,
958
- coalesce(iv.locked_uom_value,0) as locked_uom_value, iv.qty, greatest(coalesce(iv.locked_qty,0),0) as locked_qty, coalesce(pds.unassigned_uom_value,0) as unassigned_uom_value, greatest(coalesce(pds.unassigned_qty,0),0) as unassigned_qty, iv.created_at,
959
- 0 as release_qty, 0 as release_uom_value
960
- FROM "inventories" "iv"
961
- LEFT JOIN "product_detail_stocks" "pds" ON "pds"."product_detail_id" = "iv"."product_detail_id"
962
- INNER JOIN "locations" "loc" ON "loc"."id"="iv"."location_id"
963
- INNER JOIN "products" "p" ON "p"."id"="iv"."product_id"
964
- INNER JOIN "warehouse_inventory_assignment_rankings" "wiar" ON "wiar"."location_type"="loc"."type"
965
- WHERE case when coalesce("iv"."locked_qty",0) < 0 then 0 else ("iv"."qty" - coalesce("iv"."locked_qty",0)) end > 0 AND
966
- "iv"."domain_id" = $2 AND "iv"."bizplace_id" = $3 AND "iv"."packing_type" = $4 AND "iv"."packing_size" = $5 AND "iv"."product_id" = $6 AND "iv"."status" = $7 AND "loc"."type" NOT IN ($8, $9, $10)
967
- AND ${orderInventory.batchId ? `"iv"."batch_id" = $11` : `1=1`}
968
- AND "iv"."obsolete" = false AND case when "iv"."expiration_date" is not null and "p"."min_outbound_shelf_life" is not null then CURRENT_DATE < "iv"."expiration_date" - "p"."min_outbound_shelf_life" else true end
969
- ${queryStrings.query.length > 0 ? `AND ${queryStrings.join(' AND ')}` : ''}
970
- ORDER BY wiar.rank ${sortQuery ? ', ' + sortQuery : ''}
971
- )
972
- ) dt1
973
- ) dt2 where case when "lock_amount" < 0 then "available_qty" else "available_qty" - "lock_amount" end > 0
974
- ) dt3 where sort_seq > 0
975
- ) src where src.id = tgt.id
976
- returning
977
- tgt."id", tgt."qty", tgt."pallet_id", tgt."carton_id", tgt."batch_id", tgt."batch_id_ref", tgt."unit",
978
- tgt."uom", tgt."packing_type", tgt."packing_size", tgt."manufacture_year",
979
- tgt."locked_qty", tgt."uom_value", tgt."locked_uom_value", src."reserve_qty", src."reserve_uom_value";`, params);
980
- let totalAssigned = updatedInventories[0].reduce((acc, inv) => {
981
- return acc + inv.reserve_qty;
982
- }, 0);
983
- if (orderProduct.releaseQty != totalAssigned) {
984
- throw new index_1.ValidationError({
985
- errorCode: 'INSUFFICIENT_STOCK',
986
- message: 'insufficient stock',
987
- detail: JSON.stringify({
988
- code: 'insufficient stock',
989
- sku: orderProduct.product.sku,
990
- packingType: orderProduct.packingType,
991
- packingSize: orderProduct.packingSize,
992
- uom: orderProduct.uom,
993
- qty: orderProduct.releaseQty,
994
- uom_value: orderProduct.releaseUomValue
995
- })
996
- });
997
- }
998
- updatedInventories[0].forEach(inv => {
999
- let oi = Object.assign(Object.assign({}, orderInventory), { inventory: { id: inv.id }, uom: inv.uom, packingType: inv.packing_type, batchId: inv.batch_id, releaseQty: inv.reserve_qty, releaseUomValue: inv.reserve_uom_value, pickedQty: 0, packedQty: 0, type: sales_base_1.ORDER_TYPES.RELEASE_OF_GOODS, status: sales_base_1.ORDER_INVENTORY_STATUS.PENDING_WORKSHEET, domain: { id: domain.id }, bizplace: { id: customerBizplace.id } });
1000
- assignedOrderInventories.push(oi);
1001
- });
1002
- orderProducts[opIdx].orderInventories = assignedOrderInventories;
1003
- }
1004
- else {
1005
- await tx
1006
- .getRepository(warehouse_base_1.ProductDetailStock)
1007
- .createQueryBuilder()
1008
- .update(warehouse_base_1.ProductDetailStock)
1009
- .set({
1010
- unassignedQty: () => `"unassigned_qty" + ${orderInventory.releaseQty}`,
1011
- unassignedUomValue: () => `"unassigned_uom_value" + ${orderInventory.releaseUomValue}`
1012
- })
1013
- .where({ productDetail: orderInventory.productDetail.id })
1014
- .execute();
1015
- }
1016
- }
1017
- return orderProducts;
1018
- }
1019
- async function autoAssignLmd(domain, countryId, postalCode, bizplace) {
1020
- let lmdResult;
1021
- const qb = (0, typeorm_1.getRepository)(integration_lmd_1.LastMileDelivery)
1022
- .createQueryBuilder('lmd')
1023
- .leftJoinAndSelect('lmd.lastMileDeliverySettings', 'lmds')
1024
- .innerJoinAndSelect('lmds.geoCountry', 'gc')
1025
- .leftJoinAndSelect(`lmd.lastMileDeliveryBizplaces`, `lmdb`)
1026
- .leftJoinAndSelect('lmdb.bizplace', 'bz')
1027
- .where('lmd.domain_id = :domainId', { domainId: domain.id })
1028
- .andWhere('lower(lmd.status) = :status', { status: 'active' })
1029
- .andWhere('gc.id = :gcId', { gcId: countryId })
1030
- .andWhere('lmdb.bizplace_id = :bzId', { bzId: bizplace.id })
1031
- .orderBy('lmdb.bizplace_id', 'ASC');
1032
- let lmdList = await qb.getMany();
1033
- if (lmdList.length > 1) {
1034
- qb.andWhere('lmd.id IN (:...lmdIds)', {
1035
- lmdIds: lmdList.map(lmd => {
1036
- return lmd.id;
1037
- })
1038
- });
1039
- }
1040
- qb.andWhere(new typeorm_1.Brackets(qb => {
1041
- qb.where(`lmds.include_postal_code = ''`)
1042
- .orWhere('lmds.include_postal_code is null')
1043
- .orWhere('lmds.include_postal_code like :includePostCode', { includePostCode: `%${postalCode}%` });
1044
- }))
1045
- .andWhere(new typeorm_1.Brackets(qb => {
1046
- qb.where(`lmds.exclude_postal_code = ''`)
1047
- .orWhere('lmds.exclude_postal_code is null')
1048
- .orWhere('lmds.exclude_postal_code not like :excludePostCode', { excludePostCode: `%${postalCode}%` });
1049
- }))
1050
- .addOrderBy('lmds.include_postal_code')
1051
- .addOrderBy('lmd.rank', 'ASC');
1052
- lmdResult = await qb.getOne();
1053
- if (!lmdResult) {
1054
- const newQb = (0, typeorm_1.getRepository)(integration_lmd_1.LastMileDelivery)
1055
- .createQueryBuilder('lmd')
1056
- .leftJoinAndSelect('lmd.lastMileDeliverySettings', 'lmds')
1057
- .innerJoinAndSelect('lmds.geoCountry', 'gc')
1058
- .leftJoinAndSelect(`lmd.lastMileDeliveryBizplaces`, `lmdb`)
1059
- .leftJoinAndSelect('lmdb.bizplace', 'bz')
1060
- .where('lmd.domain_id = :domainId', { domainId: domain.id })
1061
- .andWhere('lower(lmd.status) = :status', { status: 'active' })
1062
- .andWhere('gc.id = :gcId', { gcId: countryId })
1063
- .andWhere('lmdb.bizplace_id is null')
1064
- .andWhere(new typeorm_1.Brackets(qb => {
1065
- qb.where(`lmds.include_postal_code = ''`)
1066
- .orWhere('lmds.include_postal_code is null')
1067
- .orWhere('lmds.include_postal_code like :includePostCode', { includePostCode: `%${postalCode}%` });
1068
- }))
1069
- .andWhere(new typeorm_1.Brackets(qb => {
1070
- qb.where(`lmds.exclude_postal_code = ''`)
1071
- .orWhere('lmds.exclude_postal_code is null')
1072
- .orWhere('lmds.exclude_postal_code not like :excludePostCode', { excludePostCode: `%${postalCode}%` });
1073
- }))
1074
- .orderBy('lmds.include_postal_code')
1075
- .addOrderBy('lmd.rank', 'ASC');
1076
- lmdResult = await newQb.getOne();
1077
- }
1078
- return lmdResult;
1079
- }
1080
- //# sourceMappingURL=add-release-order.js.map