@things-factory/operato-hub 4.3.649 → 4.3.651

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