addio-admin-sdk 1.7.86 → 1.7.87
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 +14 -0
- package/.env.dev +14 -14
- package/.github/workflows/publish_coverage.yam_ +69 -69
- package/addio-sdk-doc.md +1473 -1473
- package/changelog.md +537 -537
- package/dist/Interfaces/Address/index.d.ts +21 -21
- package/dist/Interfaces/Address/index.js +16 -16
- package/dist/Interfaces/Algolia/index.d.ts +164 -164
- 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 +52 -52
- 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 +25 -25
- package/dist/Interfaces/CMS/index.js +2 -2
- 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 +424 -424
- package/dist/Interfaces/Cart/index.js +192 -192
- 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 +12 -12
- package/dist/Interfaces/Customer/IStoreCredit.js +2 -2
- package/dist/Interfaces/Customer/index.d.ts +97 -97
- package/dist/Interfaces/Customer/index.js +141 -141
- package/dist/Interfaces/Declination/index.d.ts +114 -114
- package/dist/Interfaces/Declination/index.js +60 -60
- 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 +56 -56
- 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 +36 -36
- 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 +97 -97
- package/dist/Interfaces/Indexed/Product/index.js +212 -212
- 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 +23 -23
- package/dist/Interfaces/Menu/index.js +10 -10
- package/dist/Interfaces/Note/index.d.ts +10 -0
- package/dist/Interfaces/Note/index.js +8 -0
- package/dist/Interfaces/Note/index.js.map +1 -0
- 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 +13 -13
- package/dist/Interfaces/Payment/index.js +2 -2
- 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 +791 -791
- package/dist/Interfaces/Product/IInventoryItem.d.ts +84 -84
- package/dist/Interfaces/Product/IInventoryItem.js +36 -36
- package/dist/Interfaces/Product/IPricing.d.ts +177 -177
- package/dist/Interfaces/Product/IPricing.js +174 -174
- package/dist/Interfaces/Product/index.d.ts +127 -127
- package/dist/Interfaces/Product/index.js +56 -56
- 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 +137 -137
- package/dist/Interfaces/Rules/IDiscountRule.js +95 -95
- 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 +12 -12
- 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 +48 -48
- 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 +52 -52
- package/dist/Interfaces/Space/IExternalService.js +43 -43
- package/dist/Interfaces/Space/IMember.d.ts +16 -16
- package/dist/Interfaces/Space/IMember.js +9 -9
- package/dist/Interfaces/Space/index.d.ts +385 -385
- package/dist/Interfaces/Space/index.js +159 -159
- 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 +62 -62
- 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 +110 -110
- package/dist/Interfaces/TCG/index.js +27 -27
- 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 +43 -43
- 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 +111 -111
- package/dist/constants/version.d.ts +2 -2
- package/dist/constants/version.js +5 -5
- package/dist/index.d.ts +32 -32
- package/dist/index.js +242 -242
- package/dist/lib/Attribute/index.d.ts +14 -14
- package/dist/lib/Attribute/index.js +143 -143
- package/dist/lib/BGJob/index.d.ts +9 -9
- package/dist/lib/BGJob/index.js +212 -212
- 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 +70 -70
- package/dist/lib/Booking/index.js +576 -576
- package/dist/lib/Brand/index.d.ts +17 -17
- package/dist/lib/Brand/index.js +113 -113
- package/dist/lib/Cart/index.d.ts +206 -206
- package/dist/lib/Cart/index.js +3164 -3164
- package/dist/lib/Catalogue/index.d.ts +9 -9
- package/dist/lib/Catalogue/index.js +69 -69
- package/dist/lib/Category/index.d.ts +27 -27
- package/dist/lib/Category/index.js +190 -190
- package/dist/lib/Class/index.d.ts +12 -12
- package/dist/lib/Class/index.js +58 -58
- package/dist/lib/Consent/index.d.ts +4 -4
- package/dist/lib/Consent/index.js +29 -29
- package/dist/lib/Customer/index.d.ts +11 -11
- package/dist/lib/Customer/index.js +68 -68
- package/dist/lib/Declination/index.d.ts +9 -9
- package/dist/lib/Declination/index.js +24 -24
- package/dist/lib/Discount/index.d.ts +18 -18
- package/dist/lib/Discount/index.js +470 -470
- package/dist/lib/ElasticSearch/index.d.ts +8 -8
- package/dist/lib/ElasticSearch/index.js +45 -45
- package/dist/lib/Elavon/index.d.ts +18 -18
- package/dist/lib/Elavon/index.js +130 -130
- package/dist/lib/Email/AbandonedCartEmail.d.ts +8 -8
- package/dist/lib/Email/AbandonedCartEmail.js +16 -16
- package/dist/lib/Email/AccountConfirmationEmail.d.ts +11 -11
- package/dist/lib/Email/AccountConfirmationEmail.js +22 -22
- package/dist/lib/Email/AdminOrderConfirmationEmail.d.ts +8 -8
- package/dist/lib/Email/AdminOrderConfirmationEmail.js +16 -16
- package/dist/lib/Email/ApplicationEmail.d.ts +8 -8
- package/dist/lib/Email/ApplicationEmail.js +16 -16
- package/dist/lib/Email/BackInStockEmail.d.ts +8 -8
- package/dist/lib/Email/BackInStockEmail.js +16 -16
- package/dist/lib/Email/ContactEmail.d.ts +8 -8
- package/dist/lib/Email/ContactEmail.js +16 -16
- package/dist/lib/Email/CustomerBookingAdminEmail.d.ts +8 -8
- package/dist/lib/Email/CustomerBookingAdminEmail.js +16 -16
- package/dist/lib/Email/CustomerBookingEmail.d.ts +8 -8
- package/dist/lib/Email/CustomerBookingEmail.js +16 -16
- package/dist/lib/Email/OrderConfirmationEmail.d.ts +8 -8
- package/dist/lib/Email/OrderConfirmationEmail.js +16 -16
- package/dist/lib/Email/OrderDenounciationEmail.d.ts +8 -8
- package/dist/lib/Email/OrderDenounciationEmail.js +16 -16
- package/dist/lib/Email/OrderSampleEmail.d.ts +8 -8
- package/dist/lib/Email/OrderSampleEmail.js +16 -16
- package/dist/lib/Email/OtherTypeEmails.d.ts +8 -8
- package/dist/lib/Email/OtherTypeEmails.js +19 -19
- package/dist/lib/Email/PasswordResetEmail.d.ts +8 -8
- package/dist/lib/Email/PasswordResetEmail.js +16 -16
- package/dist/lib/Email/PhotoShootEmail.d.ts +8 -8
- package/dist/lib/Email/PhotoShootEmail.js +16 -16
- package/dist/lib/Email/PickUpConfirmation.d.ts +8 -8
- package/dist/lib/Email/PickUpConfirmation.js +16 -16
- package/dist/lib/Email/ShippingConfirmation.d.ts +8 -8
- package/dist/lib/Email/ShippingConfirmation.js +16 -16
- package/dist/lib/Email/WelcomeEmail.d.ts +8 -8
- package/dist/lib/Email/WelcomeEmail.js +16 -16
- package/dist/lib/Email/index.d.ts +8 -8
- package/dist/lib/Email/index.js +23 -23
- package/dist/lib/ExternalService/Ebay.d.ts +62 -62
- package/dist/lib/ExternalService/Ebay.js +102 -102
- 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 +86 -86
- package/dist/lib/Indexed/Product.d.ts +17 -17
- package/dist/lib/Indexed/Product.js +48 -48
- package/dist/lib/Inventory/index.d.ts +49 -49
- package/dist/lib/Inventory/index.js +314 -314
- package/dist/lib/Invoice/index.d.ts +5 -5
- package/dist/lib/Invoice/index.js +10 -10
- package/dist/lib/MarketplacePublication/index.d.ts +9 -9
- package/dist/lib/MarketplacePublication/index.js +118 -118
- package/dist/lib/Menu/index.d.ts +11 -11
- package/dist/lib/Menu/index.js +103 -103
- 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 -0
- package/dist/lib/Note/index.js +7 -0
- package/dist/lib/Note/index.js.map +1 -0
- package/dist/lib/Order/index.d.ts +7 -7
- package/dist/lib/Order/index.js +33 -33
- package/dist/lib/Org/index.d.ts +27 -27
- package/dist/lib/Org/index.js +175 -175
- package/dist/lib/PandaPay/index.d.ts +16 -16
- package/dist/lib/PandaPay/index.js +170 -170
- package/dist/lib/Paysafe/index.d.ts +11 -11
- package/dist/lib/Paysafe/index.js +40 -40
- package/dist/lib/Product/index.d.ts +154 -154
- package/dist/lib/Product/index.js +793 -793
- package/dist/lib/ProductAttribute/index.d.ts +15 -15
- package/dist/lib/ProductAttribute/index.js +45 -45
- package/dist/lib/PromiseToPurchase/index.d.ts +37 -37
- package/dist/lib/PromiseToPurchase/index.js +264 -264
- package/dist/lib/PurchaseOrder/index.d.ts +9 -9
- package/dist/lib/PurchaseOrder/index.js +16 -16
- 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 +5 -5
- package/dist/lib/Service/index.js +13 -13
- package/dist/lib/Shipment/index.d.ts +28 -28
- package/dist/lib/Shipment/index.js +357 -357
- package/dist/lib/Slider/index.d.ts +16 -16
- package/dist/lib/Slider/index.js +113 -113
- package/dist/lib/Space/index.d.ts +873 -873
- package/dist/lib/Space/index.js +5094 -5094
- 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 +22 -22
- package/dist/lib/Tags/index.d.ts +6 -6
- package/dist/lib/Tags/index.js +21 -21
- package/dist/lib/Tax/index.d.ts +8 -8
- package/dist/lib/Tax/index.js +54 -54
- package/dist/lib/TransferRequest/index.d.ts +112 -112
- package/dist/lib/TransferRequest/index.js +794 -794
- package/dist/lib/Update/index.d.ts +10 -10
- package/dist/lib/Update/index.js +22 -22
- package/dist/lib/User/index.d.ts +35 -35
- package/dist/lib/User/index.js +248 -248
- 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 +43 -43
- package/dist/rules/GR/constants/data.d.ts +26 -26
- package/dist/rules/GR/constants/data.js +55 -55
- package/dist/rules/GR/constants/products.d.ts +8 -8
- package/dist/rules/GR/constants/products.js +234 -234
- package/dist/rules/GR/interfaces/cart.d.ts +84 -83
- package/dist/rules/GR/interfaces/cart.js +41 -40
- package/dist/rules/GR/interfaces/cart.js.map +1 -1
- package/dist/rules/GR/interfaces/data.d.ts +97 -97
- package/dist/rules/GR/interfaces/data.js +104 -104
- 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 +53 -53
- package/dist/rules/GR/utils/cart.js +637 -631
- package/dist/rules/GR/utils/cart.js.map +1 -1
- package/dist/rules/GR/utils/data.d.ts +3 -3
- package/dist/rules/GR/utils/data.js +25 -25
- package/dist/rules/GR/utils/expedition.d.ts +71 -71
- package/dist/rules/GR/utils/expedition.js +1542 -1542
- package/dist/rules/GR/utils/g2.d.ts +176 -176
- package/dist/rules/GR/utils/g2.js +845 -845
- package/dist/rules/GR/utils/invoices.d.ts +24 -24
- package/dist/rules/GR/utils/invoices.js +174 -171
- package/dist/rules/GR/utils/invoices.js.map +1 -1
- package/dist/rules/GR/utils/products.d.ts +104 -104
- package/dist/rules/GR/utils/products.js +984 -984
- package/dist/rules/GR/utils/upsells.d.ts +79 -79
- package/dist/rules/GR/utils/upsells.js +183 -183
- 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 +41 -41
- package/dist/services/database/DatabaseService.js +152 -152
- package/dist/services/database/FirebaseProvider.d.ts +17 -17
- package/dist/services/database/FirebaseProvider.js +218 -218
- package/dist/services/database/NotFirebaseProvider.d.ts +35 -35
- package/dist/services/database/NotFirebaseProvider.js +243 -243
- package/dist/services/g2/G2OrderSlip.d.ts +42 -42
- package/dist/services/g2/G2OrderSlip.js +210 -210
- package/dist/services/g2/utils.d.ts +9 -9
- package/dist/services/g2/utils.js +703 -695
- package/dist/services/g2/utils.js.map +1 -1
- package/dist/services/logs/index.d.ts +20 -20
- package/dist/services/logs/index.js +61 -61
- package/dist/services/products/BaseClass.d.ts +50 -50
- package/dist/services/products/BaseClass.js +64 -64
- package/dist/services/products/TCGService.d.ts +29 -29
- package/dist/services/products/TCGService.js +499 -499
- package/dist/services/products/utils.d.ts +9 -9
- package/dist/services/products/utils.js +94 -94
- package/dist/utils/algolia.d.ts +6 -6
- package/dist/utils/algolia.js +21 -21
- package/dist/utils/anonymisation.d.ts +30 -30
- package/dist/utils/anonymisation.js +250 -250
- package/dist/utils/array.d.ts +5 -5
- package/dist/utils/array.js +14 -14
- package/dist/utils/aws.d.ts +14 -14
- package/dist/utils/aws.js +126 -126
- package/dist/utils/booking.d.ts +22 -22
- package/dist/utils/booking.js +118 -118
- package/dist/utils/cart.d.ts +103 -102
- package/dist/utils/cart.js +690 -652
- package/dist/utils/cart.js.map +1 -1
- 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 +61 -61
- package/dist/utils/data.d.ts +31 -31
- package/dist/utils/data.js +293 -293
- 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 +46 -46
- package/dist/utils/discount.js +934 -934
- 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 +38 -38
- package/dist/utils/file.d.ts +38 -38
- package/dist/utils/file.js +200 -200
- package/dist/utils/firebase-admin.d.ts +2 -2
- package/dist/utils/firebase-admin.js +61 -61
- package/dist/utils/firebase.d.ts +41 -41
- package/dist/utils/firebase.js +131 -131
- package/dist/utils/import.d.ts +1 -1
- package/dist/utils/import.js +21 -21
- package/dist/utils/inventories.d.ts +49 -49
- package/dist/utils/inventories.js +392 -392
- package/dist/utils/locale.d.ts +15 -15
- package/dist/utils/locale.js +78 -78
- package/dist/utils/mailchimp.d.ts +58 -58
- package/dist/utils/mailchimp.js +495 -495
- package/dist/utils/mathUtils.d.ts +17 -17
- package/dist/utils/mathUtils.js +315 -315
- package/dist/utils/mongodb.d.ts +1 -1
- package/dist/utils/mongodb.js +22 -22
- package/dist/utils/object.d.ts +13 -13
- package/dist/utils/object.js +115 -115
- package/dist/utils/payment.d.ts +10 -10
- package/dist/utils/payment.js +23 -23
- package/dist/utils/products.d.ts +32 -32
- package/dist/utils/products.js +186 -186
- package/dist/utils/promiseToPurchase.d.ts +56 -56
- package/dist/utils/promiseToPurchase.js +195 -195
- package/dist/utils/prosprsearch.d.ts +26 -26
- package/dist/utils/prosprsearch.js +182 -182
- 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 +1302 -1302
- package/dist/utils/searchIndexes.d.ts +21 -21
- package/dist/utils/searchIndexes.js +210 -210
- 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 +191 -191
- package/dist/utils/tcgService.d.ts +2 -2
- package/dist/utils/tcgService.js +8 -8
- package/dist/utils/tools.d.ts +1 -1
- package/dist/utils/tools.js +9 -9
- package/dist/utils/transferRequests.d.ts +19 -19
- package/dist/utils/transferRequests.js +43 -43
- package/dist/utils/update.d.ts +7 -7
- package/dist/utils/update.js +125 -125
- 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 +110 -110
- package/publish.sh +143 -143
- package/readme.md +182 -182
|
@@ -1,795 +1,795 @@
|
|
|
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
|
-
exports.TransferRequest = void 0;
|
|
8
|
-
const TransferRequest_1 = require("../../Interfaces/TransferRequest");
|
|
9
|
-
const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
|
|
10
|
-
const baseService_1 = require("../baseService");
|
|
11
|
-
const Inventory_1 = __importDefault(require("../Inventory"));
|
|
12
|
-
const Space_1 = __importDefault(require("../Space"));
|
|
13
|
-
const toNumber_1 = __importDefault(require("lodash/toNumber"));
|
|
14
|
-
const ceil_1 = __importDefault(require("lodash/ceil"));
|
|
15
|
-
const round_1 = __importDefault(require("lodash/round"));
|
|
16
|
-
const data_1 = require("../../utils/data");
|
|
17
|
-
const inventories_1 = require("../../utils/inventories");
|
|
18
|
-
const transferRequests_1 = require("../../utils/transferRequests");
|
|
19
|
-
const sumBy_1 = __importDefault(require("lodash/sumBy"));
|
|
20
|
-
const weight_1 = require("../../utils/weight");
|
|
21
|
-
const algolia_1 = require("../../utils/algolia");
|
|
22
|
-
const __1 = require("../..");
|
|
23
|
-
const console_1 = require("../../utils/console");
|
|
24
|
-
const context_1 = require("../../utils/context");
|
|
25
|
-
const tools_1 = require("../../utils/tools");
|
|
26
|
-
const products_1 = require("../../rules/GR/utils/products");
|
|
27
|
-
const Cart_1 = require("../../Interfaces/Cart");
|
|
28
|
-
class TransferRequest extends baseService_1.BaseServiceClass {
|
|
29
|
-
constructor(_data, _collection, _user) {
|
|
30
|
-
super(_data, _collection, _user);
|
|
31
|
-
this._listener = null;
|
|
32
|
-
this.prevProducts = [];
|
|
33
|
-
this.prevFromStore = undefined;
|
|
34
|
-
this.processData = (data) => (Object.assign(Object.assign({}, data), { transfer_updates: data.transfer_updates.map((update) => (Object.assign(Object.assign({}, update), { date: (0, data_1.formatDate)(update.date) }))) }));
|
|
35
|
-
this.checkIfTransferCanBeClosedManually = () => {
|
|
36
|
-
return this._data.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL;
|
|
37
|
-
};
|
|
38
|
-
this.transferAllowAssignFromStore = () => TransferRequest.transferAllowAssignFromStore(this._data);
|
|
39
|
-
this.transferAllowEditFromStore = () => TransferRequest.transferAllowEditFromStore(this._data);
|
|
40
|
-
this.transferAllowAddProductOnEdit = () => TransferRequest.transferAllowAddProductOnEdit(this._data);
|
|
41
|
-
this.transferAllowProductDelete = () => TransferRequest.transferAllowProductDelete(this._data);
|
|
42
|
-
this.transferAllowEditProductOnEdit = () => TransferRequest.transferAllowEditProductOnEdit(this._data);
|
|
43
|
-
this.transferAllowDeleteProductOnEdit = () => TransferRequest.transferAllowProductDelete(this._data);
|
|
44
|
-
this.transferShouldDisplayWeight = () => TransferRequest.transferShouldDisplayWeight(this._data);
|
|
45
|
-
this.transferAllowsIndependantProductUpdate = () => TransferRequest.transferAllowsIndependantProductUpdate(this._data);
|
|
46
|
-
this.fetchAssociatedCart = async () => {
|
|
47
|
-
if (!!!this._data.associated_order)
|
|
48
|
-
return;
|
|
49
|
-
let associatedCart = undefined;
|
|
50
|
-
try {
|
|
51
|
-
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
52
|
-
const cartQuery = await space.carts.get({
|
|
53
|
-
query: [{ field: 'ref', operator: '==', value: this._data.associated_order }]
|
|
54
|
-
});
|
|
55
|
-
if (!!cartQuery && !!cartQuery.length)
|
|
56
|
-
associatedCart = cartQuery[0];
|
|
57
|
-
}
|
|
58
|
-
catch (e) {
|
|
59
|
-
console.log('could not fetch cart associated to transfer: ', e.toString());
|
|
60
|
-
}
|
|
61
|
-
return associatedCart;
|
|
62
|
-
};
|
|
63
|
-
this.addProduct = (sku, parent_slug, qte, name, image, other_units, weight, count_in_pallet_total) => {
|
|
64
|
-
const data = this.data();
|
|
65
|
-
if (!TransferRequest.transferAllowEditProductOnEdit(this._data))
|
|
66
|
-
return false;
|
|
67
|
-
let updatedProducts = data.products;
|
|
68
|
-
if (!updatedProducts.find((p) => p.sku == sku)) {
|
|
69
|
-
updatedProducts.push({
|
|
70
|
-
sku,
|
|
71
|
-
parent_slug,
|
|
72
|
-
qte,
|
|
73
|
-
name,
|
|
74
|
-
image,
|
|
75
|
-
other_units,
|
|
76
|
-
weight,
|
|
77
|
-
count_in_pallet_total,
|
|
78
|
-
qte_received: 0
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
else {
|
|
82
|
-
updatedProducts = updatedProducts.map((p) => {
|
|
83
|
-
if (p.sku !== sku)
|
|
84
|
-
return p;
|
|
85
|
-
return Object.assign(Object.assign({}, p), { qte: p.qte + qte <= 1 ? 1 : p.qte + qte });
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
this._data = Object.assign(Object.assign({}, data), { products: updatedProducts });
|
|
89
|
-
return true;
|
|
90
|
-
};
|
|
91
|
-
this.editProduct = (sku, newQte) => {
|
|
92
|
-
const data = this.data();
|
|
93
|
-
if (!TransferRequest.transferAllowEditProductOnEdit(this._data))
|
|
94
|
-
return false;
|
|
95
|
-
this._data = Object.assign(Object.assign({}, data), { products: data.products.map((p) => {
|
|
96
|
-
if (p.sku !== sku)
|
|
97
|
-
return p;
|
|
98
|
-
return Object.assign(Object.assign({}, p), { qte: newQte });
|
|
99
|
-
}) });
|
|
100
|
-
return true;
|
|
101
|
-
};
|
|
102
|
-
this.deleteProduct = (sku) => {
|
|
103
|
-
const data = this.data();
|
|
104
|
-
if (!TransferRequest.transferAllowProductDelete(this._data))
|
|
105
|
-
return false;
|
|
106
|
-
this._data = Object.assign(Object.assign({}, data), { products: data.products.filter((p) => p.sku !== sku) });
|
|
107
|
-
return true;
|
|
108
|
-
};
|
|
109
|
-
this.data = () => this._data;
|
|
110
|
-
this.isListening = () => !!this._listener;
|
|
111
|
-
this.killListener = () => {
|
|
112
|
-
if (!!!this._listener)
|
|
113
|
-
return false;
|
|
114
|
-
this._listener = null;
|
|
115
|
-
return true;
|
|
116
|
-
};
|
|
117
|
-
this.listen = (callback) => {
|
|
118
|
-
if (!!this._listener)
|
|
119
|
-
return false;
|
|
120
|
-
DatabaseService_1.default.registerListener((snap) => {
|
|
121
|
-
if (snap === null)
|
|
122
|
-
this._listener = null;
|
|
123
|
-
if (snap.length === 0)
|
|
124
|
-
this._listener = null;
|
|
125
|
-
snap.map((s) => {
|
|
126
|
-
if (s.id == this.data().id) {
|
|
127
|
-
this._data = this.processData(s.data);
|
|
128
|
-
if (!!callback)
|
|
129
|
-
callback();
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
}, this._collection.path, { id: this.data().id });
|
|
133
|
-
return true;
|
|
134
|
-
};
|
|
135
|
-
this._getTransferRef = async () => {
|
|
136
|
-
let newRef = undefined;
|
|
137
|
-
try {
|
|
138
|
-
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
139
|
-
const token = (0, context_1.getSpaceTokenFromSpaceOnly)(space);
|
|
140
|
-
const api = __1.API_URL;
|
|
141
|
-
let triesLeft = 3;
|
|
142
|
-
while (triesLeft > 0) {
|
|
143
|
-
try {
|
|
144
|
-
const resp = await fetch(`${api}/transfers/refnumber`, {
|
|
145
|
-
method: 'GET',
|
|
146
|
-
headers: {
|
|
147
|
-
'Content-Type': 'application/json',
|
|
148
|
-
Authorization: `Bearer ${token}`
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
if (resp.status >= 200 && resp.status < 300) {
|
|
152
|
-
const data = await resp.json();
|
|
153
|
-
if (data.status == 'success') {
|
|
154
|
-
newRef = (0, toNumber_1.default)(data.result);
|
|
155
|
-
break;
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
catch (e) {
|
|
160
|
-
console.log('Error fetching transfer number', e);
|
|
161
|
-
}
|
|
162
|
-
await (0, tools_1.waitFor)(1000);
|
|
163
|
-
triesLeft--;
|
|
164
|
-
}
|
|
165
|
-
if (triesLeft == 0)
|
|
166
|
-
throw new Error('could not get a Ref number');
|
|
167
|
-
return newRef;
|
|
168
|
-
}
|
|
169
|
-
catch (e) {
|
|
170
|
-
console.log('error on fetching new transfer ref: ', e.toString());
|
|
171
|
-
return;
|
|
172
|
-
}
|
|
173
|
-
};
|
|
174
|
-
this.save = async (partial, saveToDatabase = true, merge = true) => {
|
|
175
|
-
const saveResult = await super.save(partial, undefined, saveToDatabase, undefined, merge);
|
|
176
|
-
if (typeof saveResult === 'string') {
|
|
177
|
-
this._data = Object.assign(Object.assign({}, this._data), { id: saveResult });
|
|
178
|
-
}
|
|
179
|
-
return saveResult;
|
|
180
|
-
};
|
|
181
|
-
this.validateBeforeSubmit = async (strictQty = true) => {
|
|
182
|
-
if (strictQty) {
|
|
183
|
-
return this.data().products.every((p) => typeof p.qte_validation == 'undefined' || p.qte === p.qte_validation);
|
|
184
|
-
}
|
|
185
|
-
return this.data().products.every((p) => typeof p.qte_validation == 'undefined' || p.qte_validation >= 0);
|
|
186
|
-
};
|
|
187
|
-
this.clearValidationQuantitiesFromProductData = (copyQte = false) => {
|
|
188
|
-
this._data = Object.assign(Object.assign({}, this._data), { products: this._data.products.map((p) => (Object.assign(Object.assign({}, p), { qte: copyQte ? p.qte_validation || 0 : p.qte, qte_validation: undefined }))) });
|
|
189
|
-
};
|
|
190
|
-
this.addValidationQuantitiesToReceivedQuantities = () => {
|
|
191
|
-
this._data = Object.assign(Object.assign({}, this._data), { products: this._data.products.map((p) => (Object.assign(Object.assign({}, p), { qte_received: (p.qte_validation || 0) + (p.qte_received || 0), qte_validation: undefined }))) });
|
|
192
|
-
};
|
|
193
|
-
this.getPreviousReceivedQuantity = (sku) => {
|
|
194
|
-
const entry = this._data.transfer_updates.find((u) => (u.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL || u.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED) &&
|
|
195
|
-
u.products &&
|
|
196
|
-
u.products[sku]);
|
|
197
|
-
if (entry) {
|
|
198
|
-
return entry.products[sku].qte_after;
|
|
199
|
-
}
|
|
200
|
-
return 0;
|
|
201
|
-
};
|
|
202
|
-
this.getOriginalRequestedQuantity = (sku) => {
|
|
203
|
-
const product = this._data.products.find((p) => p.sku == sku);
|
|
204
|
-
if (!product)
|
|
205
|
-
return 0;
|
|
206
|
-
let result = product.qte;
|
|
207
|
-
this._data.transfer_updates.map((u) => {
|
|
208
|
-
if (u.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL &&
|
|
209
|
-
u.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED &&
|
|
210
|
-
u.products &&
|
|
211
|
-
u.products[sku])
|
|
212
|
-
result = u.products[sku].qte_before;
|
|
213
|
-
});
|
|
214
|
-
return result;
|
|
215
|
-
};
|
|
216
|
-
this.getQuantityAtStatus = (sku, status) => {
|
|
217
|
-
const statusPos = (0, transferRequests_1.getOrderPositionForStatus)(status, TransferRequest_1.transferRequestStatusOrder) || 0;
|
|
218
|
-
if (statusPos == 0) {
|
|
219
|
-
const updates = this._data.transfer_updates.filter((u) => u.status == status);
|
|
220
|
-
if (!updates.some((u) => !!u.products && !!u.products && !!u.products[sku]))
|
|
221
|
-
return this.getOriginalRequestedQuantity(sku);
|
|
222
|
-
}
|
|
223
|
-
const product = this._data.products.find((p) => p.sku == sku);
|
|
224
|
-
if (!product)
|
|
225
|
-
return 0;
|
|
226
|
-
let result = product.qte;
|
|
227
|
-
for (let i of this._data.transfer_updates) {
|
|
228
|
-
if (((0, transferRequests_1.getOrderPositionForStatus)(i.status, TransferRequest_1.transferRequestStatusOrder) || 0) <= statusPos &&
|
|
229
|
-
i.products &&
|
|
230
|
-
i.products[sku]) {
|
|
231
|
-
result = i.products[sku].qte_after;
|
|
232
|
-
break;
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
return result;
|
|
236
|
-
};
|
|
237
|
-
this.getInventoryQuantitiesStillMissingForCartTransfer = (associatedCart, itemSku, otherUnits) => {
|
|
238
|
-
var _b;
|
|
239
|
-
if (!!!associatedCart)
|
|
240
|
-
return 0;
|
|
241
|
-
const sameProd = associatedCart.data().items.find((i) => i.sku == itemSku);
|
|
242
|
-
if (!!!sameProd)
|
|
243
|
-
return 0;
|
|
244
|
-
const alreadyReservedQuantities = (_b = sameProd.qte_reserved) !== null && _b !== void 0 ? _b : 0;
|
|
245
|
-
const quantitiesNeededForCart = sameProd.qte - alreadyReservedQuantities;
|
|
246
|
-
const convertedToInventoryForCartQuantities = (0, inventories_1.getConvertedUnitQuantity)(otherUnits, quantitiesNeededForCart, 'inventory_unit');
|
|
247
|
-
return convertedToInventoryForCartQuantities;
|
|
248
|
-
};
|
|
249
|
-
this.handleFreeTransitInventory = async () => {
|
|
250
|
-
if (!this._data.from || this._data.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL)
|
|
251
|
-
return false;
|
|
252
|
-
try {
|
|
253
|
-
if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
|
|
254
|
-
return false;
|
|
255
|
-
const inventoryColl = DatabaseService_1.default.asCollectionObject(DatabaseService_1.default.getPathParent(this._collection.path), 'inventories');
|
|
256
|
-
for (const product of this._data.products) {
|
|
257
|
-
if (product.qte_received >= product.qte)
|
|
258
|
-
continue;
|
|
259
|
-
const inventoryItemQuery = await DatabaseService_1.default.getDocument(inventoryColl.path, product.sku);
|
|
260
|
-
if (!!!inventoryItemQuery.exists)
|
|
261
|
-
continue;
|
|
262
|
-
const inventoryItem = new Inventory_1.default(inventoryItemQuery.data, inventoryColl, this._user);
|
|
263
|
-
await inventoryItem.handleCancelInTransit(this._data.from, product.qte - product.qte_received, undefined, !!this._data.associated_order);
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
catch (err) {
|
|
267
|
-
console.log('err', err);
|
|
268
|
-
return false;
|
|
269
|
-
}
|
|
270
|
-
};
|
|
271
|
-
this.handleChangeStoreInventory = async (newStatus) => {
|
|
272
|
-
if (!this._data.from)
|
|
273
|
-
return false;
|
|
274
|
-
try {
|
|
275
|
-
if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
|
|
276
|
-
return false;
|
|
277
|
-
const inventoryColl = DatabaseService_1.default.asCollectionObject(DatabaseService_1.default.getPathParent(this._collection.path), 'inventories');
|
|
278
|
-
let associatedCart;
|
|
279
|
-
if (newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED || newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL) {
|
|
280
|
-
try {
|
|
281
|
-
associatedCart = await this.fetchAssociatedCart();
|
|
282
|
-
}
|
|
283
|
-
catch (e) {
|
|
284
|
-
console.log('error on fetching cart for transfer: ', e.toString());
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
for (const product of this._data.products) {
|
|
288
|
-
const inventoryItemQuery = await DatabaseService_1.default.getDocument(inventoryColl.path, product.sku);
|
|
289
|
-
if (!!!inventoryItemQuery.exists)
|
|
290
|
-
continue;
|
|
291
|
-
const inventoryItem = new Inventory_1.default(inventoryItemQuery.data, inventoryColl, this._user);
|
|
292
|
-
switch (newStatus) {
|
|
293
|
-
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
294
|
-
await inventoryItem.handleTransferInTransit(this._data.from, product.qte, undefined, !!this._data.associated_order);
|
|
295
|
-
break;
|
|
296
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
297
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
298
|
-
const qteReceivedSinceLastStatus = product.qte_received - this.getPreviousReceivedQuantity(product.sku);
|
|
299
|
-
if (qteReceivedSinceLastStatus == 0)
|
|
300
|
-
continue;
|
|
301
|
-
const cartWasProcessed = !!associatedCart && associatedCart.data().status > Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS;
|
|
302
|
-
const qteToReserve = cartWasProcessed
|
|
303
|
-
? undefined
|
|
304
|
-
: this.getInventoryQuantitiesStillMissingForCartTransfer(associatedCart, product.sku, inventoryItem.data().other_units);
|
|
305
|
-
await inventoryItem.handleTransferReceived(this._data.from, this._data.to, qteReceivedSinceLastStatus, undefined, {
|
|
306
|
-
forOrder: !!this._data.associated_order,
|
|
307
|
-
maxProcessingQte: typeof qteToReserve == 'number' && qteToReserve >= 0
|
|
308
|
-
? qteToReserve > qteReceivedSinceLastStatus
|
|
309
|
-
? qteReceivedSinceLastStatus
|
|
310
|
-
: qteToReserve
|
|
311
|
-
: 0,
|
|
312
|
-
skipWebUpdateForAvailable: cartWasProcessed
|
|
313
|
-
});
|
|
314
|
-
break;
|
|
315
|
-
}
|
|
316
|
-
continue;
|
|
317
|
-
}
|
|
318
|
-
return true;
|
|
319
|
-
}
|
|
320
|
-
catch (err) {
|
|
321
|
-
console.log('err', err);
|
|
322
|
-
return false;
|
|
323
|
-
}
|
|
324
|
-
};
|
|
325
|
-
this.handleUpdateAssociatedCartReservedQuantities = async () => {
|
|
326
|
-
var _b, _c;
|
|
327
|
-
const associatedCart = await this.fetchAssociatedCart();
|
|
328
|
-
if (!!!associatedCart)
|
|
329
|
-
return;
|
|
330
|
-
if (associatedCart.data().status > Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS)
|
|
331
|
-
return;
|
|
332
|
-
let somethingHasChanged = false;
|
|
333
|
-
let cartItems = associatedCart.data().items;
|
|
334
|
-
let updatedCartItems = [];
|
|
335
|
-
for (let item of cartItems) {
|
|
336
|
-
const sameInTransfer = this._data.products.find((p) => p.sku == item.sku);
|
|
337
|
-
if (!!!sameInTransfer) {
|
|
338
|
-
updatedCartItems.push(item);
|
|
339
|
-
continue;
|
|
340
|
-
}
|
|
341
|
-
const sellUnit = (item.other_units || []).find((o) => o.is_sale_unit);
|
|
342
|
-
const unitHasDecimals = !!sellUnit && (0, products_1.productUnitSupportsDecimals)(sellUnit.unit_slug);
|
|
343
|
-
if (typeof item.qte_reserved == 'number' && (0, round_1.default)(item.qte_reserved, unitHasDecimals ? 2 : 0) >= item.qte) {
|
|
344
|
-
updatedCartItems.push(item);
|
|
345
|
-
continue;
|
|
346
|
-
}
|
|
347
|
-
const qteReceivedSinceLastStatus = sameInTransfer.qte_received - this.getPreviousReceivedQuantity(sameInTransfer.sku);
|
|
348
|
-
if (!!!qteReceivedSinceLastStatus) {
|
|
349
|
-
updatedCartItems.push(item);
|
|
350
|
-
continue;
|
|
351
|
-
}
|
|
352
|
-
const reservedQteInInventoryUnit = (0, inventories_1.getConvertedUnitQuantity)(item.other_units, (_b = item.qte_reserved) !== null && _b !== void 0 ? _b : 0, 'inventory_unit');
|
|
353
|
-
const qteInInventoryUnit = (0, inventories_1.getConvertedUnitQuantity)(item.other_units, (_c = item.qte) !== null && _c !== void 0 ? _c : 0, 'inventory_unit');
|
|
354
|
-
const newReservedQte = reservedQteInInventoryUnit + qteReceivedSinceLastStatus;
|
|
355
|
-
updatedCartItems.push(Object.assign(Object.assign({}, item), { qte_reserved: (0, inventories_1.getConvertedUnitQuantity)(item.other_units, newReservedQte > qteInInventoryUnit ? qteInInventoryUnit : newReservedQte, 'sale_unit', true) }));
|
|
356
|
-
somethingHasChanged = true;
|
|
357
|
-
}
|
|
358
|
-
if (!!!somethingHasChanged)
|
|
359
|
-
return;
|
|
360
|
-
try {
|
|
361
|
-
await associatedCart.save({ items: updatedCartItems, id: associatedCart.data().id }, undefined, true, true, true);
|
|
362
|
-
}
|
|
363
|
-
catch (e) {
|
|
364
|
-
console.log('error on saving cart with new qte_received in items: ', e.toString());
|
|
365
|
-
}
|
|
366
|
-
};
|
|
367
|
-
this.constructProductObjFromUpdates = (updatesToDo) => {
|
|
368
|
-
let updatedProducts = this._data.products.map((currentProd) => {
|
|
369
|
-
const sameInUpdates = updatesToDo.find((u) => u.sku == currentProd.sku);
|
|
370
|
-
if (!!!sameInUpdates)
|
|
371
|
-
return currentProd;
|
|
372
|
-
let newQte = currentProd.qte + sameInUpdates.ajustmentQte;
|
|
373
|
-
if (newQte < 0)
|
|
374
|
-
newQte = 0;
|
|
375
|
-
return Object.assign(Object.assign({}, currentProd), { qte: newQte });
|
|
376
|
-
});
|
|
377
|
-
return updatedProducts;
|
|
378
|
-
};
|
|
379
|
-
this.saveUpdatesToContentOnly = async (updatedContent, options, cancelTransferIfAllProductsAtZero, updateContext = TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_UPDATED) => {
|
|
380
|
-
if (updatedContent.products) {
|
|
381
|
-
if (!TransferRequest.transferAllowsIndependantProductUpdate(this._data)) {
|
|
382
|
-
throw new Error('Cannot update products without changing status for current transfer status.');
|
|
383
|
-
}
|
|
384
|
-
await this.save({ products: updatedContent.products }, false, true);
|
|
385
|
-
if (!!updatedContent.products.some((p) => typeof p.qte_validation == 'number')) {
|
|
386
|
-
this.clearValidationQuantitiesFromProductData(true);
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
if (updatedContent.fromStore) {
|
|
390
|
-
if (!TransferRequest.transferAllowEditFromStore(this._data)) {
|
|
391
|
-
throw new Error('Cannot update origin store for this transfer.');
|
|
392
|
-
}
|
|
393
|
-
await this.save({ from: updatedContent.fromStore }, false, true);
|
|
394
|
-
}
|
|
395
|
-
try {
|
|
396
|
-
const statusPositionObj = await this._getOrderObject();
|
|
397
|
-
const shouldCancelTransfer = updatedContent.products &&
|
|
398
|
-
cancelTransferIfAllProductsAtZero &&
|
|
399
|
-
updatedContent.products.every((p) => p.qte <= 0) &&
|
|
400
|
-
TransferRequest.checkIfTransferCanBeCancelled(this._data.status, statusPositionObj);
|
|
401
|
-
const statusToUse = !!shouldCancelTransfer ? TransferRequest_1.TransferRequestStatusEnum.CANCELLED : this._data.status;
|
|
402
|
-
const newUpdates = this._generateNewTransferStatusUpdates(statusToUse, options.user, options.comment, undefined, updateContext);
|
|
403
|
-
await this.save(Object.assign({ transfer_updates: newUpdates }, (shouldCancelTransfer ? { status: statusToUse, completed: true } : {})), true, true);
|
|
404
|
-
}
|
|
405
|
-
catch (e) {
|
|
406
|
-
const errorStr = 'error on updating products independantly from status: ' + e.toString();
|
|
407
|
-
console.log(errorStr);
|
|
408
|
-
throw new Error(errorStr);
|
|
409
|
-
}
|
|
410
|
-
return this.data();
|
|
411
|
-
};
|
|
412
|
-
this.setDraftValue = (newVal) => {
|
|
413
|
-
this._data = Object.assign(Object.assign({}, this._data), { draft: newVal });
|
|
414
|
-
};
|
|
415
|
-
this.setAssociatedOrder = (newVal) => {
|
|
416
|
-
this._data = Object.assign(Object.assign({}, this._data), { associated_order: newVal });
|
|
417
|
-
};
|
|
418
|
-
this.setTransportRef = async (newVal, saveToDatabase = false) => {
|
|
419
|
-
await this.save({ transport_ref: newVal }, saveToDatabase, true);
|
|
420
|
-
};
|
|
421
|
-
this.setOriginalTransferId = async (newVal) => {
|
|
422
|
-
this._data = Object.assign(Object.assign({}, this._data), { original_transfer_id: newVal });
|
|
423
|
-
};
|
|
424
|
-
this.setAsCompleted = async (user, comment) => {
|
|
425
|
-
this._generateNewTransferStatusUpdates(this._data.status, user, `Fermé manuellement${!!comment ? ' : ' + comment : ''}`, this._data.products, TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_COMPLETED_MANUALLY);
|
|
426
|
-
await this.handleFreeTransitInventory();
|
|
427
|
-
await this.save({ completed: true }, true, true);
|
|
428
|
-
};
|
|
429
|
-
this.changeStatus = async (newStatus, comment, user, saveToDatabase = true, options = {}) => {
|
|
430
|
-
const saveOptions = {
|
|
431
|
-
comment,
|
|
432
|
-
user,
|
|
433
|
-
saveToDatabase,
|
|
434
|
-
originalRequestProducts: options.originalRequestProducts,
|
|
435
|
-
space: options.space
|
|
436
|
-
};
|
|
437
|
-
let fncToCall;
|
|
438
|
-
switch (newStatus) {
|
|
439
|
-
case TransferRequest_1.TransferRequestStatusEnum.OPEN:
|
|
440
|
-
fncToCall = this.updateToStatus.open;
|
|
441
|
-
break;
|
|
442
|
-
case TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED:
|
|
443
|
-
fncToCall = this.updateToStatus.toBePrepared;
|
|
444
|
-
break;
|
|
445
|
-
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
446
|
-
fncToCall = this.updateToStatus.inTransit;
|
|
447
|
-
break;
|
|
448
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
449
|
-
fncToCall = this.updateToStatus.received;
|
|
450
|
-
break;
|
|
451
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
452
|
-
saveOptions.markAsCompleted = options.setAsCompleted;
|
|
453
|
-
fncToCall = this.updateToStatus.receivedPartial;
|
|
454
|
-
break;
|
|
455
|
-
case TransferRequest_1.TransferRequestStatusEnum.CANCELLED:
|
|
456
|
-
fncToCall = this.updateToStatus.cancelled;
|
|
457
|
-
break;
|
|
458
|
-
}
|
|
459
|
-
if (!!!fncToCall)
|
|
460
|
-
throw new Error('No status update function associated to provided status! Returning.');
|
|
461
|
-
try {
|
|
462
|
-
await fncToCall(saveOptions, options.context);
|
|
463
|
-
return this.data();
|
|
464
|
-
}
|
|
465
|
-
catch (e) {
|
|
466
|
-
throw new Error('Impossible de soumettre le(s) transfert(s)');
|
|
467
|
-
}
|
|
468
|
-
};
|
|
469
|
-
this.saveNewTransfer = async (currentUser, comment, saveToDatabase = true, skipRef) => {
|
|
470
|
-
if (!!this.data().id)
|
|
471
|
-
throw 'Cette demande de transfert existe déjà en base de données!';
|
|
472
|
-
if (!!!this.data().status)
|
|
473
|
-
throw "Cette demande n'a pas encore de statut initial, et ne peut être sauvegardée!";
|
|
474
|
-
const newUpdates = this._generateNewTransferStatusUpdates(this.data().status, currentUser, comment);
|
|
475
|
-
let newTransferRef = undefined;
|
|
476
|
-
if (!!!skipRef) {
|
|
477
|
-
newTransferRef = await this._getTransferRef();
|
|
478
|
-
}
|
|
479
|
-
return await this.save(Object.assign(Object.assign({}, this.data()), { ref: newTransferRef, transfer_updates: newUpdates }), saveToDatabase);
|
|
480
|
-
};
|
|
481
|
-
this.getProductWeight = (sku, unit = 'pounds') => {
|
|
482
|
-
const item = this.data().products.find((p) => p.sku == sku);
|
|
483
|
-
if (!item)
|
|
484
|
-
return 0;
|
|
485
|
-
if (!!!item.weight)
|
|
486
|
-
return 0;
|
|
487
|
-
const value = (0, toNumber_1.default)(item.weight.value) || 0;
|
|
488
|
-
return item.weight.unit === unit ? value * item.qte : (0, weight_1.convertWeight)(value, item.weight.unit, unit) * item.qte;
|
|
489
|
-
};
|
|
490
|
-
this._getOrderObject = async (space) => {
|
|
491
|
-
if (!space)
|
|
492
|
-
space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
493
|
-
return space.transferRequests.getTransferStatusOrder();
|
|
494
|
-
};
|
|
495
|
-
this._checkIfCanChangeToStatus = async (statusToCheck, space) => {
|
|
496
|
-
const currentStatus = this._data.status;
|
|
497
|
-
if (currentStatus == statusToCheck)
|
|
498
|
-
return true;
|
|
499
|
-
try {
|
|
500
|
-
const orderObj = await this._getOrderObject(space);
|
|
501
|
-
const possibleNextStatus = (0, transferRequests_1.getTransferStatusAfter)(currentStatus, orderObj);
|
|
502
|
-
return possibleNextStatus !== null && possibleNextStatus.values.includes(statusToCheck);
|
|
503
|
-
}
|
|
504
|
-
catch (e) {
|
|
505
|
-
console.log('error on checking status change: ', e.toString());
|
|
506
|
-
return false;
|
|
507
|
-
}
|
|
508
|
-
};
|
|
509
|
-
this._generateNewTransferStatusUpdates = (newStatus, user, comment, originalRequestProducts, context) => {
|
|
510
|
-
const updates = this._data.transfer_updates;
|
|
511
|
-
const newProducts = this._data.products;
|
|
512
|
-
const newFromStore = this._data.from;
|
|
513
|
-
let prodUpdateObj = {};
|
|
514
|
-
if (!!this._data.id || !!originalRequestProducts) {
|
|
515
|
-
if (newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED || newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL) {
|
|
516
|
-
for (let prod of newProducts) {
|
|
517
|
-
const addedQty = prod.qte_received - this.getPreviousReceivedQuantity(prod.sku);
|
|
518
|
-
if (addedQty != 0) {
|
|
519
|
-
prodUpdateObj[prod.sku] = {
|
|
520
|
-
qte_before: prod.qte_received - addedQty,
|
|
521
|
-
qte_after: prod.qte_received,
|
|
522
|
-
name: prod.name
|
|
523
|
-
};
|
|
524
|
-
}
|
|
525
|
-
}
|
|
526
|
-
}
|
|
527
|
-
else {
|
|
528
|
-
const prevProducts = !!originalRequestProducts ? originalRequestProducts : this.prevProducts;
|
|
529
|
-
for (let prod of newProducts) {
|
|
530
|
-
const name = prod.name;
|
|
531
|
-
const sameInPrev = prevProducts.find((p) => p.sku == prod.sku);
|
|
532
|
-
if (!!!sameInPrev) {
|
|
533
|
-
prodUpdateObj[prod.sku] = { qte_before: 0, qte_after: prod.qte, name };
|
|
534
|
-
}
|
|
535
|
-
else if (sameInPrev.qte !== prod.qte) {
|
|
536
|
-
prodUpdateObj[prod.sku] = { qte_before: sameInPrev.qte, qte_after: prod.qte, name };
|
|
537
|
-
}
|
|
538
|
-
}
|
|
539
|
-
for (let prevProd of this.prevProducts) {
|
|
540
|
-
const sameInNew = newProducts.find((p) => p.sku == prevProd.sku);
|
|
541
|
-
if (!!!sameInNew) {
|
|
542
|
-
prodUpdateObj[prevProd.sku] = { qte_before: prevProd.qte, qte_after: 0, name: prevProd.name };
|
|
543
|
-
}
|
|
544
|
-
}
|
|
545
|
-
}
|
|
546
|
-
}
|
|
547
|
-
updates.unshift(Object.assign({ status: newStatus, date: new Date(), updated_by: user, comment: comment, products: !!Object.keys(prodUpdateObj).length ? prodUpdateObj : null, fromStore: this.prevFromStore != this._data.from && this._data.status == TransferRequest_1.TransferRequestStatusEnum.OPEN
|
|
548
|
-
? { before: this.prevFromStore || '', after: newFromStore || '' }
|
|
549
|
-
: null }, (!!context ? { context } : {})));
|
|
550
|
-
return updates;
|
|
551
|
-
};
|
|
552
|
-
this._saveNewStatus = async (newStatus, options, forceCompleted = false, context = TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_STATUS_CHANGE) => {
|
|
553
|
-
const newUpdates = this._generateNewTransferStatusUpdates(newStatus, options.user, options.comment, options.originalRequestProducts, context);
|
|
554
|
-
const completedProps = options.markAsCompleted;
|
|
555
|
-
const canSetAsCompleted = !!completedProps && TransferRequest.checkIfStatusCountsAsCompleted(newStatus);
|
|
556
|
-
if (!!completedProps && !canSetAsCompleted) {
|
|
557
|
-
console.log('Could not set completed property to true since provided new status was not found in "elligible" array!');
|
|
558
|
-
}
|
|
559
|
-
try {
|
|
560
|
-
const response = await this.save(Object.assign({ status: newStatus, transfer_updates: newUpdates }, (forceCompleted || canSetAsCompleted ? { completed: true } : {})), options.saveToDatabase);
|
|
561
|
-
if (!!!response)
|
|
562
|
-
throw new Error('Error while saving the transfer reqeust.');
|
|
563
|
-
}
|
|
564
|
-
catch (e) {
|
|
565
|
-
console.error('Error while saving the transfer reqeust.');
|
|
566
|
-
throw new Error('Error while saving the transfer reqeust.');
|
|
567
|
-
}
|
|
568
|
-
};
|
|
569
|
-
this._setAsOpen = async (options) => {
|
|
570
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.OPEN;
|
|
571
|
-
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
572
|
-
if (!statusChangeValid)
|
|
573
|
-
throw new Error('Trying to change to wrong status! Returning.');
|
|
574
|
-
await this._saveNewStatus(newStatus, options);
|
|
575
|
-
};
|
|
576
|
-
this._setAsToBePrepared = async (options) => {
|
|
577
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED;
|
|
578
|
-
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
579
|
-
if (!statusChangeValid)
|
|
580
|
-
throw new Error('Trying to change to wrong status! Returning.');
|
|
581
|
-
await this._saveNewStatus(newStatus, options);
|
|
582
|
-
};
|
|
583
|
-
this._setAsInTransit = async (options) => {
|
|
584
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT;
|
|
585
|
-
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
586
|
-
if (!statusChangeValid)
|
|
587
|
-
throw new Error('Trying to change to wrong status! Returning.');
|
|
588
|
-
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
589
|
-
if (!!!inventoryChangesSuccess) {
|
|
590
|
-
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
591
|
-
}
|
|
592
|
-
await this._saveNewStatus(newStatus, options);
|
|
593
|
-
};
|
|
594
|
-
this._setAsReceived = async (options) => {
|
|
595
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.RECEIVED;
|
|
596
|
-
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
597
|
-
if (!statusChangeValid)
|
|
598
|
-
throw new Error('Trying to change to wrong status! Returning.');
|
|
599
|
-
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
600
|
-
if (!!!inventoryChangesSuccess) {
|
|
601
|
-
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
602
|
-
}
|
|
603
|
-
await this.handleUpdateAssociatedCartReservedQuantities();
|
|
604
|
-
await this._saveNewStatus(newStatus, options, true);
|
|
605
|
-
};
|
|
606
|
-
this._setAsReceivedPartially = async (options) => {
|
|
607
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL;
|
|
608
|
-
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
609
|
-
if (!statusChangeValid)
|
|
610
|
-
throw new Error('Trying to change to wrong status! Returning.');
|
|
611
|
-
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
612
|
-
if (!!!inventoryChangesSuccess) {
|
|
613
|
-
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
614
|
-
}
|
|
615
|
-
await this.handleUpdateAssociatedCartReservedQuantities();
|
|
616
|
-
await this._saveNewStatus(newStatus, options);
|
|
617
|
-
};
|
|
618
|
-
this._setAsCancelled = async (options, context) => {
|
|
619
|
-
const newStatus = TransferRequest_1.TransferRequestStatusEnum.CANCELLED;
|
|
620
|
-
const statusPositionObj = await this._getOrderObject();
|
|
621
|
-
const canBeCancelled = TransferRequest.checkIfTransferCanBeCancelled(this._data.status, statusPositionObj);
|
|
622
|
-
if (!canBeCancelled) {
|
|
623
|
-
throw new Error('transfer cannot be cancelled, status is same of after IN_TRANSIT');
|
|
624
|
-
}
|
|
625
|
-
await this._saveNewStatus(newStatus, options, true, context);
|
|
626
|
-
};
|
|
627
|
-
this.updateToStatus = {
|
|
628
|
-
open: this._setAsOpen,
|
|
629
|
-
toBePrepared: this._setAsToBePrepared,
|
|
630
|
-
inTransit: this._setAsInTransit,
|
|
631
|
-
received: this._setAsReceived,
|
|
632
|
-
receivedPartial: this._setAsReceivedPartially,
|
|
633
|
-
cancelled: this._setAsCancelled
|
|
634
|
-
};
|
|
635
|
-
this.getFormattedRef = (spaceTransferSettings) => {
|
|
636
|
-
if (typeof this._data.ref == 'undefined') {
|
|
637
|
-
console.log('transfer has no ref, returning!');
|
|
638
|
-
return;
|
|
639
|
-
}
|
|
640
|
-
if (!!!spaceTransferSettings)
|
|
641
|
-
return this._data.ref.toString();
|
|
642
|
-
const prefix = spaceTransferSettings.prefix;
|
|
643
|
-
const suffix = spaceTransferSettings.suffix;
|
|
644
|
-
return `${prefix ? prefix + '-' : ''}${this._data.ref}${suffix ? '-' + suffix : ''}`;
|
|
645
|
-
};
|
|
646
|
-
this._data = this.processData(_data);
|
|
647
|
-
if (!!this._data.products.length) {
|
|
648
|
-
this.prevProducts = [...this._data.products];
|
|
649
|
-
}
|
|
650
|
-
if (!!this._data.from)
|
|
651
|
-
this.prevFromStore = this._data.from;
|
|
652
|
-
}
|
|
653
|
-
}
|
|
654
|
-
exports.TransferRequest = TransferRequest;
|
|
655
|
-
_a = TransferRequest;
|
|
656
|
-
TransferRequest.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'transfer_request', f = '', space, useProspr = false }) => {
|
|
657
|
-
try {
|
|
658
|
-
let prosprSearch = false;
|
|
659
|
-
if (!!space) {
|
|
660
|
-
const prosprService = space
|
|
661
|
-
.data()
|
|
662
|
-
.external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
|
|
663
|
-
prosprSearch = !!prosprService && prosprService.is_active;
|
|
664
|
-
}
|
|
665
|
-
const algolia = (0, algolia_1.createClient)({
|
|
666
|
-
app,
|
|
667
|
-
indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
|
|
668
|
-
key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
|
|
669
|
-
prospr: !!prosprSearch || !!useProspr
|
|
670
|
-
});
|
|
671
|
-
const results = await algolia.search(query, {
|
|
672
|
-
hitsPerPage: hpp,
|
|
673
|
-
facetFilters: filters,
|
|
674
|
-
filters: f,
|
|
675
|
-
page,
|
|
676
|
-
facets: ['*']
|
|
677
|
-
});
|
|
678
|
-
return results;
|
|
679
|
-
}
|
|
680
|
-
catch (error) {
|
|
681
|
-
(0, console_1.errorMessage)(error);
|
|
682
|
-
throw error;
|
|
683
|
-
}
|
|
684
|
-
};
|
|
685
|
-
TransferRequest.getStatusLabel = (status) => {
|
|
686
|
-
switch (status) {
|
|
687
|
-
case TransferRequest_1.TransferRequestStatusEnum.INITIATED:
|
|
688
|
-
return 'Initialisée';
|
|
689
|
-
case TransferRequest_1.TransferRequestStatusEnum.OPEN:
|
|
690
|
-
return 'Ouverte';
|
|
691
|
-
case TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED:
|
|
692
|
-
return 'À préparer';
|
|
693
|
-
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
694
|
-
return 'En transit';
|
|
695
|
-
case TransferRequest_1.TransferRequestStatusEnum.CANCELLED:
|
|
696
|
-
return 'Annulée';
|
|
697
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
698
|
-
return 'Reçue partiellement';
|
|
699
|
-
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
700
|
-
return 'Reçue';
|
|
701
|
-
}
|
|
702
|
-
};
|
|
703
|
-
TransferRequest.checkIfTransferCanBeCancelled = (currentTransferStatus, statusOrderObj) => {
|
|
704
|
-
const currentPosition = (0, transferRequests_1.getOrderPositionForStatus)(currentTransferStatus, statusOrderObj);
|
|
705
|
-
if (typeof currentPosition != 'number') {
|
|
706
|
-
console.log('could not compare status since currentPosition was not found');
|
|
707
|
-
return false;
|
|
708
|
-
}
|
|
709
|
-
const inTransitPosition = (0, transferRequests_1.getOrderPositionForStatus)(TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT, statusOrderObj);
|
|
710
|
-
if (typeof inTransitPosition != 'number') {
|
|
711
|
-
console.log('could not compare status since inTransitPosition was not found');
|
|
712
|
-
return false;
|
|
713
|
-
}
|
|
714
|
-
return (0, toNumber_1.default)(currentPosition) < (0, toNumber_1.default)(inTransitPosition);
|
|
715
|
-
};
|
|
716
|
-
TransferRequest.checkIfStatusCountsAsCompleted = (statusToCheck) => {
|
|
717
|
-
return [
|
|
718
|
-
TransferRequest_1.TransferRequestStatusEnum.RECEIVED,
|
|
719
|
-
TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL,
|
|
720
|
-
TransferRequest_1.TransferRequestStatusEnum.CANCELLED
|
|
721
|
-
].includes(statusToCheck);
|
|
722
|
-
};
|
|
723
|
-
TransferRequest.transferAllowAssignFromStore = (data) => {
|
|
724
|
-
if (!!data.completed)
|
|
725
|
-
return false;
|
|
726
|
-
return !!data.id && TransferRequest_1.TransferRequestStatusEnum.INITIATED === data.status;
|
|
727
|
-
};
|
|
728
|
-
TransferRequest.transferAllowEditFromStore = (data) => {
|
|
729
|
-
if (!!data.completed)
|
|
730
|
-
return false;
|
|
731
|
-
return !!data.id && TransferRequest_1.TransferRequestStatusEnum.OPEN === data.status;
|
|
732
|
-
};
|
|
733
|
-
TransferRequest.transferAllowAddProductOnEdit = (data) => {
|
|
734
|
-
if (!!data.completed)
|
|
735
|
-
return false;
|
|
736
|
-
if (data.draft)
|
|
737
|
-
return true;
|
|
738
|
-
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
739
|
-
};
|
|
740
|
-
TransferRequest.transferAllowProductDelete = (data) => {
|
|
741
|
-
if (!!data.completed)
|
|
742
|
-
return false;
|
|
743
|
-
if (!!!data.id)
|
|
744
|
-
return true;
|
|
745
|
-
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
746
|
-
};
|
|
747
|
-
TransferRequest.transferAllowEditProductOnEdit = (data) => {
|
|
748
|
-
if (!!data.completed)
|
|
749
|
-
return false;
|
|
750
|
-
return [
|
|
751
|
-
TransferRequest_1.TransferRequestStatusEnum.INITIATED,
|
|
752
|
-
TransferRequest_1.TransferRequestStatusEnum.OPEN,
|
|
753
|
-
TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED
|
|
754
|
-
].includes(data.status);
|
|
755
|
-
};
|
|
756
|
-
TransferRequest.transferAllowDeleteProductOnEdit = (data) => {
|
|
757
|
-
if (!!data.completed)
|
|
758
|
-
return false;
|
|
759
|
-
if (!!!data.id)
|
|
760
|
-
return true;
|
|
761
|
-
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED, TransferRequest_1.TransferRequestStatusEnum.OPEN].includes(data.status);
|
|
762
|
-
};
|
|
763
|
-
TransferRequest.transferShouldDisplayWeight = (data) => {
|
|
764
|
-
return ![TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
765
|
-
};
|
|
766
|
-
TransferRequest.transferAllowsIndependantProductUpdate = (data) => {
|
|
767
|
-
if (!!data.completed)
|
|
768
|
-
return false;
|
|
769
|
-
let acceptedStatuses = [TransferRequest_1.TransferRequestStatusEnum.INITIATED, TransferRequest_1.TransferRequestStatusEnum.OPEN];
|
|
770
|
-
if (!data.associated_order)
|
|
771
|
-
acceptedStatuses.push(TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED);
|
|
772
|
-
return acceptedStatuses.includes(data.status);
|
|
773
|
-
};
|
|
774
|
-
TransferRequest.getTotalWeight = (products, unit = 'pounds') => {
|
|
775
|
-
return (0, sumBy_1.default)(products, (item) => {
|
|
776
|
-
if (!!!item.weight)
|
|
777
|
-
return 0;
|
|
778
|
-
const value = (0, toNumber_1.default)(item.weight.value) || 0;
|
|
779
|
-
return item.weight.unit === unit ? value * item.qte : (0, weight_1.convertWeight)(value, item.weight.unit, unit) * item.qte;
|
|
780
|
-
});
|
|
781
|
-
};
|
|
782
|
-
TransferRequest.getTotalPalletQte = (items) => {
|
|
783
|
-
const total = (0, sumBy_1.default)(items.map((item) => {
|
|
784
|
-
if (!!!item.other_units || !!!item.count_in_pallet_total) {
|
|
785
|
-
return 0;
|
|
786
|
-
}
|
|
787
|
-
const paletteUnit = item.other_units.find((u) => u.unit_slug === 'pal');
|
|
788
|
-
if (!!!paletteUnit || !!!paletteUnit.fitting_unit) {
|
|
789
|
-
return 0;
|
|
790
|
-
}
|
|
791
|
-
return item.qte / paletteUnit.fitting_unit;
|
|
792
|
-
}));
|
|
793
|
-
return (0, ceil_1.default)(total);
|
|
794
|
-
};
|
|
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
|
+
exports.TransferRequest = void 0;
|
|
8
|
+
const TransferRequest_1 = require("../../Interfaces/TransferRequest");
|
|
9
|
+
const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
|
|
10
|
+
const baseService_1 = require("../baseService");
|
|
11
|
+
const Inventory_1 = __importDefault(require("../Inventory"));
|
|
12
|
+
const Space_1 = __importDefault(require("../Space"));
|
|
13
|
+
const toNumber_1 = __importDefault(require("lodash/toNumber"));
|
|
14
|
+
const ceil_1 = __importDefault(require("lodash/ceil"));
|
|
15
|
+
const round_1 = __importDefault(require("lodash/round"));
|
|
16
|
+
const data_1 = require("../../utils/data");
|
|
17
|
+
const inventories_1 = require("../../utils/inventories");
|
|
18
|
+
const transferRequests_1 = require("../../utils/transferRequests");
|
|
19
|
+
const sumBy_1 = __importDefault(require("lodash/sumBy"));
|
|
20
|
+
const weight_1 = require("../../utils/weight");
|
|
21
|
+
const algolia_1 = require("../../utils/algolia");
|
|
22
|
+
const __1 = require("../..");
|
|
23
|
+
const console_1 = require("../../utils/console");
|
|
24
|
+
const context_1 = require("../../utils/context");
|
|
25
|
+
const tools_1 = require("../../utils/tools");
|
|
26
|
+
const products_1 = require("../../rules/GR/utils/products");
|
|
27
|
+
const Cart_1 = require("../../Interfaces/Cart");
|
|
28
|
+
class TransferRequest extends baseService_1.BaseServiceClass {
|
|
29
|
+
constructor(_data, _collection, _user) {
|
|
30
|
+
super(_data, _collection, _user);
|
|
31
|
+
this._listener = null;
|
|
32
|
+
this.prevProducts = [];
|
|
33
|
+
this.prevFromStore = undefined;
|
|
34
|
+
this.processData = (data) => (Object.assign(Object.assign({}, data), { transfer_updates: data.transfer_updates.map((update) => (Object.assign(Object.assign({}, update), { date: (0, data_1.formatDate)(update.date) }))) }));
|
|
35
|
+
this.checkIfTransferCanBeClosedManually = () => {
|
|
36
|
+
return this._data.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL;
|
|
37
|
+
};
|
|
38
|
+
this.transferAllowAssignFromStore = () => TransferRequest.transferAllowAssignFromStore(this._data);
|
|
39
|
+
this.transferAllowEditFromStore = () => TransferRequest.transferAllowEditFromStore(this._data);
|
|
40
|
+
this.transferAllowAddProductOnEdit = () => TransferRequest.transferAllowAddProductOnEdit(this._data);
|
|
41
|
+
this.transferAllowProductDelete = () => TransferRequest.transferAllowProductDelete(this._data);
|
|
42
|
+
this.transferAllowEditProductOnEdit = () => TransferRequest.transferAllowEditProductOnEdit(this._data);
|
|
43
|
+
this.transferAllowDeleteProductOnEdit = () => TransferRequest.transferAllowProductDelete(this._data);
|
|
44
|
+
this.transferShouldDisplayWeight = () => TransferRequest.transferShouldDisplayWeight(this._data);
|
|
45
|
+
this.transferAllowsIndependantProductUpdate = () => TransferRequest.transferAllowsIndependantProductUpdate(this._data);
|
|
46
|
+
this.fetchAssociatedCart = async () => {
|
|
47
|
+
if (!!!this._data.associated_order)
|
|
48
|
+
return;
|
|
49
|
+
let associatedCart = undefined;
|
|
50
|
+
try {
|
|
51
|
+
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
52
|
+
const cartQuery = await space.carts.get({
|
|
53
|
+
query: [{ field: 'ref', operator: '==', value: this._data.associated_order }]
|
|
54
|
+
});
|
|
55
|
+
if (!!cartQuery && !!cartQuery.length)
|
|
56
|
+
associatedCart = cartQuery[0];
|
|
57
|
+
}
|
|
58
|
+
catch (e) {
|
|
59
|
+
console.log('could not fetch cart associated to transfer: ', e.toString());
|
|
60
|
+
}
|
|
61
|
+
return associatedCart;
|
|
62
|
+
};
|
|
63
|
+
this.addProduct = (sku, parent_slug, qte, name, image, other_units, weight, count_in_pallet_total) => {
|
|
64
|
+
const data = this.data();
|
|
65
|
+
if (!TransferRequest.transferAllowEditProductOnEdit(this._data))
|
|
66
|
+
return false;
|
|
67
|
+
let updatedProducts = data.products;
|
|
68
|
+
if (!updatedProducts.find((p) => p.sku == sku)) {
|
|
69
|
+
updatedProducts.push({
|
|
70
|
+
sku,
|
|
71
|
+
parent_slug,
|
|
72
|
+
qte,
|
|
73
|
+
name,
|
|
74
|
+
image,
|
|
75
|
+
other_units,
|
|
76
|
+
weight,
|
|
77
|
+
count_in_pallet_total,
|
|
78
|
+
qte_received: 0
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
updatedProducts = updatedProducts.map((p) => {
|
|
83
|
+
if (p.sku !== sku)
|
|
84
|
+
return p;
|
|
85
|
+
return Object.assign(Object.assign({}, p), { qte: p.qte + qte <= 1 ? 1 : p.qte + qte });
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
this._data = Object.assign(Object.assign({}, data), { products: updatedProducts });
|
|
89
|
+
return true;
|
|
90
|
+
};
|
|
91
|
+
this.editProduct = (sku, newQte) => {
|
|
92
|
+
const data = this.data();
|
|
93
|
+
if (!TransferRequest.transferAllowEditProductOnEdit(this._data))
|
|
94
|
+
return false;
|
|
95
|
+
this._data = Object.assign(Object.assign({}, data), { products: data.products.map((p) => {
|
|
96
|
+
if (p.sku !== sku)
|
|
97
|
+
return p;
|
|
98
|
+
return Object.assign(Object.assign({}, p), { qte: newQte });
|
|
99
|
+
}) });
|
|
100
|
+
return true;
|
|
101
|
+
};
|
|
102
|
+
this.deleteProduct = (sku) => {
|
|
103
|
+
const data = this.data();
|
|
104
|
+
if (!TransferRequest.transferAllowProductDelete(this._data))
|
|
105
|
+
return false;
|
|
106
|
+
this._data = Object.assign(Object.assign({}, data), { products: data.products.filter((p) => p.sku !== sku) });
|
|
107
|
+
return true;
|
|
108
|
+
};
|
|
109
|
+
this.data = () => this._data;
|
|
110
|
+
this.isListening = () => !!this._listener;
|
|
111
|
+
this.killListener = () => {
|
|
112
|
+
if (!!!this._listener)
|
|
113
|
+
return false;
|
|
114
|
+
this._listener = null;
|
|
115
|
+
return true;
|
|
116
|
+
};
|
|
117
|
+
this.listen = (callback) => {
|
|
118
|
+
if (!!this._listener)
|
|
119
|
+
return false;
|
|
120
|
+
DatabaseService_1.default.registerListener((snap) => {
|
|
121
|
+
if (snap === null)
|
|
122
|
+
this._listener = null;
|
|
123
|
+
if (snap.length === 0)
|
|
124
|
+
this._listener = null;
|
|
125
|
+
snap.map((s) => {
|
|
126
|
+
if (s.id == this.data().id) {
|
|
127
|
+
this._data = this.processData(s.data);
|
|
128
|
+
if (!!callback)
|
|
129
|
+
callback();
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}, this._collection.path, { id: this.data().id });
|
|
133
|
+
return true;
|
|
134
|
+
};
|
|
135
|
+
this._getTransferRef = async () => {
|
|
136
|
+
let newRef = undefined;
|
|
137
|
+
try {
|
|
138
|
+
const space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
139
|
+
const token = (0, context_1.getSpaceTokenFromSpaceOnly)(space);
|
|
140
|
+
const api = __1.API_URL;
|
|
141
|
+
let triesLeft = 3;
|
|
142
|
+
while (triesLeft > 0) {
|
|
143
|
+
try {
|
|
144
|
+
const resp = await fetch(`${api}/transfers/refnumber`, {
|
|
145
|
+
method: 'GET',
|
|
146
|
+
headers: {
|
|
147
|
+
'Content-Type': 'application/json',
|
|
148
|
+
Authorization: `Bearer ${token}`
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
if (resp.status >= 200 && resp.status < 300) {
|
|
152
|
+
const data = await resp.json();
|
|
153
|
+
if (data.status == 'success') {
|
|
154
|
+
newRef = (0, toNumber_1.default)(data.result);
|
|
155
|
+
break;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
catch (e) {
|
|
160
|
+
console.log('Error fetching transfer number', e);
|
|
161
|
+
}
|
|
162
|
+
await (0, tools_1.waitFor)(1000);
|
|
163
|
+
triesLeft--;
|
|
164
|
+
}
|
|
165
|
+
if (triesLeft == 0)
|
|
166
|
+
throw new Error('could not get a Ref number');
|
|
167
|
+
return newRef;
|
|
168
|
+
}
|
|
169
|
+
catch (e) {
|
|
170
|
+
console.log('error on fetching new transfer ref: ', e.toString());
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
};
|
|
174
|
+
this.save = async (partial, saveToDatabase = true, merge = true) => {
|
|
175
|
+
const saveResult = await super.save(partial, undefined, saveToDatabase, undefined, merge);
|
|
176
|
+
if (typeof saveResult === 'string') {
|
|
177
|
+
this._data = Object.assign(Object.assign({}, this._data), { id: saveResult });
|
|
178
|
+
}
|
|
179
|
+
return saveResult;
|
|
180
|
+
};
|
|
181
|
+
this.validateBeforeSubmit = async (strictQty = true) => {
|
|
182
|
+
if (strictQty) {
|
|
183
|
+
return this.data().products.every((p) => typeof p.qte_validation == 'undefined' || p.qte === p.qte_validation);
|
|
184
|
+
}
|
|
185
|
+
return this.data().products.every((p) => typeof p.qte_validation == 'undefined' || p.qte_validation >= 0);
|
|
186
|
+
};
|
|
187
|
+
this.clearValidationQuantitiesFromProductData = (copyQte = false) => {
|
|
188
|
+
this._data = Object.assign(Object.assign({}, this._data), { products: this._data.products.map((p) => (Object.assign(Object.assign({}, p), { qte: copyQte ? p.qte_validation || 0 : p.qte, qte_validation: undefined }))) });
|
|
189
|
+
};
|
|
190
|
+
this.addValidationQuantitiesToReceivedQuantities = () => {
|
|
191
|
+
this._data = Object.assign(Object.assign({}, this._data), { products: this._data.products.map((p) => (Object.assign(Object.assign({}, p), { qte_received: (p.qte_validation || 0) + (p.qte_received || 0), qte_validation: undefined }))) });
|
|
192
|
+
};
|
|
193
|
+
this.getPreviousReceivedQuantity = (sku) => {
|
|
194
|
+
const entry = this._data.transfer_updates.find((u) => (u.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL || u.status == TransferRequest_1.TransferRequestStatusEnum.RECEIVED) &&
|
|
195
|
+
u.products &&
|
|
196
|
+
u.products[sku]);
|
|
197
|
+
if (entry) {
|
|
198
|
+
return entry.products[sku].qte_after;
|
|
199
|
+
}
|
|
200
|
+
return 0;
|
|
201
|
+
};
|
|
202
|
+
this.getOriginalRequestedQuantity = (sku) => {
|
|
203
|
+
const product = this._data.products.find((p) => p.sku == sku);
|
|
204
|
+
if (!product)
|
|
205
|
+
return 0;
|
|
206
|
+
let result = product.qte;
|
|
207
|
+
this._data.transfer_updates.map((u) => {
|
|
208
|
+
if (u.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL &&
|
|
209
|
+
u.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED &&
|
|
210
|
+
u.products &&
|
|
211
|
+
u.products[sku])
|
|
212
|
+
result = u.products[sku].qte_before;
|
|
213
|
+
});
|
|
214
|
+
return result;
|
|
215
|
+
};
|
|
216
|
+
this.getQuantityAtStatus = (sku, status) => {
|
|
217
|
+
const statusPos = (0, transferRequests_1.getOrderPositionForStatus)(status, TransferRequest_1.transferRequestStatusOrder) || 0;
|
|
218
|
+
if (statusPos == 0) {
|
|
219
|
+
const updates = this._data.transfer_updates.filter((u) => u.status == status);
|
|
220
|
+
if (!updates.some((u) => !!u.products && !!u.products && !!u.products[sku]))
|
|
221
|
+
return this.getOriginalRequestedQuantity(sku);
|
|
222
|
+
}
|
|
223
|
+
const product = this._data.products.find((p) => p.sku == sku);
|
|
224
|
+
if (!product)
|
|
225
|
+
return 0;
|
|
226
|
+
let result = product.qte;
|
|
227
|
+
for (let i of this._data.transfer_updates) {
|
|
228
|
+
if (((0, transferRequests_1.getOrderPositionForStatus)(i.status, TransferRequest_1.transferRequestStatusOrder) || 0) <= statusPos &&
|
|
229
|
+
i.products &&
|
|
230
|
+
i.products[sku]) {
|
|
231
|
+
result = i.products[sku].qte_after;
|
|
232
|
+
break;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return result;
|
|
236
|
+
};
|
|
237
|
+
this.getInventoryQuantitiesStillMissingForCartTransfer = (associatedCart, itemSku, otherUnits) => {
|
|
238
|
+
var _b;
|
|
239
|
+
if (!!!associatedCart)
|
|
240
|
+
return 0;
|
|
241
|
+
const sameProd = associatedCart.data().items.find((i) => i.sku == itemSku);
|
|
242
|
+
if (!!!sameProd)
|
|
243
|
+
return 0;
|
|
244
|
+
const alreadyReservedQuantities = (_b = sameProd.qte_reserved) !== null && _b !== void 0 ? _b : 0;
|
|
245
|
+
const quantitiesNeededForCart = sameProd.qte - alreadyReservedQuantities;
|
|
246
|
+
const convertedToInventoryForCartQuantities = (0, inventories_1.getConvertedUnitQuantity)(otherUnits, quantitiesNeededForCart, 'inventory_unit');
|
|
247
|
+
return convertedToInventoryForCartQuantities;
|
|
248
|
+
};
|
|
249
|
+
this.handleFreeTransitInventory = async () => {
|
|
250
|
+
if (!this._data.from || this._data.status != TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL)
|
|
251
|
+
return false;
|
|
252
|
+
try {
|
|
253
|
+
if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
|
|
254
|
+
return false;
|
|
255
|
+
const inventoryColl = DatabaseService_1.default.asCollectionObject(DatabaseService_1.default.getPathParent(this._collection.path), 'inventories');
|
|
256
|
+
for (const product of this._data.products) {
|
|
257
|
+
if (product.qte_received >= product.qte)
|
|
258
|
+
continue;
|
|
259
|
+
const inventoryItemQuery = await DatabaseService_1.default.getDocument(inventoryColl.path, product.sku);
|
|
260
|
+
if (!!!inventoryItemQuery.exists)
|
|
261
|
+
continue;
|
|
262
|
+
const inventoryItem = new Inventory_1.default(inventoryItemQuery.data, inventoryColl, this._user);
|
|
263
|
+
await inventoryItem.handleCancelInTransit(this._data.from, product.qte - product.qte_received, undefined, !!this._data.associated_order);
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
catch (err) {
|
|
267
|
+
console.log('err', err);
|
|
268
|
+
return false;
|
|
269
|
+
}
|
|
270
|
+
};
|
|
271
|
+
this.handleChangeStoreInventory = async (newStatus) => {
|
|
272
|
+
if (!this._data.from)
|
|
273
|
+
return false;
|
|
274
|
+
try {
|
|
275
|
+
if (DatabaseService_1.default.getPathParent(this._collection.path) == '/')
|
|
276
|
+
return false;
|
|
277
|
+
const inventoryColl = DatabaseService_1.default.asCollectionObject(DatabaseService_1.default.getPathParent(this._collection.path), 'inventories');
|
|
278
|
+
let associatedCart;
|
|
279
|
+
if (newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED || newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL) {
|
|
280
|
+
try {
|
|
281
|
+
associatedCart = await this.fetchAssociatedCart();
|
|
282
|
+
}
|
|
283
|
+
catch (e) {
|
|
284
|
+
console.log('error on fetching cart for transfer: ', e.toString());
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
for (const product of this._data.products) {
|
|
288
|
+
const inventoryItemQuery = await DatabaseService_1.default.getDocument(inventoryColl.path, product.sku);
|
|
289
|
+
if (!!!inventoryItemQuery.exists)
|
|
290
|
+
continue;
|
|
291
|
+
const inventoryItem = new Inventory_1.default(inventoryItemQuery.data, inventoryColl, this._user);
|
|
292
|
+
switch (newStatus) {
|
|
293
|
+
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
294
|
+
await inventoryItem.handleTransferInTransit(this._data.from, product.qte, undefined, !!this._data.associated_order);
|
|
295
|
+
break;
|
|
296
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
297
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
298
|
+
const qteReceivedSinceLastStatus = product.qte_received - this.getPreviousReceivedQuantity(product.sku);
|
|
299
|
+
if (qteReceivedSinceLastStatus == 0)
|
|
300
|
+
continue;
|
|
301
|
+
const cartWasProcessed = !!associatedCart && associatedCart.data().status > Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS;
|
|
302
|
+
const qteToReserve = cartWasProcessed
|
|
303
|
+
? undefined
|
|
304
|
+
: this.getInventoryQuantitiesStillMissingForCartTransfer(associatedCart, product.sku, inventoryItem.data().other_units);
|
|
305
|
+
await inventoryItem.handleTransferReceived(this._data.from, this._data.to, qteReceivedSinceLastStatus, undefined, {
|
|
306
|
+
forOrder: !!this._data.associated_order,
|
|
307
|
+
maxProcessingQte: typeof qteToReserve == 'number' && qteToReserve >= 0
|
|
308
|
+
? qteToReserve > qteReceivedSinceLastStatus
|
|
309
|
+
? qteReceivedSinceLastStatus
|
|
310
|
+
: qteToReserve
|
|
311
|
+
: 0,
|
|
312
|
+
skipWebUpdateForAvailable: cartWasProcessed
|
|
313
|
+
});
|
|
314
|
+
break;
|
|
315
|
+
}
|
|
316
|
+
continue;
|
|
317
|
+
}
|
|
318
|
+
return true;
|
|
319
|
+
}
|
|
320
|
+
catch (err) {
|
|
321
|
+
console.log('err', err);
|
|
322
|
+
return false;
|
|
323
|
+
}
|
|
324
|
+
};
|
|
325
|
+
this.handleUpdateAssociatedCartReservedQuantities = async () => {
|
|
326
|
+
var _b, _c;
|
|
327
|
+
const associatedCart = await this.fetchAssociatedCart();
|
|
328
|
+
if (!!!associatedCart)
|
|
329
|
+
return;
|
|
330
|
+
if (associatedCart.data().status > Cart_1.CartStatusEnum.CHECKOUT_PAYMENT_SUCCESS)
|
|
331
|
+
return;
|
|
332
|
+
let somethingHasChanged = false;
|
|
333
|
+
let cartItems = associatedCart.data().items;
|
|
334
|
+
let updatedCartItems = [];
|
|
335
|
+
for (let item of cartItems) {
|
|
336
|
+
const sameInTransfer = this._data.products.find((p) => p.sku == item.sku);
|
|
337
|
+
if (!!!sameInTransfer) {
|
|
338
|
+
updatedCartItems.push(item);
|
|
339
|
+
continue;
|
|
340
|
+
}
|
|
341
|
+
const sellUnit = (item.other_units || []).find((o) => o.is_sale_unit);
|
|
342
|
+
const unitHasDecimals = !!sellUnit && (0, products_1.productUnitSupportsDecimals)(sellUnit.unit_slug);
|
|
343
|
+
if (typeof item.qte_reserved == 'number' && (0, round_1.default)(item.qte_reserved, unitHasDecimals ? 2 : 0) >= item.qte) {
|
|
344
|
+
updatedCartItems.push(item);
|
|
345
|
+
continue;
|
|
346
|
+
}
|
|
347
|
+
const qteReceivedSinceLastStatus = sameInTransfer.qte_received - this.getPreviousReceivedQuantity(sameInTransfer.sku);
|
|
348
|
+
if (!!!qteReceivedSinceLastStatus) {
|
|
349
|
+
updatedCartItems.push(item);
|
|
350
|
+
continue;
|
|
351
|
+
}
|
|
352
|
+
const reservedQteInInventoryUnit = (0, inventories_1.getConvertedUnitQuantity)(item.other_units, (_b = item.qte_reserved) !== null && _b !== void 0 ? _b : 0, 'inventory_unit');
|
|
353
|
+
const qteInInventoryUnit = (0, inventories_1.getConvertedUnitQuantity)(item.other_units, (_c = item.qte) !== null && _c !== void 0 ? _c : 0, 'inventory_unit');
|
|
354
|
+
const newReservedQte = reservedQteInInventoryUnit + qteReceivedSinceLastStatus;
|
|
355
|
+
updatedCartItems.push(Object.assign(Object.assign({}, item), { qte_reserved: (0, inventories_1.getConvertedUnitQuantity)(item.other_units, newReservedQte > qteInInventoryUnit ? qteInInventoryUnit : newReservedQte, 'sale_unit', true) }));
|
|
356
|
+
somethingHasChanged = true;
|
|
357
|
+
}
|
|
358
|
+
if (!!!somethingHasChanged)
|
|
359
|
+
return;
|
|
360
|
+
try {
|
|
361
|
+
await associatedCart.save({ items: updatedCartItems, id: associatedCart.data().id }, undefined, true, true, true);
|
|
362
|
+
}
|
|
363
|
+
catch (e) {
|
|
364
|
+
console.log('error on saving cart with new qte_received in items: ', e.toString());
|
|
365
|
+
}
|
|
366
|
+
};
|
|
367
|
+
this.constructProductObjFromUpdates = (updatesToDo) => {
|
|
368
|
+
let updatedProducts = this._data.products.map((currentProd) => {
|
|
369
|
+
const sameInUpdates = updatesToDo.find((u) => u.sku == currentProd.sku);
|
|
370
|
+
if (!!!sameInUpdates)
|
|
371
|
+
return currentProd;
|
|
372
|
+
let newQte = currentProd.qte + sameInUpdates.ajustmentQte;
|
|
373
|
+
if (newQte < 0)
|
|
374
|
+
newQte = 0;
|
|
375
|
+
return Object.assign(Object.assign({}, currentProd), { qte: newQte });
|
|
376
|
+
});
|
|
377
|
+
return updatedProducts;
|
|
378
|
+
};
|
|
379
|
+
this.saveUpdatesToContentOnly = async (updatedContent, options, cancelTransferIfAllProductsAtZero, updateContext = TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_UPDATED) => {
|
|
380
|
+
if (updatedContent.products) {
|
|
381
|
+
if (!TransferRequest.transferAllowsIndependantProductUpdate(this._data)) {
|
|
382
|
+
throw new Error('Cannot update products without changing status for current transfer status.');
|
|
383
|
+
}
|
|
384
|
+
await this.save({ products: updatedContent.products }, false, true);
|
|
385
|
+
if (!!updatedContent.products.some((p) => typeof p.qte_validation == 'number')) {
|
|
386
|
+
this.clearValidationQuantitiesFromProductData(true);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
if (updatedContent.fromStore) {
|
|
390
|
+
if (!TransferRequest.transferAllowEditFromStore(this._data)) {
|
|
391
|
+
throw new Error('Cannot update origin store for this transfer.');
|
|
392
|
+
}
|
|
393
|
+
await this.save({ from: updatedContent.fromStore }, false, true);
|
|
394
|
+
}
|
|
395
|
+
try {
|
|
396
|
+
const statusPositionObj = await this._getOrderObject();
|
|
397
|
+
const shouldCancelTransfer = updatedContent.products &&
|
|
398
|
+
cancelTransferIfAllProductsAtZero &&
|
|
399
|
+
updatedContent.products.every((p) => p.qte <= 0) &&
|
|
400
|
+
TransferRequest.checkIfTransferCanBeCancelled(this._data.status, statusPositionObj);
|
|
401
|
+
const statusToUse = !!shouldCancelTransfer ? TransferRequest_1.TransferRequestStatusEnum.CANCELLED : this._data.status;
|
|
402
|
+
const newUpdates = this._generateNewTransferStatusUpdates(statusToUse, options.user, options.comment, undefined, updateContext);
|
|
403
|
+
await this.save(Object.assign({ transfer_updates: newUpdates }, (shouldCancelTransfer ? { status: statusToUse, completed: true } : {})), true, true);
|
|
404
|
+
}
|
|
405
|
+
catch (e) {
|
|
406
|
+
const errorStr = 'error on updating products independantly from status: ' + e.toString();
|
|
407
|
+
console.log(errorStr);
|
|
408
|
+
throw new Error(errorStr);
|
|
409
|
+
}
|
|
410
|
+
return this.data();
|
|
411
|
+
};
|
|
412
|
+
this.setDraftValue = (newVal) => {
|
|
413
|
+
this._data = Object.assign(Object.assign({}, this._data), { draft: newVal });
|
|
414
|
+
};
|
|
415
|
+
this.setAssociatedOrder = (newVal) => {
|
|
416
|
+
this._data = Object.assign(Object.assign({}, this._data), { associated_order: newVal });
|
|
417
|
+
};
|
|
418
|
+
this.setTransportRef = async (newVal, saveToDatabase = false) => {
|
|
419
|
+
await this.save({ transport_ref: newVal }, saveToDatabase, true);
|
|
420
|
+
};
|
|
421
|
+
this.setOriginalTransferId = async (newVal) => {
|
|
422
|
+
this._data = Object.assign(Object.assign({}, this._data), { original_transfer_id: newVal });
|
|
423
|
+
};
|
|
424
|
+
this.setAsCompleted = async (user, comment) => {
|
|
425
|
+
this._generateNewTransferStatusUpdates(this._data.status, user, `Fermé manuellement${!!comment ? ' : ' + comment : ''}`, this._data.products, TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_COMPLETED_MANUALLY);
|
|
426
|
+
await this.handleFreeTransitInventory();
|
|
427
|
+
await this.save({ completed: true }, true, true);
|
|
428
|
+
};
|
|
429
|
+
this.changeStatus = async (newStatus, comment, user, saveToDatabase = true, options = {}) => {
|
|
430
|
+
const saveOptions = {
|
|
431
|
+
comment,
|
|
432
|
+
user,
|
|
433
|
+
saveToDatabase,
|
|
434
|
+
originalRequestProducts: options.originalRequestProducts,
|
|
435
|
+
space: options.space
|
|
436
|
+
};
|
|
437
|
+
let fncToCall;
|
|
438
|
+
switch (newStatus) {
|
|
439
|
+
case TransferRequest_1.TransferRequestStatusEnum.OPEN:
|
|
440
|
+
fncToCall = this.updateToStatus.open;
|
|
441
|
+
break;
|
|
442
|
+
case TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED:
|
|
443
|
+
fncToCall = this.updateToStatus.toBePrepared;
|
|
444
|
+
break;
|
|
445
|
+
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
446
|
+
fncToCall = this.updateToStatus.inTransit;
|
|
447
|
+
break;
|
|
448
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
449
|
+
fncToCall = this.updateToStatus.received;
|
|
450
|
+
break;
|
|
451
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
452
|
+
saveOptions.markAsCompleted = options.setAsCompleted;
|
|
453
|
+
fncToCall = this.updateToStatus.receivedPartial;
|
|
454
|
+
break;
|
|
455
|
+
case TransferRequest_1.TransferRequestStatusEnum.CANCELLED:
|
|
456
|
+
fncToCall = this.updateToStatus.cancelled;
|
|
457
|
+
break;
|
|
458
|
+
}
|
|
459
|
+
if (!!!fncToCall)
|
|
460
|
+
throw new Error('No status update function associated to provided status! Returning.');
|
|
461
|
+
try {
|
|
462
|
+
await fncToCall(saveOptions, options.context);
|
|
463
|
+
return this.data();
|
|
464
|
+
}
|
|
465
|
+
catch (e) {
|
|
466
|
+
throw new Error('Impossible de soumettre le(s) transfert(s)');
|
|
467
|
+
}
|
|
468
|
+
};
|
|
469
|
+
this.saveNewTransfer = async (currentUser, comment, saveToDatabase = true, skipRef) => {
|
|
470
|
+
if (!!this.data().id)
|
|
471
|
+
throw 'Cette demande de transfert existe déjà en base de données!';
|
|
472
|
+
if (!!!this.data().status)
|
|
473
|
+
throw "Cette demande n'a pas encore de statut initial, et ne peut être sauvegardée!";
|
|
474
|
+
const newUpdates = this._generateNewTransferStatusUpdates(this.data().status, currentUser, comment);
|
|
475
|
+
let newTransferRef = undefined;
|
|
476
|
+
if (!!!skipRef) {
|
|
477
|
+
newTransferRef = await this._getTransferRef();
|
|
478
|
+
}
|
|
479
|
+
return await this.save(Object.assign(Object.assign({}, this.data()), { ref: newTransferRef, transfer_updates: newUpdates }), saveToDatabase);
|
|
480
|
+
};
|
|
481
|
+
this.getProductWeight = (sku, unit = 'pounds') => {
|
|
482
|
+
const item = this.data().products.find((p) => p.sku == sku);
|
|
483
|
+
if (!item)
|
|
484
|
+
return 0;
|
|
485
|
+
if (!!!item.weight)
|
|
486
|
+
return 0;
|
|
487
|
+
const value = (0, toNumber_1.default)(item.weight.value) || 0;
|
|
488
|
+
return item.weight.unit === unit ? value * item.qte : (0, weight_1.convertWeight)(value, item.weight.unit, unit) * item.qte;
|
|
489
|
+
};
|
|
490
|
+
this._getOrderObject = async (space) => {
|
|
491
|
+
if (!space)
|
|
492
|
+
space = await Space_1.default.getCurrentSpaceWithRef(this._collection.path, this._user);
|
|
493
|
+
return space.transferRequests.getTransferStatusOrder();
|
|
494
|
+
};
|
|
495
|
+
this._checkIfCanChangeToStatus = async (statusToCheck, space) => {
|
|
496
|
+
const currentStatus = this._data.status;
|
|
497
|
+
if (currentStatus == statusToCheck)
|
|
498
|
+
return true;
|
|
499
|
+
try {
|
|
500
|
+
const orderObj = await this._getOrderObject(space);
|
|
501
|
+
const possibleNextStatus = (0, transferRequests_1.getTransferStatusAfter)(currentStatus, orderObj);
|
|
502
|
+
return possibleNextStatus !== null && possibleNextStatus.values.includes(statusToCheck);
|
|
503
|
+
}
|
|
504
|
+
catch (e) {
|
|
505
|
+
console.log('error on checking status change: ', e.toString());
|
|
506
|
+
return false;
|
|
507
|
+
}
|
|
508
|
+
};
|
|
509
|
+
this._generateNewTransferStatusUpdates = (newStatus, user, comment, originalRequestProducts, context) => {
|
|
510
|
+
const updates = this._data.transfer_updates;
|
|
511
|
+
const newProducts = this._data.products;
|
|
512
|
+
const newFromStore = this._data.from;
|
|
513
|
+
let prodUpdateObj = {};
|
|
514
|
+
if (!!this._data.id || !!originalRequestProducts) {
|
|
515
|
+
if (newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED || newStatus == TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL) {
|
|
516
|
+
for (let prod of newProducts) {
|
|
517
|
+
const addedQty = prod.qte_received - this.getPreviousReceivedQuantity(prod.sku);
|
|
518
|
+
if (addedQty != 0) {
|
|
519
|
+
prodUpdateObj[prod.sku] = {
|
|
520
|
+
qte_before: prod.qte_received - addedQty,
|
|
521
|
+
qte_after: prod.qte_received,
|
|
522
|
+
name: prod.name
|
|
523
|
+
};
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
else {
|
|
528
|
+
const prevProducts = !!originalRequestProducts ? originalRequestProducts : this.prevProducts;
|
|
529
|
+
for (let prod of newProducts) {
|
|
530
|
+
const name = prod.name;
|
|
531
|
+
const sameInPrev = prevProducts.find((p) => p.sku == prod.sku);
|
|
532
|
+
if (!!!sameInPrev) {
|
|
533
|
+
prodUpdateObj[prod.sku] = { qte_before: 0, qte_after: prod.qte, name };
|
|
534
|
+
}
|
|
535
|
+
else if (sameInPrev.qte !== prod.qte) {
|
|
536
|
+
prodUpdateObj[prod.sku] = { qte_before: sameInPrev.qte, qte_after: prod.qte, name };
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
for (let prevProd of this.prevProducts) {
|
|
540
|
+
const sameInNew = newProducts.find((p) => p.sku == prevProd.sku);
|
|
541
|
+
if (!!!sameInNew) {
|
|
542
|
+
prodUpdateObj[prevProd.sku] = { qte_before: prevProd.qte, qte_after: 0, name: prevProd.name };
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
updates.unshift(Object.assign({ status: newStatus, date: new Date(), updated_by: user, comment: comment, products: !!Object.keys(prodUpdateObj).length ? prodUpdateObj : null, fromStore: this.prevFromStore != this._data.from && this._data.status == TransferRequest_1.TransferRequestStatusEnum.OPEN
|
|
548
|
+
? { before: this.prevFromStore || '', after: newFromStore || '' }
|
|
549
|
+
: null }, (!!context ? { context } : {})));
|
|
550
|
+
return updates;
|
|
551
|
+
};
|
|
552
|
+
this._saveNewStatus = async (newStatus, options, forceCompleted = false, context = TransferRequest_1.TransferRequestUpdateContextEnum.TRANSFER_STATUS_CHANGE) => {
|
|
553
|
+
const newUpdates = this._generateNewTransferStatusUpdates(newStatus, options.user, options.comment, options.originalRequestProducts, context);
|
|
554
|
+
const completedProps = options.markAsCompleted;
|
|
555
|
+
const canSetAsCompleted = !!completedProps && TransferRequest.checkIfStatusCountsAsCompleted(newStatus);
|
|
556
|
+
if (!!completedProps && !canSetAsCompleted) {
|
|
557
|
+
console.log('Could not set completed property to true since provided new status was not found in "elligible" array!');
|
|
558
|
+
}
|
|
559
|
+
try {
|
|
560
|
+
const response = await this.save(Object.assign({ status: newStatus, transfer_updates: newUpdates }, (forceCompleted || canSetAsCompleted ? { completed: true } : {})), options.saveToDatabase);
|
|
561
|
+
if (!!!response)
|
|
562
|
+
throw new Error('Error while saving the transfer reqeust.');
|
|
563
|
+
}
|
|
564
|
+
catch (e) {
|
|
565
|
+
console.error('Error while saving the transfer reqeust.');
|
|
566
|
+
throw new Error('Error while saving the transfer reqeust.');
|
|
567
|
+
}
|
|
568
|
+
};
|
|
569
|
+
this._setAsOpen = async (options) => {
|
|
570
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.OPEN;
|
|
571
|
+
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
572
|
+
if (!statusChangeValid)
|
|
573
|
+
throw new Error('Trying to change to wrong status! Returning.');
|
|
574
|
+
await this._saveNewStatus(newStatus, options);
|
|
575
|
+
};
|
|
576
|
+
this._setAsToBePrepared = async (options) => {
|
|
577
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED;
|
|
578
|
+
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
579
|
+
if (!statusChangeValid)
|
|
580
|
+
throw new Error('Trying to change to wrong status! Returning.');
|
|
581
|
+
await this._saveNewStatus(newStatus, options);
|
|
582
|
+
};
|
|
583
|
+
this._setAsInTransit = async (options) => {
|
|
584
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT;
|
|
585
|
+
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
586
|
+
if (!statusChangeValid)
|
|
587
|
+
throw new Error('Trying to change to wrong status! Returning.');
|
|
588
|
+
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
589
|
+
if (!!!inventoryChangesSuccess) {
|
|
590
|
+
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
591
|
+
}
|
|
592
|
+
await this._saveNewStatus(newStatus, options);
|
|
593
|
+
};
|
|
594
|
+
this._setAsReceived = async (options) => {
|
|
595
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.RECEIVED;
|
|
596
|
+
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
597
|
+
if (!statusChangeValid)
|
|
598
|
+
throw new Error('Trying to change to wrong status! Returning.');
|
|
599
|
+
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
600
|
+
if (!!!inventoryChangesSuccess) {
|
|
601
|
+
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
602
|
+
}
|
|
603
|
+
await this.handleUpdateAssociatedCartReservedQuantities();
|
|
604
|
+
await this._saveNewStatus(newStatus, options, true);
|
|
605
|
+
};
|
|
606
|
+
this._setAsReceivedPartially = async (options) => {
|
|
607
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL;
|
|
608
|
+
const statusChangeValid = await this._checkIfCanChangeToStatus(newStatus, options.space);
|
|
609
|
+
if (!statusChangeValid)
|
|
610
|
+
throw new Error('Trying to change to wrong status! Returning.');
|
|
611
|
+
const inventoryChangesSuccess = await this.handleChangeStoreInventory(newStatus);
|
|
612
|
+
if (!!!inventoryChangesSuccess) {
|
|
613
|
+
throw "Une erreur est survenue lors de la mise à jour de l'inventaire.";
|
|
614
|
+
}
|
|
615
|
+
await this.handleUpdateAssociatedCartReservedQuantities();
|
|
616
|
+
await this._saveNewStatus(newStatus, options);
|
|
617
|
+
};
|
|
618
|
+
this._setAsCancelled = async (options, context) => {
|
|
619
|
+
const newStatus = TransferRequest_1.TransferRequestStatusEnum.CANCELLED;
|
|
620
|
+
const statusPositionObj = await this._getOrderObject();
|
|
621
|
+
const canBeCancelled = TransferRequest.checkIfTransferCanBeCancelled(this._data.status, statusPositionObj);
|
|
622
|
+
if (!canBeCancelled) {
|
|
623
|
+
throw new Error('transfer cannot be cancelled, status is same of after IN_TRANSIT');
|
|
624
|
+
}
|
|
625
|
+
await this._saveNewStatus(newStatus, options, true, context);
|
|
626
|
+
};
|
|
627
|
+
this.updateToStatus = {
|
|
628
|
+
open: this._setAsOpen,
|
|
629
|
+
toBePrepared: this._setAsToBePrepared,
|
|
630
|
+
inTransit: this._setAsInTransit,
|
|
631
|
+
received: this._setAsReceived,
|
|
632
|
+
receivedPartial: this._setAsReceivedPartially,
|
|
633
|
+
cancelled: this._setAsCancelled
|
|
634
|
+
};
|
|
635
|
+
this.getFormattedRef = (spaceTransferSettings) => {
|
|
636
|
+
if (typeof this._data.ref == 'undefined') {
|
|
637
|
+
console.log('transfer has no ref, returning!');
|
|
638
|
+
return;
|
|
639
|
+
}
|
|
640
|
+
if (!!!spaceTransferSettings)
|
|
641
|
+
return this._data.ref.toString();
|
|
642
|
+
const prefix = spaceTransferSettings.prefix;
|
|
643
|
+
const suffix = spaceTransferSettings.suffix;
|
|
644
|
+
return `${prefix ? prefix + '-' : ''}${this._data.ref}${suffix ? '-' + suffix : ''}`;
|
|
645
|
+
};
|
|
646
|
+
this._data = this.processData(_data);
|
|
647
|
+
if (!!this._data.products.length) {
|
|
648
|
+
this.prevProducts = [...this._data.products];
|
|
649
|
+
}
|
|
650
|
+
if (!!this._data.from)
|
|
651
|
+
this.prevFromStore = this._data.from;
|
|
652
|
+
}
|
|
653
|
+
}
|
|
654
|
+
exports.TransferRequest = TransferRequest;
|
|
655
|
+
_a = TransferRequest;
|
|
656
|
+
TransferRequest.fetch = async ({ app, api, hpp = 10, page = 0, query = '', filters = '', indice = 'transfer_request', f = '', space, useProspr = false }) => {
|
|
657
|
+
try {
|
|
658
|
+
let prosprSearch = false;
|
|
659
|
+
if (!!space) {
|
|
660
|
+
const prosprService = space
|
|
661
|
+
.data()
|
|
662
|
+
.external_services.find((es) => es.external_service_name.toLowerCase().trim() === 'prosprsearch');
|
|
663
|
+
prosprSearch = !!prosprService && prosprService.is_active;
|
|
664
|
+
}
|
|
665
|
+
const algolia = (0, algolia_1.createClient)({
|
|
666
|
+
app,
|
|
667
|
+
indexId: `${__1.isTestEnv ? 'test' : 'prod'}_${indice}`,
|
|
668
|
+
key: !!useProspr ? api : prosprSearch && !!space ? space.preferences.prosprsearch.app() : api,
|
|
669
|
+
prospr: !!prosprSearch || !!useProspr
|
|
670
|
+
});
|
|
671
|
+
const results = await algolia.search(query, {
|
|
672
|
+
hitsPerPage: hpp,
|
|
673
|
+
facetFilters: filters,
|
|
674
|
+
filters: f,
|
|
675
|
+
page,
|
|
676
|
+
facets: ['*']
|
|
677
|
+
});
|
|
678
|
+
return results;
|
|
679
|
+
}
|
|
680
|
+
catch (error) {
|
|
681
|
+
(0, console_1.errorMessage)(error);
|
|
682
|
+
throw error;
|
|
683
|
+
}
|
|
684
|
+
};
|
|
685
|
+
TransferRequest.getStatusLabel = (status) => {
|
|
686
|
+
switch (status) {
|
|
687
|
+
case TransferRequest_1.TransferRequestStatusEnum.INITIATED:
|
|
688
|
+
return 'Initialisée';
|
|
689
|
+
case TransferRequest_1.TransferRequestStatusEnum.OPEN:
|
|
690
|
+
return 'Ouverte';
|
|
691
|
+
case TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED:
|
|
692
|
+
return 'À préparer';
|
|
693
|
+
case TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT:
|
|
694
|
+
return 'En transit';
|
|
695
|
+
case TransferRequest_1.TransferRequestStatusEnum.CANCELLED:
|
|
696
|
+
return 'Annulée';
|
|
697
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL:
|
|
698
|
+
return 'Reçue partiellement';
|
|
699
|
+
case TransferRequest_1.TransferRequestStatusEnum.RECEIVED:
|
|
700
|
+
return 'Reçue';
|
|
701
|
+
}
|
|
702
|
+
};
|
|
703
|
+
TransferRequest.checkIfTransferCanBeCancelled = (currentTransferStatus, statusOrderObj) => {
|
|
704
|
+
const currentPosition = (0, transferRequests_1.getOrderPositionForStatus)(currentTransferStatus, statusOrderObj);
|
|
705
|
+
if (typeof currentPosition != 'number') {
|
|
706
|
+
console.log('could not compare status since currentPosition was not found');
|
|
707
|
+
return false;
|
|
708
|
+
}
|
|
709
|
+
const inTransitPosition = (0, transferRequests_1.getOrderPositionForStatus)(TransferRequest_1.TransferRequestStatusEnum.IN_TRANSIT, statusOrderObj);
|
|
710
|
+
if (typeof inTransitPosition != 'number') {
|
|
711
|
+
console.log('could not compare status since inTransitPosition was not found');
|
|
712
|
+
return false;
|
|
713
|
+
}
|
|
714
|
+
return (0, toNumber_1.default)(currentPosition) < (0, toNumber_1.default)(inTransitPosition);
|
|
715
|
+
};
|
|
716
|
+
TransferRequest.checkIfStatusCountsAsCompleted = (statusToCheck) => {
|
|
717
|
+
return [
|
|
718
|
+
TransferRequest_1.TransferRequestStatusEnum.RECEIVED,
|
|
719
|
+
TransferRequest_1.TransferRequestStatusEnum.RECEIVED_PARTIAL,
|
|
720
|
+
TransferRequest_1.TransferRequestStatusEnum.CANCELLED
|
|
721
|
+
].includes(statusToCheck);
|
|
722
|
+
};
|
|
723
|
+
TransferRequest.transferAllowAssignFromStore = (data) => {
|
|
724
|
+
if (!!data.completed)
|
|
725
|
+
return false;
|
|
726
|
+
return !!data.id && TransferRequest_1.TransferRequestStatusEnum.INITIATED === data.status;
|
|
727
|
+
};
|
|
728
|
+
TransferRequest.transferAllowEditFromStore = (data) => {
|
|
729
|
+
if (!!data.completed)
|
|
730
|
+
return false;
|
|
731
|
+
return !!data.id && TransferRequest_1.TransferRequestStatusEnum.OPEN === data.status;
|
|
732
|
+
};
|
|
733
|
+
TransferRequest.transferAllowAddProductOnEdit = (data) => {
|
|
734
|
+
if (!!data.completed)
|
|
735
|
+
return false;
|
|
736
|
+
if (data.draft)
|
|
737
|
+
return true;
|
|
738
|
+
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
739
|
+
};
|
|
740
|
+
TransferRequest.transferAllowProductDelete = (data) => {
|
|
741
|
+
if (!!data.completed)
|
|
742
|
+
return false;
|
|
743
|
+
if (!!!data.id)
|
|
744
|
+
return true;
|
|
745
|
+
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
746
|
+
};
|
|
747
|
+
TransferRequest.transferAllowEditProductOnEdit = (data) => {
|
|
748
|
+
if (!!data.completed)
|
|
749
|
+
return false;
|
|
750
|
+
return [
|
|
751
|
+
TransferRequest_1.TransferRequestStatusEnum.INITIATED,
|
|
752
|
+
TransferRequest_1.TransferRequestStatusEnum.OPEN,
|
|
753
|
+
TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED
|
|
754
|
+
].includes(data.status);
|
|
755
|
+
};
|
|
756
|
+
TransferRequest.transferAllowDeleteProductOnEdit = (data) => {
|
|
757
|
+
if (!!data.completed)
|
|
758
|
+
return false;
|
|
759
|
+
if (!!!data.id)
|
|
760
|
+
return true;
|
|
761
|
+
return [TransferRequest_1.TransferRequestStatusEnum.INITIATED, TransferRequest_1.TransferRequestStatusEnum.OPEN].includes(data.status);
|
|
762
|
+
};
|
|
763
|
+
TransferRequest.transferShouldDisplayWeight = (data) => {
|
|
764
|
+
return ![TransferRequest_1.TransferRequestStatusEnum.INITIATED].includes(data.status);
|
|
765
|
+
};
|
|
766
|
+
TransferRequest.transferAllowsIndependantProductUpdate = (data) => {
|
|
767
|
+
if (!!data.completed)
|
|
768
|
+
return false;
|
|
769
|
+
let acceptedStatuses = [TransferRequest_1.TransferRequestStatusEnum.INITIATED, TransferRequest_1.TransferRequestStatusEnum.OPEN];
|
|
770
|
+
if (!data.associated_order)
|
|
771
|
+
acceptedStatuses.push(TransferRequest_1.TransferRequestStatusEnum.TO_BE_PREPARED);
|
|
772
|
+
return acceptedStatuses.includes(data.status);
|
|
773
|
+
};
|
|
774
|
+
TransferRequest.getTotalWeight = (products, unit = 'pounds') => {
|
|
775
|
+
return (0, sumBy_1.default)(products, (item) => {
|
|
776
|
+
if (!!!item.weight)
|
|
777
|
+
return 0;
|
|
778
|
+
const value = (0, toNumber_1.default)(item.weight.value) || 0;
|
|
779
|
+
return item.weight.unit === unit ? value * item.qte : (0, weight_1.convertWeight)(value, item.weight.unit, unit) * item.qte;
|
|
780
|
+
});
|
|
781
|
+
};
|
|
782
|
+
TransferRequest.getTotalPalletQte = (items) => {
|
|
783
|
+
const total = (0, sumBy_1.default)(items.map((item) => {
|
|
784
|
+
if (!!!item.other_units || !!!item.count_in_pallet_total) {
|
|
785
|
+
return 0;
|
|
786
|
+
}
|
|
787
|
+
const paletteUnit = item.other_units.find((u) => u.unit_slug === 'pal');
|
|
788
|
+
if (!!!paletteUnit || !!!paletteUnit.fitting_unit) {
|
|
789
|
+
return 0;
|
|
790
|
+
}
|
|
791
|
+
return item.qte / paletteUnit.fitting_unit;
|
|
792
|
+
}));
|
|
793
|
+
return (0, ceil_1.default)(total);
|
|
794
|
+
};
|
|
795
795
|
//# sourceMappingURL=index.js.map
|