@things-factory/operato-hub 4.3.671 → 4.3.674

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