addio-admin-sdk 1.7.143 → 1.7.144
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.
- package/.babelrc +17 -17
- package/.env.dev +14 -14
- package/.github/workflows/run_unit_test.yaml +48 -48
- package/addio-sdk-doc.md +1473 -1473
- package/changelog.md +564 -564
- package/dist/Interfaces/Address/index.d.ts +21 -21
- package/dist/Interfaces/Address/index.js +16 -16
- package/dist/Interfaces/Algolia/index.d.ts +177 -177
- package/dist/Interfaces/Algolia/index.js +2 -2
- package/dist/Interfaces/Attachement/index.d.ts +5 -5
- package/dist/Interfaces/Attachement/index.js +2 -2
- package/dist/Interfaces/Attribute/index.d.ts +53 -53
- package/dist/Interfaces/Attribute/index.js +10 -10
- package/dist/Interfaces/BGJob/index.d.ts +56 -56
- package/dist/Interfaces/BGJob/index.js +25 -25
- package/dist/Interfaces/BaseClass/index.d.ts +8 -8
- package/dist/Interfaces/BaseClass/index.js +2 -2
- package/dist/Interfaces/Blog/IBlogArticle.d.ts +18 -18
- package/dist/Interfaces/Blog/IBlogArticle.js +2 -2
- package/dist/Interfaces/Blog/IBlogAuthor.d.ts +7 -7
- package/dist/Interfaces/Blog/IBlogAuthor.js +2 -2
- package/dist/Interfaces/Blog/IBlogCategory.d.ts +9 -9
- package/dist/Interfaces/Blog/IBlogCategory.js +2 -2
- package/dist/Interfaces/Blog/IBlogComment.d.ts +13 -13
- package/dist/Interfaces/Blog/IBlogComment.js +2 -2
- package/dist/Interfaces/Blog/IBlogKeywords.d.ts +9 -9
- package/dist/Interfaces/Blog/IBlogKeywords.js +2 -2
- package/dist/Interfaces/Booking/index.d.ts +74 -74
- package/dist/Interfaces/Booking/index.js +17 -17
- package/dist/Interfaces/Brand/index.d.ts +15 -15
- package/dist/Interfaces/Brand/index.js +2 -2
- package/dist/Interfaces/CMS/index.d.ts +28 -28
- package/dist/Interfaces/CMS/index.js +5 -5
- package/dist/Interfaces/Cart/IElavonPayload.d.ts +93 -93
- package/dist/Interfaces/Cart/IElavonPayload.js +17 -17
- package/dist/Interfaces/Cart/IPandaPayload.d.ts +64 -64
- package/dist/Interfaces/Cart/IPandaPayload.js +18 -18
- package/dist/Interfaces/Cart/IPaymentCard.d.ts +22 -22
- package/dist/Interfaces/Cart/IPaymentCard.js +44 -44
- package/dist/Interfaces/Cart/IPaypalPayload.d.ts +9 -9
- package/dist/Interfaces/Cart/IPaypalPayload.js +2 -2
- package/dist/Interfaces/Cart/IPaysafePayload.d.ts +72 -72
- package/dist/Interfaces/Cart/IPaysafePayload.js +2 -2
- package/dist/Interfaces/Cart/IStripePayload.d.ts +66 -66
- package/dist/Interfaces/Cart/IStripePayload.js +2 -2
- package/dist/Interfaces/Cart/index.d.ts +444 -439
- package/dist/Interfaces/Cart/index.js +197 -197
- package/dist/Interfaces/Cart/index.js.map +1 -1
- package/dist/Interfaces/CartReservedQuantities/index.d.ts +10 -10
- package/dist/Interfaces/CartReservedQuantities/index.js +2 -2
- package/dist/Interfaces/CashDrawers/index.d.ts +37 -37
- package/dist/Interfaces/CashDrawers/index.js +19 -19
- package/dist/Interfaces/Catalogue/index.d.ts +68 -68
- package/dist/Interfaces/Catalogue/index.js +37 -37
- package/dist/Interfaces/Category/index.d.ts +33 -33
- package/dist/Interfaces/Category/index.js +2 -2
- package/dist/Interfaces/Chart/index.d.ts +11 -11
- package/dist/Interfaces/Chart/index.js +2 -2
- package/dist/Interfaces/Class/index.d.ts +8 -8
- package/dist/Interfaces/Class/index.js +2 -2
- package/dist/Interfaces/Consent/index.d.ts +6 -6
- package/dist/Interfaces/Consent/index.js +2 -2
- package/dist/Interfaces/Context/IContextProps.d.ts +4 -4
- package/dist/Interfaces/Context/IContextProps.js +2 -2
- package/dist/Interfaces/Context/IContextState.d.ts +15 -15
- package/dist/Interfaces/Context/IContextState.js +2 -2
- package/dist/Interfaces/Customer/ICustomerBadge.d.ts +2 -2
- package/dist/Interfaces/Customer/ICustomerBadge.js +2 -2
- package/dist/Interfaces/Customer/ICustomerRating.d.ts +10 -10
- package/dist/Interfaces/Customer/ICustomerRating.js +2 -2
- package/dist/Interfaces/Customer/IStoreCredit.d.ts +13 -13
- package/dist/Interfaces/Customer/IStoreCredit.js +2 -2
- package/dist/Interfaces/Customer/index.d.ts +104 -104
- package/dist/Interfaces/Customer/index.js +148 -148
- package/dist/Interfaces/Declination/index.d.ts +117 -114
- package/dist/Interfaces/Declination/index.js +66 -66
- package/dist/Interfaces/Declination/index.js.map +1 -1
- package/dist/Interfaces/Document/index.d.ts +8 -8
- package/dist/Interfaces/Document/index.js +2 -2
- package/dist/Interfaces/Elastic/index.d.ts +89 -89
- package/dist/Interfaces/Elastic/index.js +2 -2
- package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.d.ts +11 -11
- package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.d.ts +15 -15
- package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.d.ts +12 -12
- package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.d.ts +36 -36
- package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.d.ts +12 -12
- package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/ITransportEmail.d.ts +12 -12
- package/dist/Interfaces/Email/CustomGR/ITransportEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.d.ts +12 -12
- package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.d.ts +16 -16
- package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.js +2 -2
- package/dist/Interfaces/Email/CustomGR/IWishlistEmail.d.ts +15 -15
- package/dist/Interfaces/Email/CustomGR/IWishlistEmail.js +2 -2
- package/dist/Interfaces/Email/IAbandonnedCartEmail.d.ts +29 -29
- package/dist/Interfaces/Email/IAbandonnedCartEmail.js +2 -2
- package/dist/Interfaces/Email/IAccountConfirmationEmail.d.ts +22 -22
- package/dist/Interfaces/Email/IAccountConfirmationEmail.js +2 -2
- package/dist/Interfaces/Email/IApplicationEmail.d.ts +19 -19
- package/dist/Interfaces/Email/IApplicationEmail.js +2 -2
- package/dist/Interfaces/Email/IBackInStockEmail.d.ts +21 -21
- package/dist/Interfaces/Email/IBackInStockEmail.js +2 -2
- package/dist/Interfaces/Email/IContactEmail.d.ts +20 -20
- package/dist/Interfaces/Email/IContactEmail.js +2 -2
- package/dist/Interfaces/Email/ICustomerBookingAdminEmail.d.ts +15 -15
- package/dist/Interfaces/Email/ICustomerBookingAdminEmail.js +2 -2
- package/dist/Interfaces/Email/ICustomerBookingEmail.d.ts +14 -14
- package/dist/Interfaces/Email/ICustomerBookingEmail.js +2 -2
- package/dist/Interfaces/Email/IEmail.d.ts +20 -20
- package/dist/Interfaces/Email/IEmail.js +60 -60
- package/dist/Interfaces/Email/IOrderConfirmationEmail.d.ts +47 -47
- package/dist/Interfaces/Email/IOrderConfirmationEmail.js +2 -2
- package/dist/Interfaces/Email/IPasswordResetEmail.d.ts +17 -17
- package/dist/Interfaces/Email/IPasswordResetEmail.js +2 -2
- package/dist/Interfaces/Email/IPhotoShootEmail.d.ts +14 -14
- package/dist/Interfaces/Email/IPhotoShootEmail.js +2 -2
- package/dist/Interfaces/Email/IPickupConfirmation.d.ts +23 -23
- package/dist/Interfaces/Email/IPickupConfirmation.js +2 -2
- package/dist/Interfaces/Email/IShippingConfirmation.d.ts +23 -23
- package/dist/Interfaces/Email/IShippingConfirmation.js +2 -2
- package/dist/Interfaces/Email/IWelcomeEmail.d.ts +19 -19
- package/dist/Interfaces/Email/IWelcomeEmail.js +2 -2
- package/dist/Interfaces/ExportSchema/index.d.ts +7 -7
- package/dist/Interfaces/ExportSchema/index.js +2 -2
- package/dist/Interfaces/ExternalService/BaseExternalService.d.ts +12 -12
- package/dist/Interfaces/ExternalService/BaseExternalService.js +2 -2
- package/dist/Interfaces/ExternalService/ExternalProductsService.d.ts +4 -4
- package/dist/Interfaces/ExternalService/ExternalProductsService.js +2 -2
- package/dist/Interfaces/ExternalService/index.d.ts +9 -9
- package/dist/Interfaces/ExternalService/index.js +2 -2
- package/dist/Interfaces/FirstOrderTracking/index.d.ts +5 -5
- package/dist/Interfaces/FirstOrderTracking/index.js +2 -2
- package/dist/Interfaces/G2/index.d.ts +556 -556
- package/dist/Interfaces/G2/index.js +38 -38
- package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.d.ts +20 -20
- package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.js +2 -2
- package/dist/Interfaces/Indexed/Product/index.d.ts +105 -103
- package/dist/Interfaces/Indexed/Product/index.js +253 -253
- package/dist/Interfaces/Indexed/Product/index.js.map +1 -1
- package/dist/Interfaces/Inventory/index.d.ts +19 -19
- package/dist/Interfaces/Inventory/index.js +8 -8
- package/dist/Interfaces/Invoice/index.d.ts +4 -4
- package/dist/Interfaces/Invoice/index.js +2 -2
- package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.d.ts +3 -3
- package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.js +2 -2
- package/dist/Interfaces/MarketplacePublication/index.d.ts +23 -23
- package/dist/Interfaces/MarketplacePublication/index.js +22 -22
- package/dist/Interfaces/Menu/index.d.ts +40 -40
- package/dist/Interfaces/Menu/index.js +16 -16
- package/dist/Interfaces/Note/index.d.ts +10 -10
- package/dist/Interfaces/Note/index.js +7 -7
- package/dist/Interfaces/Operations/ICreatedBy.d.ts +6 -6
- package/dist/Interfaces/Operations/ICreatedBy.js +2 -2
- package/dist/Interfaces/Operations/IUpdate.d.ts +5 -5
- package/dist/Interfaces/Operations/IUpdate.js +2 -2
- package/dist/Interfaces/Order/index.d.ts +4 -4
- package/dist/Interfaces/Order/index.js +2 -2
- package/dist/Interfaces/Org/IRelUser.d.ts +9 -9
- package/dist/Interfaces/Org/IRelUser.js +2 -2
- package/dist/Interfaces/Org/index.d.ts +29 -29
- package/dist/Interfaces/Org/index.js +12 -12
- package/dist/Interfaces/Payment/index.d.ts +26 -26
- package/dist/Interfaces/Payment/index.js +14 -14
- package/dist/Interfaces/Product/IAttributeFamily.d.ts +6 -6
- package/dist/Interfaces/Product/IAttributeFamily.js +2 -2
- package/dist/Interfaces/Product/IImportProduct.d.ts +42 -42
- package/dist/Interfaces/Product/IImportProduct.js +882 -882
- package/dist/Interfaces/Product/IInventoryItem.d.ts +74 -74
- package/dist/Interfaces/Product/IInventoryItem.js +38 -38
- package/dist/Interfaces/Product/IPricing.d.ts +177 -177
- package/dist/Interfaces/Product/IPricing.js +180 -180
- package/dist/Interfaces/Product/index.d.ts +138 -138
- package/dist/Interfaces/Product/index.js +64 -64
- package/dist/Interfaces/ProductAttribute/index.d.ts +11 -11
- package/dist/Interfaces/ProductAttribute/index.js +2 -2
- package/dist/Interfaces/PromiseToPurchase/BankType.d.ts +41 -41
- package/dist/Interfaces/PromiseToPurchase/BankType.js +41 -41
- package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.d.ts +33 -33
- package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.js +15 -15
- package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.d.ts +19 -19
- package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.js +2 -2
- package/dist/Interfaces/PromiseToPurchase/index.d.ts +50 -50
- package/dist/Interfaces/PromiseToPurchase/index.js +13 -13
- package/dist/Interfaces/PurchaseOrder/index.d.ts +17 -17
- package/dist/Interfaces/PurchaseOrder/index.js +2 -2
- package/dist/Interfaces/Query/IBrandQueryOptions.d.ts +11 -11
- package/dist/Interfaces/Query/IBrandQueryOptions.js +2 -2
- package/dist/Interfaces/Query/ICategoryQueryOptions.d.ts +11 -11
- package/dist/Interfaces/Query/ICategoryQueryOptions.js +2 -2
- package/dist/Interfaces/Query/IProductQueryOptions.d.ts +16 -16
- package/dist/Interfaces/Query/IProductQueryOptions.js +2 -2
- package/dist/Interfaces/Quote/index.d.ts +5 -5
- package/dist/Interfaces/Quote/index.js +2 -2
- package/dist/Interfaces/Refunds/index.d.ts +106 -106
- package/dist/Interfaces/Refunds/index.js +2 -2
- package/dist/Interfaces/Rules/IDiscountRule.d.ts +155 -155
- package/dist/Interfaces/Rules/IDiscountRule.js +114 -114
- package/dist/Interfaces/Schedule/index.d.ts +48 -48
- package/dist/Interfaces/Schedule/index.js +2 -2
- package/dist/Interfaces/Services/IAddServiceResponse.d.ts +4 -4
- package/dist/Interfaces/Services/IAddServiceResponse.js +2 -2
- package/dist/Interfaces/Services/IService.d.ts +16 -16
- package/dist/Interfaces/Services/IService.js +2 -2
- package/dist/Interfaces/Services/IServiceSecret.d.ts +8 -8
- package/dist/Interfaces/Services/IServiceSecret.js +2 -2
- package/dist/Interfaces/Shipping/Shipstation/carriers.d.ts +10 -10
- package/dist/Interfaces/Shipping/Shipstation/carriers.js +2 -2
- package/dist/Interfaces/Shipping/Shipstation/order.d.ts +227 -227
- package/dist/Interfaces/Shipping/Shipstation/order.js +2 -2
- package/dist/Interfaces/Shipping/Shipstation/quote.d.ts +31 -31
- package/dist/Interfaces/Shipping/Shipstation/quote.js +2 -2
- package/dist/Interfaces/Shipping/Shiptime/order.d.ts +54 -54
- package/dist/Interfaces/Shipping/Shiptime/order.js +71 -71
- package/dist/Interfaces/Shipping/Shiptime/quote.d.ts +111 -111
- package/dist/Interfaces/Shipping/Shiptime/quote.js +2 -2
- package/dist/Interfaces/Slider/GR.d.ts +114 -114
- package/dist/Interfaces/Slider/GR.js +271 -271
- package/dist/Interfaces/Slider/index.d.ts +30 -30
- package/dist/Interfaces/Slider/index.js +2 -2
- package/dist/Interfaces/Space/IExternalService.d.ts +53 -52
- package/dist/Interfaces/Space/IExternalService.js +44 -43
- package/dist/Interfaces/Space/IExternalService.js.map +1 -1
- package/dist/Interfaces/Space/IMember.d.ts +16 -16
- package/dist/Interfaces/Space/IMember.js +9 -9
- package/dist/Interfaces/Space/index.d.ts +405 -405
- package/dist/Interfaces/Space/index.js +174 -174
- package/dist/Interfaces/Specials/gr.d.ts +61 -61
- package/dist/Interfaces/Specials/gr.js +2 -2
- package/dist/Interfaces/StockNotification/index.d.ts +7 -7
- package/dist/Interfaces/StockNotification/index.js +2 -2
- package/dist/Interfaces/Store/index.d.ts +63 -63
- package/dist/Interfaces/Store/index.js +27 -27
- package/dist/Interfaces/Supplier/ICommand.d.ts +11 -11
- package/dist/Interfaces/Supplier/ICommand.js +2 -2
- package/dist/Interfaces/Supplier/index.d.ts +36 -36
- package/dist/Interfaces/Supplier/index.js +24 -24
- package/dist/Interfaces/TCG/index.d.ts +161 -161
- package/dist/Interfaces/TCG/index.js +54 -54
- package/dist/Interfaces/Tag/index.d.ts +18 -18
- package/dist/Interfaces/Tag/index.js +2 -2
- package/dist/Interfaces/Tax/index.d.ts +13 -13
- package/dist/Interfaces/Tax/index.js +2 -2
- package/dist/Interfaces/TransferRequest/index.d.ts +103 -103
- package/dist/Interfaces/TransferRequest/index.js +46 -46
- package/dist/Interfaces/Translation/index.d.ts +8 -8
- package/dist/Interfaces/Translation/index.js +5 -5
- package/dist/Interfaces/Update/index.d.ts +10 -10
- package/dist/Interfaces/Update/index.js +2 -2
- package/dist/Interfaces/User/IUser.d.ts +65 -65
- package/dist/Interfaces/User/IUser.js +8 -8
- package/dist/Interfaces/Version/index.d.ts +11 -11
- package/dist/Interfaces/Version/index.js +2 -2
- package/dist/Interfaces/Wishlist/index.d.ts +7 -7
- package/dist/Interfaces/Wishlist/index.js +2 -2
- package/dist/constants/Interfaces/IBaseApi.d.ts +15 -15
- package/dist/constants/Interfaces/IBaseApi.js +2 -2
- package/dist/constants/Interfaces/IEndpointResult.d.ts +9 -9
- package/dist/constants/Interfaces/IEndpointResult.js +2 -2
- package/dist/constants/enums.d.ts +6 -6
- package/dist/constants/enums.js +10 -10
- package/dist/constants/services.d.ts +2 -2
- package/dist/constants/services.js +117 -112
- package/dist/constants/services.js.map +1 -1
- package/dist/constants/version.d.ts +2 -2
- package/dist/constants/version.js +5 -5
- package/dist/index.d.ts +50 -50
- package/dist/index.js +266 -266
- package/dist/lib/Attribute/index.d.ts +14 -14
- package/dist/lib/Attribute/index.js +186 -186
- package/dist/lib/BGJob/index.d.ts +9 -9
- package/dist/lib/BGJob/index.js +216 -216
- package/dist/lib/BackgroundWorker/index.d.ts +34 -34
- package/dist/lib/BackgroundWorker/index.js +59 -59
- package/dist/lib/Blog/BlogArticle.d.ts +5 -5
- package/dist/lib/Blog/BlogArticle.js +10 -10
- package/dist/lib/Blog/BlogAuthor.d.ts +5 -5
- package/dist/lib/Blog/BlogAuthor.js +10 -10
- package/dist/lib/Blog/BlogCategory.d.ts +5 -5
- package/dist/lib/Blog/BlogCategory.js +10 -10
- package/dist/lib/Blog/BlogKeyword.d.ts +5 -5
- package/dist/lib/Blog/BlogKeyword.js +10 -10
- package/dist/lib/Booking/index.d.ts +85 -85
- package/dist/lib/Booking/index.js +596 -596
- package/dist/lib/Brand/index.d.ts +26 -26
- package/dist/lib/Brand/index.js +131 -131
- package/dist/lib/Cart/index.d.ts +335 -335
- package/dist/lib/Cart/index.js +3977 -3977
- package/dist/lib/CartReservedQuantities/index.d.ts +49 -49
- package/dist/lib/CartReservedQuantities/index.js +159 -159
- package/dist/lib/CashDrawerShift/index.d.ts +83 -83
- package/dist/lib/CashDrawerShift/index.js +205 -205
- package/dist/lib/Catalogue/index.d.ts +15 -15
- package/dist/lib/Catalogue/index.js +78 -78
- package/dist/lib/Category/index.d.ts +34 -34
- package/dist/lib/Category/index.js +230 -230
- package/dist/lib/Class/index.d.ts +16 -16
- package/dist/lib/Class/index.js +66 -66
- package/dist/lib/Consent/index.d.ts +4 -4
- package/dist/lib/Consent/index.js +29 -29
- package/dist/lib/Customer/index.d.ts +30 -30
- package/dist/lib/Customer/index.js +92 -92
- package/dist/lib/Declination/index.d.ts +9 -9
- package/dist/lib/Declination/index.js +26 -26
- package/dist/lib/Discount/index.d.ts +27 -27
- package/dist/lib/Discount/index.js +493 -493
- package/dist/lib/ElasticSearch/index.d.ts +13 -13
- package/dist/lib/ElasticSearch/index.js +50 -50
- package/dist/lib/Elavon/index.d.ts +18 -18
- package/dist/lib/Elavon/index.js +135 -135
- package/dist/lib/Email/AbandonedCartEmail.d.ts +16 -16
- package/dist/lib/Email/AbandonedCartEmail.js +24 -24
- package/dist/lib/Email/AccountConfirmationEmail.d.ts +19 -19
- package/dist/lib/Email/AccountConfirmationEmail.js +30 -30
- package/dist/lib/Email/AdminOrderConfirmationEmail.d.ts +16 -16
- package/dist/lib/Email/AdminOrderConfirmationEmail.js +24 -24
- package/dist/lib/Email/ApplicationEmail.d.ts +16 -16
- package/dist/lib/Email/ApplicationEmail.js +24 -24
- package/dist/lib/Email/BackInStockEmail.d.ts +16 -16
- package/dist/lib/Email/BackInStockEmail.js +24 -24
- package/dist/lib/Email/ContactEmail.d.ts +16 -16
- package/dist/lib/Email/ContactEmail.js +24 -24
- package/dist/lib/Email/CustomerBookingAdminEmail.d.ts +16 -16
- package/dist/lib/Email/CustomerBookingAdminEmail.js +24 -24
- package/dist/lib/Email/CustomerBookingEmail.d.ts +16 -16
- package/dist/lib/Email/CustomerBookingEmail.js +24 -24
- package/dist/lib/Email/OrderConfirmationEmail.d.ts +16 -16
- package/dist/lib/Email/OrderConfirmationEmail.js +24 -24
- package/dist/lib/Email/OrderDenounciationEmail.d.ts +16 -16
- package/dist/lib/Email/OrderDenounciationEmail.js +24 -24
- package/dist/lib/Email/OrderSampleEmail.d.ts +16 -16
- package/dist/lib/Email/OrderSampleEmail.js +24 -24
- package/dist/lib/Email/OtherTypeEmails.d.ts +16 -16
- package/dist/lib/Email/OtherTypeEmails.js +27 -27
- package/dist/lib/Email/PasswordResetEmail.d.ts +16 -16
- package/dist/lib/Email/PasswordResetEmail.js +24 -24
- package/dist/lib/Email/PhotoShootEmail.d.ts +16 -16
- package/dist/lib/Email/PhotoShootEmail.js +24 -24
- package/dist/lib/Email/PickUpConfirmation.d.ts +16 -16
- package/dist/lib/Email/PickUpConfirmation.js +24 -24
- package/dist/lib/Email/ShippingConfirmation.d.ts +16 -16
- package/dist/lib/Email/ShippingConfirmation.js +24 -24
- package/dist/lib/Email/WelcomeEmail.d.ts +16 -16
- package/dist/lib/Email/WelcomeEmail.js +24 -24
- package/dist/lib/Email/index.d.ts +16 -16
- package/dist/lib/Email/index.js +31 -31
- package/dist/lib/ExternalService/Ebay.d.ts +74 -74
- package/dist/lib/ExternalService/Ebay.js +124 -124
- package/dist/lib/ExternalService/index.d.ts +5 -5
- package/dist/lib/ExternalService/index.js +10 -10
- package/dist/lib/FirstOrderTracking/index.d.ts +5 -5
- package/dist/lib/FirstOrderTracking/index.js +10 -10
- package/dist/lib/Indexed/IndexedCart.d.ts +13 -13
- package/dist/lib/Indexed/IndexedCart.js +91 -91
- package/dist/lib/Indexed/Product.d.ts +17 -17
- package/dist/lib/Indexed/Product.js +98 -98
- package/dist/lib/Inventory/index.d.ts +112 -112
- package/dist/lib/Inventory/index.js +492 -492
- package/dist/lib/Invoice/index.d.ts +16 -16
- package/dist/lib/Invoice/index.js +21 -21
- package/dist/lib/MarketplacePublication/index.d.ts +9 -9
- package/dist/lib/MarketplacePublication/index.js +426 -426
- package/dist/lib/Menu/index.d.ts +11 -11
- package/dist/lib/Menu/index.js +107 -107
- package/dist/lib/MongoDB/BaseAPI.d.ts +18 -18
- package/dist/lib/MongoDB/BaseAPI.js +200 -200
- package/dist/lib/Note/index.d.ts +4 -4
- package/dist/lib/Note/index.js +6 -6
- package/dist/lib/Order/index.d.ts +27 -27
- package/dist/lib/Order/index.js +56 -56
- package/dist/lib/Org/index.d.ts +68 -68
- package/dist/lib/Org/index.js +216 -216
- package/dist/lib/PandaPay/index.d.ts +16 -16
- package/dist/lib/PandaPay/index.js +176 -176
- package/dist/lib/Paysafe/index.d.ts +11 -11
- package/dist/lib/Paysafe/index.js +41 -41
- package/dist/lib/Product/index.d.ts +182 -182
- package/dist/lib/Product/index.js +847 -847
- package/dist/lib/ProductAttribute/index.d.ts +15 -15
- package/dist/lib/ProductAttribute/index.js +45 -45
- package/dist/lib/PromiseToPurchase/index.d.ts +109 -109
- package/dist/lib/PromiseToPurchase/index.js +343 -343
- package/dist/lib/PurchaseOrder/index.d.ts +20 -20
- package/dist/lib/PurchaseOrder/index.js +28 -28
- package/dist/lib/Queue/index.d.ts +40 -40
- package/dist/lib/Queue/index.js +254 -254
- package/dist/lib/Schedule/index.d.ts +5 -5
- package/dist/lib/Schedule/index.js +12 -12
- package/dist/lib/Service/Enum/ServiceEnum.d.ts +3 -3
- package/dist/lib/Service/Enum/ServiceEnum.js +7 -7
- package/dist/lib/Service/index.d.ts +13 -13
- package/dist/lib/Service/index.js +21 -21
- package/dist/lib/Shipment/index.d.ts +28 -28
- package/dist/lib/Shipment/index.js +370 -370
- package/dist/lib/Slider/index.d.ts +22 -22
- package/dist/lib/Slider/index.js +119 -119
- package/dist/lib/Space/index.d.ts +1150 -1150
- package/dist/lib/Space/index.js +5792 -5792
- package/dist/lib/StockNotification/index.d.ts +4 -4
- package/dist/lib/StockNotification/index.js +6 -6
- package/dist/lib/Store/index.d.ts +5 -5
- package/dist/lib/Store/index.js +12 -12
- package/dist/lib/Supplier/Command.d.ts +5 -5
- package/dist/lib/Supplier/Command.js +10 -10
- package/dist/lib/Supplier/index.d.ts +25 -25
- package/dist/lib/Supplier/index.js +27 -27
- package/dist/lib/Tags/index.d.ts +6 -6
- package/dist/lib/Tags/index.js +26 -26
- package/dist/lib/Tax/index.d.ts +8 -8
- package/dist/lib/Tax/index.js +54 -54
- package/dist/lib/TransferRequest/index.d.ts +290 -290
- package/dist/lib/TransferRequest/index.js +1026 -1026
- package/dist/lib/Update/index.d.ts +10 -10
- package/dist/lib/Update/index.js +22 -22
- package/dist/lib/User/index.d.ts +89 -89
- package/dist/lib/User/index.js +328 -328
- package/dist/lib/Wishlist/index.d.ts +5 -5
- package/dist/lib/Wishlist/index.js +10 -10
- package/dist/lib/base.d.ts +14 -14
- package/dist/lib/base.js +62 -62
- package/dist/lib/baseService.d.ts +17 -17
- package/dist/lib/baseService.js +69 -69
- package/dist/rules/GR/constants/data.d.ts +26 -26
- package/dist/rules/GR/constants/data.js +81 -81
- package/dist/rules/GR/constants/expedition.d.ts +4 -4
- package/dist/rules/GR/constants/expedition.js +9 -9
- package/dist/rules/GR/constants/products.d.ts +22 -22
- package/dist/rules/GR/constants/products.js +263 -263
- package/dist/rules/GR/interfaces/cart.d.ts +84 -84
- package/dist/rules/GR/interfaces/cart.js +41 -41
- package/dist/rules/GR/interfaces/data.d.ts +101 -101
- package/dist/rules/GR/interfaces/data.js +114 -114
- package/dist/rules/GR/interfaces/products.d.ts +61 -61
- package/dist/rules/GR/interfaces/products.js +10 -10
- package/dist/rules/GR/utils/cart.d.ts +95 -95
- package/dist/rules/GR/utils/cart.js +836 -836
- package/dist/rules/GR/utils/data.d.ts +3 -3
- package/dist/rules/GR/utils/data.js +28 -28
- package/dist/rules/GR/utils/expedition.d.ts +140 -140
- package/dist/rules/GR/utils/expedition.js +2016 -2016
- package/dist/rules/GR/utils/g2.d.ts +209 -209
- package/dist/rules/GR/utils/g2.js +999 -999
- package/dist/rules/GR/utils/invoices.d.ts +51 -51
- package/dist/rules/GR/utils/invoices.js +215 -215
- package/dist/rules/GR/utils/products.d.ts +277 -277
- package/dist/rules/GR/utils/products.js +1350 -1350
- package/dist/rules/GR/utils/upsells.d.ts +111 -111
- package/dist/rules/GR/utils/upsells.js +215 -215
- package/dist/services/database/BaseProvider.d.ts +29 -29
- package/dist/services/database/BaseProvider.js +28 -28
- package/dist/services/database/BatchUtils.d.ts +14 -14
- package/dist/services/database/BatchUtils.js +43 -43
- package/dist/services/database/Config.d.ts +2 -2
- package/dist/services/database/Config.js +5 -5
- package/dist/services/database/DatabaseService.d.ts +125 -125
- package/dist/services/database/DatabaseService.js +237 -237
- package/dist/services/database/FirebaseProvider.d.ts +17 -17
- package/dist/services/database/FirebaseProvider.js +235 -235
- package/dist/services/database/NotFirebaseProvider.d.ts +49 -49
- package/dist/services/database/NotFirebaseProvider.js +262 -262
- package/dist/services/g2/G2OrderSlip.d.ts +49 -49
- package/dist/services/g2/G2OrderSlip.js +228 -228
- package/dist/services/g2/utils.d.ts +19 -19
- package/dist/services/g2/utils.js +953 -953
- package/dist/services/logs/index.d.ts +23 -23
- package/dist/services/logs/index.js +66 -66
- package/dist/services/marketplace/BaseMarketServiceClass.d.ts +52 -0
- package/dist/services/marketplace/BaseMarketServiceClass.js +112 -0
- package/dist/services/marketplace/BaseMarketServiceClass.js.map +1 -0
- package/dist/services/marketplace/CardtraderServiceClass.d.ts +17 -0
- package/dist/services/marketplace/CardtraderServiceClass.js +140 -0
- package/dist/services/marketplace/CardtraderServiceClass.js.map +1 -0
- package/dist/services/marketplace/utils.d.ts +14 -0
- package/dist/services/marketplace/utils.js +30 -0
- package/dist/services/marketplace/utils.js.map +1 -0
- package/dist/services/products/BaseClass.d.ts +50 -50
- package/dist/services/products/BaseClass.js +66 -66
- package/dist/services/products/TCGService.d.ts +32 -32
- package/dist/services/products/TCGService.js +555 -555
- package/dist/services/products/utils.d.ts +31 -31
- package/dist/services/products/utils.js +144 -144
- package/dist/utils/algolia.d.ts +46 -46
- package/dist/utils/algolia.js +21 -21
- package/dist/utils/anonymisation.d.ts +54 -54
- package/dist/utils/anonymisation.js +280 -280
- package/dist/utils/array.d.ts +5 -5
- package/dist/utils/array.js +14 -14
- package/dist/utils/aws.d.ts +36 -36
- package/dist/utils/aws.js +154 -154
- package/dist/utils/booking.d.ts +30 -30
- package/dist/utils/booking.js +127 -127
- package/dist/utils/cart.d.ts +259 -259
- package/dist/utils/cart.js +1145 -1145
- package/dist/utils/categories.d.ts +2 -2
- package/dist/utils/categories.js +54 -54
- package/dist/utils/cmv.d.ts +10 -10
- package/dist/utils/cmv.js +107 -107
- package/dist/utils/console.d.ts +6 -6
- package/dist/utils/console.js +59 -59
- package/dist/utils/context.d.ts +20 -20
- package/dist/utils/context.js +61 -61
- package/dist/utils/currency.d.ts +6 -6
- package/dist/utils/currency.js +91 -91
- package/dist/utils/data.d.ts +31 -31
- package/dist/utils/data.js +296 -296
- package/dist/utils/date.d.ts +1 -1
- package/dist/utils/date.js +16 -16
- package/dist/utils/dimensions.d.ts +3 -3
- package/dist/utils/dimensions.js +16 -16
- package/dist/utils/discount.d.ts +164 -164
- package/dist/utils/discount.js +1111 -1111
- package/dist/utils/errors.d.ts +113 -113
- package/dist/utils/errors.js +113 -113
- package/dist/utils/file-admin.d.ts +8 -8
- package/dist/utils/file-admin.js +39 -39
- package/dist/utils/file.d.ts +39 -39
- package/dist/utils/file.js +208 -208
- package/dist/utils/firebase-admin.d.ts +11 -11
- package/dist/utils/firebase-admin.js +73 -73
- package/dist/utils/firebase.d.ts +58 -58
- package/dist/utils/firebase.js +148 -148
- package/dist/utils/import.d.ts +1 -1
- package/dist/utils/import.js +21 -21
- package/dist/utils/inventories.d.ts +101 -101
- package/dist/utils/inventories.js +467 -467
- package/dist/utils/locale.d.ts +24 -24
- package/dist/utils/locale.js +89 -89
- package/dist/utils/mailchimp.d.ts +58 -58
- package/dist/utils/mailchimp.js +531 -531
- package/dist/utils/mathUtils.d.ts +17 -17
- package/dist/utils/mathUtils.js +324 -324
- package/dist/utils/mongodb.d.ts +1 -1
- package/dist/utils/mongodb.js +22 -22
- package/dist/utils/object.d.ts +32 -32
- package/dist/utils/object.js +133 -133
- package/dist/utils/payment.d.ts +10 -10
- package/dist/utils/payment.js +23 -23
- package/dist/utils/products.d.ts +39 -39
- package/dist/utils/products.js +195 -195
- package/dist/utils/promiseToPurchase.d.ts +88 -88
- package/dist/utils/promiseToPurchase.js +229 -229
- package/dist/utils/prosprsearch.d.ts +42 -42
- package/dist/utils/prosprsearch.js +216 -216
- package/dist/utils/refunds.d.ts +2 -2
- package/dist/utils/refunds.js +21 -21
- package/dist/utils/sdc.d.ts +10 -10
- package/dist/utils/sdc.js +1309 -1309
- package/dist/utils/searchIndexes.d.ts +58 -58
- package/dist/utils/searchIndexes.js +247 -247
- package/dist/utils/services.d.ts +42 -42
- package/dist/utils/services.js +409 -409
- package/dist/utils/shipment.d.ts +110 -110
- package/dist/utils/shipment.js +345 -345
- package/dist/utils/simpletexting.d.ts +2 -2
- package/dist/utils/simpletexting.js +45 -45
- package/dist/utils/sliders.d.ts +4 -4
- package/dist/utils/sliders.js +24 -24
- package/dist/utils/string.d.ts +16 -16
- package/dist/utils/string.js +192 -192
- package/dist/utils/tcgService.d.ts +74 -74
- package/dist/utils/tcgService.js +308 -308
- package/dist/utils/tools.d.ts +5 -5
- package/dist/utils/tools.js +13 -13
- package/dist/utils/transferRequests.d.ts +43 -43
- package/dist/utils/transferRequests.js +67 -67
- package/dist/utils/update.d.ts +7 -7
- package/dist/utils/update.js +137 -137
- package/dist/utils/weight.d.ts +3 -3
- package/dist/utils/weight.js +16 -16
- package/dist/utils/zones.d.ts +11 -11
- package/dist/utils/zones.js +218 -218
- package/package.json +107 -107
- package/publish.sh +143 -143
- package/readme.md +182 -182
- package/.env +0 -15
|
@@ -1,344 +1,344 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
var _a;
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
const moment_1 = __importDefault(require("moment"));
|
|
8
|
-
const Space_1 = __importDefault(require("../Space"));
|
|
9
|
-
const Cart_1 = require("../../Interfaces/Cart");
|
|
10
|
-
const data_1 = require("../../utils/data");
|
|
11
|
-
const algolia_1 = require("../../utils/algolia");
|
|
12
|
-
const __1 = require("../..");
|
|
13
|
-
const console_1 = require("../../utils/console");
|
|
14
|
-
const promiseToPurchase_1 = require("../../utils/promiseToPurchase");
|
|
15
|
-
const searchIndexes_1 = require("../../utils/searchIndexes");
|
|
16
|
-
const baseService_1 = require("../baseService");
|
|
17
|
-
class PromiseToPurchase extends baseService_1.BaseServiceClass {
|
|
18
|
-
constructor() {
|
|
19
|
-
super(...arguments);
|
|
20
|
-
this.data = () => {
|
|
21
|
-
return this._data;
|
|
22
|
-
};
|
|
23
|
-
/**
|
|
24
|
-
* @deprecated a promise to purchase cannot be deleted.
|
|
25
|
-
*/
|
|
26
|
-
this.delete = async () => {
|
|
27
|
-
console.log('cannot delete Promise to Purchase!');
|
|
28
|
-
return false;
|
|
29
|
-
};
|
|
30
|
-
/**
|
|
31
|
-
* Save the changes to a promise to purchase
|
|
32
|
-
* @param partial the partial containing the changes
|
|
33
|
-
* @param saveToDatabase whether or not the changes should be persisted
|
|
34
|
-
* @param options.noEvent whether to trigger onWritePromise or not
|
|
35
|
-
*/
|
|
36
|
-
this.save = async (partial, saveToDatabase = true, noEvent = false) => {
|
|
37
|
-
try {
|
|
38
|
-
const currentData = this._data;
|
|
39
|
-
let newData = Object.assign(Object.assign({}, currentData), (!!partial ? partial : {}));
|
|
40
|
-
if (!!!newData.created_by) {
|
|
41
|
-
newData = Object.assign(Object.assign({}, newData), { created_by: this._user, created_date: (0, moment_1.default)().toDate() });
|
|
42
|
-
}
|
|
43
|
-
const id = await super.save(newData, undefined, saveToDatabase, undefined, undefined, undefined, undefined, noEvent);
|
|
44
|
-
if (!!id && !!!this._data.id && typeof id === 'string') {
|
|
45
|
-
this._data = Object.assign(Object.assign({}, this._data), { id });
|
|
46
|
-
}
|
|
47
|
-
return !!id ? id : true;
|
|
48
|
-
}
|
|
49
|
-
catch (e) {
|
|
50
|
-
console.log('error on saving PromiseToPurchase: ', e.toString());
|
|
51
|
-
return false;
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
/**
|
|
55
|
-
* Adjust the amount remaining in a bank and adds an entry in the bank adjustments history.
|
|
56
|
-
* @param adjustment the adjustment entry
|
|
57
|
-
* @param bankTypeId the bank type id to be updated
|
|
58
|
-
* @param bankNowEmpty Optionnal. If set, will set bank as inactive
|
|
59
|
-
*/
|
|
60
|
-
this.adjustAmountLeftInPromise = async (adjustment, bankTypeId, bankNowEmpty) => {
|
|
61
|
-
var _b;
|
|
62
|
-
const balancedBank = this.getBank(bankTypeId);
|
|
63
|
-
if (balancedBank === undefined)
|
|
64
|
-
return false;
|
|
65
|
-
const adjustments = [...((_b = balancedBank.adjustments) !== null && _b !== void 0 ? _b : []), Object.assign(Object.assign({}, adjustment), { issued_by: this._user })];
|
|
66
|
-
const bank = Object.assign(Object.assign(Object.assign({}, balancedBank), { adjustments }), (!!bankNowEmpty ? { active: false } : {}));
|
|
67
|
-
const newBanks = this._data.banks.map((b) => (b.bank_type_id === bankTypeId ? bank : b));
|
|
68
|
-
const allBanksInactive = newBanks.every((b) => !!!b.active);
|
|
69
|
-
try {
|
|
70
|
-
const saved = await this.save(Object.assign({ banks: newBanks }, (!!allBanksInactive ? { ending_date: (0, moment_1.default)().toDate() } : {})));
|
|
71
|
-
return !!saved;
|
|
72
|
-
}
|
|
73
|
-
catch (e) {
|
|
74
|
-
console.log('error on saving adjustment in bank: ', e.toString());
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
/**
|
|
79
|
-
* Returns all the rules for a bank.
|
|
80
|
-
*/
|
|
81
|
-
this.getRulesForAllBanks = async () => {
|
|
82
|
-
const allBanks = this._data.banks;
|
|
83
|
-
try {
|
|
84
|
-
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
85
|
-
const rules = allBanks.map((bank) => {
|
|
86
|
-
const rulesForType = space.bankTypes.getRulesByType(bank.bank_type_id, bank.version);
|
|
87
|
-
if (!!!rulesForType)
|
|
88
|
-
return undefined;
|
|
89
|
-
return Object.assign({ type_id: bank.bank_type_id }, rulesForType);
|
|
90
|
-
});
|
|
91
|
-
return rules.filter((i) => !!i);
|
|
92
|
-
}
|
|
93
|
-
catch (e) {
|
|
94
|
-
console.log('error on getting Rules for banks: ', e.toString());
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
};
|
|
98
|
-
/**
|
|
99
|
-
* Retrieves the default settings to build an empty promise to purchase so that it can be edited.
|
|
100
|
-
*/
|
|
101
|
-
this.constructDefaultPromiseToPurchase = async (space, customer_id) => {
|
|
102
|
-
let newData = Object.assign({}, this._data);
|
|
103
|
-
try {
|
|
104
|
-
const allCurrentBankTypes = space.bankTypes.get();
|
|
105
|
-
// Check if customer is defined and already has active promises
|
|
106
|
-
let isOnlyActivePromiseForCustomer = true;
|
|
107
|
-
let activePAs;
|
|
108
|
-
if (!!customer_id) {
|
|
109
|
-
let currentCustomerPAs = await space.promisesToPurchase.get({
|
|
110
|
-
query: [{ field: 'customer_id', operator: '==', value: customer_id !== null && customer_id !== void 0 ? customer_id : newData.customer_id }]
|
|
111
|
-
});
|
|
112
|
-
if (!!currentCustomerPAs) {
|
|
113
|
-
activePAs = currentCustomerPAs.filter((p) => !!!p.data().ending_date);
|
|
114
|
-
if (!!activePAs.length)
|
|
115
|
-
isOnlyActivePromiseForCustomer = false;
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
newData = Object.assign(Object.assign({}, newData), { banks: allCurrentBankTypes
|
|
119
|
-
.map((bankType) => {
|
|
120
|
-
const rulesToApply = space.bankTypes.getRulesByType(bankType.id);
|
|
121
|
-
if (!!!rulesToApply)
|
|
122
|
-
return undefined;
|
|
123
|
-
const bankReductions = rulesToApply.rules.map((bankRule) => (Object.assign(Object.assign({}, bankRule), { default_promo: null, additionnal_promo: null })));
|
|
124
|
-
const otherBankOfSameTypeIsActive = (0, promiseToPurchase_1.checkIfOtherBankOfSameTypeIsActive)(bankType.id, activePAs);
|
|
125
|
-
return {
|
|
126
|
-
bank_type_id: bankType.id,
|
|
127
|
-
version: rulesToApply.version,
|
|
128
|
-
name: bankType.name,
|
|
129
|
-
association_type: bankType.association_type,
|
|
130
|
-
initial_amount: null,
|
|
131
|
-
remaining_amount: null,
|
|
132
|
-
reductions: bankReductions,
|
|
133
|
-
adjustments: [],
|
|
134
|
-
active: !!otherBankOfSameTypeIsActive ? false : isOnlyActivePromiseForCustomer
|
|
135
|
-
};
|
|
136
|
-
})
|
|
137
|
-
.filter((b) => !!b) });
|
|
138
|
-
this._data = newData;
|
|
139
|
-
}
|
|
140
|
-
catch (e) {
|
|
141
|
-
console.log('error on creating default Promise to Purchase: ', e.toString());
|
|
142
|
-
}
|
|
143
|
-
};
|
|
144
|
-
/**
|
|
145
|
-
* Retrieves and returns all the carts using a this promise to purchase.
|
|
146
|
-
* @param options the query options.
|
|
147
|
-
*/
|
|
148
|
-
this.getAssociatedCarts = async (options) => {
|
|
149
|
-
if (!!!this.data().id)
|
|
150
|
-
return [];
|
|
151
|
-
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
152
|
-
const carts = await space.carts.get(Object.assign({ query: [
|
|
153
|
-
{
|
|
154
|
-
field: 'promise_to_purchase.ids',
|
|
155
|
-
operator: 'array-contains',
|
|
156
|
-
value: this.data().id
|
|
157
|
-
}
|
|
158
|
-
] }, (!!options ? options : {})));
|
|
159
|
-
return carts.filter((f) => !!f.data().paid_at && f.data().status >= Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS);
|
|
160
|
-
};
|
|
161
|
-
/**
|
|
162
|
-
* Function isValid
|
|
163
|
-
* @description checks if a promise to purchase can be used based on the presence of a custom price list and the validity of the ending and starting date
|
|
164
|
-
* @param customPriceList the custom price list
|
|
165
|
-
* @param checkDate the date to use for checking validity
|
|
166
|
-
* @returns true if valid, false if not
|
|
167
|
-
*/
|
|
168
|
-
this.isValid = (customPriceList, checkDate = new Date()) => {
|
|
169
|
-
if (!!!customPriceList || customPriceList.length === 0 || typeof customPriceList === 'string')
|
|
170
|
-
return false;
|
|
171
|
-
let startDate = this.data().starting_date;
|
|
172
|
-
let endDate = this.data().ending_date;
|
|
173
|
-
if ((0, moment_1.default)(checkDate).isBefore((0, moment_1.default)((0, data_1.formatDate)(startDate), 'day')))
|
|
174
|
-
return false;
|
|
175
|
-
if (!!endDate && (0, moment_1.default)(checkDate).isSameOrAfter((0, moment_1.default)((0, data_1.formatDate)(endDate), 'day')))
|
|
176
|
-
return false;
|
|
177
|
-
return true;
|
|
178
|
-
};
|
|
179
|
-
/**
|
|
180
|
-
* Disables empty banks for a specific customer's promise to purchase.
|
|
181
|
-
* If the disabled banks were the last active banks of the PA, disable the PA
|
|
182
|
-
* @async
|
|
183
|
-
* @param {{ [bankId: string]: number; }} bankIDsWithRemainingAmounts - The bank IDs to disable.
|
|
184
|
-
*/
|
|
185
|
-
this.disableEmptyPABanks = async (bankIDsWithRemainingAmounts) => {
|
|
186
|
-
// If none of the bank IDs are found in promises banks, throw error
|
|
187
|
-
if (this._data.banks.every((b) => !!!Object.keys(bankIDsWithRemainingAmounts).includes(b.bank_type_id)))
|
|
188
|
-
throw new Error('None of the provided bank IDs were found in promise');
|
|
189
|
-
let newBankArray = [...this._data.banks];
|
|
190
|
-
for (let [bankID, remaining] of Object.entries(bankIDsWithRemainingAmounts)) {
|
|
191
|
-
// Find the bank that matches the one that needs to be deactivated in the targeted PA and deactivate it
|
|
192
|
-
newBankArray = newBankArray.map((b) => {
|
|
193
|
-
if (b.bank_type_id !== bankID)
|
|
194
|
-
return b;
|
|
195
|
-
return Object.assign(Object.assign({}, b), { active: false, remaining_amount: remaining });
|
|
196
|
-
});
|
|
197
|
-
}
|
|
198
|
-
let newData = {
|
|
199
|
-
banks: newBankArray
|
|
200
|
-
};
|
|
201
|
-
// Check if the new bank array only has inactive banks, deactivate the target PA
|
|
202
|
-
const allBanksAreInactive = newBankArray.every((b) => !!!b.active);
|
|
203
|
-
if (!!allBanksAreInactive) {
|
|
204
|
-
newData = Object.assign(Object.assign({}, newData), { ending_date: new Date() });
|
|
205
|
-
}
|
|
206
|
-
// Save the targeted PA with a deactivated bank and an ending_date if it applies
|
|
207
|
-
await this.save(newData);
|
|
208
|
-
};
|
|
209
|
-
/**
|
|
210
|
-
* Function deactivate
|
|
211
|
-
* @description deactivates the promise
|
|
212
|
-
* @param save save to database?
|
|
213
|
-
*/
|
|
214
|
-
this.deactivate = async (save = false) => {
|
|
215
|
-
var _b;
|
|
216
|
-
this._data = Object.assign(Object.assign({}, this._data), { ending_date: (_b = this._data.ending_date) !== null && _b !== void 0 ? _b : new Date() });
|
|
217
|
-
if (!!save)
|
|
218
|
-
await this.save();
|
|
219
|
-
};
|
|
220
|
-
/**
|
|
221
|
-
* Function activate
|
|
222
|
-
* @description activates the promise from a given date
|
|
223
|
-
* @param newDate the date of starting validity
|
|
224
|
-
* @param save save to database?
|
|
225
|
-
*/
|
|
226
|
-
this.activate = async (newDate = new Date(), save = false) => {
|
|
227
|
-
this._data = Object.assign(Object.assign({}, this._data), { starting_date: newDate, ending_date: null });
|
|
228
|
-
if (!!save)
|
|
229
|
-
await this.save();
|
|
230
|
-
};
|
|
231
|
-
this.archive = async (save = false) => {
|
|
232
|
-
this._data = Object.assign(Object.assign({}, this._data), { archived: true });
|
|
233
|
-
if (!!save)
|
|
234
|
-
await this.save();
|
|
235
|
-
};
|
|
236
|
-
}
|
|
237
|
-
/**
|
|
238
|
-
* Returns a bank object.
|
|
239
|
-
* @param bankTypeId
|
|
240
|
-
*/
|
|
241
|
-
getBank(bankTypeId) {
|
|
242
|
-
return this._data.banks.find((b) => b.bank_type_id === bankTypeId);
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
exports.default = PromiseToPurchase;
|
|
246
|
-
_a = PromiseToPurchase;
|
|
247
|
-
PromiseToPurchase.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'customer_pa_cust_id', f = '', space, useProspr = false }) => {
|
|
248
|
-
try {
|
|
249
|
-
let prosprSearch = false;
|
|
250
|
-
if (!!space) {
|
|
251
|
-
const prosprService = space
|
|
252
|
-
.data()
|
|
253
|
-
.external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
|
|
254
|
-
prosprSearch = !!prosprService && prosprService.is_active;
|
|
255
|
-
}
|
|
256
|
-
const algolia = (0, algolia_1.createClient)({
|
|
257
|
-
app,
|
|
258
|
-
indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
|
|
259
|
-
key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
|
|
260
|
-
prospr: !!prosprSearch || !!useProspr
|
|
261
|
-
});
|
|
262
|
-
const results = await algolia.search(query, {
|
|
263
|
-
hitsPerPage: hpp,
|
|
264
|
-
facetFilters: filters,
|
|
265
|
-
filters: f,
|
|
266
|
-
page,
|
|
267
|
-
facets: ['*']
|
|
268
|
-
});
|
|
269
|
-
return results;
|
|
270
|
-
}
|
|
271
|
-
catch (error) {
|
|
272
|
-
(0, console_1.errorMessage)(error);
|
|
273
|
-
throw error;
|
|
274
|
-
}
|
|
275
|
-
};
|
|
276
|
-
/**
|
|
277
|
-
*
|
|
278
|
-
* @param space
|
|
279
|
-
* @param hpp
|
|
280
|
-
* @param page
|
|
281
|
-
* @param query
|
|
282
|
-
* @param filters
|
|
283
|
-
* @param indice
|
|
284
|
-
* @param f
|
|
285
|
-
* @param useProspr
|
|
286
|
-
*/
|
|
287
|
-
PromiseToPurchase.fetchHistory = async ({ app, api, hpp = 50, page = 0, query = '', filters = '', indice = 'pa_bank_history', f = '', useProspr = false }) => {
|
|
288
|
-
try {
|
|
289
|
-
const results = await (0, searchIndexes_1.searchAPIFetchAlgoliaAddioSearch)({
|
|
290
|
-
app,
|
|
291
|
-
api,
|
|
292
|
-
indice,
|
|
293
|
-
hpp,
|
|
294
|
-
page,
|
|
295
|
-
query,
|
|
296
|
-
filters,
|
|
297
|
-
f,
|
|
298
|
-
useProspr
|
|
299
|
-
});
|
|
300
|
-
return results;
|
|
301
|
-
}
|
|
302
|
-
catch (e) {
|
|
303
|
-
console.log('error on fetching history for promises : ', e.toString());
|
|
304
|
-
}
|
|
305
|
-
};
|
|
306
|
-
/**
|
|
307
|
-
* Returns calculated remaining amounts for each bank
|
|
308
|
-
* @param actualCart the cart that we are trying to pay
|
|
309
|
-
* @param applicableBanks the banks that could be applied for user on cart
|
|
310
|
-
* @param applicableBanksHistory list of history entries for applicable banks
|
|
311
|
-
* @param space the Space obj
|
|
312
|
-
* @returns an array of banks used
|
|
313
|
-
*/
|
|
314
|
-
PromiseToPurchase.calculateRemainingAmounts = async (actualCart, applicableBanks, applicableBanksHistory, space) => {
|
|
315
|
-
// Fetch history for banks
|
|
316
|
-
let remainingAmountsForApplicableBanks = await space.promisesToPurchase.getAvailableAmountForApplicableBanks(applicableBanks, applicableBanksHistory);
|
|
317
|
-
if (!!!actualCart)
|
|
318
|
-
throw new Error(`ActualCart can't be undefined`);
|
|
319
|
-
const cartDataPA = actualCart.data().promise_to_purchase;
|
|
320
|
-
if (!!!cartDataPA || !!!cartDataPA.banks_used || cartDataPA.banks_used.length === 0)
|
|
321
|
-
throw new Error(`ActualCart must have an associated promise to purchase and at least one bank_used`);
|
|
322
|
-
// on calcule les montants restants dans les banques que le cart et la PA ont en commun
|
|
323
|
-
const remainingBankAmounts = applicableBanks.map((applicable) => {
|
|
324
|
-
const { bank, promise_id, promise_unique_id } = applicable;
|
|
325
|
-
const remainingAmount = remainingAmountsForApplicableBanks[bank.bank_type_id];
|
|
326
|
-
if (typeof remainingAmount === 'undefined')
|
|
327
|
-
return;
|
|
328
|
-
return {
|
|
329
|
-
bank_type_id: bank.bank_type_id,
|
|
330
|
-
amount: remainingAmount,
|
|
331
|
-
promise_id: promise_id,
|
|
332
|
-
promise_unique_id: promise_unique_id
|
|
333
|
-
};
|
|
334
|
-
});
|
|
335
|
-
return remainingBankAmounts.filter((bankApplied) => !!bankApplied);
|
|
336
|
-
};
|
|
337
|
-
PromiseToPurchase.getDefaultPromiseToPurchase = (customerId) => ({
|
|
338
|
-
archived: false,
|
|
339
|
-
promise_unique_id: '',
|
|
340
|
-
customer_id: customerId,
|
|
341
|
-
banks: [],
|
|
342
|
-
starting_date: (0, moment_1.default)().toDate()
|
|
343
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
var _a;
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
const moment_1 = __importDefault(require("moment"));
|
|
8
|
+
const Space_1 = __importDefault(require("../Space"));
|
|
9
|
+
const Cart_1 = require("../../Interfaces/Cart");
|
|
10
|
+
const data_1 = require("../../utils/data");
|
|
11
|
+
const algolia_1 = require("../../utils/algolia");
|
|
12
|
+
const __1 = require("../..");
|
|
13
|
+
const console_1 = require("../../utils/console");
|
|
14
|
+
const promiseToPurchase_1 = require("../../utils/promiseToPurchase");
|
|
15
|
+
const searchIndexes_1 = require("../../utils/searchIndexes");
|
|
16
|
+
const baseService_1 = require("../baseService");
|
|
17
|
+
class PromiseToPurchase extends baseService_1.BaseServiceClass {
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments);
|
|
20
|
+
this.data = () => {
|
|
21
|
+
return this._data;
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* @deprecated a promise to purchase cannot be deleted.
|
|
25
|
+
*/
|
|
26
|
+
this.delete = async () => {
|
|
27
|
+
console.log('cannot delete Promise to Purchase!');
|
|
28
|
+
return false;
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Save the changes to a promise to purchase
|
|
32
|
+
* @param partial the partial containing the changes
|
|
33
|
+
* @param saveToDatabase whether or not the changes should be persisted
|
|
34
|
+
* @param options.noEvent whether to trigger onWritePromise or not
|
|
35
|
+
*/
|
|
36
|
+
this.save = async (partial, saveToDatabase = true, noEvent = false) => {
|
|
37
|
+
try {
|
|
38
|
+
const currentData = this._data;
|
|
39
|
+
let newData = Object.assign(Object.assign({}, currentData), (!!partial ? partial : {}));
|
|
40
|
+
if (!!!newData.created_by) {
|
|
41
|
+
newData = Object.assign(Object.assign({}, newData), { created_by: this._user, created_date: (0, moment_1.default)().toDate() });
|
|
42
|
+
}
|
|
43
|
+
const id = await super.save(newData, undefined, saveToDatabase, undefined, undefined, undefined, undefined, noEvent);
|
|
44
|
+
if (!!id && !!!this._data.id && typeof id === 'string') {
|
|
45
|
+
this._data = Object.assign(Object.assign({}, this._data), { id });
|
|
46
|
+
}
|
|
47
|
+
return !!id ? id : true;
|
|
48
|
+
}
|
|
49
|
+
catch (e) {
|
|
50
|
+
console.log('error on saving PromiseToPurchase: ', e.toString());
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
/**
|
|
55
|
+
* Adjust the amount remaining in a bank and adds an entry in the bank adjustments history.
|
|
56
|
+
* @param adjustment the adjustment entry
|
|
57
|
+
* @param bankTypeId the bank type id to be updated
|
|
58
|
+
* @param bankNowEmpty Optionnal. If set, will set bank as inactive
|
|
59
|
+
*/
|
|
60
|
+
this.adjustAmountLeftInPromise = async (adjustment, bankTypeId, bankNowEmpty) => {
|
|
61
|
+
var _b;
|
|
62
|
+
const balancedBank = this.getBank(bankTypeId);
|
|
63
|
+
if (balancedBank === undefined)
|
|
64
|
+
return false;
|
|
65
|
+
const adjustments = [...((_b = balancedBank.adjustments) !== null && _b !== void 0 ? _b : []), Object.assign(Object.assign({}, adjustment), { issued_by: this._user })];
|
|
66
|
+
const bank = Object.assign(Object.assign(Object.assign({}, balancedBank), { adjustments }), (!!bankNowEmpty ? { active: false } : {}));
|
|
67
|
+
const newBanks = this._data.banks.map((b) => (b.bank_type_id === bankTypeId ? bank : b));
|
|
68
|
+
const allBanksInactive = newBanks.every((b) => !!!b.active);
|
|
69
|
+
try {
|
|
70
|
+
const saved = await this.save(Object.assign({ banks: newBanks }, (!!allBanksInactive ? { ending_date: (0, moment_1.default)().toDate() } : {})));
|
|
71
|
+
return !!saved;
|
|
72
|
+
}
|
|
73
|
+
catch (e) {
|
|
74
|
+
console.log('error on saving adjustment in bank: ', e.toString());
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
/**
|
|
79
|
+
* Returns all the rules for a bank.
|
|
80
|
+
*/
|
|
81
|
+
this.getRulesForAllBanks = async () => {
|
|
82
|
+
const allBanks = this._data.banks;
|
|
83
|
+
try {
|
|
84
|
+
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
85
|
+
const rules = allBanks.map((bank) => {
|
|
86
|
+
const rulesForType = space.bankTypes.getRulesByType(bank.bank_type_id, bank.version);
|
|
87
|
+
if (!!!rulesForType)
|
|
88
|
+
return undefined;
|
|
89
|
+
return Object.assign({ type_id: bank.bank_type_id }, rulesForType);
|
|
90
|
+
});
|
|
91
|
+
return rules.filter((i) => !!i);
|
|
92
|
+
}
|
|
93
|
+
catch (e) {
|
|
94
|
+
console.log('error on getting Rules for banks: ', e.toString());
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* Retrieves the default settings to build an empty promise to purchase so that it can be edited.
|
|
100
|
+
*/
|
|
101
|
+
this.constructDefaultPromiseToPurchase = async (space, customer_id) => {
|
|
102
|
+
let newData = Object.assign({}, this._data);
|
|
103
|
+
try {
|
|
104
|
+
const allCurrentBankTypes = space.bankTypes.get();
|
|
105
|
+
// Check if customer is defined and already has active promises
|
|
106
|
+
let isOnlyActivePromiseForCustomer = true;
|
|
107
|
+
let activePAs;
|
|
108
|
+
if (!!customer_id) {
|
|
109
|
+
let currentCustomerPAs = await space.promisesToPurchase.get({
|
|
110
|
+
query: [{ field: 'customer_id', operator: '==', value: customer_id !== null && customer_id !== void 0 ? customer_id : newData.customer_id }]
|
|
111
|
+
});
|
|
112
|
+
if (!!currentCustomerPAs) {
|
|
113
|
+
activePAs = currentCustomerPAs.filter((p) => !!!p.data().ending_date);
|
|
114
|
+
if (!!activePAs.length)
|
|
115
|
+
isOnlyActivePromiseForCustomer = false;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
newData = Object.assign(Object.assign({}, newData), { banks: allCurrentBankTypes
|
|
119
|
+
.map((bankType) => {
|
|
120
|
+
const rulesToApply = space.bankTypes.getRulesByType(bankType.id);
|
|
121
|
+
if (!!!rulesToApply)
|
|
122
|
+
return undefined;
|
|
123
|
+
const bankReductions = rulesToApply.rules.map((bankRule) => (Object.assign(Object.assign({}, bankRule), { default_promo: null, additionnal_promo: null })));
|
|
124
|
+
const otherBankOfSameTypeIsActive = (0, promiseToPurchase_1.checkIfOtherBankOfSameTypeIsActive)(bankType.id, activePAs);
|
|
125
|
+
return {
|
|
126
|
+
bank_type_id: bankType.id,
|
|
127
|
+
version: rulesToApply.version,
|
|
128
|
+
name: bankType.name,
|
|
129
|
+
association_type: bankType.association_type,
|
|
130
|
+
initial_amount: null,
|
|
131
|
+
remaining_amount: null,
|
|
132
|
+
reductions: bankReductions,
|
|
133
|
+
adjustments: [],
|
|
134
|
+
active: !!otherBankOfSameTypeIsActive ? false : isOnlyActivePromiseForCustomer
|
|
135
|
+
};
|
|
136
|
+
})
|
|
137
|
+
.filter((b) => !!b) });
|
|
138
|
+
this._data = newData;
|
|
139
|
+
}
|
|
140
|
+
catch (e) {
|
|
141
|
+
console.log('error on creating default Promise to Purchase: ', e.toString());
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
/**
|
|
145
|
+
* Retrieves and returns all the carts using a this promise to purchase.
|
|
146
|
+
* @param options the query options.
|
|
147
|
+
*/
|
|
148
|
+
this.getAssociatedCarts = async (options) => {
|
|
149
|
+
if (!!!this.data().id)
|
|
150
|
+
return [];
|
|
151
|
+
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
152
|
+
const carts = await space.carts.get(Object.assign({ query: [
|
|
153
|
+
{
|
|
154
|
+
field: 'promise_to_purchase.ids',
|
|
155
|
+
operator: 'array-contains',
|
|
156
|
+
value: this.data().id
|
|
157
|
+
}
|
|
158
|
+
] }, (!!options ? options : {})));
|
|
159
|
+
return carts.filter((f) => !!f.data().paid_at && f.data().status >= Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS);
|
|
160
|
+
};
|
|
161
|
+
/**
|
|
162
|
+
* Function isValid
|
|
163
|
+
* @description checks if a promise to purchase can be used based on the presence of a custom price list and the validity of the ending and starting date
|
|
164
|
+
* @param customPriceList the custom price list
|
|
165
|
+
* @param checkDate the date to use for checking validity
|
|
166
|
+
* @returns true if valid, false if not
|
|
167
|
+
*/
|
|
168
|
+
this.isValid = (customPriceList, checkDate = new Date()) => {
|
|
169
|
+
if (!!!customPriceList || customPriceList.length === 0 || typeof customPriceList === 'string')
|
|
170
|
+
return false;
|
|
171
|
+
let startDate = this.data().starting_date;
|
|
172
|
+
let endDate = this.data().ending_date;
|
|
173
|
+
if ((0, moment_1.default)(checkDate).isBefore((0, moment_1.default)((0, data_1.formatDate)(startDate), 'day')))
|
|
174
|
+
return false;
|
|
175
|
+
if (!!endDate && (0, moment_1.default)(checkDate).isSameOrAfter((0, moment_1.default)((0, data_1.formatDate)(endDate), 'day')))
|
|
176
|
+
return false;
|
|
177
|
+
return true;
|
|
178
|
+
};
|
|
179
|
+
/**
|
|
180
|
+
* Disables empty banks for a specific customer's promise to purchase.
|
|
181
|
+
* If the disabled banks were the last active banks of the PA, disable the PA
|
|
182
|
+
* @async
|
|
183
|
+
* @param {{ [bankId: string]: number; }} bankIDsWithRemainingAmounts - The bank IDs to disable.
|
|
184
|
+
*/
|
|
185
|
+
this.disableEmptyPABanks = async (bankIDsWithRemainingAmounts) => {
|
|
186
|
+
// If none of the bank IDs are found in promises banks, throw error
|
|
187
|
+
if (this._data.banks.every((b) => !!!Object.keys(bankIDsWithRemainingAmounts).includes(b.bank_type_id)))
|
|
188
|
+
throw new Error('None of the provided bank IDs were found in promise');
|
|
189
|
+
let newBankArray = [...this._data.banks];
|
|
190
|
+
for (let [bankID, remaining] of Object.entries(bankIDsWithRemainingAmounts)) {
|
|
191
|
+
// Find the bank that matches the one that needs to be deactivated in the targeted PA and deactivate it
|
|
192
|
+
newBankArray = newBankArray.map((b) => {
|
|
193
|
+
if (b.bank_type_id !== bankID)
|
|
194
|
+
return b;
|
|
195
|
+
return Object.assign(Object.assign({}, b), { active: false, remaining_amount: remaining });
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
let newData = {
|
|
199
|
+
banks: newBankArray
|
|
200
|
+
};
|
|
201
|
+
// Check if the new bank array only has inactive banks, deactivate the target PA
|
|
202
|
+
const allBanksAreInactive = newBankArray.every((b) => !!!b.active);
|
|
203
|
+
if (!!allBanksAreInactive) {
|
|
204
|
+
newData = Object.assign(Object.assign({}, newData), { ending_date: new Date() });
|
|
205
|
+
}
|
|
206
|
+
// Save the targeted PA with a deactivated bank and an ending_date if it applies
|
|
207
|
+
await this.save(newData);
|
|
208
|
+
};
|
|
209
|
+
/**
|
|
210
|
+
* Function deactivate
|
|
211
|
+
* @description deactivates the promise
|
|
212
|
+
* @param save save to database?
|
|
213
|
+
*/
|
|
214
|
+
this.deactivate = async (save = false) => {
|
|
215
|
+
var _b;
|
|
216
|
+
this._data = Object.assign(Object.assign({}, this._data), { ending_date: (_b = this._data.ending_date) !== null && _b !== void 0 ? _b : new Date() });
|
|
217
|
+
if (!!save)
|
|
218
|
+
await this.save();
|
|
219
|
+
};
|
|
220
|
+
/**
|
|
221
|
+
* Function activate
|
|
222
|
+
* @description activates the promise from a given date
|
|
223
|
+
* @param newDate the date of starting validity
|
|
224
|
+
* @param save save to database?
|
|
225
|
+
*/
|
|
226
|
+
this.activate = async (newDate = new Date(), save = false) => {
|
|
227
|
+
this._data = Object.assign(Object.assign({}, this._data), { starting_date: newDate, ending_date: null });
|
|
228
|
+
if (!!save)
|
|
229
|
+
await this.save();
|
|
230
|
+
};
|
|
231
|
+
this.archive = async (save = false) => {
|
|
232
|
+
this._data = Object.assign(Object.assign({}, this._data), { archived: true });
|
|
233
|
+
if (!!save)
|
|
234
|
+
await this.save();
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* Returns a bank object.
|
|
239
|
+
* @param bankTypeId
|
|
240
|
+
*/
|
|
241
|
+
getBank(bankTypeId) {
|
|
242
|
+
return this._data.banks.find((b) => b.bank_type_id === bankTypeId);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
exports.default = PromiseToPurchase;
|
|
246
|
+
_a = PromiseToPurchase;
|
|
247
|
+
PromiseToPurchase.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'customer_pa_cust_id', f = '', space, useProspr = false }) => {
|
|
248
|
+
try {
|
|
249
|
+
let prosprSearch = false;
|
|
250
|
+
if (!!space) {
|
|
251
|
+
const prosprService = space
|
|
252
|
+
.data()
|
|
253
|
+
.external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
|
|
254
|
+
prosprSearch = !!prosprService && prosprService.is_active;
|
|
255
|
+
}
|
|
256
|
+
const algolia = (0, algolia_1.createClient)({
|
|
257
|
+
app,
|
|
258
|
+
indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
|
|
259
|
+
key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
|
|
260
|
+
prospr: !!prosprSearch || !!useProspr
|
|
261
|
+
});
|
|
262
|
+
const results = await algolia.search(query, {
|
|
263
|
+
hitsPerPage: hpp,
|
|
264
|
+
facetFilters: filters,
|
|
265
|
+
filters: f,
|
|
266
|
+
page,
|
|
267
|
+
facets: ['*']
|
|
268
|
+
});
|
|
269
|
+
return results;
|
|
270
|
+
}
|
|
271
|
+
catch (error) {
|
|
272
|
+
(0, console_1.errorMessage)(error);
|
|
273
|
+
throw error;
|
|
274
|
+
}
|
|
275
|
+
};
|
|
276
|
+
/**
|
|
277
|
+
*
|
|
278
|
+
* @param space
|
|
279
|
+
* @param hpp
|
|
280
|
+
* @param page
|
|
281
|
+
* @param query
|
|
282
|
+
* @param filters
|
|
283
|
+
* @param indice
|
|
284
|
+
* @param f
|
|
285
|
+
* @param useProspr
|
|
286
|
+
*/
|
|
287
|
+
PromiseToPurchase.fetchHistory = async ({ app, api, hpp = 50, page = 0, query = '', filters = '', indice = 'pa_bank_history', f = '', useProspr = false }) => {
|
|
288
|
+
try {
|
|
289
|
+
const results = await (0, searchIndexes_1.searchAPIFetchAlgoliaAddioSearch)({
|
|
290
|
+
app,
|
|
291
|
+
api,
|
|
292
|
+
indice,
|
|
293
|
+
hpp,
|
|
294
|
+
page,
|
|
295
|
+
query,
|
|
296
|
+
filters,
|
|
297
|
+
f,
|
|
298
|
+
useProspr
|
|
299
|
+
});
|
|
300
|
+
return results;
|
|
301
|
+
}
|
|
302
|
+
catch (e) {
|
|
303
|
+
console.log('error on fetching history for promises : ', e.toString());
|
|
304
|
+
}
|
|
305
|
+
};
|
|
306
|
+
/**
|
|
307
|
+
* Returns calculated remaining amounts for each bank
|
|
308
|
+
* @param actualCart the cart that we are trying to pay
|
|
309
|
+
* @param applicableBanks the banks that could be applied for user on cart
|
|
310
|
+
* @param applicableBanksHistory list of history entries for applicable banks
|
|
311
|
+
* @param space the Space obj
|
|
312
|
+
* @returns an array of banks used
|
|
313
|
+
*/
|
|
314
|
+
PromiseToPurchase.calculateRemainingAmounts = async (actualCart, applicableBanks, applicableBanksHistory, space) => {
|
|
315
|
+
// Fetch history for banks
|
|
316
|
+
let remainingAmountsForApplicableBanks = await space.promisesToPurchase.getAvailableAmountForApplicableBanks(applicableBanks, applicableBanksHistory);
|
|
317
|
+
if (!!!actualCart)
|
|
318
|
+
throw new Error(`ActualCart can't be undefined`);
|
|
319
|
+
const cartDataPA = actualCart.data().promise_to_purchase;
|
|
320
|
+
if (!!!cartDataPA || !!!cartDataPA.banks_used || cartDataPA.banks_used.length === 0)
|
|
321
|
+
throw new Error(`ActualCart must have an associated promise to purchase and at least one bank_used`);
|
|
322
|
+
// on calcule les montants restants dans les banques que le cart et la PA ont en commun
|
|
323
|
+
const remainingBankAmounts = applicableBanks.map((applicable) => {
|
|
324
|
+
const { bank, promise_id, promise_unique_id } = applicable;
|
|
325
|
+
const remainingAmount = remainingAmountsForApplicableBanks[bank.bank_type_id];
|
|
326
|
+
if (typeof remainingAmount === 'undefined')
|
|
327
|
+
return;
|
|
328
|
+
return {
|
|
329
|
+
bank_type_id: bank.bank_type_id,
|
|
330
|
+
amount: remainingAmount,
|
|
331
|
+
promise_id: promise_id,
|
|
332
|
+
promise_unique_id: promise_unique_id
|
|
333
|
+
};
|
|
334
|
+
});
|
|
335
|
+
return remainingBankAmounts.filter((bankApplied) => !!bankApplied);
|
|
336
|
+
};
|
|
337
|
+
PromiseToPurchase.getDefaultPromiseToPurchase = (customerId) => ({
|
|
338
|
+
archived: false,
|
|
339
|
+
promise_unique_id: '',
|
|
340
|
+
customer_id: customerId,
|
|
341
|
+
banks: [],
|
|
342
|
+
starting_date: (0, moment_1.default)().toDate()
|
|
343
|
+
});
|
|
344
344
|
//# sourceMappingURL=index.js.map
|