@things-factory/operato-hub 4.3.651 → 4.3.653

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 (518) hide show
  1. package/config.development.js +10 -3
  2. package/dist-server/controllers/bizplace-initializer/codes.js +21 -0
  3. package/dist-server/controllers/bizplace-initializer/codes.js.map +1 -0
  4. package/dist-server/controllers/bizplace-initializer/dataset/codes.js +403 -0
  5. package/dist-server/controllers/bizplace-initializer/dataset/codes.js.map +1 -0
  6. package/dist-server/controllers/bizplace-initializer/dataset/groups.js +24 -0
  7. package/dist-server/controllers/bizplace-initializer/dataset/groups.js.map +1 -0
  8. package/dist-server/controllers/bizplace-initializer/dataset/index.js +22 -0
  9. package/dist-server/controllers/bizplace-initializer/dataset/index.js.map +1 -0
  10. package/dist-server/controllers/bizplace-initializer/dataset/menus.js +504 -0
  11. package/dist-server/controllers/bizplace-initializer/dataset/menus.js.map +1 -0
  12. package/dist-server/controllers/bizplace-initializer/dataset/roles-privileges.js +406 -0
  13. package/dist-server/controllers/bizplace-initializer/dataset/roles-privileges.js.map +1 -0
  14. package/dist-server/controllers/bizplace-initializer/dataset/settings.js +112 -0
  15. package/dist-server/controllers/bizplace-initializer/dataset/settings.js.map +1 -0
  16. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain-roles.js +26 -0
  17. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain-roles.js.map +1 -0
  18. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain.js +43 -0
  19. package/dist-server/controllers/bizplace-initializer/generate-bizplace-domain.js.map +1 -0
  20. package/dist-server/controllers/bizplace-initializer/groups.js +18 -0
  21. package/dist-server/controllers/bizplace-initializer/groups.js.map +1 -0
  22. package/dist-server/controllers/bizplace-initializer/index.js +22 -0
  23. package/dist-server/controllers/bizplace-initializer/index.js.map +1 -0
  24. package/dist-server/controllers/bizplace-initializer/menus.js +28 -0
  25. package/dist-server/controllers/bizplace-initializer/menus.js.map +1 -0
  26. package/dist-server/controllers/bizplace-initializer/settings.js +16 -0
  27. package/dist-server/controllers/bizplace-initializer/settings.js.map +1 -0
  28. package/dist-server/controllers/company-initializer/business-register.js +48 -0
  29. package/dist-server/controllers/company-initializer/business-register.js.map +1 -0
  30. package/dist-server/controllers/company-initializer/codes.js +137 -0
  31. package/dist-server/controllers/company-initializer/codes.js.map +1 -0
  32. package/dist-server/controllers/company-initializer/generate-company-roles.js +117 -0
  33. package/dist-server/controllers/company-initializer/generate-company-roles.js.map +1 -0
  34. package/dist-server/controllers/company-initializer/index.js +23 -0
  35. package/dist-server/controllers/company-initializer/index.js.map +1 -0
  36. package/dist-server/controllers/company-initializer/menus.js +348 -0
  37. package/dist-server/controllers/company-initializer/menus.js.map +1 -0
  38. package/dist-server/controllers/company-initializer/settings.js +35 -0
  39. package/dist-server/controllers/company-initializer/settings.js.map +1 -0
  40. package/dist-server/controllers/company-initializer/transporter.js +18 -0
  41. package/dist-server/controllers/company-initializer/transporter.js.map +1 -0
  42. package/dist-server/controllers/index.js +1 -0
  43. package/dist-server/controllers/index.js.map +1 -0
  44. package/dist-server/controllers/invitation.js +118 -0
  45. package/dist-server/controllers/invitation.js.map +1 -0
  46. package/dist-server/controllers/utils/make-invitation-token.js +12 -0
  47. package/dist-server/controllers/utils/make-invitation-token.js.map +1 -0
  48. package/dist-server/controllers/utils/save-invitation-token.js +13 -0
  49. package/dist-server/controllers/utils/save-invitation-token.js.map +1 -0
  50. package/dist-server/entities/email-attachment.js +81 -0
  51. package/dist-server/entities/email-attachment.js.map +1 -0
  52. package/dist-server/entities/email-recipient.js +69 -0
  53. package/dist-server/entities/email-recipient.js.map +1 -0
  54. package/dist-server/entities/email.js +98 -0
  55. package/dist-server/entities/email.js.map +1 -0
  56. package/dist-server/entities/index.js +11 -0
  57. package/dist-server/entities/index.js.map +1 -0
  58. package/dist-server/errors/index.js +18 -0
  59. package/dist-server/errors/index.js.map +1 -0
  60. package/dist-server/errors/validation-error.js +14 -0
  61. package/dist-server/errors/validation-error.js.map +1 -0
  62. package/dist-server/graphql/index.js +33 -0
  63. package/dist-server/graphql/index.js.map +1 -0
  64. package/dist-server/graphql/resolvers/email/index.js +6 -0
  65. package/dist-server/graphql/resolvers/email/index.js.map +1 -0
  66. package/dist-server/graphql/resolvers/email/send-emails.js +263 -0
  67. package/dist-server/graphql/resolvers/email/send-emails.js.map +1 -0
  68. package/dist-server/graphql/resolvers/generators/generate-bizplace.js +39 -0
  69. package/dist-server/graphql/resolvers/generators/generate-bizplace.js.map +1 -0
  70. package/dist-server/graphql/resolvers/generators/generate-company.js +62 -0
  71. package/dist-server/graphql/resolvers/generators/generate-company.js.map +1 -0
  72. package/dist-server/graphql/resolvers/generators/index.js +8 -0
  73. package/dist-server/graphql/resolvers/generators/index.js.map +1 -0
  74. package/dist-server/graphql/resolvers/generators/update-domain-extType.js +45 -0
  75. package/dist-server/graphql/resolvers/generators/update-domain-extType.js.map +1 -0
  76. package/dist-server/graphql/resolvers/index.js +35 -0
  77. package/dist-server/graphql/resolvers/index.js.map +1 -0
  78. package/dist-server/graphql/resolvers/invitations/index.js +6 -0
  79. package/dist-server/graphql/resolvers/invitations/index.js.map +1 -0
  80. package/dist-server/graphql/resolvers/invitations/partner-invitation.js +52 -0
  81. package/dist-server/graphql/resolvers/invitations/partner-invitation.js.map +1 -0
  82. package/dist-server/graphql/resolvers/oauth2/company-roles-by-scope.js +30 -0
  83. package/dist-server/graphql/resolvers/oauth2/company-roles-by-scope.js.map +1 -0
  84. package/dist-server/graphql/resolvers/oauth2/index.js +6 -0
  85. package/dist-server/graphql/resolvers/oauth2/index.js.map +1 -0
  86. package/dist-server/graphql/resolvers/reports/admiral-asn-report.js +127 -0
  87. package/dist-server/graphql/resolvers/reports/admiral-asn-report.js.map +1 -0
  88. package/dist-server/graphql/resolvers/reports/asn-report.js +126 -0
  89. package/dist-server/graphql/resolvers/reports/asn-report.js.map +1 -0
  90. package/dist-server/graphql/resolvers/reports/custom/elccl/aging-report.js +157 -0
  91. package/dist-server/graphql/resolvers/reports/custom/elccl/aging-report.js.map +1 -0
  92. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-dispatch-report.js +74 -0
  93. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-dispatch-report.js.map +1 -0
  94. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-monthly-dispatch-report.js +99 -0
  95. package/dist-server/graphql/resolvers/reports/custom/elccl/custom-elccl-fn-monthly-dispatch-report.js.map +1 -0
  96. package/dist-server/graphql/resolvers/reports/custom/elccl/export-report.js +156 -0
  97. package/dist-server/graphql/resolvers/reports/custom/elccl/export-report.js.map +1 -0
  98. package/dist-server/graphql/resolvers/reports/custom/posmy/custom-posmy-aging-report.js +131 -0
  99. package/dist-server/graphql/resolvers/reports/custom/posmy/custom-posmy-aging-report.js.map +1 -0
  100. package/dist-server/graphql/resolvers/reports/inbound-order-details-report.js +189 -0
  101. package/dist-server/graphql/resolvers/reports/inbound-order-details-report.js.map +1 -0
  102. package/dist-server/graphql/resolvers/reports/index.js +16 -0
  103. package/dist-server/graphql/resolvers/reports/index.js.map +1 -0
  104. package/dist-server/graphql/resolvers/reports/outbound-order-details-report.js +231 -0
  105. package/dist-server/graphql/resolvers/reports/outbound-order-details-report.js.map +1 -0
  106. package/dist-server/graphql/resolvers/reports/receiving-report.js +103 -0
  107. package/dist-server/graphql/resolvers/reports/receiving-report.js.map +1 -0
  108. package/dist-server/graphql/resolvers/reports/shortage-report.js +164 -0
  109. package/dist-server/graphql/resolvers/reports/shortage-report.js.map +1 -0
  110. package/dist-server/graphql/resolvers/synchronization/auto-update-all-marketplace-product-variation-quantity.js +187 -0
  111. package/dist-server/graphql/resolvers/synchronization/auto-update-all-marketplace-product-variation-quantity.js.map +1 -0
  112. package/dist-server/graphql/resolvers/synchronization/create-dat-shipments.js +58 -0
  113. package/dist-server/graphql/resolvers/synchronization/create-dat-shipments.js.map +1 -0
  114. package/dist-server/graphql/resolvers/synchronization/fetch-sync-invoices.js +41 -0
  115. package/dist-server/graphql/resolvers/synchronization/fetch-sync-invoices.js.map +1 -0
  116. package/dist-server/graphql/resolvers/synchronization/fetch-sync-products.js +79 -0
  117. package/dist-server/graphql/resolvers/synchronization/fetch-sync-products.js.map +1 -0
  118. package/dist-server/graphql/resolvers/synchronization/fetch-sync-purchase-orders.js +57 -0
  119. package/dist-server/graphql/resolvers/synchronization/fetch-sync-purchase-orders.js.map +1 -0
  120. package/dist-server/graphql/resolvers/synchronization/get-lmd-awb.js +34 -0
  121. package/dist-server/graphql/resolvers/synchronization/get-lmd-awb.js.map +1 -0
  122. package/dist-server/graphql/resolvers/synchronization/index.js +30 -0
  123. package/dist-server/graphql/resolvers/synchronization/index.js.map +1 -0
  124. package/dist-server/graphql/resolvers/synchronization/mms-retry-create-lmd-parcels.js +70 -0
  125. package/dist-server/graphql/resolvers/synchronization/mms-retry-create-lmd-parcels.js.map +1 -0
  126. package/dist-server/graphql/resolvers/synchronization/powrup-get-airway-bill.js +78 -0
  127. package/dist-server/graphql/resolvers/synchronization/powrup-get-airway-bill.js.map +1 -0
  128. package/dist-server/graphql/resolvers/synchronization/powrup-get-tracking-no.js +61 -0
  129. package/dist-server/graphql/resolvers/synchronization/powrup-get-tracking-no.js.map +1 -0
  130. package/dist-server/graphql/resolvers/synchronization/powrup-initiate-shipment.js +88 -0
  131. package/dist-server/graphql/resolvers/synchronization/powrup-initiate-shipment.js.map +1 -0
  132. package/dist-server/graphql/resolvers/synchronization/powrup-pack-order.js +185 -0
  133. package/dist-server/graphql/resolvers/synchronization/powrup-pack-order.js.map +1 -0
  134. package/dist-server/graphql/resolvers/synchronization/refresh-lmd-access-token.js +72 -0
  135. package/dist-server/graphql/resolvers/synchronization/refresh-lmd-access-token.js.map +1 -0
  136. package/dist-server/graphql/resolvers/synchronization/retry-create-lmd-parcels.js +96 -0
  137. package/dist-server/graphql/resolvers/synchronization/retry-create-lmd-parcels.js.map +1 -0
  138. package/dist-server/graphql/resolvers/synchronization/sellercraft-initiate-shipment.js +97 -0
  139. package/dist-server/graphql/resolvers/synchronization/sellercraft-initiate-shipment.js.map +1 -0
  140. package/dist-server/graphql/resolvers/synchronization/sellercraft-pack-marketplace-order.js +202 -0
  141. package/dist-server/graphql/resolvers/synchronization/sellercraft-pack-marketplace-order.js.map +1 -0
  142. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-powrup.js +32 -0
  143. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-powrup.js.map +1 -0
  144. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-sellercraft.js +35 -0
  145. package/dist-server/graphql/resolvers/synchronization/sync-all-products-to-sellercraft.js.map +1 -0
  146. package/dist-server/graphql/resolvers/synchronization/sync-products-from-account.js +32 -0
  147. package/dist-server/graphql/resolvers/synchronization/sync-products-from-account.js.map +1 -0
  148. package/dist-server/graphql/resolvers/synchronization/sync-products-to-account.js +53 -0
  149. package/dist-server/graphql/resolvers/synchronization/sync-products-to-account.js.map +1 -0
  150. package/dist-server/graphql/resolvers/synchronization/sync-products-to-powrup.js +99 -0
  151. package/dist-server/graphql/resolvers/synchronization/sync-products-to-powrup.js.map +1 -0
  152. package/dist-server/graphql/resolvers/synchronization/sync-products-to-sellercraft.js +141 -0
  153. package/dist-server/graphql/resolvers/synchronization/sync-products-to-sellercraft.js.map +1 -0
  154. package/dist-server/graphql/resolvers/synchronization/versafleet-fetch-driver-runsheet.js +45 -0
  155. package/dist-server/graphql/resolvers/synchronization/versafleet-fetch-driver-runsheet.js.map +1 -0
  156. package/dist-server/graphql/resolvers/synchronization/webspert-initiate-shipment.js +37 -0
  157. package/dist-server/graphql/resolvers/synchronization/webspert-initiate-shipment.js.map +1 -0
  158. package/dist-server/graphql/resolvers/synchronization/webspert-pack-and-get.js +66 -0
  159. package/dist-server/graphql/resolvers/synchronization/webspert-pack-and-get.js.map +1 -0
  160. package/dist-server/graphql/resolvers/synchronization/webspert-update-stocks.js +27 -0
  161. package/dist-server/graphql/resolvers/synchronization/webspert-update-stocks.js.map +1 -0
  162. package/dist-server/graphql/types/generators/generate-bizplace-input.js +17 -0
  163. package/dist-server/graphql/types/generators/generate-bizplace-input.js.map +1 -0
  164. package/dist-server/graphql/types/generators/generate-company-input.js +17 -0
  165. package/dist-server/graphql/types/generators/generate-company-input.js.map +1 -0
  166. package/dist-server/graphql/types/generators/index.js +13 -0
  167. package/dist-server/graphql/types/generators/index.js.map +1 -0
  168. package/dist-server/graphql/types/generators/update-domain-type-input.js +14 -0
  169. package/dist-server/graphql/types/generators/update-domain-type-input.js.map +1 -0
  170. package/dist-server/graphql/types/index.js +35 -0
  171. package/dist-server/graphql/types/index.js.map +1 -0
  172. package/dist-server/graphql/types/invitations/index.js +9 -0
  173. package/dist-server/graphql/types/invitations/index.js.map +1 -0
  174. package/dist-server/graphql/types/oauth2/company-role.js +14 -0
  175. package/dist-server/graphql/types/oauth2/company-role.js.map +1 -0
  176. package/dist-server/graphql/types/oauth2/index.js +9 -0
  177. package/dist-server/graphql/types/oauth2/index.js.map +1 -0
  178. package/dist-server/graphql/types/reports/admiral-asn-report-list.js +14 -0
  179. package/dist-server/graphql/types/reports/admiral-asn-report-list.js.map +1 -0
  180. package/dist-server/graphql/types/reports/admiral-asn-report.js +21 -0
  181. package/dist-server/graphql/types/reports/admiral-asn-report.js.map +1 -0
  182. package/dist-server/graphql/types/reports/asn-report-list.js +14 -0
  183. package/dist-server/graphql/types/reports/asn-report-list.js.map +1 -0
  184. package/dist-server/graphql/types/reports/asn-report.js +21 -0
  185. package/dist-server/graphql/types/reports/asn-report.js.map +1 -0
  186. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report-list.js +14 -0
  187. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report-list.js.map +1 -0
  188. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report.js +31 -0
  189. package/dist-server/graphql/types/reports/custom/elccl/agingreport/aging-report.js.map +1 -0
  190. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report-list.js +14 -0
  191. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report-list.js.map +1 -0
  192. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report.js +26 -0
  193. package/dist-server/graphql/types/reports/custom/elccl/dispatchreport/custom-elccl-fn-dispatch-report.js.map +1 -0
  194. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report-list.js +14 -0
  195. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report-list.js.map +1 -0
  196. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report.js +31 -0
  197. package/dist-server/graphql/types/reports/custom/elccl/exportreport/export-report.js.map +1 -0
  198. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report-list.js +13 -0
  199. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report-list.js.map +1 -0
  200. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report.js +28 -0
  201. package/dist-server/graphql/types/reports/custom/posmy/custom-posmy-aging-report.js.map +1 -0
  202. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js +14 -0
  203. package/dist-server/graphql/types/reports/inbound-order-details-report-list.js.map +1 -0
  204. package/dist-server/graphql/types/reports/inbound-order-details-report.js +59 -0
  205. package/dist-server/graphql/types/reports/inbound-order-details-report.js.map +1 -0
  206. package/dist-server/graphql/types/reports/index.js +59 -0
  207. package/dist-server/graphql/types/reports/index.js.map +1 -0
  208. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js +14 -0
  209. package/dist-server/graphql/types/reports/outbound-order-details-report-list.js.map +1 -0
  210. package/dist-server/graphql/types/reports/outbound-order-details-report.js +76 -0
  211. package/dist-server/graphql/types/reports/outbound-order-details-report.js.map +1 -0
  212. package/dist-server/graphql/types/reports/receiving-report-list.js +14 -0
  213. package/dist-server/graphql/types/reports/receiving-report-list.js.map +1 -0
  214. package/dist-server/graphql/types/reports/receiving-report.js +23 -0
  215. package/dist-server/graphql/types/reports/receiving-report.js.map +1 -0
  216. package/dist-server/graphql/types/reports/shortage-report-list.js +14 -0
  217. package/dist-server/graphql/types/reports/shortage-report-list.js.map +1 -0
  218. package/dist-server/graphql/types/reports/shortage-report-type.js +26 -0
  219. package/dist-server/graphql/types/reports/shortage-report-type.js.map +1 -0
  220. package/dist-server/graphql/types/synchronization/index.js +49 -0
  221. package/dist-server/graphql/types/synchronization/index.js.map +1 -0
  222. package/dist-server/graphql/types/synchronization/sync-invoice-list.js +14 -0
  223. package/dist-server/graphql/types/synchronization/sync-invoice-list.js.map +1 -0
  224. package/dist-server/graphql/types/synchronization/sync-invoice-set.js +44 -0
  225. package/dist-server/graphql/types/synchronization/sync-invoice-set.js.map +1 -0
  226. package/dist-server/graphql/types/synchronization/sync-product-list.js +14 -0
  227. package/dist-server/graphql/types/synchronization/sync-product-list.js.map +1 -0
  228. package/dist-server/graphql/types/synchronization/sync-product-set.js +14 -0
  229. package/dist-server/graphql/types/synchronization/sync-product-set.js.map +1 -0
  230. package/dist-server/graphql/types/synchronization/sync-purchase-order-list.js +14 -0
  231. package/dist-server/graphql/types/synchronization/sync-purchase-order-list.js.map +1 -0
  232. package/dist-server/graphql/types/synchronization/sync-purchase-order-set.js +34 -0
  233. package/dist-server/graphql/types/synchronization/sync-purchase-order-set.js.map +1 -0
  234. package/dist-server/index.js +43 -0
  235. package/dist-server/index.js.map +1 -0
  236. package/dist-server/middlewares/business-middleware.js +32 -0
  237. package/dist-server/middlewares/business-middleware.js.map +1 -0
  238. package/dist-server/middlewares/index.js +21 -0
  239. package/dist-server/middlewares/index.js.map +1 -0
  240. package/dist-server/middlewares/store-middleware.js +34 -0
  241. package/dist-server/middlewares/store-middleware.js.map +1 -0
  242. package/dist-server/middlewares/warehouse-middleware.js +33 -0
  243. package/dist-server/middlewares/warehouse-middleware.js.map +1 -0
  244. package/dist-server/migrations/1597668478399-SeedBusinessDomain.js +27 -0
  245. package/dist-server/migrations/1597668478399-SeedBusinessDomain.js.map +1 -0
  246. package/dist-server/migrations/1597668478401-SeedBusinessRoles.js +377 -0
  247. package/dist-server/migrations/1597668478401-SeedBusinessRoles.js.map +1 -0
  248. package/dist-server/migrations/1608009991065-SeedUser.js +53 -0
  249. package/dist-server/migrations/1608009991065-SeedUser.js.map +1 -0
  250. package/dist-server/migrations/index.js +12 -0
  251. package/dist-server/migrations/index.js.map +1 -0
  252. package/dist-server/routers/api/index.js +5 -0
  253. package/dist-server/routers/api/index.js.map +1 -0
  254. package/dist-server/routers/api/restful-apis/unstable/add-contact-point.js +76 -0
  255. package/dist-server/routers/api/restful-apis/unstable/add-contact-point.js.map +1 -0
  256. package/dist-server/routers/api/restful-apis/unstable/add-draft-release-order.js +174 -0
  257. package/dist-server/routers/api/restful-apis/unstable/add-draft-release-order.js.map +1 -0
  258. package/dist-server/routers/api/restful-apis/unstable/add-inbound-order.js +217 -0
  259. package/dist-server/routers/api/restful-apis/unstable/add-inbound-order.js.map +1 -0
  260. package/dist-server/routers/api/restful-apis/unstable/add-marketplace-order.js +144 -0
  261. package/dist-server/routers/api/restful-apis/unstable/add-marketplace-order.js.map +1 -0
  262. package/dist-server/routers/api/restful-apis/unstable/add-products.js +88 -0
  263. package/dist-server/routers/api/restful-apis/unstable/add-products.js.map +1 -0
  264. package/dist-server/routers/api/restful-apis/unstable/add-release-order.js +1074 -0
  265. package/dist-server/routers/api/restful-apis/unstable/add-release-order.js.map +1 -0
  266. package/dist-server/routers/api/restful-apis/unstable/add-sales-invoice.js +140 -0
  267. package/dist-server/routers/api/restful-apis/unstable/add-sales-invoice.js.map +1 -0
  268. package/dist-server/routers/api/restful-apis/unstable/bizplace.js +45 -0
  269. package/dist-server/routers/api/restful-apis/unstable/bizplace.js.map +1 -0
  270. package/dist-server/routers/api/restful-apis/unstable/cancel-marketplace-order.js +63 -0
  271. package/dist-server/routers/api/restful-apis/unstable/cancel-marketplace-order.js.map +1 -0
  272. package/dist-server/routers/api/restful-apis/unstable/cancel-release-order.js +82 -0
  273. package/dist-server/routers/api/restful-apis/unstable/cancel-release-order.js.map +1 -0
  274. package/dist-server/routers/api/restful-apis/unstable/get-contact-point-list.js +103 -0
  275. package/dist-server/routers/api/restful-apis/unstable/get-contact-point-list.js.map +1 -0
  276. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-detail.js +47 -0
  277. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-detail.js.map +1 -0
  278. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-list.js +124 -0
  279. package/dist-server/routers/api/restful-apis/unstable/get-delivery-order-list.js.map +1 -0
  280. package/dist-server/routers/api/restful-apis/unstable/get-delivery-orders.js +164 -0
  281. package/dist-server/routers/api/restful-apis/unstable/get-delivery-orders.js.map +1 -0
  282. package/dist-server/routers/api/restful-apis/unstable/get-goods-received-notes.js +120 -0
  283. package/dist-server/routers/api/restful-apis/unstable/get-goods-received-notes.js.map +1 -0
  284. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-detail.js +115 -0
  285. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-detail.js.map +1 -0
  286. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-list.js +125 -0
  287. package/dist-server/routers/api/restful-apis/unstable/get-inbound-order-list.js.map +1 -0
  288. package/dist-server/routers/api/restful-apis/unstable/get-inventory-overall-product-group.js +88 -0
  289. package/dist-server/routers/api/restful-apis/unstable/get-inventory-overall-product-group.js.map +1 -0
  290. package/dist-server/routers/api/restful-apis/unstable/get-inventory-product-group.js +95 -0
  291. package/dist-server/routers/api/restful-apis/unstable/get-inventory-product-group.js.map +1 -0
  292. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-order-shipping-list.js +146 -0
  293. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-order-shipping-list.js.map +1 -0
  294. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-store-list.js +79 -0
  295. package/dist-server/routers/api/restful-apis/unstable/get-marketplace-store-list.js.map +1 -0
  296. package/dist-server/routers/api/restful-apis/unstable/get-onhand-inventories.js +110 -0
  297. package/dist-server/routers/api/restful-apis/unstable/get-onhand-inventories.js.map +1 -0
  298. package/dist-server/routers/api/restful-apis/unstable/get-partners.js +23 -0
  299. package/dist-server/routers/api/restful-apis/unstable/get-partners.js.map +1 -0
  300. package/dist-server/routers/api/restful-apis/unstable/get-products.js +214 -0
  301. package/dist-server/routers/api/restful-apis/unstable/get-products.js.map +1 -0
  302. package/dist-server/routers/api/restful-apis/unstable/get-release-order-detail.js +125 -0
  303. package/dist-server/routers/api/restful-apis/unstable/get-release-order-detail.js.map +1 -0
  304. package/dist-server/routers/api/restful-apis/unstable/get-release-order-list.js +195 -0
  305. package/dist-server/routers/api/restful-apis/unstable/get-release-order-list.js.map +1 -0
  306. package/dist-server/routers/api/restful-apis/unstable/get-warehouses.js +20 -0
  307. package/dist-server/routers/api/restful-apis/unstable/get-warehouses.js.map +1 -0
  308. package/dist-server/routers/api/restful-apis/unstable/index.js +35 -0
  309. package/dist-server/routers/api/restful-apis/unstable/index.js.map +1 -0
  310. package/dist-server/routers/api/restful-apis/unstable/reject-inbound-order.js +35 -0
  311. package/dist-server/routers/api/restful-apis/unstable/reject-inbound-order.js.map +1 -0
  312. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-delivered.js +45 -0
  313. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-delivered.js.map +1 -0
  314. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-failed-delivery.js +45 -0
  315. package/dist-server/routers/api/restful-apis/unstable/set-marketplace-order-failed-delivery.js.map +1 -0
  316. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-order.js +93 -0
  317. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-order.js.map +1 -0
  318. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-shipping-order.js +88 -0
  319. package/dist-server/routers/api/restful-apis/unstable/update-marketplace-shipping-order.js.map +1 -0
  320. package/dist-server/routers/api/restful-apis/unstable/update-release-order-details.js +82 -0
  321. package/dist-server/routers/api/restful-apis/unstable/update-release-order-details.js.map +1 -0
  322. package/dist-server/routers/api/restful-apis/v1/company/add-contact-points.js +105 -0
  323. package/dist-server/routers/api/restful-apis/v1/company/add-contact-points.js.map +1 -0
  324. package/dist-server/routers/api/restful-apis/v1/company/add-products.js +156 -0
  325. package/dist-server/routers/api/restful-apis/v1/company/add-products.js.map +1 -0
  326. package/dist-server/routers/api/restful-apis/v1/company/get-bizplace-list.js +49 -0
  327. package/dist-server/routers/api/restful-apis/v1/company/get-bizplace-list.js.map +1 -0
  328. package/dist-server/routers/api/restful-apis/v1/company/get-contact-point-list.js +62 -0
  329. package/dist-server/routers/api/restful-apis/v1/company/get-contact-point-list.js.map +1 -0
  330. package/dist-server/routers/api/restful-apis/v1/company/get-partner-list.js +88 -0
  331. package/dist-server/routers/api/restful-apis/v1/company/get-partner-list.js.map +1 -0
  332. package/dist-server/routers/api/restful-apis/v1/company/get-product-by-skus.js +95 -0
  333. package/dist-server/routers/api/restful-apis/v1/company/get-product-by-skus.js.map +1 -0
  334. package/dist-server/routers/api/restful-apis/v1/company/get-product-list.js +104 -0
  335. package/dist-server/routers/api/restful-apis/v1/company/get-product-list.js.map +1 -0
  336. package/dist-server/routers/api/restful-apis/v1/company/get-webhook-details.js +58 -0
  337. package/dist-server/routers/api/restful-apis/v1/company/get-webhook-details.js.map +1 -0
  338. package/dist-server/routers/api/restful-apis/v1/company/index.js +14 -0
  339. package/dist-server/routers/api/restful-apis/v1/company/index.js.map +1 -0
  340. package/dist-server/routers/api/restful-apis/v1/company/upsert-product.js +111 -0
  341. package/dist-server/routers/api/restful-apis/v1/company/upsert-product.js.map +1 -0
  342. package/dist-server/routers/api/restful-apis/v1/company/upsert-products.js +354 -0
  343. package/dist-server/routers/api/restful-apis/v1/company/upsert-products.js.map +1 -0
  344. package/dist-server/routers/api/restful-apis/v1/company/upsert-webhooks.js +146 -0
  345. package/dist-server/routers/api/restful-apis/v1/company/upsert-webhooks.js.map +1 -0
  346. package/dist-server/routers/api/restful-apis/v1/index.js +6 -0
  347. package/dist-server/routers/api/restful-apis/v1/index.js.map +1 -0
  348. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-order.js +254 -0
  349. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-order.js.map +1 -0
  350. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-products.js +78 -0
  351. package/dist-server/routers/api/restful-apis/v1/marketplace/add-marketplace-products.js.map +1 -0
  352. package/dist-server/routers/api/restful-apis/v1/marketplace/cancel-marketplace-order.js +90 -0
  353. package/dist-server/routers/api/restful-apis/v1/marketplace/cancel-marketplace-order.js.map +1 -0
  354. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-order-shipping-list.js +138 -0
  355. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-order-shipping-list.js.map +1 -0
  356. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-store-list.js +51 -0
  357. package/dist-server/routers/api/restful-apis/v1/marketplace/get-marketplace-store-list.js.map +1 -0
  358. package/dist-server/routers/api/restful-apis/v1/marketplace/index.js +11 -0
  359. package/dist-server/routers/api/restful-apis/v1/marketplace/index.js.map +1 -0
  360. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-order-delivered.js +62 -0
  361. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-order-delivered.js.map +1 -0
  362. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-product.js +76 -0
  363. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-product.js.map +1 -0
  364. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-shipping-order.js +40 -0
  365. package/dist-server/routers/api/restful-apis/v1/marketplace/update-marketplace-shipping-order.js.map +1 -0
  366. package/dist-server/routers/api/restful-apis/v1/middlewares/business-middleware.js +70 -0
  367. package/dist-server/routers/api/restful-apis/v1/middlewares/business-middleware.js.map +1 -0
  368. package/dist-server/routers/api/restful-apis/v1/middlewares/index.js +40 -0
  369. package/dist-server/routers/api/restful-apis/v1/middlewares/index.js.map +1 -0
  370. package/dist-server/routers/api/restful-apis/v1/middlewares/logging-middleware.js +53 -0
  371. package/dist-server/routers/api/restful-apis/v1/middlewares/logging-middleware.js.map +1 -0
  372. package/dist-server/routers/api/restful-apis/v1/middlewares/store-middleware.js +32 -0
  373. package/dist-server/routers/api/restful-apis/v1/middlewares/store-middleware.js.map +1 -0
  374. package/dist-server/routers/api/restful-apis/v1/middlewares/validation-middleware.js +118 -0
  375. package/dist-server/routers/api/restful-apis/v1/middlewares/validation-middleware.js.map +1 -0
  376. package/dist-server/routers/api/restful-apis/v1/middlewares/warehouse-middleware.js +31 -0
  377. package/dist-server/routers/api/restful-apis/v1/middlewares/warehouse-middleware.js.map +1 -0
  378. package/dist-server/routers/api/restful-apis/v1/utils/error-util.js +71 -0
  379. package/dist-server/routers/api/restful-apis/v1/utils/error-util.js.map +1 -0
  380. package/dist-server/routers/api/restful-apis/v1/utils/params.js +1164 -0
  381. package/dist-server/routers/api/restful-apis/v1/utils/params.js.map +1 -0
  382. package/dist-server/routers/api/restful-apis/v1/utils/validate-util.js +68 -0
  383. package/dist-server/routers/api/restful-apis/v1/utils/validate-util.js.map +1 -0
  384. package/dist-server/routers/api/restful-apis/v1/warehouse/add-inbound-order.js +254 -0
  385. package/dist-server/routers/api/restful-apis/v1/warehouse/add-inbound-order.js.map +1 -0
  386. package/dist-server/routers/api/restful-apis/v1/warehouse/add-release-order.js +1090 -0
  387. package/dist-server/routers/api/restful-apis/v1/warehouse/add-release-order.js.map +1 -0
  388. package/dist-server/routers/api/restful-apis/v1/warehouse/add-return-order.js +325 -0
  389. package/dist-server/routers/api/restful-apis/v1/warehouse/add-return-order.js.map +1 -0
  390. package/dist-server/routers/api/restful-apis/v1/warehouse/add-sales-invoice.js +97 -0
  391. package/dist-server/routers/api/restful-apis/v1/warehouse/add-sales-invoice.js.map +1 -0
  392. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-inbound-order.js +199 -0
  393. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-inbound-order.js.map +1 -0
  394. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-release-order.js +197 -0
  395. package/dist-server/routers/api/restful-apis/v1/warehouse/cancel-release-order.js.map +1 -0
  396. package/dist-server/routers/api/restful-apis/v1/warehouse/complete-delivery-order.js +170 -0
  397. package/dist-server/routers/api/restful-apis/v1/warehouse/complete-delivery-order.js.map +1 -0
  398. package/dist-server/routers/api/restful-apis/v1/warehouse/dispatch-delivery-order.js +327 -0
  399. package/dist-server/routers/api/restful-apis/v1/warehouse/dispatch-delivery-order.js.map +1 -0
  400. package/dist-server/routers/api/restful-apis/v1/warehouse/get-delivery-order-list.js +223 -0
  401. package/dist-server/routers/api/restful-apis/v1/warehouse/get-delivery-order-list.js.map +1 -0
  402. package/dist-server/routers/api/restful-apis/v1/warehouse/get-do-document.js +65 -0
  403. package/dist-server/routers/api/restful-apis/v1/warehouse/get-do-document.js.map +1 -0
  404. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-details.js +144 -0
  405. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-details.js.map +1 -0
  406. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-list.js +305 -0
  407. package/dist-server/routers/api/restful-apis/v1/warehouse/get-draft-order-list.js.map +1 -0
  408. package/dist-server/routers/api/restful-apis/v1/warehouse/get-goods-received-note-list.js +100 -0
  409. package/dist-server/routers/api/restful-apis/v1/warehouse/get-goods-received-note-list.js.map +1 -0
  410. package/dist-server/routers/api/restful-apis/v1/warehouse/get-grn-document.js +102 -0
  411. package/dist-server/routers/api/restful-apis/v1/warehouse/get-grn-document.js.map +1 -0
  412. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-details.js +166 -0
  413. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-details.js.map +1 -0
  414. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-list.js +96 -0
  415. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inbound-order-list.js.map +1 -0
  416. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-details.js +136 -0
  417. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-details.js.map +1 -0
  418. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-list.js +214 -0
  419. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-adjustment-list.js.map +1 -0
  420. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-product-group-list.js +87 -0
  421. package/dist-server/routers/api/restful-apis/v1/warehouse/get-inventory-product-group-list.js.map +1 -0
  422. package/dist-server/routers/api/restful-apis/v1/warehouse/get-manifest-details.js +138 -0
  423. package/dist-server/routers/api/restful-apis/v1/warehouse/get-manifest-details.js.map +1 -0
  424. package/dist-server/routers/api/restful-apis/v1/warehouse/get-onhand-inventory-list.js +102 -0
  425. package/dist-server/routers/api/restful-apis/v1/warehouse/get-onhand-inventory-list.js.map +1 -0
  426. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-details.js +267 -0
  427. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-details.js.map +1 -0
  428. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-list.js +142 -0
  429. package/dist-server/routers/api/restful-apis/v1/warehouse/get-release-order-list.js.map +1 -0
  430. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-details.js +106 -0
  431. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-details.js.map +1 -0
  432. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-list.js +63 -0
  433. package/dist-server/routers/api/restful-apis/v1/warehouse/get-return-order-list.js.map +1 -0
  434. package/dist-server/routers/api/restful-apis/v1/warehouse/get-warehouse-bizplace-onhand-inventories.js +68 -0
  435. package/dist-server/routers/api/restful-apis/v1/warehouse/get-warehouse-bizplace-onhand-inventories.js.map +1 -0
  436. package/dist-server/routers/api/restful-apis/v1/warehouse/index.js +32 -0
  437. package/dist-server/routers/api/restful-apis/v1/warehouse/index.js.map +1 -0
  438. package/dist-server/routers/api/restful-apis/v1/warehouse/update-gan-to-arrived.js +96 -0
  439. package/dist-server/routers/api/restful-apis/v1/warehouse/update-gan-to-arrived.js.map +1 -0
  440. package/dist-server/routers/api/restful-apis/v1/warehouse/update-order-package-details.js +46 -0
  441. package/dist-server/routers/api/restful-apis/v1/warehouse/update-order-package-details.js.map +1 -0
  442. package/dist-server/routers/api/restful-apis/v1/warehouse/update-release-order-details.js +70 -0
  443. package/dist-server/routers/api/restful-apis/v1/warehouse/update-release-order-details.js.map +1 -0
  444. package/dist-server/routers/auth-invitation-router.js +25 -0
  445. package/dist-server/routers/auth-invitation-router.js.map +1 -0
  446. package/dist-server/routers/business/bizplace-register-router.js +25 -0
  447. package/dist-server/routers/business/bizplace-register-router.js.map +1 -0
  448. package/dist-server/routers/business/business-register-router.js +31 -0
  449. package/dist-server/routers/business/business-register-router.js.map +1 -0
  450. package/dist-server/routers/business/index.js +20 -0
  451. package/dist-server/routers/business/index.js.map +1 -0
  452. package/dist-server/routers/business/path-base-business-router.js +21 -0
  453. package/dist-server/routers/business/path-base-business-router.js.map +1 -0
  454. package/dist-server/routers/internal/apis/create-bizplace.js +70 -0
  455. package/dist-server/routers/internal/apis/create-bizplace.js.map +1 -0
  456. package/dist-server/routers/internal/apis/create-company.js +77 -0
  457. package/dist-server/routers/internal/apis/create-company.js.map +1 -0
  458. package/dist-server/routers/internal/apis/create-partner.js +41 -0
  459. package/dist-server/routers/internal/apis/create-partner.js.map +1 -0
  460. package/dist-server/routers/internal/apis/create-user.js +23 -0
  461. package/dist-server/routers/internal/apis/create-user.js.map +1 -0
  462. package/dist-server/routers/internal/apis/index.js +37 -0
  463. package/dist-server/routers/internal/apis/index.js.map +1 -0
  464. package/dist-server/routers/internal/apis/invite-user.js +48 -0
  465. package/dist-server/routers/internal/apis/invite-user.js.map +1 -0
  466. package/dist-server/routers/internal/apis/terminate-partner.js +38 -0
  467. package/dist-server/routers/internal/apis/terminate-partner.js.map +1 -0
  468. package/dist-server/routers/internal/apis/terminate-user.js +53 -0
  469. package/dist-server/routers/internal/apis/terminate-user.js.map +1 -0
  470. package/dist-server/routers/internal/apis/update-bizplace.js +52 -0
  471. package/dist-server/routers/internal/apis/update-bizplace.js.map +1 -0
  472. package/dist-server/routers/internal/apis/update-company.js +55 -0
  473. package/dist-server/routers/internal/apis/update-company.js.map +1 -0
  474. package/dist-server/routers/internal/apis/update-user.js +33 -0
  475. package/dist-server/routers/internal/apis/update-user.js.map +1 -0
  476. package/dist-server/routers/internal/index.js +8 -0
  477. package/dist-server/routers/internal/index.js.map +1 -0
  478. package/dist-server/routers/internal/middlewares/index.js +20 -0
  479. package/dist-server/routers/internal/middlewares/index.js.map +1 -0
  480. package/dist-server/routers/internal/middlewares/logging-middleware.js +23 -0
  481. package/dist-server/routers/internal/middlewares/logging-middleware.js.map +1 -0
  482. package/dist-server/routers/internal/middlewares/validation-middleware.js +110 -0
  483. package/dist-server/routers/internal/middlewares/validation-middleware.js.map +1 -0
  484. package/dist-server/routers/internal/powrup-router.js +291 -0
  485. package/dist-server/routers/internal/powrup-router.js.map +1 -0
  486. package/dist-server/routers/internal/sellercraft-router.js +53 -0
  487. package/dist-server/routers/internal/sellercraft-router.js.map +1 -0
  488. package/dist-server/routers/internal/utils/error-util.js +71 -0
  489. package/dist-server/routers/internal/utils/error-util.js.map +1 -0
  490. package/dist-server/routers/internal/utils/params.js +153 -0
  491. package/dist-server/routers/internal/utils/params.js.map +1 -0
  492. package/dist-server/routers/support-router.js +386 -0
  493. package/dist-server/routers/support-router.js.map +1 -0
  494. package/dist-server/routers/webhook-service/versafleet-router.js +93 -0
  495. package/dist-server/routers/webhook-service/versafleet-router.js.map +1 -0
  496. package/dist-server/routers/xilnex-router.js +1103 -0
  497. package/dist-server/routers/xilnex-router.js.map +1 -0
  498. package/dist-server/routes.js +26 -0
  499. package/dist-server/routes.js.map +1 -0
  500. package/dist-server/templates/account-unlock-email.js +69 -0
  501. package/dist-server/templates/account-unlock-email.js.map +1 -0
  502. package/dist-server/templates/invitation-email.js +70 -0
  503. package/dist-server/templates/invitation-email.js.map +1 -0
  504. package/dist-server/templates/reset-password-email.js +66 -0
  505. package/dist-server/templates/reset-password-email.js.map +1 -0
  506. package/dist-server/templates/verification-email.js +70 -0
  507. package/dist-server/templates/verification-email.js.map +1 -0
  508. package/dist-server/utils/build-map.js +19 -0
  509. package/dist-server/utils/build-map.js.map +1 -0
  510. package/dist-server/utils/get-warehouses.js +113 -0
  511. package/dist-server/utils/get-warehouses.js.map +1 -0
  512. package/dist-server/utils/index.js +21 -0
  513. package/dist-server/utils/index.js.map +1 -0
  514. package/dist-server/utils/order-no-generator.js +11 -0
  515. package/dist-server/utils/order-no-generator.js.map +1 -0
  516. package/dist-server/utils/report-query-util.js +42 -0
  517. package/dist-server/utils/report-query-util.js.map +1 -0
  518. package/package.json +15 -15
@@ -0,0 +1,1090 @@
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