addio-admin-sdk 1.7.158 → 1.7.159

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 (575) hide show
  1. package/.babelrc +17 -17
  2. package/.env +15 -0
  3. package/.env.dev +14 -14
  4. package/.github/workflows/run_unit_test.yaml +48 -48
  5. package/addio-sdk-doc.md +1473 -1473
  6. package/changelog.md +564 -564
  7. package/dist/Interfaces/Address/index.d.ts +21 -21
  8. package/dist/Interfaces/Address/index.js +16 -16
  9. package/dist/Interfaces/Algolia/index.d.ts +180 -180
  10. package/dist/Interfaces/Algolia/index.js +2 -2
  11. package/dist/Interfaces/Attachement/index.d.ts +5 -5
  12. package/dist/Interfaces/Attachement/index.js +2 -2
  13. package/dist/Interfaces/Attribute/index.d.ts +53 -53
  14. package/dist/Interfaces/Attribute/index.js +10 -10
  15. package/dist/Interfaces/BGJob/index.d.ts +56 -56
  16. package/dist/Interfaces/BGJob/index.js +25 -25
  17. package/dist/Interfaces/BaseClass/index.d.ts +8 -8
  18. package/dist/Interfaces/BaseClass/index.js +2 -2
  19. package/dist/Interfaces/Blog/IBlogArticle.d.ts +18 -18
  20. package/dist/Interfaces/Blog/IBlogArticle.js +2 -2
  21. package/dist/Interfaces/Blog/IBlogAuthor.d.ts +7 -7
  22. package/dist/Interfaces/Blog/IBlogAuthor.js +2 -2
  23. package/dist/Interfaces/Blog/IBlogCategory.d.ts +9 -9
  24. package/dist/Interfaces/Blog/IBlogCategory.js +2 -2
  25. package/dist/Interfaces/Blog/IBlogComment.d.ts +13 -13
  26. package/dist/Interfaces/Blog/IBlogComment.js +2 -2
  27. package/dist/Interfaces/Blog/IBlogKeywords.d.ts +9 -9
  28. package/dist/Interfaces/Blog/IBlogKeywords.js +2 -2
  29. package/dist/Interfaces/Booking/index.d.ts +74 -74
  30. package/dist/Interfaces/Booking/index.js +17 -17
  31. package/dist/Interfaces/Brand/index.d.ts +15 -15
  32. package/dist/Interfaces/Brand/index.js +2 -2
  33. package/dist/Interfaces/CMS/index.d.ts +28 -28
  34. package/dist/Interfaces/CMS/index.js +5 -5
  35. package/dist/Interfaces/Cart/IElavonPayload.d.ts +93 -93
  36. package/dist/Interfaces/Cart/IElavonPayload.js +17 -17
  37. package/dist/Interfaces/Cart/IMarketPayload.d.ts +12 -12
  38. package/dist/Interfaces/Cart/IMarketPayload.js +2 -2
  39. package/dist/Interfaces/Cart/IPandaPayload.d.ts +64 -64
  40. package/dist/Interfaces/Cart/IPandaPayload.js +18 -18
  41. package/dist/Interfaces/Cart/IPaymentCard.d.ts +22 -22
  42. package/dist/Interfaces/Cart/IPaymentCard.js +44 -44
  43. package/dist/Interfaces/Cart/IPaypalPayload.d.ts +9 -9
  44. package/dist/Interfaces/Cart/IPaypalPayload.js +2 -2
  45. package/dist/Interfaces/Cart/IPaysafePayload.d.ts +72 -72
  46. package/dist/Interfaces/Cart/IPaysafePayload.js +2 -2
  47. package/dist/Interfaces/Cart/IStripePayload.d.ts +66 -66
  48. package/dist/Interfaces/Cart/IStripePayload.js +2 -2
  49. package/dist/Interfaces/Cart/index.d.ts +451 -451
  50. package/dist/Interfaces/Cart/index.js +216 -216
  51. package/dist/Interfaces/CartReservedQuantities/index.d.ts +10 -10
  52. package/dist/Interfaces/CartReservedQuantities/index.js +2 -2
  53. package/dist/Interfaces/CashDrawers/index.d.ts +38 -37
  54. package/dist/Interfaces/CashDrawers/index.js +19 -19
  55. package/dist/Interfaces/CashDrawers/index.js.map +1 -1
  56. package/dist/Interfaces/Catalogue/index.d.ts +68 -68
  57. package/dist/Interfaces/Catalogue/index.js +37 -37
  58. package/dist/Interfaces/Category/index.d.ts +33 -33
  59. package/dist/Interfaces/Category/index.js +2 -2
  60. package/dist/Interfaces/Chart/index.d.ts +11 -11
  61. package/dist/Interfaces/Chart/index.js +2 -2
  62. package/dist/Interfaces/Class/index.d.ts +8 -8
  63. package/dist/Interfaces/Class/index.js +2 -2
  64. package/dist/Interfaces/Consent/index.d.ts +6 -6
  65. package/dist/Interfaces/Consent/index.js +2 -2
  66. package/dist/Interfaces/Context/IContextProps.d.ts +4 -4
  67. package/dist/Interfaces/Context/IContextProps.js +2 -2
  68. package/dist/Interfaces/Context/IContextState.d.ts +15 -15
  69. package/dist/Interfaces/Context/IContextState.js +2 -2
  70. package/dist/Interfaces/Customer/ICustomerBadge.d.ts +2 -2
  71. package/dist/Interfaces/Customer/ICustomerBadge.js +2 -2
  72. package/dist/Interfaces/Customer/ICustomerRating.d.ts +10 -10
  73. package/dist/Interfaces/Customer/ICustomerRating.js +2 -2
  74. package/dist/Interfaces/Customer/IStoreCredit.d.ts +13 -13
  75. package/dist/Interfaces/Customer/IStoreCredit.js +2 -2
  76. package/dist/Interfaces/Customer/index.d.ts +104 -104
  77. package/dist/Interfaces/Customer/index.js +148 -148
  78. package/dist/Interfaces/Declination/index.d.ts +117 -117
  79. package/dist/Interfaces/Declination/index.js +66 -66
  80. package/dist/Interfaces/Document/index.d.ts +8 -8
  81. package/dist/Interfaces/Document/index.js +2 -2
  82. package/dist/Interfaces/Elastic/index.d.ts +89 -89
  83. package/dist/Interfaces/Elastic/index.js +2 -2
  84. package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.d.ts +11 -11
  85. package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.js +2 -2
  86. package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.d.ts +15 -15
  87. package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.js +2 -2
  88. package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.d.ts +12 -12
  89. package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.js +2 -2
  90. package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.d.ts +36 -36
  91. package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.js +2 -2
  92. package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.d.ts +12 -12
  93. package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.js +2 -2
  94. package/dist/Interfaces/Email/CustomGR/ITransportEmail.d.ts +12 -12
  95. package/dist/Interfaces/Email/CustomGR/ITransportEmail.js +2 -2
  96. package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.d.ts +12 -12
  97. package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.js +2 -2
  98. package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.d.ts +16 -16
  99. package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.js +2 -2
  100. package/dist/Interfaces/Email/CustomGR/IWishlistEmail.d.ts +15 -15
  101. package/dist/Interfaces/Email/CustomGR/IWishlistEmail.js +2 -2
  102. package/dist/Interfaces/Email/IAbandonnedCartEmail.d.ts +29 -29
  103. package/dist/Interfaces/Email/IAbandonnedCartEmail.js +2 -2
  104. package/dist/Interfaces/Email/IAccountConfirmationEmail.d.ts +22 -22
  105. package/dist/Interfaces/Email/IAccountConfirmationEmail.js +2 -2
  106. package/dist/Interfaces/Email/IApplicationEmail.d.ts +19 -19
  107. package/dist/Interfaces/Email/IApplicationEmail.js +2 -2
  108. package/dist/Interfaces/Email/IBackInStockEmail.d.ts +21 -21
  109. package/dist/Interfaces/Email/IBackInStockEmail.js +2 -2
  110. package/dist/Interfaces/Email/IContactEmail.d.ts +20 -20
  111. package/dist/Interfaces/Email/IContactEmail.js +2 -2
  112. package/dist/Interfaces/Email/ICustomerBookingAdminEmail.d.ts +15 -15
  113. package/dist/Interfaces/Email/ICustomerBookingAdminEmail.js +2 -2
  114. package/dist/Interfaces/Email/ICustomerBookingEmail.d.ts +14 -14
  115. package/dist/Interfaces/Email/ICustomerBookingEmail.js +2 -2
  116. package/dist/Interfaces/Email/IEmail.d.ts +20 -20
  117. package/dist/Interfaces/Email/IEmail.js +60 -60
  118. package/dist/Interfaces/Email/IOrderConfirmationEmail.d.ts +47 -47
  119. package/dist/Interfaces/Email/IOrderConfirmationEmail.js +2 -2
  120. package/dist/Interfaces/Email/IPasswordResetEmail.d.ts +17 -17
  121. package/dist/Interfaces/Email/IPasswordResetEmail.js +2 -2
  122. package/dist/Interfaces/Email/IPhotoShootEmail.d.ts +14 -14
  123. package/dist/Interfaces/Email/IPhotoShootEmail.js +2 -2
  124. package/dist/Interfaces/Email/IPickupConfirmation.d.ts +23 -23
  125. package/dist/Interfaces/Email/IPickupConfirmation.js +2 -2
  126. package/dist/Interfaces/Email/IShippingConfirmation.d.ts +23 -23
  127. package/dist/Interfaces/Email/IShippingConfirmation.js +2 -2
  128. package/dist/Interfaces/Email/IWelcomeEmail.d.ts +19 -19
  129. package/dist/Interfaces/Email/IWelcomeEmail.js +2 -2
  130. package/dist/Interfaces/ExportSchema/index.d.ts +7 -7
  131. package/dist/Interfaces/ExportSchema/index.js +2 -2
  132. package/dist/Interfaces/ExternalService/BaseExternalService.d.ts +12 -12
  133. package/dist/Interfaces/ExternalService/BaseExternalService.js +2 -2
  134. package/dist/Interfaces/ExternalService/ExternalProductsService.d.ts +4 -4
  135. package/dist/Interfaces/ExternalService/ExternalProductsService.js +2 -2
  136. package/dist/Interfaces/ExternalService/index.d.ts +9 -9
  137. package/dist/Interfaces/ExternalService/index.js +2 -2
  138. package/dist/Interfaces/FirstOrderTracking/index.d.ts +5 -5
  139. package/dist/Interfaces/FirstOrderTracking/index.js +2 -2
  140. package/dist/Interfaces/G2/index.d.ts +556 -556
  141. package/dist/Interfaces/G2/index.js +38 -38
  142. package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.d.ts +20 -20
  143. package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.js +2 -2
  144. package/dist/Interfaces/Indexed/Product/index.d.ts +105 -105
  145. package/dist/Interfaces/Indexed/Product/index.js +253 -253
  146. package/dist/Interfaces/Inventory/index.d.ts +19 -19
  147. package/dist/Interfaces/Inventory/index.js +8 -8
  148. package/dist/Interfaces/Invoice/index.d.ts +4 -4
  149. package/dist/Interfaces/Invoice/index.js +2 -2
  150. package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.d.ts +3 -3
  151. package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.js +2 -2
  152. package/dist/Interfaces/MarketplacePublication/index.d.ts +23 -23
  153. package/dist/Interfaces/MarketplacePublication/index.js +22 -22
  154. package/dist/Interfaces/Menu/index.d.ts +40 -40
  155. package/dist/Interfaces/Menu/index.js +16 -16
  156. package/dist/Interfaces/Note/index.d.ts +10 -10
  157. package/dist/Interfaces/Note/index.js +7 -7
  158. package/dist/Interfaces/Operations/ICreatedBy.d.ts +6 -6
  159. package/dist/Interfaces/Operations/ICreatedBy.js +2 -2
  160. package/dist/Interfaces/Operations/IUpdate.d.ts +5 -5
  161. package/dist/Interfaces/Operations/IUpdate.js +2 -2
  162. package/dist/Interfaces/Order/index.d.ts +4 -4
  163. package/dist/Interfaces/Order/index.js +2 -2
  164. package/dist/Interfaces/Org/IRelUser.d.ts +9 -9
  165. package/dist/Interfaces/Org/IRelUser.js +2 -2
  166. package/dist/Interfaces/Org/index.d.ts +29 -29
  167. package/dist/Interfaces/Org/index.js +12 -12
  168. package/dist/Interfaces/Payment/index.d.ts +26 -26
  169. package/dist/Interfaces/Payment/index.js +14 -14
  170. package/dist/Interfaces/Product/IAttributeFamily.d.ts +6 -6
  171. package/dist/Interfaces/Product/IAttributeFamily.js +2 -2
  172. package/dist/Interfaces/Product/IImportProduct.d.ts +42 -42
  173. package/dist/Interfaces/Product/IImportProduct.js +882 -882
  174. package/dist/Interfaces/Product/IInventoryItem.d.ts +74 -74
  175. package/dist/Interfaces/Product/IInventoryItem.js +38 -38
  176. package/dist/Interfaces/Product/IPricing.d.ts +177 -177
  177. package/dist/Interfaces/Product/IPricing.js +180 -180
  178. package/dist/Interfaces/Product/index.d.ts +138 -138
  179. package/dist/Interfaces/Product/index.js +64 -64
  180. package/dist/Interfaces/ProductAttribute/index.d.ts +11 -11
  181. package/dist/Interfaces/ProductAttribute/index.js +2 -2
  182. package/dist/Interfaces/PromiseToPurchase/BankType.d.ts +41 -41
  183. package/dist/Interfaces/PromiseToPurchase/BankType.js +41 -41
  184. package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.d.ts +33 -33
  185. package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.js +15 -15
  186. package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.d.ts +19 -19
  187. package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.js +2 -2
  188. package/dist/Interfaces/PromiseToPurchase/index.d.ts +50 -50
  189. package/dist/Interfaces/PromiseToPurchase/index.js +13 -13
  190. package/dist/Interfaces/PurchaseOrder/index.d.ts +17 -17
  191. package/dist/Interfaces/PurchaseOrder/index.js +2 -2
  192. package/dist/Interfaces/Query/IBrandQueryOptions.d.ts +11 -11
  193. package/dist/Interfaces/Query/IBrandQueryOptions.js +2 -2
  194. package/dist/Interfaces/Query/ICategoryQueryOptions.d.ts +11 -11
  195. package/dist/Interfaces/Query/ICategoryQueryOptions.js +2 -2
  196. package/dist/Interfaces/Query/IProductQueryOptions.d.ts +16 -16
  197. package/dist/Interfaces/Query/IProductQueryOptions.js +2 -2
  198. package/dist/Interfaces/Quote/index.d.ts +5 -5
  199. package/dist/Interfaces/Quote/index.js +2 -2
  200. package/dist/Interfaces/Refunds/index.d.ts +106 -106
  201. package/dist/Interfaces/Refunds/index.js +2 -2
  202. package/dist/Interfaces/Rules/IDiscountRule.d.ts +155 -155
  203. package/dist/Interfaces/Rules/IDiscountRule.js +114 -114
  204. package/dist/Interfaces/Schedule/index.d.ts +48 -48
  205. package/dist/Interfaces/Schedule/index.js +2 -2
  206. package/dist/Interfaces/Services/IAddServiceResponse.d.ts +4 -4
  207. package/dist/Interfaces/Services/IAddServiceResponse.js +2 -2
  208. package/dist/Interfaces/Services/IService.d.ts +16 -16
  209. package/dist/Interfaces/Services/IService.js +2 -2
  210. package/dist/Interfaces/Services/IServiceSecret.d.ts +8 -8
  211. package/dist/Interfaces/Services/IServiceSecret.js +2 -2
  212. package/dist/Interfaces/Shipping/Shipstation/carriers.d.ts +10 -10
  213. package/dist/Interfaces/Shipping/Shipstation/carriers.js +2 -2
  214. package/dist/Interfaces/Shipping/Shipstation/order.d.ts +227 -227
  215. package/dist/Interfaces/Shipping/Shipstation/order.js +2 -2
  216. package/dist/Interfaces/Shipping/Shipstation/quote.d.ts +31 -31
  217. package/dist/Interfaces/Shipping/Shipstation/quote.js +2 -2
  218. package/dist/Interfaces/Shipping/Shiptime/order.d.ts +54 -54
  219. package/dist/Interfaces/Shipping/Shiptime/order.js +71 -71
  220. package/dist/Interfaces/Shipping/Shiptime/quote.d.ts +111 -111
  221. package/dist/Interfaces/Shipping/Shiptime/quote.js +2 -2
  222. package/dist/Interfaces/Slider/GR.d.ts +114 -114
  223. package/dist/Interfaces/Slider/GR.js +271 -271
  224. package/dist/Interfaces/Slider/index.d.ts +30 -30
  225. package/dist/Interfaces/Slider/index.js +2 -2
  226. package/dist/Interfaces/Space/IExternalService.d.ts +53 -53
  227. package/dist/Interfaces/Space/IExternalService.js +44 -44
  228. package/dist/Interfaces/Space/IMember.d.ts +16 -16
  229. package/dist/Interfaces/Space/IMember.js +9 -9
  230. package/dist/Interfaces/Space/index.d.ts +411 -411
  231. package/dist/Interfaces/Space/index.js +174 -174
  232. package/dist/Interfaces/Specials/gr.d.ts +61 -61
  233. package/dist/Interfaces/Specials/gr.js +2 -2
  234. package/dist/Interfaces/StockNotification/index.d.ts +7 -7
  235. package/dist/Interfaces/StockNotification/index.js +2 -2
  236. package/dist/Interfaces/Store/index.d.ts +63 -63
  237. package/dist/Interfaces/Store/index.js +27 -27
  238. package/dist/Interfaces/Supplier/ICommand.d.ts +11 -11
  239. package/dist/Interfaces/Supplier/ICommand.js +2 -2
  240. package/dist/Interfaces/Supplier/index.d.ts +36 -36
  241. package/dist/Interfaces/Supplier/index.js +24 -24
  242. package/dist/Interfaces/TCG/index.d.ts +169 -169
  243. package/dist/Interfaces/TCG/index.js +60 -60
  244. package/dist/Interfaces/Tag/index.d.ts +18 -18
  245. package/dist/Interfaces/Tag/index.js +2 -2
  246. package/dist/Interfaces/Tax/index.d.ts +13 -13
  247. package/dist/Interfaces/Tax/index.js +2 -2
  248. package/dist/Interfaces/TransferRequest/index.d.ts +103 -103
  249. package/dist/Interfaces/TransferRequest/index.js +46 -46
  250. package/dist/Interfaces/Translation/index.d.ts +8 -8
  251. package/dist/Interfaces/Translation/index.js +5 -5
  252. package/dist/Interfaces/Update/index.d.ts +10 -10
  253. package/dist/Interfaces/Update/index.js +2 -2
  254. package/dist/Interfaces/User/IUser.d.ts +65 -65
  255. package/dist/Interfaces/User/IUser.js +8 -8
  256. package/dist/Interfaces/Version/index.d.ts +11 -11
  257. package/dist/Interfaces/Version/index.js +2 -2
  258. package/dist/Interfaces/Wishlist/index.d.ts +7 -7
  259. package/dist/Interfaces/Wishlist/index.js +2 -2
  260. package/dist/constants/Interfaces/IBaseApi.d.ts +15 -15
  261. package/dist/constants/Interfaces/IBaseApi.js +2 -2
  262. package/dist/constants/Interfaces/IEndpointResult.d.ts +9 -9
  263. package/dist/constants/Interfaces/IEndpointResult.js +2 -2
  264. package/dist/constants/enums.d.ts +6 -6
  265. package/dist/constants/enums.js +10 -10
  266. package/dist/constants/services.d.ts +2 -2
  267. package/dist/constants/services.js +117 -117
  268. package/dist/constants/version.d.ts +2 -2
  269. package/dist/constants/version.js +5 -5
  270. package/dist/index.d.ts +50 -50
  271. package/dist/index.js +266 -266
  272. package/dist/lib/Attribute/index.d.ts +14 -14
  273. package/dist/lib/Attribute/index.js +186 -186
  274. package/dist/lib/BGJob/index.d.ts +9 -9
  275. package/dist/lib/BGJob/index.js +216 -216
  276. package/dist/lib/BackgroundWorker/index.d.ts +34 -34
  277. package/dist/lib/BackgroundWorker/index.js +59 -59
  278. package/dist/lib/Blog/BlogArticle.d.ts +5 -5
  279. package/dist/lib/Blog/BlogArticle.js +10 -10
  280. package/dist/lib/Blog/BlogAuthor.d.ts +5 -5
  281. package/dist/lib/Blog/BlogAuthor.js +10 -10
  282. package/dist/lib/Blog/BlogCategory.d.ts +5 -5
  283. package/dist/lib/Blog/BlogCategory.js +10 -10
  284. package/dist/lib/Blog/BlogKeyword.d.ts +5 -5
  285. package/dist/lib/Blog/BlogKeyword.js +10 -10
  286. package/dist/lib/Booking/index.d.ts +85 -85
  287. package/dist/lib/Booking/index.js +596 -596
  288. package/dist/lib/Brand/index.d.ts +26 -26
  289. package/dist/lib/Brand/index.js +131 -131
  290. package/dist/lib/Cart/index.d.ts +335 -335
  291. package/dist/lib/Cart/index.js +3981 -3981
  292. package/dist/lib/CartReservedQuantities/index.d.ts +49 -49
  293. package/dist/lib/CartReservedQuantities/index.js +159 -159
  294. package/dist/lib/CashDrawerShift/index.d.ts +84 -84
  295. package/dist/lib/CashDrawerShift/index.js +206 -206
  296. package/dist/lib/Catalogue/index.d.ts +15 -15
  297. package/dist/lib/Catalogue/index.js +78 -78
  298. package/dist/lib/Category/index.d.ts +34 -34
  299. package/dist/lib/Category/index.js +230 -230
  300. package/dist/lib/Class/index.d.ts +16 -16
  301. package/dist/lib/Class/index.js +66 -66
  302. package/dist/lib/Consent/index.d.ts +4 -4
  303. package/dist/lib/Consent/index.js +29 -29
  304. package/dist/lib/Customer/index.d.ts +30 -30
  305. package/dist/lib/Customer/index.js +92 -92
  306. package/dist/lib/Declination/index.d.ts +9 -9
  307. package/dist/lib/Declination/index.js +26 -26
  308. package/dist/lib/Discount/index.d.ts +27 -27
  309. package/dist/lib/Discount/index.js +493 -493
  310. package/dist/lib/ElasticSearch/index.d.ts +13 -13
  311. package/dist/lib/ElasticSearch/index.js +50 -50
  312. package/dist/lib/Elavon/index.d.ts +18 -18
  313. package/dist/lib/Elavon/index.js +135 -135
  314. package/dist/lib/Email/AbandonedCartEmail.d.ts +16 -16
  315. package/dist/lib/Email/AbandonedCartEmail.js +24 -24
  316. package/dist/lib/Email/AccountConfirmationEmail.d.ts +19 -19
  317. package/dist/lib/Email/AccountConfirmationEmail.js +30 -30
  318. package/dist/lib/Email/AdminOrderConfirmationEmail.d.ts +16 -16
  319. package/dist/lib/Email/AdminOrderConfirmationEmail.js +24 -24
  320. package/dist/lib/Email/ApplicationEmail.d.ts +16 -16
  321. package/dist/lib/Email/ApplicationEmail.js +24 -24
  322. package/dist/lib/Email/BackInStockEmail.d.ts +16 -16
  323. package/dist/lib/Email/BackInStockEmail.js +24 -24
  324. package/dist/lib/Email/ContactEmail.d.ts +16 -16
  325. package/dist/lib/Email/ContactEmail.js +24 -24
  326. package/dist/lib/Email/CustomerBookingAdminEmail.d.ts +16 -16
  327. package/dist/lib/Email/CustomerBookingAdminEmail.js +24 -24
  328. package/dist/lib/Email/CustomerBookingEmail.d.ts +16 -16
  329. package/dist/lib/Email/CustomerBookingEmail.js +24 -24
  330. package/dist/lib/Email/OrderConfirmationEmail.d.ts +16 -16
  331. package/dist/lib/Email/OrderConfirmationEmail.js +24 -24
  332. package/dist/lib/Email/OrderDenounciationEmail.d.ts +16 -16
  333. package/dist/lib/Email/OrderDenounciationEmail.js +24 -24
  334. package/dist/lib/Email/OrderSampleEmail.d.ts +16 -16
  335. package/dist/lib/Email/OrderSampleEmail.js +24 -24
  336. package/dist/lib/Email/OtherTypeEmails.d.ts +16 -16
  337. package/dist/lib/Email/OtherTypeEmails.js +27 -27
  338. package/dist/lib/Email/PasswordResetEmail.d.ts +16 -16
  339. package/dist/lib/Email/PasswordResetEmail.js +24 -24
  340. package/dist/lib/Email/PhotoShootEmail.d.ts +16 -16
  341. package/dist/lib/Email/PhotoShootEmail.js +24 -24
  342. package/dist/lib/Email/PickUpConfirmation.d.ts +16 -16
  343. package/dist/lib/Email/PickUpConfirmation.js +24 -24
  344. package/dist/lib/Email/ShippingConfirmation.d.ts +16 -16
  345. package/dist/lib/Email/ShippingConfirmation.js +24 -24
  346. package/dist/lib/Email/WelcomeEmail.d.ts +16 -16
  347. package/dist/lib/Email/WelcomeEmail.js +24 -24
  348. package/dist/lib/Email/index.d.ts +16 -16
  349. package/dist/lib/Email/index.js +31 -31
  350. package/dist/lib/ExternalService/Ebay.d.ts +74 -74
  351. package/dist/lib/ExternalService/Ebay.js +124 -124
  352. package/dist/lib/ExternalService/index.d.ts +5 -5
  353. package/dist/lib/ExternalService/index.js +10 -10
  354. package/dist/lib/FirstOrderTracking/index.d.ts +5 -5
  355. package/dist/lib/FirstOrderTracking/index.js +10 -10
  356. package/dist/lib/Indexed/IndexedCart.d.ts +13 -13
  357. package/dist/lib/Indexed/IndexedCart.js +91 -91
  358. package/dist/lib/Indexed/Product.d.ts +17 -17
  359. package/dist/lib/Indexed/Product.js +98 -98
  360. package/dist/lib/Inventory/index.d.ts +112 -112
  361. package/dist/lib/Inventory/index.js +492 -492
  362. package/dist/lib/Invoice/index.d.ts +16 -16
  363. package/dist/lib/Invoice/index.js +21 -21
  364. package/dist/lib/MarketplacePublication/index.d.ts +9 -9
  365. package/dist/lib/MarketplacePublication/index.js +426 -426
  366. package/dist/lib/Menu/index.d.ts +11 -11
  367. package/dist/lib/Menu/index.js +107 -107
  368. package/dist/lib/MongoDB/BaseAPI.d.ts +18 -18
  369. package/dist/lib/MongoDB/BaseAPI.js +200 -200
  370. package/dist/lib/Note/index.d.ts +4 -4
  371. package/dist/lib/Note/index.js +6 -6
  372. package/dist/lib/Order/index.d.ts +27 -27
  373. package/dist/lib/Order/index.js +56 -56
  374. package/dist/lib/Org/index.d.ts +68 -68
  375. package/dist/lib/Org/index.js +216 -216
  376. package/dist/lib/PandaPay/index.d.ts +16 -16
  377. package/dist/lib/PandaPay/index.js +176 -176
  378. package/dist/lib/Paysafe/index.d.ts +11 -11
  379. package/dist/lib/Paysafe/index.js +41 -41
  380. package/dist/lib/Product/index.d.ts +182 -182
  381. package/dist/lib/Product/index.js +847 -847
  382. package/dist/lib/ProductAttribute/index.d.ts +15 -15
  383. package/dist/lib/ProductAttribute/index.js +45 -45
  384. package/dist/lib/PromiseToPurchase/index.d.ts +109 -109
  385. package/dist/lib/PromiseToPurchase/index.js +343 -343
  386. package/dist/lib/PurchaseOrder/index.d.ts +20 -20
  387. package/dist/lib/PurchaseOrder/index.js +28 -28
  388. package/dist/lib/Queue/index.d.ts +40 -40
  389. package/dist/lib/Queue/index.js +254 -254
  390. package/dist/lib/Schedule/index.d.ts +5 -5
  391. package/dist/lib/Schedule/index.js +12 -12
  392. package/dist/lib/Service/Enum/ServiceEnum.d.ts +3 -3
  393. package/dist/lib/Service/Enum/ServiceEnum.js +7 -7
  394. package/dist/lib/Service/index.d.ts +13 -13
  395. package/dist/lib/Service/index.js +21 -21
  396. package/dist/lib/Shipment/index.d.ts +28 -28
  397. package/dist/lib/Shipment/index.js +370 -370
  398. package/dist/lib/Slider/index.d.ts +22 -22
  399. package/dist/lib/Slider/index.js +119 -119
  400. package/dist/lib/Space/index.d.ts +1181 -1172
  401. package/dist/lib/Space/index.js +5841 -5820
  402. package/dist/lib/Space/index.js.map +1 -1
  403. package/dist/lib/StockNotification/index.d.ts +4 -4
  404. package/dist/lib/StockNotification/index.js +6 -6
  405. package/dist/lib/Store/index.d.ts +5 -5
  406. package/dist/lib/Store/index.js +12 -12
  407. package/dist/lib/Supplier/Command.d.ts +5 -5
  408. package/dist/lib/Supplier/Command.js +10 -10
  409. package/dist/lib/Supplier/index.d.ts +25 -25
  410. package/dist/lib/Supplier/index.js +27 -27
  411. package/dist/lib/Tags/index.d.ts +6 -6
  412. package/dist/lib/Tags/index.js +26 -26
  413. package/dist/lib/Tax/index.d.ts +8 -8
  414. package/dist/lib/Tax/index.js +54 -54
  415. package/dist/lib/TransferRequest/index.d.ts +290 -290
  416. package/dist/lib/TransferRequest/index.js +1026 -1026
  417. package/dist/lib/Update/index.d.ts +10 -10
  418. package/dist/lib/Update/index.js +22 -22
  419. package/dist/lib/User/index.d.ts +89 -89
  420. package/dist/lib/User/index.js +328 -328
  421. package/dist/lib/Wishlist/index.d.ts +5 -5
  422. package/dist/lib/Wishlist/index.js +10 -10
  423. package/dist/lib/base.d.ts +14 -14
  424. package/dist/lib/base.js +62 -62
  425. package/dist/lib/baseService.d.ts +17 -17
  426. package/dist/lib/baseService.js +69 -69
  427. package/dist/rules/GR/constants/data.d.ts +26 -26
  428. package/dist/rules/GR/constants/data.js +81 -81
  429. package/dist/rules/GR/constants/expedition.d.ts +4 -4
  430. package/dist/rules/GR/constants/expedition.js +9 -9
  431. package/dist/rules/GR/constants/products.d.ts +22 -22
  432. package/dist/rules/GR/constants/products.js +263 -263
  433. package/dist/rules/GR/interfaces/cart.d.ts +84 -84
  434. package/dist/rules/GR/interfaces/cart.js +41 -41
  435. package/dist/rules/GR/interfaces/data.d.ts +101 -101
  436. package/dist/rules/GR/interfaces/data.js +114 -114
  437. package/dist/rules/GR/interfaces/products.d.ts +61 -61
  438. package/dist/rules/GR/interfaces/products.js +10 -10
  439. package/dist/rules/GR/utils/cart.d.ts +95 -95
  440. package/dist/rules/GR/utils/cart.js +839 -839
  441. package/dist/rules/GR/utils/data.d.ts +3 -3
  442. package/dist/rules/GR/utils/data.js +28 -28
  443. package/dist/rules/GR/utils/expedition.d.ts +140 -140
  444. package/dist/rules/GR/utils/expedition.js +2016 -2016
  445. package/dist/rules/GR/utils/g2.d.ts +209 -209
  446. package/dist/rules/GR/utils/g2.js +1002 -1002
  447. package/dist/rules/GR/utils/invoices.d.ts +51 -51
  448. package/dist/rules/GR/utils/invoices.js +215 -215
  449. package/dist/rules/GR/utils/products.d.ts +277 -277
  450. package/dist/rules/GR/utils/products.js +1350 -1350
  451. package/dist/rules/GR/utils/upsells.d.ts +111 -111
  452. package/dist/rules/GR/utils/upsells.js +215 -215
  453. package/dist/services/database/BaseProvider.d.ts +29 -29
  454. package/dist/services/database/BaseProvider.js +28 -28
  455. package/dist/services/database/BatchUtils.d.ts +14 -14
  456. package/dist/services/database/BatchUtils.js +43 -43
  457. package/dist/services/database/Config.d.ts +2 -2
  458. package/dist/services/database/Config.js +5 -5
  459. package/dist/services/database/DatabaseService.d.ts +125 -125
  460. package/dist/services/database/DatabaseService.js +237 -237
  461. package/dist/services/database/FirebaseProvider.d.ts +17 -17
  462. package/dist/services/database/FirebaseProvider.js +235 -235
  463. package/dist/services/database/NotFirebaseProvider.d.ts +49 -49
  464. package/dist/services/database/NotFirebaseProvider.js +262 -262
  465. package/dist/services/g2/G2OrderSlip.d.ts +49 -49
  466. package/dist/services/g2/G2OrderSlip.js +228 -228
  467. package/dist/services/g2/utils.d.ts +19 -19
  468. package/dist/services/g2/utils.js +954 -954
  469. package/dist/services/logs/index.d.ts +23 -23
  470. package/dist/services/logs/index.js +66 -66
  471. package/dist/services/marketplace/BaseMarketServiceClass.d.ts +52 -52
  472. package/dist/services/marketplace/BaseMarketServiceClass.js +111 -111
  473. package/dist/services/marketplace/CardtraderServiceClass.d.ts +17 -17
  474. package/dist/services/marketplace/CardtraderServiceClass.js +139 -139
  475. package/dist/services/marketplace/utils.d.ts +14 -14
  476. package/dist/services/marketplace/utils.js +29 -29
  477. package/dist/services/products/BaseClass.d.ts +50 -50
  478. package/dist/services/products/BaseClass.js +66 -66
  479. package/dist/services/products/TCGService.d.ts +32 -32
  480. package/dist/services/products/TCGService.js +555 -555
  481. package/dist/services/products/utils.d.ts +31 -31
  482. package/dist/services/products/utils.js +144 -144
  483. package/dist/utils/algolia.d.ts +46 -46
  484. package/dist/utils/algolia.js +21 -21
  485. package/dist/utils/anonymisation.d.ts +54 -54
  486. package/dist/utils/anonymisation.js +280 -280
  487. package/dist/utils/array.d.ts +5 -5
  488. package/dist/utils/array.js +14 -14
  489. package/dist/utils/aws.d.ts +36 -36
  490. package/dist/utils/aws.js +154 -154
  491. package/dist/utils/booking.d.ts +30 -30
  492. package/dist/utils/booking.js +127 -127
  493. package/dist/utils/cart.d.ts +272 -272
  494. package/dist/utils/cart.js +1169 -1169
  495. package/dist/utils/categories.d.ts +2 -2
  496. package/dist/utils/categories.js +54 -54
  497. package/dist/utils/cmv.d.ts +10 -10
  498. package/dist/utils/cmv.js +107 -107
  499. package/dist/utils/console.d.ts +6 -6
  500. package/dist/utils/console.js +59 -59
  501. package/dist/utils/context.d.ts +20 -20
  502. package/dist/utils/context.js +61 -61
  503. package/dist/utils/currency.d.ts +6 -6
  504. package/dist/utils/currency.js +91 -91
  505. package/dist/utils/data.d.ts +31 -31
  506. package/dist/utils/data.js +296 -296
  507. package/dist/utils/date.d.ts +1 -1
  508. package/dist/utils/date.js +16 -16
  509. package/dist/utils/dimensions.d.ts +3 -3
  510. package/dist/utils/dimensions.js +16 -16
  511. package/dist/utils/discount.d.ts +174 -174
  512. package/dist/utils/discount.js +1118 -1118
  513. package/dist/utils/errors.d.ts +118 -118
  514. package/dist/utils/errors.js +123 -123
  515. package/dist/utils/file-admin.d.ts +8 -8
  516. package/dist/utils/file-admin.js +39 -39
  517. package/dist/utils/file.d.ts +39 -39
  518. package/dist/utils/file.js +208 -208
  519. package/dist/utils/firebase-admin.d.ts +11 -11
  520. package/dist/utils/firebase-admin.js +73 -73
  521. package/dist/utils/firebase.d.ts +58 -58
  522. package/dist/utils/firebase.js +148 -148
  523. package/dist/utils/import.d.ts +1 -1
  524. package/dist/utils/import.js +21 -21
  525. package/dist/utils/inventories.d.ts +101 -101
  526. package/dist/utils/inventories.js +467 -467
  527. package/dist/utils/locale.d.ts +24 -24
  528. package/dist/utils/locale.js +91 -91
  529. package/dist/utils/mailchimp.d.ts +58 -58
  530. package/dist/utils/mailchimp.js +531 -531
  531. package/dist/utils/mathUtils.d.ts +17 -17
  532. package/dist/utils/mathUtils.js +324 -324
  533. package/dist/utils/mongodb.d.ts +1 -1
  534. package/dist/utils/mongodb.js +22 -22
  535. package/dist/utils/object.d.ts +32 -32
  536. package/dist/utils/object.js +133 -133
  537. package/dist/utils/payment.d.ts +10 -10
  538. package/dist/utils/payment.js +23 -23
  539. package/dist/utils/products.d.ts +39 -39
  540. package/dist/utils/products.js +195 -195
  541. package/dist/utils/promiseToPurchase.d.ts +88 -88
  542. package/dist/utils/promiseToPurchase.js +229 -229
  543. package/dist/utils/prosprsearch.d.ts +42 -42
  544. package/dist/utils/prosprsearch.js +216 -216
  545. package/dist/utils/refunds.d.ts +2 -2
  546. package/dist/utils/refunds.js +21 -21
  547. package/dist/utils/sdc.d.ts +10 -10
  548. package/dist/utils/sdc.js +1309 -1309
  549. package/dist/utils/searchIndexes.d.ts +58 -58
  550. package/dist/utils/searchIndexes.js +247 -247
  551. package/dist/utils/services.d.ts +42 -42
  552. package/dist/utils/services.js +409 -409
  553. package/dist/utils/shipment.d.ts +110 -110
  554. package/dist/utils/shipment.js +345 -345
  555. package/dist/utils/simpletexting.d.ts +2 -2
  556. package/dist/utils/simpletexting.js +45 -45
  557. package/dist/utils/sliders.d.ts +4 -4
  558. package/dist/utils/sliders.js +24 -24
  559. package/dist/utils/string.d.ts +16 -16
  560. package/dist/utils/string.js +192 -192
  561. package/dist/utils/tcgService.d.ts +81 -81
  562. package/dist/utils/tcgService.js +353 -353
  563. package/dist/utils/tools.d.ts +5 -5
  564. package/dist/utils/tools.js +13 -13
  565. package/dist/utils/transferRequests.d.ts +43 -43
  566. package/dist/utils/transferRequests.js +67 -67
  567. package/dist/utils/update.d.ts +7 -7
  568. package/dist/utils/update.js +137 -137
  569. package/dist/utils/weight.d.ts +3 -3
  570. package/dist/utils/weight.js +16 -16
  571. package/dist/utils/zones.d.ts +11 -11
  572. package/dist/utils/zones.js +218 -218
  573. package/package.json +107 -107
  574. package/publish.sh +143 -143
  575. package/readme.md +182 -182
@@ -1,848 +1,848 @@
1
- "use strict";
2
- /**
3
- * Products class.
4
- *
5
- * @link ecomm.gitngin.com/wiki/models/products
6
- * @file This files defines the Product class.
7
- * @author Alexandre Hébert-Vincent.
8
- * @since 01-01-2020
9
- */
10
- var __rest = (this && this.__rest) || function (s, e) {
11
- var t = {};
12
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
13
- t[p] = s[p];
14
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
15
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
16
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
17
- t[p[i]] = s[p[i]];
18
- }
19
- return t;
20
- };
21
- var __importDefault = (this && this.__importDefault) || function (mod) {
22
- return (mod && mod.__esModule) ? mod : { "default": mod };
23
- };
24
- var _b;
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- const Product_1 = require("../../Interfaces/Indexed/Product");
27
- const lodash_1 = require("lodash");
28
- const file_1 = require("../../utils/file");
29
- const context_1 = require("../../utils/context");
30
- const console_1 = require("../../utils/console");
31
- const currency_1 = require("../../utils/currency");
32
- const object_1 = require("../../utils/object");
33
- const services_1 = require("../../utils/services");
34
- const locale_1 = require("../../utils/locale");
35
- const algolia_1 = require("../../utils/algolia");
36
- const __1 = require("../..");
37
- const MarketplacePublication_1 = __importDefault(require("../MarketplacePublication"));
38
- const ProductAttribute_1 = __importDefault(require("../ProductAttribute"));
39
- const Product_2 = __importDefault(require("../Indexed/Product"));
40
- const Declination_1 = __importDefault(require("../Declination"));
41
- const Category_1 = __importDefault(require("../Category"));
42
- const Discount_1 = __importDefault(require("../Discount"));
43
- const moment_1 = __importDefault(require("moment"));
44
- const Brand_1 = __importDefault(require("../Brand"));
45
- const Space_1 = __importDefault(require("../Space"));
46
- const g2_1 = require("../../rules/GR/utils/g2");
47
- const baseService_1 = require("../baseService");
48
- const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
49
- //#endregion
50
- /**
51
- * Product class
52
- */
53
- class Product extends baseService_1.BaseServiceClass {
54
- constructor() {
55
- //#region STATIC
56
- super(...arguments);
57
- //#endregion
58
- /**
59
- * Get the product properties
60
- */
61
- this.data = () => this._data;
62
- this.toCSV = () => {
63
- return Object.assign(Object.assign({}, this.data()), { product_attributes: !!this.data().product_attributes
64
- ? this.data().product_attributes.map((pa) => pa.attribute_id)
65
- : undefined, declinations: !!this.data().declinations
66
- ? this.data().declinations.map((d) => d.name)
67
- : undefined, brand: !!this.data().brand ? this.data().brand.key : undefined, classes: !!this.data().classes ? this.data().classes.map((c) => c.key) : undefined, category: !!this.data().category ? this.data().category.key : undefined });
68
- };
69
- this.allRelationships = async () => {
70
- return await this.relationships(['brands']);
71
- };
72
- this.getDefaultSupplier = () => {
73
- const data = this.data();
74
- if (!!!data.suppliers)
75
- return undefined;
76
- const supplier = data.suppliers.filter((supplier) => {
77
- return supplier.supplier_order == 0;
78
- })[0];
79
- return supplier.supplier_id;
80
- };
81
- /**
82
- * Returns complete relationship object mapped by product interface.
83
- * @param relations Array of strings reprensenting the wanted relationships objects.
84
- * @returns Partial product IProduct
85
- */
86
- this.relationships = async (relations) => {
87
- if (relations.length === 0)
88
- return {};
89
- const relationships = {};
90
- const _getKeyFromRelationType = (_relation) => {
91
- switch (_relation) {
92
- case 'brands':
93
- default:
94
- return 'brand';
95
- }
96
- };
97
- for (const relation of relations) {
98
- if (!!relationships[relation])
99
- continue;
100
- if (!!!this._data[_getKeyFromRelationType(relation)])
101
- continue;
102
- const relationReq = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), relation), this._data[_getKeyFromRelationType(relation)].key);
103
- if (!relationReq.exists)
104
- continue;
105
- const relationData = relationReq.data;
106
- if (!!!relationData)
107
- continue;
108
- relationships[_getKeyFromRelationType(relation)] = Object.assign(Object.assign({}, relationData), { id: relationReq.id });
109
- }
110
- return relationships;
111
- };
112
- this.save = async (partialProduct, options) => {
113
- const beforeData = Object.assign({}, this._data);
114
- this._data = Object.assign(Object.assign({}, this._data), partialProduct);
115
- this._data = (await this._updateDependancies(this._data, beforeData, !!options ? options.space : undefined));
116
- // if (!!!(this._data as IProduct).last_update_by) {
117
- this._data = Object.assign(Object.assign({}, this._data), { last_update_by: this._user });
118
- // }
119
- const id = await super.save(this._data, undefined, true, true, true, beforeData);
120
- if (!!id && !!!this._data.id && typeof id === 'string') {
121
- this._data = Object.assign(Object.assign({}, this._data), { id });
122
- }
123
- if (!!!options) {
124
- return true;
125
- }
126
- return id;
127
- };
128
- this._updateDependancies = async (product, beforeData, space) => {
129
- (0, console_1.workingMessage)('Updating images and stuff');
130
- let productToUpdate = product;
131
- try {
132
- if (!!!space)
133
- space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
134
- const useService = space.preferences.storage.getServiceToUse();
135
- productToUpdate = await this._uploadDeclinationsImages(productToUpdate, useService);
136
- productToUpdate = await this._updateSEOImage(productToUpdate, useService);
137
- productToUpdate = await this._updatePanelDescriptionsImage(productToUpdate, useService);
138
- productToUpdate = await this._updateDeclinationsDiscountRules(productToUpdate, beforeData);
139
- productToUpdate = await this._updateBarcode(productToUpdate, space);
140
- await this._updateInventoryItem(productToUpdate, beforeData, space);
141
- return productToUpdate;
142
- }
143
- catch (error) {
144
- (0, console_1.errorMessage)(`Error while updating dependancies: ${error} - ${JSON.stringify(error)}`);
145
- return product;
146
- }
147
- };
148
- this._updateSEOImage = async (product, useService) => {
149
- return Object.assign(Object.assign({}, product), { seo_info: Object.assign(Object.assign({}, product.seo_info), { seoImage: !!product.seo_info &&
150
- !!product.seo_info.seoImage &&
151
- !!product.seo_info.seoImage.img_path &&
152
- typeof product.seo_info.seoImage.img_path === 'string'
153
- ? product.seo_info.seoImage
154
- : {
155
- img_path: !!product.seo_info && !!product.seo_info.seoImage && !!product.seo_info.seoImage.img_path
156
- ? await (0, file_1.uploadFileToPath)(useService, product.seo_info.seoImage.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))))
157
- : ''
158
- } }) });
159
- };
160
- this._updatePanelDescriptionsImage = async (product, useService) => {
161
- if (!!!product.panel_descriptions || !!!product.panel_descriptions.length)
162
- return product;
163
- return Object.assign(Object.assign({}, product), { panel_descriptions: await Promise.all(product.panel_descriptions.map(async (panel) => {
164
- if (!!!panel.img)
165
- return panel;
166
- if (typeof panel.img.img_path === 'string' && !panel.img.img_path.includes('base64'))
167
- return panel;
168
- if (typeof panel.img.img_path === 'string')
169
- return Object.assign(Object.assign({}, panel), { img: Object.assign(Object.assign({}, panel.img), { img_path: await (0, file_1.uploadStringToPath)(useService, panel.img.img_path, (0, context_1.getPathTo)(`products/${product.slug}/panels`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(panel.label_name), 'jpg') }) });
170
- if (!!panel.img.img_path.file)
171
- return Object.assign(Object.assign({}, panel), { img: Object.assign(Object.assign({}, panel.img), { img_path: await (0, file_1.uploadFileToPath)(useService, panel.img.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}/panels`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path)))) }) });
172
- return Object.assign(Object.assign({}, panel), { img: undefined });
173
- })) });
174
- };
175
- this._updateBarcode = async (product, space) => {
176
- try {
177
- if (!!!space)
178
- space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
179
- if (!!!space.data().product_preferences.generate_barcode)
180
- return product;
181
- return Object.assign(Object.assign({}, product), { declinations: await Promise.all((product.declinations || []).map(async (_d) => {
182
- if (!!_d.upc)
183
- return _d;
184
- if (!!!space)
185
- return _d;
186
- const upc = space.data().product_preferences.barcode_next;
187
- await space.save({
188
- product_preferences: Object.assign(Object.assign({}, space.data().product_preferences), { barcode_next: `${(0, lodash_1.toNumber)(upc) + 1}` })
189
- });
190
- return Object.assign(Object.assign({}, _d), { upc });
191
- })) });
192
- }
193
- catch (error) {
194
- console.log(error);
195
- return product;
196
- }
197
- };
198
- this._updateInventoryItem = async (product, beforeData, space) => {
199
- const declis = product.declinations;
200
- if (!!!declis || !!!declis.length)
201
- return;
202
- if (!!!space)
203
- space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
204
- // On product save, remove all deletedSkus from inventory
205
- const allSameProductInventories = await space.inventoryItems.getAllFromSameProduct(!!product.slug ? product.slug : this.data().slug);
206
- if (!!!allSameProductInventories || !!!allSameProductInventories.length)
207
- return true;
208
- // If product is service now, delete all inventoryItems associated
209
- if (!!beforeData && !!product.is_service && beforeData.is_service !== product.is_service) {
210
- try {
211
- for (let inventory of allSameProductInventories) {
212
- await inventory.delete();
213
- }
214
- }
215
- catch (e) {
216
- console.log('error on deleting inventories of now service product: ', e);
217
- }
218
- return true;
219
- }
220
- const allSameProductInventoriesSamples = allSameProductInventories.filter((i) => !!i.data().is_sample);
221
- const allSameProductInventoriesNotSamples = allSameProductInventories.filter((i) => !!!i.data().is_sample);
222
- const deletedSkusSamples = allSameProductInventoriesSamples.filter((inventory) => {
223
- const decliSku = inventory.data().decli_sku_associated_to_sample;
224
- const foundDecli = declis.find((d) => d.sku === decliSku);
225
- return !!!foundDecli || !foundDecli.is_sample;
226
- });
227
- const deletedSkusNotSamples = allSameProductInventoriesNotSamples.filter((inventory) => !!!declis.some((d) => d.sku === inventory.data().sku) && !!!inventory.data().is_sample);
228
- const skusToDelete = [...deletedSkusSamples, ...deletedSkusNotSamples];
229
- if (!!!skusToDelete.length)
230
- return true;
231
- try {
232
- await Promise.all(skusToDelete.map(async (inventory) => {
233
- await inventory.delete();
234
- }));
235
- }
236
- catch (e) {
237
- console.log('error on deleting inventories of deleted skus: ', e);
238
- }
239
- return true;
240
- };
241
- this._updateDeclinationsDiscountRules = async (product, beforeData) => {
242
- let lastPushedTime = '';
243
- return Object.assign(Object.assign({}, product), { declinations: !!product.declinations
244
- ? await Promise.all(product.declinations.map(async (declination, index) => {
245
- const timestamp = (0, moment_1.default)().toDate().getTime();
246
- let idString = String(timestamp) + '-' + String(index);
247
- const duplicateTime = idString === lastPushedTime;
248
- lastPushedTime = String(timestamp) + '-' + String(index);
249
- const currentDataDeclis = !!beforeData.declinations ? beforeData.declinations : [];
250
- const sameInCurrentData = currentDataDeclis.find((d) => !!d && d.sku === declination.sku);
251
- let discountsToDelete = [];
252
- if (!!sameInCurrentData) {
253
- discountsToDelete = (sameInCurrentData.discount_rules || []).filter((d) => !!d &&
254
- d.discountRule_type === 'tier-pricing' &&
255
- (!!!declination.discount_rules ||
256
- !!!declination.discount_rules.length ||
257
- !!!declination.discount_rules.some((_d) => _d.id === d.id)));
258
- }
259
- if (!!duplicateTime) {
260
- idString =
261
- idString.split('-')[0] + '-' + String(index + product.declinations.length);
262
- }
263
- if (!!discountsToDelete &&
264
- !!discountsToDelete.length &&
265
- DatabaseService_1.default.getPathParent(this._collection.path) !== '/') {
266
- console.log('** Going to delete tier-pricing discount_rules no longer in declination **');
267
- for (let discount of discountsToDelete) {
268
- try {
269
- const discountObj = new Discount_1.default(discount, {
270
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'discountRules')
271
- }, this._user);
272
- await discountObj.delete();
273
- }
274
- catch (e) {
275
- console.log('error on deleting discount: ', e);
276
- }
277
- }
278
- }
279
- return Object.assign(Object.assign({}, declination), { id: !!declination.id ? declination.id : idString, discount_rules: !!declination.discount_rules && !!declination.discount_rules.length
280
- ? await Promise.all((0, lodash_1.sortedUniqBy)(declination.discount_rules, (dr) => {
281
- const rule = !!dr.rules && dr.rules.find((r) => r.field === 'quantity');
282
- if (!!!rule)
283
- return false;
284
- return rule.ruleDetails[0].value[0];
285
- }).map(async (rule) => {
286
- if (DatabaseService_1.default.getPathParent(this._collection.path) === '/')
287
- return rule;
288
- if (rule.discountRule_type !== 'tier-pricing')
289
- return rule;
290
- const _rule = new Discount_1.default(rule, {
291
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'discountRules')
292
- }, this._user);
293
- const id = await _rule.save();
294
- return Object.assign(Object.assign({}, rule), (!!!rule.id && typeof id === 'string' && !!id ? { id: id } : {}));
295
- }))
296
- : [] });
297
- }))
298
- : [] });
299
- };
300
- this._uploadDeclinationsImages = async (product, useService) => {
301
- return Object.assign(Object.assign({}, product), { image_files: !!!product.image_files || !!!product.image_files.length
302
- ? []
303
- : await Promise.all(product.image_files
304
- .filter((i) => !!i && !!i.img_path)
305
- .map(async (imageInfo) => {
306
- // If img_path is of type { dataURL: ... }
307
- if (!!imageInfo.img_path.dataURL && !!!imageInfo.img_path.file) {
308
- if (typeof imageInfo.img_path.dataURL === 'string' &&
309
- !!imageInfo.img_path.dataURL.includes('base64')) {
310
- return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(useService, imageInfo.img_path.dataURL, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(product.name), imageInfo.img_path.dataURL.split(';')[0].split('/')[1])) });
311
- }
312
- else {
313
- return Object.assign(Object.assign({}, imageInfo), { img_path: imageInfo.img_path.dataURL });
314
- }
315
- }
316
- // If img_path is of type string
317
- if (typeof imageInfo.img_path === 'string') {
318
- if (!!imageInfo.img_path.includes('base64')) {
319
- return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(useService, imageInfo.img_path, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(product.name), imageInfo.img_path.split(';')[0].split('/')[1])) });
320
- }
321
- else {
322
- return imageInfo;
323
- }
324
- }
325
- // If img_path is of type { file: ... }
326
- const img_path = await (0, file_1.uploadFileToPath)(useService, imageInfo.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))));
327
- return Object.assign(Object.assign({}, imageInfo), { img_path: img_path });
328
- })), declinations: !!!product.declinations || !!!product.declinations.length
329
- ? []
330
- : await Promise.all(product.declinations.map(async (declination) => {
331
- if (!!!declination.image_files)
332
- return declination;
333
- if (!!!declination.image_files.length)
334
- return declination;
335
- if (!!!declination.image_files.find((imageInfo) => !!imageInfo.img_path && !!imageInfo.img_path.file))
336
- return declination;
337
- return Object.assign(Object.assign({}, declination), { image_files: await Promise.all(declination.image_files
338
- .filter((i) => !!i && !!i.img_path)
339
- .map(async (imageInfo) => {
340
- if (typeof imageInfo.img_path === 'string') {
341
- if (!!imageInfo.img_path.includes('base64')) {
342
- return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(imageInfo.img_path, (0, context_1.getPathTo)(`brands/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(declination.name), imageInfo.img_path.split(';')[0].split('/')[1])) });
343
- }
344
- else {
345
- return imageInfo;
346
- }
347
- }
348
- const img_path = (await (0, file_1.uploadFileToPath)(useService, imageInfo.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path)))));
349
- return Object.assign(Object.assign({}, imageInfo), { img_path });
350
- })) });
351
- })) });
352
- };
353
- //#region ATTRIBUTES
354
- this._getAttributes = () => {
355
- try {
356
- if (!!!this.data().product_attributes || !!!this._data.id)
357
- return [];
358
- return this.data().product_attributes.map((d) => new ProductAttribute_1.default(d, DatabaseService_1.default.addToPath(DatabaseService_1.default.addToPath(this._collection.path, this._data.id), 'attributes'), this._user));
359
- }
360
- catch (err) {
361
- throw new Error(`Error while getting attributes: ${err}`);
362
- }
363
- };
364
- this._addAttribute = async (productAttribute) => {
365
- const pas = !!this.data().product_attributes ? this.data().product_attributes : [];
366
- const existingPA = pas.find((a) => a.attribute_id === productAttribute.attribute_id);
367
- if (!!existingPA) {
368
- const _attributes = pas.map((pa) => {
369
- if (pa.id !== existingPA.id)
370
- return pa;
371
- return Object.assign(Object.assign({}, pa), productAttribute);
372
- });
373
- return await this.save({ product_attributes: _attributes });
374
- }
375
- return await this.save({
376
- product_attributes: [...pas, productAttribute]
377
- });
378
- };
379
- //#endregion
380
- //#region CATEGORIES
381
- this._getCategory = async () => {
382
- if (!!!this._data.category)
383
- throw new Error(`Product categoy is not yet defined`);
384
- try {
385
- const categorySnap = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'categories'), this._data.category);
386
- if (!!!categorySnap)
387
- throw new Error(`Inexisting category`);
388
- if (!categorySnap.exists)
389
- throw new Error(`Impossible to retreive the category`);
390
- if (!!!categorySnap.data)
391
- throw new Error(`Impossible te retreive the category data`);
392
- return new Category_1.default(Object.assign(Object.assign({}, categorySnap.data), { id: categorySnap.id }), {
393
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'categories')
394
- }, this._user);
395
- }
396
- catch (err) {
397
- throw new Error(`Error while getting categories: ${err}`);
398
- }
399
- };
400
- //#endregion
401
- //#region BRANDS
402
- this._getBrand = async () => {
403
- if (!!!this._data.brand)
404
- return undefined;
405
- try {
406
- const brandSnap = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'brands'), this._data.brand);
407
- if (!!!brandSnap)
408
- throw new Error(`Inexisting brand`);
409
- if (!brandSnap.exists)
410
- throw new Error(`Impossible to retreive the brand`);
411
- if (!!!brandSnap.data)
412
- throw new Error(`Impossible te retreive the brand data`);
413
- return new Brand_1.default(Object.assign(Object.assign({}, brandSnap.data), { id: brandSnap.id }), {
414
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'brands')
415
- }, this._user);
416
- }
417
- catch (err) {
418
- throw new Error(`Error while getting brands: ${err}`);
419
- }
420
- };
421
- //#endregion
422
- //#region DECLINATIONS
423
- this._getDeclinations = () => {
424
- if (!!!this._data.id)
425
- throw new Error(`Product must be saved to create declinations.`);
426
- const declinationCollectionRef = DatabaseService_1.default.addToPath(DatabaseService_1.default.addToPath(this._collection.path, this._data.id), 'declinations');
427
- if (!!!this.data().declinations)
428
- return [];
429
- return this.data().declinations.map((d) => new Declination_1.default(d, declinationCollectionRef, this._user));
430
- };
431
- this._addDeclination = async (declination) => {
432
- if (!!!this._data.id)
433
- throw new Error(`Product must be saved to create declinations.`);
434
- if (!!!this.data().declinations)
435
- return;
436
- return this.save({
437
- declinations: [...this.data().declinations, declination]
438
- });
439
- };
440
- this._saveIndex = async (category) => {
441
- if (!!!this._data.id)
442
- throw new Error('Product must be saved first.');
443
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
444
- throw new Error('BD badly initialised. Products collection must have a parent.');
445
- let brand = undefined;
446
- const declinations = this.data().declinations;
447
- if (!!!declinations) {
448
- console.log(`No declinations to update`);
449
- return true;
450
- }
451
- try {
452
- if (!!!category && !!!this.data().is_service) {
453
- category = await this.category.get();
454
- if (!!!category)
455
- throw new Error(`A category must be set`);
456
- }
457
- if (!!this._data.brand) {
458
- try {
459
- brand = await this.brand.get();
460
- }
461
- catch (e) {
462
- console.log('could not fetch brand with id ', this._data.brand, ': ', e.toString());
463
- }
464
- }
465
- const tree = !!category ? await category.getParentTree() : [];
466
- const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
467
- await space.initCurrencies();
468
- const indexed = await (0, Product_1.populateIndexedProduct)(this.data(), tree, space, category, brand);
469
- console.log('index is created');
470
- await DatabaseService_1.default.saveDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), this._data.id, (0, moment_1.default)().unix(), (0, object_1.stripObjectForFirebase)(Object.assign(Object.assign({}, indexed), { declinations: indexed.declinations.map((declination) => {
471
- if (!!declination.promo_price || typeof declination.promo_price !== 'boolean')
472
- return declination;
473
- const { promo_price } = declination, rest = __rest(declination, ["promo_price"]);
474
- return Object.assign({}, rest);
475
- }) })), { merge: true });
476
- return true;
477
- }
478
- catch (error) {
479
- console.log(`error while indexing`, error.toString());
480
- console.trace(`indexing error trace`);
481
- throw error;
482
- }
483
- };
484
- this._getIndex = async () => {
485
- if (!!!this._data.id)
486
- throw new Error(`Product has never been saved`);
487
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
488
- throw new Error(`Can't access indexes collection`);
489
- const indexedProductsDocs = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), { query: [{ field: 'product_id', operator: '==', value: this._data.id }] });
490
- return await Promise.all(indexedProductsDocs
491
- .filter((d) => !!d.exists && !!d.data)
492
- .map((doc) => {
493
- return new Product_2.default(Object.assign(Object.assign({}, doc.data), { id: doc.id }), {
494
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public')
495
- }, this._user);
496
- }));
497
- };
498
- this._deleteIndex = async () => {
499
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
500
- throw new Error(`Can't access parent collection`);
501
- try {
502
- if (!!!this._data.id)
503
- throw new Error('No id for selected product');
504
- await DatabaseService_1.default.deleteDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), this._data.id);
505
- }
506
- catch (error) {
507
- throw error;
508
- }
509
- };
510
- //#endregion
511
- this.callPublicService = async (service, fromServer = false) => {
512
- const requestHeader = (0, services_1.productServiceUrl)(Object.assign({}, service.external_service_infos), service.external_service_name);
513
- if (!!!requestHeader)
514
- throw new Error(`Can't access service provider. Please validate your external services configuration`);
515
- const { url, type: method } = requestHeader;
516
- try {
517
- const quoteReq = await fetch(!!fromServer ? `${url}&q=${this.data().name[0].value}` : '/api/services/cors', {
518
- headers: { 'content-type': 'application/json' },
519
- method: !!fromServer ? method : 'POST',
520
- body: JSON.stringify({
521
- props: { method, headers: { 'content-type': 'application/json' } },
522
- url: `${url}&q=${this.data().name[0].value}`
523
- })
524
- });
525
- if (quoteReq.status.toString() !== '200')
526
- throw new Error(`Error while getting service: ${quoteReq.statusText}`);
527
- const details = await quoteReq.json();
528
- return { confirmed: true, details };
529
- }
530
- catch (error) {
531
- (0, console_1.errorMessage)(`Error while calling order service ${error} - ${JSON.stringify(error)}`);
532
- return { confirmed: false, error };
533
- }
534
- };
535
- this._updateAllDeclinationsPrice = async (pricingMapFromExternalOrCustom, attributes, saveToDatabase = true, updateRegular = true, spaceToUse) => {
536
- try {
537
- const space = !!spaceToUse ? spaceToUse : await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
538
- const spacePrice = this.adaptPriceChartingValues(pricingMapFromExternalOrCustom, space);
539
- const declinations = this.data().declinations;
540
- if (!!!declinations)
541
- return false;
542
- const declinationsWithAttributeLinkedToService = declinations.filter((d) => !!d.attributes.find((pa) => {
543
- const attr = attributes.find((_a) => _a.id === pa.attribute_id);
544
- if (!!!attr)
545
- return false;
546
- if (!!!attr.is_service_related)
547
- return false;
548
- if (!!!attr.service_links_to_attribute)
549
- return false;
550
- return true;
551
- }));
552
- if (!!!declinationsWithAttributeLinkedToService.length)
553
- return false;
554
- for (const declinationToUpdate of declinationsWithAttributeLinkedToService) {
555
- const relationProductAttribute = declinationToUpdate.attributes.find((pa) => {
556
- const attr = attributes.find((_a) => _a.id === pa.attribute_id);
557
- if (!!!attr)
558
- return false;
559
- if (!!!attr.is_service_related)
560
- return false;
561
- return true;
562
- });
563
- if (!!!relationProductAttribute)
564
- continue;
565
- const relationAttribute = attributes.find((a) => a.id === relationProductAttribute.attribute_id);
566
- if (!!!relationAttribute)
567
- continue;
568
- if (!!!relationAttribute.service_links_to_attribute)
569
- continue;
570
- const propsToLink = relationAttribute.service_links_to_attribute.find((slta) => slta.value_slugs.find((vs) => !!relationProductAttribute.values.find((value) => value.slug === vs.slug)));
571
- if (!!!propsToLink)
572
- continue;
573
- if (!!!spacePrice[propsToLink.service_field])
574
- continue;
575
- let price = (0, lodash_1.toNumber)(spacePrice[propsToLink.service_field]) / 100;
576
- const priceDetails = propsToLink.value_slugs.find((vs) => !!relationProductAttribute.values.find((value) => value.slug === vs.slug));
577
- if (!!priceDetails) {
578
- if (!!priceDetails.percent_variation) {
579
- price = price * (1 + priceDetails.percent_variation / 100);
580
- }
581
- }
582
- const _declinations = declinations.map((declination) => {
583
- if (declination.sku !== declinationToUpdate.sku)
584
- return declination;
585
- return Object.assign(Object.assign({}, declination), { price: Object.assign(Object.assign(Object.assign({}, declination.price), { pdsf: { amount: (0, lodash_1.toNumber)(price) } }), (!!updateRegular
586
- ? {
587
- regular: {
588
- amount: (0, lodash_1.ceil)((0, lodash_1.toNumber)(price)) - 0.01 >= (0, lodash_1.toNumber)(declination.price.regular.amount)
589
- ? (0, lodash_1.ceil)((0, lodash_1.toNumber)(price)) - 0.01
590
- : (0, lodash_1.toNumber)(declination.price.regular.amount)
591
- }
592
- }
593
- : {})) });
594
- });
595
- if (!!!saveToDatabase)
596
- return {
597
- declinations: _declinations,
598
- services: { price_charting: spacePrice }
599
- };
600
- await this.save({
601
- declinations: _declinations
602
- }, { index: true });
603
- }
604
- await this.save({
605
- services: Object.assign(Object.assign({}, this.data().services), { price_charting: spacePrice })
606
- });
607
- return true;
608
- }
609
- catch (error) {
610
- if (process.env.NODE_ENV !== 'production')
611
- console.log(error);
612
- return false;
613
- }
614
- };
615
- this.adaptPriceChartingValues = (pricingMap, space) => {
616
- let returnValue = {};
617
- (0, lodash_1.forEach)(pricingMap, (val, key) => {
618
- if (['loose-price', 'cib-price', 'loose-price', 'box-only-price', 'manual-only-price', 'new-price'].includes(key)) {
619
- returnValue[key] = (0, currency_1.calculateAmountByCurrency)(space, space.preferences.default.currency(), (0, lodash_1.toNumber)(val), 'USD');
620
- return;
621
- }
622
- });
623
- return Object.assign(Object.assign({}, pricingMap), returnValue);
624
- };
625
- this._updateAllDeclinationsPriceAsync = async (pricingMapFromExternalOrCustom) => {
626
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
627
- throw new Error(`Can't fetch attributes`);
628
- try {
629
- const attributesRes = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'attributes'));
630
- const attributes = attributesRes
631
- .filter((d) => !!d.exists && !!d.data)
632
- .map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id })));
633
- return await this._updateAllDeclinationsPrice(pricingMapFromExternalOrCustom, attributes);
634
- }
635
- catch (error) {
636
- (0, console_1.errorMessage)(`Error while fetching price and attributes`);
637
- return [];
638
- }
639
- };
640
- this._getMarketplacePublications = async (options) => {
641
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
642
- throw new Error(`Can't fetch marketplace publications`);
643
- try {
644
- let publications = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), options);
645
- return publications.map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id })));
646
- }
647
- catch (error) {
648
- (0, console_1.errorMessage)(`Error while fetching marketplace publications`);
649
- return [];
650
- }
651
- };
652
- this._marketplacePublicationsListner = (callback, options) => {
653
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
654
- throw new Error(`Can't fetch marketplace publications`);
655
- try {
656
- let call = DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications');
657
- return DatabaseService_1.default.registerListener((dataSnap) => {
658
- if (!!!dataSnap.length)
659
- callback([]);
660
- (0, console_1.workingMessage)(`Marketplace publications has been udpated. Refreshing...`);
661
- callback(dataSnap.map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id }))));
662
- }, call, !!options ? options : { query: [{ field: 'parent_slug', operator: '==', value: this._data.slug }] });
663
- }
664
- catch (error) {
665
- (0, console_1.errorMessage)(`Error while listening marketplace publications`);
666
- return '';
667
- }
668
- };
669
- this._createNewPublication = async (sku, marketplacePublication, space) => {
670
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
671
- throw new Error(`Can't fetch marketplace publications`);
672
- try {
673
- const productInvetory = await space.inventoryItems.getOne(sku);
674
- if (!!!productInvetory || !!!productInvetory.web_inventory)
675
- throw new Error(`Can't find inventory item with sku: ${sku}`);
676
- if (!!!productInvetory.web_inventory.available)
677
- throw new Error(`Inventory item with sku: ${sku} is not available`);
678
- if (marketplacePublication.quantity < 1)
679
- throw new Error(`No quantity available`);
680
- if ((0, lodash_1.toNumber)(productInvetory.web_inventory.available) < 1)
681
- throw new Error(`No quantity available`);
682
- if ((0, lodash_1.toNumber)(productInvetory.web_inventory.available) < marketplacePublication.quantity)
683
- throw new Error(`Inventory item with sku: ${sku} is not available`);
684
- }
685
- catch (error) {
686
- (0, console_1.errorMessage)(`Error while fetching inventory item with sku: ${sku}`);
687
- return false;
688
- }
689
- try {
690
- const newMarketplacePublication = new MarketplacePublication_1.default(Object.assign(Object.assign({}, marketplacePublication), { sku, parent_slug: this.data().slug, created_at: new Date(), created_by: this._user }), {
691
- path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications')
692
- }, this._user);
693
- return await newMarketplacePublication.save();
694
- }
695
- catch (error) {
696
- (0, console_1.errorMessage)(`Error while creating marketplace publications`);
697
- return false;
698
- }
699
- };
700
- this._updateMarketplacePublication = async (sku, marketplacePublication) => {
701
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
702
- throw new Error(`Can't update marketplace publications`);
703
- try {
704
- const marketplacePublicationObj = await MarketplacePublication_1.default.getMarketplacePublicationObj(sku, DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), this._user);
705
- if (!!!marketplacePublicationObj)
706
- throw new Error(`No marketplace publication found`);
707
- return await marketplacePublicationObj.save(marketplacePublication);
708
- }
709
- catch (error) {
710
- (0, console_1.errorMessage)(`Error while updating marketplace publications`);
711
- return false;
712
- }
713
- };
714
- this._removeMarketplacePublication = async (publicationId) => {
715
- if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
716
- throw new Error(`Can't remove marketplace publications`);
717
- try {
718
- const marketplacePublicationObj = await MarketplacePublication_1.default.getMarketplacePublicationObjById(publicationId, DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), this._user);
719
- if (!!!marketplacePublicationObj)
720
- throw new Error(`No marketplace publication found`);
721
- return await marketplacePublicationObj.delete();
722
- }
723
- catch (error) {
724
- (0, console_1.errorMessage)(`Error while deleting marketplace publications`);
725
- return false;
726
- }
727
- };
728
- this._updateAllDeclinationsPriceUsingCategoryRules = async (basePrices, attributeVariationId, defaultVariation, options = {}) => {
729
- if (!!!this._data.category || !this._data.declinations || !this._data.id)
730
- return false;
731
- if (basePrices.length == 0)
732
- return false;
733
- if (!!this._data.disable_price_auto_update)
734
- return false;
735
- // get category
736
- const cat = await this.category.get();
737
- let hasUpdate = false;
738
- const newDecli = this._data.declinations.map((d) => {
739
- var _c;
740
- const basePrice = (_c = basePrices.find((x) => d.attributes.some((a) => a.attribute_id.toLowerCase() == attributeVariationId.toLowerCase() &&
741
- a.values.some((v) => v.slug.toLowerCase() == x.variation.toLowerCase())))) !== null && _c !== void 0 ? _c : basePrices.find((x) => x.variation.toLowerCase() == defaultVariation.toLowerCase());
742
- if (!basePrice)
743
- return d; // if no price found dont update
744
- const newPrice = cat.costPriceRule(basePrice.price, d, 'sell');
745
- if (newPrice == d.price.regular.amount)
746
- return d;
747
- hasUpdate = true;
748
- return Object.assign(Object.assign({}, d), { price: Object.assign(Object.assign({}, d.price), { regular: { amount: newPrice }, pdsf: { amount: basePrice.price } }) });
749
- });
750
- if (hasUpdate) {
751
- this._data = Object.assign(Object.assign({}, this._data), { declinations: newDecli });
752
- if (options && !!options.saveToDatabase) {
753
- await DatabaseService_1.default.saveDocument(this._collection.path, this._data.id, 0, { declinations: newDecli }, { merge: true, noEvent: options.noEvent });
754
- }
755
- }
756
- return hasUpdate;
757
- };
758
- //#region GETTERS
759
- this.attributes = {
760
- get: this._getAttributes,
761
- add: this._addAttribute
762
- };
763
- this.brand = {
764
- get: this._getBrand
765
- };
766
- this.category = {
767
- get: this._getCategory
768
- };
769
- this.publications = {
770
- get: this._getMarketplacePublications,
771
- listen: this._marketplacePublicationsListner,
772
- update: this._updateMarketplacePublication,
773
- create: this._createNewPublication,
774
- remove: this._removeMarketplacePublication
775
- };
776
- this.declinations = {
777
- get: this._getDeclinations,
778
- add: this._addDeclination,
779
- update: {
780
- // SDC only
781
- priceSync: this._updateAllDeclinationsPrice,
782
- priceAsync: this._updateAllDeclinationsPriceAsync,
783
- // New system
784
- byCategoryRules: this._updateAllDeclinationsPriceUsingCategoryRules
785
- }
786
- // Automatic declinations
787
- // create: this._createDeclinations
788
- };
789
- this.index = {
790
- save: this._saveIndex,
791
- get: this._getIndex,
792
- delete: this._deleteIndex
793
- };
794
- //#endregion
795
- }
796
- }
797
- exports.default = Product;
798
- _b = Product;
799
- Product.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'products', f = '', space, useProspr = false }) => {
800
- try {
801
- let prosprSearch = false;
802
- if (!!space) {
803
- const prosprService = space
804
- .data()
805
- .external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
806
- prosprSearch = !!prosprService && prosprService.is_active;
807
- }
808
- const algolia = (0, algolia_1.createClient)({
809
- app,
810
- indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
811
- key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
812
- prospr: !!prosprSearch || !!useProspr
813
- });
814
- const results = await algolia.search(query, {
815
- hitsPerPage: hpp,
816
- facetFilters: filters,
817
- filters: f,
818
- page,
819
- // facetingAfterDistinct: true,
820
- facets: ['*']
821
- });
822
- return results;
823
- }
824
- catch (error) {
825
- (0, console_1.errorMessage)(error);
826
- throw error;
827
- }
828
- };
829
- //#endregion
830
- //#region EXTERNAL VALUES
831
- /**
832
- * Checks for external values from external services for a sku.
833
- * Available services checked (as of now) : G2.
834
- * @param space
835
- * @param sku
836
- */
837
- Product.checkExternalValuesForDecli = async (sku, space, org) => {
838
- if (!!!space)
839
- return;
840
- let externalValues = undefined;
841
- // Check for G2 external service
842
- const serviceQuery = space.services({ field: 'external_service_name', value: 'G2' });
843
- if (!!serviceQuery && serviceQuery.length) {
844
- externalValues = await (0, g2_1.getG2ProductExternalValues)(sku, serviceQuery[0], space, org);
845
- }
846
- return externalValues;
847
- };
1
+ "use strict";
2
+ /**
3
+ * Products class.
4
+ *
5
+ * @link ecomm.gitngin.com/wiki/models/products
6
+ * @file This files defines the Product class.
7
+ * @author Alexandre Hébert-Vincent.
8
+ * @since 01-01-2020
9
+ */
10
+ var __rest = (this && this.__rest) || function (s, e) {
11
+ var t = {};
12
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
13
+ t[p] = s[p];
14
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
15
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
16
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
17
+ t[p[i]] = s[p[i]];
18
+ }
19
+ return t;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ var _b;
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const Product_1 = require("../../Interfaces/Indexed/Product");
27
+ const lodash_1 = require("lodash");
28
+ const file_1 = require("../../utils/file");
29
+ const context_1 = require("../../utils/context");
30
+ const console_1 = require("../../utils/console");
31
+ const currency_1 = require("../../utils/currency");
32
+ const object_1 = require("../../utils/object");
33
+ const services_1 = require("../../utils/services");
34
+ const locale_1 = require("../../utils/locale");
35
+ const algolia_1 = require("../../utils/algolia");
36
+ const __1 = require("../..");
37
+ const MarketplacePublication_1 = __importDefault(require("../MarketplacePublication"));
38
+ const ProductAttribute_1 = __importDefault(require("../ProductAttribute"));
39
+ const Product_2 = __importDefault(require("../Indexed/Product"));
40
+ const Declination_1 = __importDefault(require("../Declination"));
41
+ const Category_1 = __importDefault(require("../Category"));
42
+ const Discount_1 = __importDefault(require("../Discount"));
43
+ const moment_1 = __importDefault(require("moment"));
44
+ const Brand_1 = __importDefault(require("../Brand"));
45
+ const Space_1 = __importDefault(require("../Space"));
46
+ const g2_1 = require("../../rules/GR/utils/g2");
47
+ const baseService_1 = require("../baseService");
48
+ const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
49
+ //#endregion
50
+ /**
51
+ * Product class
52
+ */
53
+ class Product extends baseService_1.BaseServiceClass {
54
+ constructor() {
55
+ //#region STATIC
56
+ super(...arguments);
57
+ //#endregion
58
+ /**
59
+ * Get the product properties
60
+ */
61
+ this.data = () => this._data;
62
+ this.toCSV = () => {
63
+ return Object.assign(Object.assign({}, this.data()), { product_attributes: !!this.data().product_attributes
64
+ ? this.data().product_attributes.map((pa) => pa.attribute_id)
65
+ : undefined, declinations: !!this.data().declinations
66
+ ? this.data().declinations.map((d) => d.name)
67
+ : undefined, brand: !!this.data().brand ? this.data().brand.key : undefined, classes: !!this.data().classes ? this.data().classes.map((c) => c.key) : undefined, category: !!this.data().category ? this.data().category.key : undefined });
68
+ };
69
+ this.allRelationships = async () => {
70
+ return await this.relationships(['brands']);
71
+ };
72
+ this.getDefaultSupplier = () => {
73
+ const data = this.data();
74
+ if (!!!data.suppliers)
75
+ return undefined;
76
+ const supplier = data.suppliers.filter((supplier) => {
77
+ return supplier.supplier_order == 0;
78
+ })[0];
79
+ return supplier.supplier_id;
80
+ };
81
+ /**
82
+ * Returns complete relationship object mapped by product interface.
83
+ * @param relations Array of strings reprensenting the wanted relationships objects.
84
+ * @returns Partial product IProduct
85
+ */
86
+ this.relationships = async (relations) => {
87
+ if (relations.length === 0)
88
+ return {};
89
+ const relationships = {};
90
+ const _getKeyFromRelationType = (_relation) => {
91
+ switch (_relation) {
92
+ case 'brands':
93
+ default:
94
+ return 'brand';
95
+ }
96
+ };
97
+ for (const relation of relations) {
98
+ if (!!relationships[relation])
99
+ continue;
100
+ if (!!!this._data[_getKeyFromRelationType(relation)])
101
+ continue;
102
+ const relationReq = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), relation), this._data[_getKeyFromRelationType(relation)].key);
103
+ if (!relationReq.exists)
104
+ continue;
105
+ const relationData = relationReq.data;
106
+ if (!!!relationData)
107
+ continue;
108
+ relationships[_getKeyFromRelationType(relation)] = Object.assign(Object.assign({}, relationData), { id: relationReq.id });
109
+ }
110
+ return relationships;
111
+ };
112
+ this.save = async (partialProduct, options) => {
113
+ const beforeData = Object.assign({}, this._data);
114
+ this._data = Object.assign(Object.assign({}, this._data), partialProduct);
115
+ this._data = (await this._updateDependancies(this._data, beforeData, !!options ? options.space : undefined));
116
+ // if (!!!(this._data as IProduct).last_update_by) {
117
+ this._data = Object.assign(Object.assign({}, this._data), { last_update_by: this._user });
118
+ // }
119
+ const id = await super.save(this._data, undefined, true, true, true, beforeData);
120
+ if (!!id && !!!this._data.id && typeof id === 'string') {
121
+ this._data = Object.assign(Object.assign({}, this._data), { id });
122
+ }
123
+ if (!!!options) {
124
+ return true;
125
+ }
126
+ return id;
127
+ };
128
+ this._updateDependancies = async (product, beforeData, space) => {
129
+ (0, console_1.workingMessage)('Updating images and stuff');
130
+ let productToUpdate = product;
131
+ try {
132
+ if (!!!space)
133
+ space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
134
+ const useService = space.preferences.storage.getServiceToUse();
135
+ productToUpdate = await this._uploadDeclinationsImages(productToUpdate, useService);
136
+ productToUpdate = await this._updateSEOImage(productToUpdate, useService);
137
+ productToUpdate = await this._updatePanelDescriptionsImage(productToUpdate, useService);
138
+ productToUpdate = await this._updateDeclinationsDiscountRules(productToUpdate, beforeData);
139
+ productToUpdate = await this._updateBarcode(productToUpdate, space);
140
+ await this._updateInventoryItem(productToUpdate, beforeData, space);
141
+ return productToUpdate;
142
+ }
143
+ catch (error) {
144
+ (0, console_1.errorMessage)(`Error while updating dependancies: ${error} - ${JSON.stringify(error)}`);
145
+ return product;
146
+ }
147
+ };
148
+ this._updateSEOImage = async (product, useService) => {
149
+ return Object.assign(Object.assign({}, product), { seo_info: Object.assign(Object.assign({}, product.seo_info), { seoImage: !!product.seo_info &&
150
+ !!product.seo_info.seoImage &&
151
+ !!product.seo_info.seoImage.img_path &&
152
+ typeof product.seo_info.seoImage.img_path === 'string'
153
+ ? product.seo_info.seoImage
154
+ : {
155
+ img_path: !!product.seo_info && !!product.seo_info.seoImage && !!product.seo_info.seoImage.img_path
156
+ ? await (0, file_1.uploadFileToPath)(useService, product.seo_info.seoImage.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))))
157
+ : ''
158
+ } }) });
159
+ };
160
+ this._updatePanelDescriptionsImage = async (product, useService) => {
161
+ if (!!!product.panel_descriptions || !!!product.panel_descriptions.length)
162
+ return product;
163
+ return Object.assign(Object.assign({}, product), { panel_descriptions: await Promise.all(product.panel_descriptions.map(async (panel) => {
164
+ if (!!!panel.img)
165
+ return panel;
166
+ if (typeof panel.img.img_path === 'string' && !panel.img.img_path.includes('base64'))
167
+ return panel;
168
+ if (typeof panel.img.img_path === 'string')
169
+ return Object.assign(Object.assign({}, panel), { img: Object.assign(Object.assign({}, panel.img), { img_path: await (0, file_1.uploadStringToPath)(useService, panel.img.img_path, (0, context_1.getPathTo)(`products/${product.slug}/panels`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(panel.label_name), 'jpg') }) });
170
+ if (!!panel.img.img_path.file)
171
+ return Object.assign(Object.assign({}, panel), { img: Object.assign(Object.assign({}, panel.img), { img_path: await (0, file_1.uploadFileToPath)(useService, panel.img.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}/panels`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path)))) }) });
172
+ return Object.assign(Object.assign({}, panel), { img: undefined });
173
+ })) });
174
+ };
175
+ this._updateBarcode = async (product, space) => {
176
+ try {
177
+ if (!!!space)
178
+ space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
179
+ if (!!!space.data().product_preferences.generate_barcode)
180
+ return product;
181
+ return Object.assign(Object.assign({}, product), { declinations: await Promise.all((product.declinations || []).map(async (_d) => {
182
+ if (!!_d.upc)
183
+ return _d;
184
+ if (!!!space)
185
+ return _d;
186
+ const upc = space.data().product_preferences.barcode_next;
187
+ await space.save({
188
+ product_preferences: Object.assign(Object.assign({}, space.data().product_preferences), { barcode_next: `${(0, lodash_1.toNumber)(upc) + 1}` })
189
+ });
190
+ return Object.assign(Object.assign({}, _d), { upc });
191
+ })) });
192
+ }
193
+ catch (error) {
194
+ console.log(error);
195
+ return product;
196
+ }
197
+ };
198
+ this._updateInventoryItem = async (product, beforeData, space) => {
199
+ const declis = product.declinations;
200
+ if (!!!declis || !!!declis.length)
201
+ return;
202
+ if (!!!space)
203
+ space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
204
+ // On product save, remove all deletedSkus from inventory
205
+ const allSameProductInventories = await space.inventoryItems.getAllFromSameProduct(!!product.slug ? product.slug : this.data().slug);
206
+ if (!!!allSameProductInventories || !!!allSameProductInventories.length)
207
+ return true;
208
+ // If product is service now, delete all inventoryItems associated
209
+ if (!!beforeData && !!product.is_service && beforeData.is_service !== product.is_service) {
210
+ try {
211
+ for (let inventory of allSameProductInventories) {
212
+ await inventory.delete();
213
+ }
214
+ }
215
+ catch (e) {
216
+ console.log('error on deleting inventories of now service product: ', e);
217
+ }
218
+ return true;
219
+ }
220
+ const allSameProductInventoriesSamples = allSameProductInventories.filter((i) => !!i.data().is_sample);
221
+ const allSameProductInventoriesNotSamples = allSameProductInventories.filter((i) => !!!i.data().is_sample);
222
+ const deletedSkusSamples = allSameProductInventoriesSamples.filter((inventory) => {
223
+ const decliSku = inventory.data().decli_sku_associated_to_sample;
224
+ const foundDecli = declis.find((d) => d.sku === decliSku);
225
+ return !!!foundDecli || !foundDecli.is_sample;
226
+ });
227
+ const deletedSkusNotSamples = allSameProductInventoriesNotSamples.filter((inventory) => !!!declis.some((d) => d.sku === inventory.data().sku) && !!!inventory.data().is_sample);
228
+ const skusToDelete = [...deletedSkusSamples, ...deletedSkusNotSamples];
229
+ if (!!!skusToDelete.length)
230
+ return true;
231
+ try {
232
+ await Promise.all(skusToDelete.map(async (inventory) => {
233
+ await inventory.delete();
234
+ }));
235
+ }
236
+ catch (e) {
237
+ console.log('error on deleting inventories of deleted skus: ', e);
238
+ }
239
+ return true;
240
+ };
241
+ this._updateDeclinationsDiscountRules = async (product, beforeData) => {
242
+ let lastPushedTime = '';
243
+ return Object.assign(Object.assign({}, product), { declinations: !!product.declinations
244
+ ? await Promise.all(product.declinations.map(async (declination, index) => {
245
+ const timestamp = (0, moment_1.default)().toDate().getTime();
246
+ let idString = String(timestamp) + '-' + String(index);
247
+ const duplicateTime = idString === lastPushedTime;
248
+ lastPushedTime = String(timestamp) + '-' + String(index);
249
+ const currentDataDeclis = !!beforeData.declinations ? beforeData.declinations : [];
250
+ const sameInCurrentData = currentDataDeclis.find((d) => !!d && d.sku === declination.sku);
251
+ let discountsToDelete = [];
252
+ if (!!sameInCurrentData) {
253
+ discountsToDelete = (sameInCurrentData.discount_rules || []).filter((d) => !!d &&
254
+ d.discountRule_type === 'tier-pricing' &&
255
+ (!!!declination.discount_rules ||
256
+ !!!declination.discount_rules.length ||
257
+ !!!declination.discount_rules.some((_d) => _d.id === d.id)));
258
+ }
259
+ if (!!duplicateTime) {
260
+ idString =
261
+ idString.split('-')[0] + '-' + String(index + product.declinations.length);
262
+ }
263
+ if (!!discountsToDelete &&
264
+ !!discountsToDelete.length &&
265
+ DatabaseService_1.default.getPathParent(this._collection.path) !== '/') {
266
+ console.log('** Going to delete tier-pricing discount_rules no longer in declination **');
267
+ for (let discount of discountsToDelete) {
268
+ try {
269
+ const discountObj = new Discount_1.default(discount, {
270
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'discountRules')
271
+ }, this._user);
272
+ await discountObj.delete();
273
+ }
274
+ catch (e) {
275
+ console.log('error on deleting discount: ', e);
276
+ }
277
+ }
278
+ }
279
+ return Object.assign(Object.assign({}, declination), { id: !!declination.id ? declination.id : idString, discount_rules: !!declination.discount_rules && !!declination.discount_rules.length
280
+ ? await Promise.all((0, lodash_1.sortedUniqBy)(declination.discount_rules, (dr) => {
281
+ const rule = !!dr.rules && dr.rules.find((r) => r.field === 'quantity');
282
+ if (!!!rule)
283
+ return false;
284
+ return rule.ruleDetails[0].value[0];
285
+ }).map(async (rule) => {
286
+ if (DatabaseService_1.default.getPathParent(this._collection.path) === '/')
287
+ return rule;
288
+ if (rule.discountRule_type !== 'tier-pricing')
289
+ return rule;
290
+ const _rule = new Discount_1.default(rule, {
291
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'discountRules')
292
+ }, this._user);
293
+ const id = await _rule.save();
294
+ return Object.assign(Object.assign({}, rule), (!!!rule.id && typeof id === 'string' && !!id ? { id: id } : {}));
295
+ }))
296
+ : [] });
297
+ }))
298
+ : [] });
299
+ };
300
+ this._uploadDeclinationsImages = async (product, useService) => {
301
+ return Object.assign(Object.assign({}, product), { image_files: !!!product.image_files || !!!product.image_files.length
302
+ ? []
303
+ : await Promise.all(product.image_files
304
+ .filter((i) => !!i && !!i.img_path)
305
+ .map(async (imageInfo) => {
306
+ // If img_path is of type { dataURL: ... }
307
+ if (!!imageInfo.img_path.dataURL && !!!imageInfo.img_path.file) {
308
+ if (typeof imageInfo.img_path.dataURL === 'string' &&
309
+ !!imageInfo.img_path.dataURL.includes('base64')) {
310
+ return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(useService, imageInfo.img_path.dataURL, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(product.name), imageInfo.img_path.dataURL.split(';')[0].split('/')[1])) });
311
+ }
312
+ else {
313
+ return Object.assign(Object.assign({}, imageInfo), { img_path: imageInfo.img_path.dataURL });
314
+ }
315
+ }
316
+ // If img_path is of type string
317
+ if (typeof imageInfo.img_path === 'string') {
318
+ if (!!imageInfo.img_path.includes('base64')) {
319
+ return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(useService, imageInfo.img_path, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(product.name), imageInfo.img_path.split(';')[0].split('/')[1])) });
320
+ }
321
+ else {
322
+ return imageInfo;
323
+ }
324
+ }
325
+ // If img_path is of type { file: ... }
326
+ const img_path = await (0, file_1.uploadFileToPath)(useService, imageInfo.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))));
327
+ return Object.assign(Object.assign({}, imageInfo), { img_path: img_path });
328
+ })), declinations: !!!product.declinations || !!!product.declinations.length
329
+ ? []
330
+ : await Promise.all(product.declinations.map(async (declination) => {
331
+ if (!!!declination.image_files)
332
+ return declination;
333
+ if (!!!declination.image_files.length)
334
+ return declination;
335
+ if (!!!declination.image_files.find((imageInfo) => !!imageInfo.img_path && !!imageInfo.img_path.file))
336
+ return declination;
337
+ return Object.assign(Object.assign({}, declination), { image_files: await Promise.all(declination.image_files
338
+ .filter((i) => !!i && !!i.img_path)
339
+ .map(async (imageInfo) => {
340
+ if (typeof imageInfo.img_path === 'string') {
341
+ if (!!imageInfo.img_path.includes('base64')) {
342
+ return Object.assign(Object.assign({}, imageInfo), { img_path: (await (0, file_1.uploadStringToPath)(imageInfo.img_path, (0, context_1.getPathTo)(`brands/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path))), (0, locale_1.getPrincipalWord)(declination.name), imageInfo.img_path.split(';')[0].split('/')[1])) });
343
+ }
344
+ else {
345
+ return imageInfo;
346
+ }
347
+ }
348
+ const img_path = (await (0, file_1.uploadFileToPath)(useService, imageInfo.img_path.file, (0, context_1.getPathTo)(`products/${product.slug}`, (0, context_1.getIdsBasedOnSpaceDocRef)(DatabaseService_1.default.getPathParent(this._collection.path)))));
349
+ return Object.assign(Object.assign({}, imageInfo), { img_path });
350
+ })) });
351
+ })) });
352
+ };
353
+ //#region ATTRIBUTES
354
+ this._getAttributes = () => {
355
+ try {
356
+ if (!!!this.data().product_attributes || !!!this._data.id)
357
+ return [];
358
+ return this.data().product_attributes.map((d) => new ProductAttribute_1.default(d, DatabaseService_1.default.addToPath(DatabaseService_1.default.addToPath(this._collection.path, this._data.id), 'attributes'), this._user));
359
+ }
360
+ catch (err) {
361
+ throw new Error(`Error while getting attributes: ${err}`);
362
+ }
363
+ };
364
+ this._addAttribute = async (productAttribute) => {
365
+ const pas = !!this.data().product_attributes ? this.data().product_attributes : [];
366
+ const existingPA = pas.find((a) => a.attribute_id === productAttribute.attribute_id);
367
+ if (!!existingPA) {
368
+ const _attributes = pas.map((pa) => {
369
+ if (pa.id !== existingPA.id)
370
+ return pa;
371
+ return Object.assign(Object.assign({}, pa), productAttribute);
372
+ });
373
+ return await this.save({ product_attributes: _attributes });
374
+ }
375
+ return await this.save({
376
+ product_attributes: [...pas, productAttribute]
377
+ });
378
+ };
379
+ //#endregion
380
+ //#region CATEGORIES
381
+ this._getCategory = async () => {
382
+ if (!!!this._data.category)
383
+ throw new Error(`Product categoy is not yet defined`);
384
+ try {
385
+ const categorySnap = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'categories'), this._data.category);
386
+ if (!!!categorySnap)
387
+ throw new Error(`Inexisting category`);
388
+ if (!categorySnap.exists)
389
+ throw new Error(`Impossible to retreive the category`);
390
+ if (!!!categorySnap.data)
391
+ throw new Error(`Impossible te retreive the category data`);
392
+ return new Category_1.default(Object.assign(Object.assign({}, categorySnap.data), { id: categorySnap.id }), {
393
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'categories')
394
+ }, this._user);
395
+ }
396
+ catch (err) {
397
+ throw new Error(`Error while getting categories: ${err}`);
398
+ }
399
+ };
400
+ //#endregion
401
+ //#region BRANDS
402
+ this._getBrand = async () => {
403
+ if (!!!this._data.brand)
404
+ return undefined;
405
+ try {
406
+ const brandSnap = await DatabaseService_1.default.getDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'brands'), this._data.brand);
407
+ if (!!!brandSnap)
408
+ throw new Error(`Inexisting brand`);
409
+ if (!brandSnap.exists)
410
+ throw new Error(`Impossible to retreive the brand`);
411
+ if (!!!brandSnap.data)
412
+ throw new Error(`Impossible te retreive the brand data`);
413
+ return new Brand_1.default(Object.assign(Object.assign({}, brandSnap.data), { id: brandSnap.id }), {
414
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'brands')
415
+ }, this._user);
416
+ }
417
+ catch (err) {
418
+ throw new Error(`Error while getting brands: ${err}`);
419
+ }
420
+ };
421
+ //#endregion
422
+ //#region DECLINATIONS
423
+ this._getDeclinations = () => {
424
+ if (!!!this._data.id)
425
+ throw new Error(`Product must be saved to create declinations.`);
426
+ const declinationCollectionRef = DatabaseService_1.default.addToPath(DatabaseService_1.default.addToPath(this._collection.path, this._data.id), 'declinations');
427
+ if (!!!this.data().declinations)
428
+ return [];
429
+ return this.data().declinations.map((d) => new Declination_1.default(d, declinationCollectionRef, this._user));
430
+ };
431
+ this._addDeclination = async (declination) => {
432
+ if (!!!this._data.id)
433
+ throw new Error(`Product must be saved to create declinations.`);
434
+ if (!!!this.data().declinations)
435
+ return;
436
+ return this.save({
437
+ declinations: [...this.data().declinations, declination]
438
+ });
439
+ };
440
+ this._saveIndex = async (category) => {
441
+ if (!!!this._data.id)
442
+ throw new Error('Product must be saved first.');
443
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
444
+ throw new Error('BD badly initialised. Products collection must have a parent.');
445
+ let brand = undefined;
446
+ const declinations = this.data().declinations;
447
+ if (!!!declinations) {
448
+ console.log(`No declinations to update`);
449
+ return true;
450
+ }
451
+ try {
452
+ if (!!!category && !!!this.data().is_service) {
453
+ category = await this.category.get();
454
+ if (!!!category)
455
+ throw new Error(`A category must be set`);
456
+ }
457
+ if (!!this._data.brand) {
458
+ try {
459
+ brand = await this.brand.get();
460
+ }
461
+ catch (e) {
462
+ console.log('could not fetch brand with id ', this._data.brand, ': ', e.toString());
463
+ }
464
+ }
465
+ const tree = !!category ? await category.getParentTree() : [];
466
+ const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
467
+ await space.initCurrencies();
468
+ const indexed = await (0, Product_1.populateIndexedProduct)(this.data(), tree, space, category, brand);
469
+ console.log('index is created');
470
+ await DatabaseService_1.default.saveDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), this._data.id, (0, moment_1.default)().unix(), (0, object_1.stripObjectForFirebase)(Object.assign(Object.assign({}, indexed), { declinations: indexed.declinations.map((declination) => {
471
+ if (!!declination.promo_price || typeof declination.promo_price !== 'boolean')
472
+ return declination;
473
+ const { promo_price } = declination, rest = __rest(declination, ["promo_price"]);
474
+ return Object.assign({}, rest);
475
+ }) })), { merge: true });
476
+ return true;
477
+ }
478
+ catch (error) {
479
+ console.log(`error while indexing`, error.toString());
480
+ console.trace(`indexing error trace`);
481
+ throw error;
482
+ }
483
+ };
484
+ this._getIndex = async () => {
485
+ if (!!!this._data.id)
486
+ throw new Error(`Product has never been saved`);
487
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
488
+ throw new Error(`Can't access indexes collection`);
489
+ const indexedProductsDocs = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), { query: [{ field: 'product_id', operator: '==', value: this._data.id }] });
490
+ return await Promise.all(indexedProductsDocs
491
+ .filter((d) => !!d.exists && !!d.data)
492
+ .map((doc) => {
493
+ return new Product_2.default(Object.assign(Object.assign({}, doc.data), { id: doc.id }), {
494
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public')
495
+ }, this._user);
496
+ }));
497
+ };
498
+ this._deleteIndex = async () => {
499
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
500
+ throw new Error(`Can't access parent collection`);
501
+ try {
502
+ if (!!!this._data.id)
503
+ throw new Error('No id for selected product');
504
+ await DatabaseService_1.default.deleteDocument(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'indexes/products/public'), this._data.id);
505
+ }
506
+ catch (error) {
507
+ throw error;
508
+ }
509
+ };
510
+ //#endregion
511
+ this.callPublicService = async (service, fromServer = false) => {
512
+ const requestHeader = (0, services_1.productServiceUrl)(Object.assign({}, service.external_service_infos), service.external_service_name);
513
+ if (!!!requestHeader)
514
+ throw new Error(`Can't access service provider. Please validate your external services configuration`);
515
+ const { url, type: method } = requestHeader;
516
+ try {
517
+ const quoteReq = await fetch(!!fromServer ? `${url}&q=${this.data().name[0].value}` : '/api/services/cors', {
518
+ headers: { 'content-type': 'application/json' },
519
+ method: !!fromServer ? method : 'POST',
520
+ body: JSON.stringify({
521
+ props: { method, headers: { 'content-type': 'application/json' } },
522
+ url: `${url}&q=${this.data().name[0].value}`
523
+ })
524
+ });
525
+ if (quoteReq.status.toString() !== '200')
526
+ throw new Error(`Error while getting service: ${quoteReq.statusText}`);
527
+ const details = await quoteReq.json();
528
+ return { confirmed: true, details };
529
+ }
530
+ catch (error) {
531
+ (0, console_1.errorMessage)(`Error while calling order service ${error} - ${JSON.stringify(error)}`);
532
+ return { confirmed: false, error };
533
+ }
534
+ };
535
+ this._updateAllDeclinationsPrice = async (pricingMapFromExternalOrCustom, attributes, saveToDatabase = true, updateRegular = true, spaceToUse) => {
536
+ try {
537
+ const space = !!spaceToUse ? spaceToUse : await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
538
+ const spacePrice = this.adaptPriceChartingValues(pricingMapFromExternalOrCustom, space);
539
+ const declinations = this.data().declinations;
540
+ if (!!!declinations)
541
+ return false;
542
+ const declinationsWithAttributeLinkedToService = declinations.filter((d) => !!d.attributes.find((pa) => {
543
+ const attr = attributes.find((_a) => _a.id === pa.attribute_id);
544
+ if (!!!attr)
545
+ return false;
546
+ if (!!!attr.is_service_related)
547
+ return false;
548
+ if (!!!attr.service_links_to_attribute)
549
+ return false;
550
+ return true;
551
+ }));
552
+ if (!!!declinationsWithAttributeLinkedToService.length)
553
+ return false;
554
+ for (const declinationToUpdate of declinationsWithAttributeLinkedToService) {
555
+ const relationProductAttribute = declinationToUpdate.attributes.find((pa) => {
556
+ const attr = attributes.find((_a) => _a.id === pa.attribute_id);
557
+ if (!!!attr)
558
+ return false;
559
+ if (!!!attr.is_service_related)
560
+ return false;
561
+ return true;
562
+ });
563
+ if (!!!relationProductAttribute)
564
+ continue;
565
+ const relationAttribute = attributes.find((a) => a.id === relationProductAttribute.attribute_id);
566
+ if (!!!relationAttribute)
567
+ continue;
568
+ if (!!!relationAttribute.service_links_to_attribute)
569
+ continue;
570
+ const propsToLink = relationAttribute.service_links_to_attribute.find((slta) => slta.value_slugs.find((vs) => !!relationProductAttribute.values.find((value) => value.slug === vs.slug)));
571
+ if (!!!propsToLink)
572
+ continue;
573
+ if (!!!spacePrice[propsToLink.service_field])
574
+ continue;
575
+ let price = (0, lodash_1.toNumber)(spacePrice[propsToLink.service_field]) / 100;
576
+ const priceDetails = propsToLink.value_slugs.find((vs) => !!relationProductAttribute.values.find((value) => value.slug === vs.slug));
577
+ if (!!priceDetails) {
578
+ if (!!priceDetails.percent_variation) {
579
+ price = price * (1 + priceDetails.percent_variation / 100);
580
+ }
581
+ }
582
+ const _declinations = declinations.map((declination) => {
583
+ if (declination.sku !== declinationToUpdate.sku)
584
+ return declination;
585
+ return Object.assign(Object.assign({}, declination), { price: Object.assign(Object.assign(Object.assign({}, declination.price), { pdsf: { amount: (0, lodash_1.toNumber)(price) } }), (!!updateRegular
586
+ ? {
587
+ regular: {
588
+ amount: (0, lodash_1.ceil)((0, lodash_1.toNumber)(price)) - 0.01 >= (0, lodash_1.toNumber)(declination.price.regular.amount)
589
+ ? (0, lodash_1.ceil)((0, lodash_1.toNumber)(price)) - 0.01
590
+ : (0, lodash_1.toNumber)(declination.price.regular.amount)
591
+ }
592
+ }
593
+ : {})) });
594
+ });
595
+ if (!!!saveToDatabase)
596
+ return {
597
+ declinations: _declinations,
598
+ services: { price_charting: spacePrice }
599
+ };
600
+ await this.save({
601
+ declinations: _declinations
602
+ }, { index: true });
603
+ }
604
+ await this.save({
605
+ services: Object.assign(Object.assign({}, this.data().services), { price_charting: spacePrice })
606
+ });
607
+ return true;
608
+ }
609
+ catch (error) {
610
+ if (process.env.NODE_ENV !== 'production')
611
+ console.log(error);
612
+ return false;
613
+ }
614
+ };
615
+ this.adaptPriceChartingValues = (pricingMap, space) => {
616
+ let returnValue = {};
617
+ (0, lodash_1.forEach)(pricingMap, (val, key) => {
618
+ if (['loose-price', 'cib-price', 'loose-price', 'box-only-price', 'manual-only-price', 'new-price'].includes(key)) {
619
+ returnValue[key] = (0, currency_1.calculateAmountByCurrency)(space, space.preferences.default.currency(), (0, lodash_1.toNumber)(val), 'USD');
620
+ return;
621
+ }
622
+ });
623
+ return Object.assign(Object.assign({}, pricingMap), returnValue);
624
+ };
625
+ this._updateAllDeclinationsPriceAsync = async (pricingMapFromExternalOrCustom) => {
626
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
627
+ throw new Error(`Can't fetch attributes`);
628
+ try {
629
+ const attributesRes = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'attributes'));
630
+ const attributes = attributesRes
631
+ .filter((d) => !!d.exists && !!d.data)
632
+ .map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id })));
633
+ return await this._updateAllDeclinationsPrice(pricingMapFromExternalOrCustom, attributes);
634
+ }
635
+ catch (error) {
636
+ (0, console_1.errorMessage)(`Error while fetching price and attributes`);
637
+ return [];
638
+ }
639
+ };
640
+ this._getMarketplacePublications = async (options) => {
641
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
642
+ throw new Error(`Can't fetch marketplace publications`);
643
+ try {
644
+ let publications = await DatabaseService_1.default.getDocuments(DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), options);
645
+ return publications.map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id })));
646
+ }
647
+ catch (error) {
648
+ (0, console_1.errorMessage)(`Error while fetching marketplace publications`);
649
+ return [];
650
+ }
651
+ };
652
+ this._marketplacePublicationsListner = (callback, options) => {
653
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
654
+ throw new Error(`Can't fetch marketplace publications`);
655
+ try {
656
+ let call = DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications');
657
+ return DatabaseService_1.default.registerListener((dataSnap) => {
658
+ if (!!!dataSnap.length)
659
+ callback([]);
660
+ (0, console_1.workingMessage)(`Marketplace publications has been udpated. Refreshing...`);
661
+ callback(dataSnap.map((d) => (Object.assign(Object.assign({}, d.data), { id: d.id }))));
662
+ }, call, !!options ? options : { query: [{ field: 'parent_slug', operator: '==', value: this._data.slug }] });
663
+ }
664
+ catch (error) {
665
+ (0, console_1.errorMessage)(`Error while listening marketplace publications`);
666
+ return '';
667
+ }
668
+ };
669
+ this._createNewPublication = async (sku, marketplacePublication, space) => {
670
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
671
+ throw new Error(`Can't fetch marketplace publications`);
672
+ try {
673
+ const productInvetory = await space.inventoryItems.getOne(sku);
674
+ if (!!!productInvetory || !!!productInvetory.web_inventory)
675
+ throw new Error(`Can't find inventory item with sku: ${sku}`);
676
+ if (!!!productInvetory.web_inventory.available)
677
+ throw new Error(`Inventory item with sku: ${sku} is not available`);
678
+ if (marketplacePublication.quantity < 1)
679
+ throw new Error(`No quantity available`);
680
+ if ((0, lodash_1.toNumber)(productInvetory.web_inventory.available) < 1)
681
+ throw new Error(`No quantity available`);
682
+ if ((0, lodash_1.toNumber)(productInvetory.web_inventory.available) < marketplacePublication.quantity)
683
+ throw new Error(`Inventory item with sku: ${sku} is not available`);
684
+ }
685
+ catch (error) {
686
+ (0, console_1.errorMessage)(`Error while fetching inventory item with sku: ${sku}`);
687
+ return false;
688
+ }
689
+ try {
690
+ const newMarketplacePublication = new MarketplacePublication_1.default(Object.assign(Object.assign({}, marketplacePublication), { sku, parent_slug: this.data().slug, created_at: new Date(), created_by: this._user }), {
691
+ path: DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications')
692
+ }, this._user);
693
+ return await newMarketplacePublication.save();
694
+ }
695
+ catch (error) {
696
+ (0, console_1.errorMessage)(`Error while creating marketplace publications`);
697
+ return false;
698
+ }
699
+ };
700
+ this._updateMarketplacePublication = async (sku, marketplacePublication) => {
701
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
702
+ throw new Error(`Can't update marketplace publications`);
703
+ try {
704
+ const marketplacePublicationObj = await MarketplacePublication_1.default.getMarketplacePublicationObj(sku, DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), this._user);
705
+ if (!!!marketplacePublicationObj)
706
+ throw new Error(`No marketplace publication found`);
707
+ return await marketplacePublicationObj.save(marketplacePublication);
708
+ }
709
+ catch (error) {
710
+ (0, console_1.errorMessage)(`Error while updating marketplace publications`);
711
+ return false;
712
+ }
713
+ };
714
+ this._removeMarketplacePublication = async (publicationId) => {
715
+ if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
716
+ throw new Error(`Can't remove marketplace publications`);
717
+ try {
718
+ const marketplacePublicationObj = await MarketplacePublication_1.default.getMarketplacePublicationObjById(publicationId, DatabaseService_1.default.addToPath(DatabaseService_1.default.getPathParent(this._collection.path), 'marketplace_publications'), this._user);
719
+ if (!!!marketplacePublicationObj)
720
+ throw new Error(`No marketplace publication found`);
721
+ return await marketplacePublicationObj.delete();
722
+ }
723
+ catch (error) {
724
+ (0, console_1.errorMessage)(`Error while deleting marketplace publications`);
725
+ return false;
726
+ }
727
+ };
728
+ this._updateAllDeclinationsPriceUsingCategoryRules = async (basePrices, attributeVariationId, defaultVariation, options = {}) => {
729
+ if (!!!this._data.category || !this._data.declinations || !this._data.id)
730
+ return false;
731
+ if (basePrices.length == 0)
732
+ return false;
733
+ if (!!this._data.disable_price_auto_update)
734
+ return false;
735
+ // get category
736
+ const cat = await this.category.get();
737
+ let hasUpdate = false;
738
+ const newDecli = this._data.declinations.map((d) => {
739
+ var _c;
740
+ const basePrice = (_c = basePrices.find((x) => d.attributes.some((a) => a.attribute_id.toLowerCase() == attributeVariationId.toLowerCase() &&
741
+ a.values.some((v) => v.slug.toLowerCase() == x.variation.toLowerCase())))) !== null && _c !== void 0 ? _c : basePrices.find((x) => x.variation.toLowerCase() == defaultVariation.toLowerCase());
742
+ if (!basePrice)
743
+ return d; // if no price found dont update
744
+ const newPrice = cat.costPriceRule(basePrice.price, d, 'sell');
745
+ if (newPrice == d.price.regular.amount)
746
+ return d;
747
+ hasUpdate = true;
748
+ return Object.assign(Object.assign({}, d), { price: Object.assign(Object.assign({}, d.price), { regular: { amount: newPrice }, pdsf: { amount: basePrice.price } }) });
749
+ });
750
+ if (hasUpdate) {
751
+ this._data = Object.assign(Object.assign({}, this._data), { declinations: newDecli });
752
+ if (options && !!options.saveToDatabase) {
753
+ await DatabaseService_1.default.saveDocument(this._collection.path, this._data.id, 0, { declinations: newDecli }, { merge: true, noEvent: options.noEvent });
754
+ }
755
+ }
756
+ return hasUpdate;
757
+ };
758
+ //#region GETTERS
759
+ this.attributes = {
760
+ get: this._getAttributes,
761
+ add: this._addAttribute
762
+ };
763
+ this.brand = {
764
+ get: this._getBrand
765
+ };
766
+ this.category = {
767
+ get: this._getCategory
768
+ };
769
+ this.publications = {
770
+ get: this._getMarketplacePublications,
771
+ listen: this._marketplacePublicationsListner,
772
+ update: this._updateMarketplacePublication,
773
+ create: this._createNewPublication,
774
+ remove: this._removeMarketplacePublication
775
+ };
776
+ this.declinations = {
777
+ get: this._getDeclinations,
778
+ add: this._addDeclination,
779
+ update: {
780
+ // SDC only
781
+ priceSync: this._updateAllDeclinationsPrice,
782
+ priceAsync: this._updateAllDeclinationsPriceAsync,
783
+ // New system
784
+ byCategoryRules: this._updateAllDeclinationsPriceUsingCategoryRules
785
+ }
786
+ // Automatic declinations
787
+ // create: this._createDeclinations
788
+ };
789
+ this.index = {
790
+ save: this._saveIndex,
791
+ get: this._getIndex,
792
+ delete: this._deleteIndex
793
+ };
794
+ //#endregion
795
+ }
796
+ }
797
+ exports.default = Product;
798
+ _b = Product;
799
+ Product.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'products', f = '', space, useProspr = false }) => {
800
+ try {
801
+ let prosprSearch = false;
802
+ if (!!space) {
803
+ const prosprService = space
804
+ .data()
805
+ .external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
806
+ prosprSearch = !!prosprService && prosprService.is_active;
807
+ }
808
+ const algolia = (0, algolia_1.createClient)({
809
+ app,
810
+ indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
811
+ key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
812
+ prospr: !!prosprSearch || !!useProspr
813
+ });
814
+ const results = await algolia.search(query, {
815
+ hitsPerPage: hpp,
816
+ facetFilters: filters,
817
+ filters: f,
818
+ page,
819
+ // facetingAfterDistinct: true,
820
+ facets: ['*']
821
+ });
822
+ return results;
823
+ }
824
+ catch (error) {
825
+ (0, console_1.errorMessage)(error);
826
+ throw error;
827
+ }
828
+ };
829
+ //#endregion
830
+ //#region EXTERNAL VALUES
831
+ /**
832
+ * Checks for external values from external services for a sku.
833
+ * Available services checked (as of now) : G2.
834
+ * @param space
835
+ * @param sku
836
+ */
837
+ Product.checkExternalValuesForDecli = async (sku, space, org) => {
838
+ if (!!!space)
839
+ return;
840
+ let externalValues = undefined;
841
+ // Check for G2 external service
842
+ const serviceQuery = space.services({ field: 'external_service_name', value: 'G2' });
843
+ if (!!serviceQuery && serviceQuery.length) {
844
+ externalValues = await (0, g2_1.getG2ProductExternalValues)(sku, serviceQuery[0], space, org);
845
+ }
846
+ return externalValues;
847
+ };
848
848
  //# sourceMappingURL=index.js.map