@retailrocketgroup/retailrocket-create.abandoned-basket-price-drop-vue-email-template-render 3.0.377566 → 5.0.384530

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/.turbo/turbo-build.log +25 -0
  2. package/dist/assets/index.css +1 -0
  3. package/dist/assets/index.js +379 -0
  4. package/dist/assets/index.js.map +1 -0
  5. package/dist/createAbandonedBasketPriceDropEmailTemplateApp.d.ts +0 -0
  6. package/dist/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropComponentSectionItemFactory.d.ts +4 -0
  7. package/dist/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropEmailComponentFactory.d.ts +4 -0
  8. package/dist/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CustomComponentLibrary/abandonedBasketPriceDropComponentLibraryFactory.d.ts +4 -0
  9. package/dist/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CustomComponentLibrary/abandonedBasketPriceDropSectionFactory.d.ts +4 -0
  10. package/dist/implementation/DataSources/ListDataExpressionSource/abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory.d.ts +8 -0
  11. package/dist/implementation/DataSources/NumberExpressionDataSource/abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory.d.ts +2 -0
  12. package/dist/implementation/DataSources/StringExpressionDataSource/abandonedBasketPriceDropEvaluateStringExpressionDataSource.d.ts +9 -0
  13. package/dist/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/ShelfBuilders/abandonedBasketPriceDropProductListShelfBuilderDepsFactory.d.ts +8 -0
  14. package/dist/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/ShelfBuilders/alternativeProductsForAbandonedBasketPriceDropProductListShelfBuilderDepsFactory.d.ts +8 -0
  15. package/dist/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModalDepsFactory.d.ts +11 -0
  16. package/dist/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderDepsFactory.d.ts +11 -0
  17. package/dist/index.d.ts +1 -0
  18. package/dist/index.html +35 -0
  19. package/env.d.ts +1 -0
  20. package/index.html +1 -2
  21. package/package.json +1 -1
  22. package/src/createAbandonedBasketPriceDropEmailTemplateApp.ts +295 -0
  23. package/src/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropComponentSectionItemFactory.ts +32 -0
  24. package/src/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropEmailComponentFactory.ts +26 -0
  25. package/src/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CustomComponentLibrary/abandonedBasketPriceDropComponentLibraryFactory.ts +29 -0
  26. package/src/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CustomComponentLibrary/abandonedBasketPriceDropSectionFactory.ts +34 -0
  27. package/src/implementation/DataSources/ListDataExpressionSource/abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory.ts +125 -0
  28. package/src/implementation/DataSources/NumberExpressionDataSource/abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory.ts +10 -0
  29. package/src/implementation/DataSources/StringExpressionDataSource/abandonedBasketPriceDropEvaluateStringExpressionDataSource.ts +56 -0
  30. package/src/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/ShelfBuilders/abandonedBasketPriceDropProductListShelfBuilderDepsFactory.ts +33 -0
  31. package/src/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/ShelfBuilders/alternativeProductsForAbandonedBasketPriceDropProductListShelfBuilderDepsFactory.ts +33 -0
  32. package/src/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModal/abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModalDepsFactory.ts +142 -0
  33. package/src/implementation/EmailComponentSettingsModifierPlugin/ProductShelfDataSourceExpressionBuilder/abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderDepsFactory.ts +34 -0
  34. package/src/index.ts +0 -0
  35. package/tsconfig.app.json +19 -0
  36. package/tsconfig.json +14 -0
  37. package/tsconfig.node.json +11 -0
  38. package/tsconfig.test.json +11 -0
  39. package/vite.config.ts +36 -0
  40. package/assets/main.css +0 -1
  41. package/assets/main.js +0 -179
  42. package/favicon.ico +0 -0
@@ -0,0 +1,4 @@
1
+ import { ComponentLibrarySectionItem } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
2
+ import { CustomComponentSectionItemType } from '@easy-wizzy/core';
3
+ import { AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropComponentSectionItemFactory: (componentLibrarySectionItem: ComponentLibrarySectionItem) => CustomComponentSectionItemType<AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource>;
@@ -0,0 +1,4 @@
1
+ import { EmailComponentType } from '@easy-wizzy/core';
2
+ import { Component } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.addcomponentlibrarysectionitemmodalwindow/main';
3
+ import { AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropEmailComponentFactory: (component: Component) => EmailComponentType<AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource>;
@@ -0,0 +1,4 @@
1
+ import { ComponentLibrarySection } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
2
+ import { CustomComponentLibraryType } from '@easy-wizzy/core';
3
+ import { AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropComponentLibraryFactory: (componentLibrary: Array<ComponentLibrarySection>) => CustomComponentLibraryType<AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource>;
@@ -0,0 +1,4 @@
1
+ import { ComponentLibrarySection } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
2
+ import { CustomComponentSectionType } from '@easy-wizzy/core';
3
+ import { AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropSectionFactory: (section: ComponentLibrarySection) => CustomComponentSectionType<AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource>;
@@ -0,0 +1,8 @@
1
+ import { ListExpressionDataSourceBffClient } from '@easy-wizzy/common-app';
2
+ import { ListExpressionDataSourceEvaluatorDelegate } from '@easy-wizzy/core';
3
+ import { AbandonedBasketPriceDropListExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory: (arg: {
5
+ partnerId: string;
6
+ listExpressionDataSourceBffClient: ListExpressionDataSourceBffClient;
7
+ customerStockId: string | undefined;
8
+ }) => ListExpressionDataSourceEvaluatorDelegate<AbandonedBasketPriceDropListExpressionDataSource>;
@@ -0,0 +1,2 @@
1
+ import { NumberExpressionDataSourceEvaluatorDelegate } from '@easy-wizzy/core';
2
+ export declare const abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory: <TNumberExpressionDataSource>() => NumberExpressionDataSourceEvaluatorDelegate<TNumberExpressionDataSource>;
@@ -0,0 +1,9 @@
1
+ import { StringExpressionDataSourceEvaluatorDelegate } from '@easy-wizzy/core';
2
+ import { ContactCustomData, NextCouponFromBatchType } from '@easy-wizzy/retailrocket-common';
3
+ import { ProductImageUrlBuilderExpressionEvaluatorDelegate } from '@easy-wizzy/common-app';
4
+ import { AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource, AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
5
+ export declare const abandonedBasketPriceDropStringExpressionDataSourceEvaluatorFactory: (arg: {
6
+ productImageUrlBuilderExpressionEvaluator: ProductImageUrlBuilderExpressionEvaluatorDelegate<AbandonedBasketPriceDropListExpressionDataSource, AbandonedBasketPriceDropNumberExpressionDataSource>;
7
+ contactCustomData: ContactCustomData;
8
+ nextCouponFromBatch: NextCouponFromBatchType;
9
+ }) => StringExpressionDataSourceEvaluatorDelegate<AbandonedBasketPriceDropStringExpressionDataSource>;
@@ -0,0 +1,8 @@
1
+ import { LocaleKey } from '@easy-wizzy/core';
2
+ import { ProductShelfBuilderModalWindowBffClient } from '@easy-wizzy/common-app';
3
+ import { AbandonedBasketPriceDropProductListShelfBuilderDeps } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropProductListShelfBuilderDepsFactory: (arg: {
5
+ localeKey: LocaleKey;
6
+ partnerId: string;
7
+ getAllStockIdsHttpClient: ProductShelfBuilderModalWindowBffClient["postGetAllStockIds"];
8
+ }) => AbandonedBasketPriceDropProductListShelfBuilderDeps;
@@ -0,0 +1,8 @@
1
+ import { LocaleKey } from '@easy-wizzy/core';
2
+ import { ProductShelfBuilderModalWindowBffClient } from '@easy-wizzy/common-app';
3
+ import { AlternativeProductsForAbandonedBasketPriceDropProductListShelfBuilderDeps } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const alternativeProductsForAbandonedProductListShelfBuilderDepsFactory: (arg: {
5
+ localeKey: LocaleKey;
6
+ partnerId: string;
7
+ getAllStockIdsHttpClient: ProductShelfBuilderModalWindowBffClient["postGetAllStockIds"];
8
+ }) => AlternativeProductsForAbandonedBasketPriceDropProductListShelfBuilderDeps;
@@ -0,0 +1,11 @@
1
+ import { LocaleKey } from '@easy-wizzy/core';
2
+ import { ProductShelfBuilderModalWindowBffClient, ProductCategoryPickerModalWindowBffClient, ProductPickerModalWindowBffClient } from '@easy-wizzy/common-app';
3
+ import { AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModalDeps } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModalDepsFactory: (arg: {
5
+ localeKey: LocaleKey;
6
+ partnerId: string;
7
+ customerStockId: string | undefined;
8
+ productShelfBuilderModalWindowBffClient: ProductShelfBuilderModalWindowBffClient;
9
+ productCategoryPickerModalWindowBffClient: ProductCategoryPickerModalWindowBffClient;
10
+ productPickerModalWindowBffClient: ProductPickerModalWindowBffClient;
11
+ }) => AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderModalDeps;
@@ -0,0 +1,11 @@
1
+ import { LocaleKey } from '@easy-wizzy/core';
2
+ import { ProductShelfBuilderModalWindowBffClient, ProductCategoryPickerModalWindowBffClient, ProductPickerModalWindowBffClient } from '@easy-wizzy/common-app';
3
+ import { AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderDeps } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
4
+ export declare const abandonedBasketPriceDropProductShelfDataSourceExpressionBuilderDepsFactory: (arg: {
5
+ localeKey: LocaleKey;
6
+ partnerId: string;
7
+ customerStockId: string | undefined;
8
+ productShelfBuilderModalWindowBffClient: ProductShelfBuilderModalWindowBffClient;
9
+ productCategoryPickerModalWindowBffClient: ProductCategoryPickerModalWindowBffClient;
10
+ productPickerModalWindowBffClient: ProductPickerModalWindowBffClient;
11
+ }) => AbandonedBasketPriceDropProductShelfDataSourceExpressionBuilderDeps;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,35 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <link rel="icon" href="/favicon.ico">
6
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
7
+ <link rel="preconnect" href="https://fonts.googleapis.com">
8
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
9
+ <link
10
+ href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap"
11
+ rel="stylesheet"
12
+ />
13
+ <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Lato:wght@100;300;400;700;900&family=Roboto:wght@400;700&display=swap" rel="stylesheet">
14
+ <title>Vite App</title>
15
+ <script type="module" crossorigin src="/assets/index.js"></script>
16
+ <link rel="stylesheet" crossorigin href="/assets/index.css">
17
+ </head>
18
+ <body>
19
+ <div
20
+ id="app"
21
+ data-partner-id="5df72bdc97a52507605e4cc1"
22
+ data-wysiwyg-template-editor-bff-base-url="https://my.retailrocket.ru/5db801c197a52821e86b0d45/TransactionalEmailCampaign/6757225a5520d1ae575e7f0e/CampaignWizard/Step2/WysiwygTemplateEditorBff"
23
+ data-wysiwyg-bff-proxy-base-url="https://k8s-b1.retailrocket.ru/"
24
+ data-anti-forgery-header-token-name="data-anti-forgery-header-token-name"
25
+ data-anti-forgery-header-token-value="data-anti-forgery-header-token-value"
26
+ data-anti-forgery-form-token-name="data-anti-forgery-form-token-name"
27
+ data-anti-forgery-form-token-value="data-anti-forgery-form-token-value"
28
+ data-initial-abandoned-basket-price-drop-template=""
29
+ data-abandoned-basket-price-drop-favorites-templates="[]"
30
+ data-create-email-template-submit-url="data-create-email-template-submit-url"
31
+ data-common-favorites-templates="[]"
32
+ data-exit-link="#"
33
+ ></div>
34
+ </body>
35
+ </html>
package/env.d.ts ADDED
@@ -0,0 +1 @@
1
+ /// <reference types="vite/client" />
package/index.html CHANGED
@@ -12,8 +12,6 @@
12
12
  />
13
13
  <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&family=Lato:wght@100;300;400;700;900&family=Roboto:wght@400;700&display=swap" rel="stylesheet">
14
14
  <title>Vite App</title>
15
- <script type="module" crossorigin src="/assets/main.js"></script>
16
- <link rel="stylesheet" crossorigin href="/assets/main.css">
17
15
  </head>
18
16
  <body>
19
17
  <div
@@ -31,5 +29,6 @@
31
29
  data-common-favorites-templates="[]"
32
30
  data-exit-link="#"
33
31
  ></div>
32
+ <script type="module" src="/src/createAbandonedBasketPriceDropEmailTemplateApp.ts"></script>
34
33
  </body>
35
34
  </html>
package/package.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@retailrocketgroup/retailrocket-create.abandoned-basket-price-drop-vue-email-template-render",
3
- "version": "3.0.377566",
3
+ "version": "5.0.384530",
4
4
  "private": false
5
5
  }
@@ -0,0 +1,295 @@
1
+ import 'bootstrap';
2
+ import '@easy-wizzy/core/index.css';
3
+
4
+ import { createApp } from 'vue';
5
+ import { createVuetify } from 'vuetify';
6
+ import { ClickOutside } from 'vuetify/directives';
7
+
8
+ import { CreateEmailTemplateApp } from '@easy-wizzy/core';
9
+ import { createSimpleDataForm, matcherFactory } from '@easy-wizzy/core';
10
+ import type { GeneralStringExpressionDataSource } from '@easy-wizzy/retailrocket-common';
11
+ import { expressionEvaluatorFactory } from '@easy-wizzy/core';
12
+ import { listExpressionEvaluatorFactory } from '@easy-wizzy/core';
13
+ import { numberExpressionEvaluatorDelegate } from '@easy-wizzy/core';
14
+ import { stringExpressionEvaluatorFactory } from '@easy-wizzy/core';
15
+ import { dataStructBuilderExpressionEvaluatorFactory } from '@easy-wizzy/core';
16
+
17
+ import type { EmailTemplateType } from '@easy-wizzy/core';
18
+ import type { EmailTemplatePreviewTileComponent } from '@easy-wizzy/core';
19
+ import type { LocaleKey } from '@easy-wizzy/core';
20
+ import type { StringExpressionEvaluatorDelegate } from '@easy-wizzy/core';
21
+
22
+ import { createEmailTemplateAppDepsFactory } from '@easy-wizzy/common-app';
23
+ import { emailTemplatePreviewTileComponentFactory } from '@easy-wizzy/common-app';
24
+ import { emailTemplatePreviewTileDepsFactory } from '@easy-wizzy/common-app';
25
+ import { productImageUrlBuilderExpressionEvaluatorFactory } from '@easy-wizzy/common-app';
26
+ import { defaultTemplateLibraryFactory } from '@easy-wizzy/common-app';
27
+ import { apiMachineFetchFactory } from '@easy-wizzy/common-app';
28
+ import { variableSelectorDepsFactory } from '@easy-wizzy/common-app';
29
+
30
+ import type { ApiMachineFetchDelegate } from '@easy-wizzy/common-app';
31
+
32
+ import { stringExpressionBuilderPluginFactory, richTextToolbarPluginFactory, VariableSelector } from '@easy-wizzy/retailrocket-common';
33
+
34
+ import type { ContactCustomData } from '@easy-wizzy/retailrocket-common';
35
+ import type { NextCouponFromBatchType } from '@easy-wizzy/retailrocket-common';
36
+
37
+ import type { AbandonedBasketPriceDropListExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
38
+ import type { AbandonedBasketPriceDropNumberExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
39
+ import type { AbandonedBasketPriceDropStringExpressionDataSource } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
40
+
41
+ import { initialEmailTemplateRu } from '@easy-wizzy/template-library';
42
+ import { initialEmailTemplateEn } from '@easy-wizzy/template-library';
43
+
44
+ import { abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory } from '@/implementation/DataSources/ListDataExpressionSource/abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory';
45
+ import { abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory } from '@/implementation/DataSources/NumberExpressionDataSource/abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory';
46
+ import { abandonedBasketPriceDropStringExpressionDataSourceEvaluatorFactory } from '@/implementation/DataSources/StringExpressionDataSource/abandonedBasketPriceDropEvaluateStringExpressionDataSource';
47
+
48
+ import { createApi as listExpressionDataSourceBffClientFactory } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.listexpressiondatasource';
49
+
50
+ const appTagId = '#app';
51
+ const appTag = document.querySelector(appTagId);
52
+
53
+ const params = {
54
+ partnerId: appTag!.getAttribute('data-partner-id')!,
55
+ wysiwygTemplateEditorBffBaseUrl: appTag!.getAttribute('data-wysiwyg-template-editor-bff-base-url')!,
56
+ wysiwygBffProxyBaseUrl: appTag!.getAttribute('data-wysiwyg-bff-proxy-base-url')!,
57
+ antiForgeryHeaderTokenName: appTag!.getAttribute('data-anti-forgery-header-token-name')!,
58
+ antiForgeryHeaderTokenValue: appTag!.getAttribute('data-anti-forgery-header-token-value')!,
59
+ antiForgeryFormTokenName: appTag!.getAttribute('data-anti-forgery-form-token-name')!,
60
+ antiForgeryFormTokenValue: appTag!.getAttribute('data-anti-forgery-form-token-value')!,
61
+ createEmailTemplateSubmitUrl: appTag!.getAttribute('data-create-email-template-submit-url')!,
62
+ initialEmailTemplateJson: appTag!.getAttribute('data-initial-abandoned-basket-price-drop-template')!,
63
+ abandonedBasketPriceDropFavoritesTemplates: JSON.parse(appTag!.getAttribute('data-abandoned-basket-price-drop-favorites-templates')!) as [{ templateId: string, templateJson: string, favoriteTemplateName: string }],
64
+ commonFavoritesTemplates: JSON.parse(appTag!.getAttribute('data-common-favorites-templates')!) as [{ templateId: string, templateJson: string, favoriteTemplateName: string }],
65
+ exitLink: appTag!.getAttribute('data-exit-link')!,
66
+ localeKey: appTag!.getAttribute('data-locale-key') as LocaleKey || 'en'
67
+ };
68
+
69
+ const _apiMachineFetchFactory = (arg: {
70
+ baseUrl: string
71
+ }): ApiMachineFetchDelegate => apiMachineFetchFactory({
72
+ baseUrl: arg.baseUrl,
73
+ antiForgeryTokenHeaderName: params.antiForgeryHeaderTokenName,
74
+ antiForgeryTokenValue: params.antiForgeryHeaderTokenValue
75
+ });
76
+
77
+ const listExpressionDataSourceBffClient = listExpressionDataSourceBffClientFactory(
78
+ _apiMachineFetchFactory({
79
+ baseUrl: params.wysiwygBffProxyBaseUrl
80
+ })
81
+ );
82
+
83
+ const createTemplate = <
84
+ TListExpressionDataSource,
85
+ TNumberExpressionDataSource,
86
+ TStringExpressionDataSource>(arg: {
87
+ template: EmailTemplateType<
88
+ TListExpressionDataSource,
89
+ TNumberExpressionDataSource,
90
+ TStringExpressionDataSource>
91
+ }): void => {
92
+ const formData = new FormData();
93
+ formData.append(
94
+ params.antiForgeryFormTokenName,
95
+ params.antiForgeryFormTokenValue);
96
+ formData.append(
97
+ 'template',
98
+ JSON.stringify(arg.template));
99
+
100
+ const form = createSimpleDataForm({
101
+ method: 'POST',
102
+ action: params.createEmailTemplateSubmitUrl,
103
+ formData: formData
104
+ });
105
+
106
+ document.body.appendChild(form);
107
+ form.submit();
108
+ };
109
+
110
+ const contactCustomData: ContactCustomData = {};
111
+ const nextCouponFromBatch: NextCouponFromBatchType = {
112
+ BatchId: ''
113
+ };
114
+
115
+ const createEmailTemplatePreviewTile = (arg: {
116
+ template: EmailTemplateType<
117
+ AbandonedBasketPriceDropListExpressionDataSource,
118
+ AbandonedBasketPriceDropNumberExpressionDataSource,
119
+ AbandonedBasketPriceDropStringExpressionDataSource
120
+ >;
121
+ templateName: string;
122
+ }): EmailTemplatePreviewTileComponent => {
123
+
124
+ const listExpressionDataSourceEvaluator = abandonedBasketPriceDropEvaluateListExpressionDataSourceFactory({
125
+ partnerId: params.partnerId,
126
+ listExpressionDataSourceBffClient: listExpressionDataSourceBffClient,
127
+ customerStockId: undefined
128
+ });
129
+
130
+ const listExpressionEvaluator = listExpressionEvaluatorFactory({
131
+ listExpressionDataSourceEvaluator: listExpressionDataSourceEvaluator
132
+ });
133
+
134
+ const numberExpressionDataSourceEvaluator = abandonedBasketPriceDropEvaluateNumberExpressionDataSourceFactory();
135
+
136
+ const numberExpressionEvaluator = numberExpressionEvaluatorDelegate({
137
+ listExpressionEvaluator: listExpressionEvaluator,
138
+ numberExpressionDataSourceEvaluator: numberExpressionDataSourceEvaluator
139
+ })
140
+
141
+ const stringExpressionEvaluator: StringExpressionEvaluatorDelegate<
142
+ AbandonedBasketPriceDropListExpressionDataSource,
143
+ AbandonedBasketPriceDropNumberExpressionDataSource,
144
+ AbandonedBasketPriceDropStringExpressionDataSource
145
+ > = stringExpressionEvaluatorFactory({
146
+ listExpressionEvaluator: listExpressionEvaluator,
147
+ numberExpressionEvaluator: numberExpressionEvaluator,
148
+ stringExpressionDataSourceEvaluatorFactory: () => abandonedBasketPriceDropStringExpressionDataSourceEvaluatorFactory({
149
+ productImageUrlBuilderExpressionEvaluator: productImageUrlBuilderExpressionEvaluatorFactory({
150
+ partnerId: params.partnerId,
151
+ numberExpressionEvaluator: numberExpressionEvaluator
152
+ }),
153
+ contactCustomData: contactCustomData,
154
+ nextCouponFromBatch: nextCouponFromBatch
155
+ })
156
+ });
157
+
158
+ const expressionEvaluator = expressionEvaluatorFactory({
159
+ listExpressionEvaluator: listExpressionEvaluator,
160
+ numberExpressionEvaluator: numberExpressionEvaluator,
161
+ stringExpressionEvaluator: stringExpressionEvaluator,
162
+ dataStructBuilderExpressionEvaluatorFactory: expressionEvaluator => dataStructBuilderExpressionEvaluatorFactory({
163
+ expressionEvaluator: expressionEvaluator
164
+ })
165
+ });
166
+
167
+ const dataStructExpressionEvaluator = dataStructBuilderExpressionEvaluatorFactory({
168
+ expressionEvaluator: expressionEvaluator
169
+ });
170
+
171
+ const stringExpressionBuilderPlugin = stringExpressionBuilderPluginFactory({
172
+ localeKey: params.localeKey
173
+ });
174
+
175
+ return emailTemplatePreviewTileComponentFactory<
176
+ AbandonedBasketPriceDropListExpressionDataSource,
177
+ AbandonedBasketPriceDropNumberExpressionDataSource,
178
+ AbandonedBasketPriceDropStringExpressionDataSource
179
+ >({
180
+ template: arg.template,
181
+ templateName: arg.templateName,
182
+ emailTemplatePreviewTileDeps: emailTemplatePreviewTileDepsFactory<
183
+ AbandonedBasketPriceDropListExpressionDataSource,
184
+ AbandonedBasketPriceDropNumberExpressionDataSource,
185
+ AbandonedBasketPriceDropStringExpressionDataSource
186
+ >({
187
+ localeKey: params.localeKey,
188
+ dataSourceFieldNameDelegate: ({ dataSource }) => {
189
+ return matcherFactory(dataSource as GeneralStringExpressionDataSource).Match({
190
+ StringFromContactCustomData: (customData) => customData.FieldName,
191
+ StringFromContactCustomDataWithFallback: (customDataWithFallback) => customDataWithFallback.FallbackValue,
192
+ ProductImageUrlBuilderExpression: () => 'ImageResizer',
193
+ NextCouponFromBatch: () => 'Coupon'
194
+ });
195
+ },
196
+ richTextToolbarPlugins: [
197
+ richTextToolbarPluginFactory({
198
+ richTextToolbarPluginComponent: VariableSelector,
199
+ deps: variableSelectorDepsFactory({
200
+ localeKey: params.localeKey,
201
+ stringExpressionBuilderPlugin: stringExpressionBuilderPlugin
202
+ })
203
+ })
204
+ ],
205
+ listExpressionEvaluator: listExpressionEvaluator,
206
+ numberExpressionEvaluator: numberExpressionEvaluator,
207
+ stringExpressionEvaluator: stringExpressionEvaluator,
208
+ dataStructExpressionEvaluator: dataStructExpressionEvaluator,
209
+ expressionEvaluator: expressionEvaluator,
210
+ stringExpressionBuilderPlugin: stringExpressionBuilderPlugin
211
+ }),
212
+ onFavoriteTemplateSelected: () => {
213
+ createTemplate({
214
+ template: arg.template
215
+ });
216
+ },
217
+ });
218
+ };
219
+
220
+ const initialEmailTemplate = params.localeKey === 'ru'
221
+ ? initialEmailTemplateRu
222
+ : initialEmailTemplateEn;
223
+
224
+ const app = createApp(
225
+ CreateEmailTemplateApp,
226
+ {
227
+ onInitialTemplateSelected: () => {
228
+ createTemplate({
229
+ template: params.initialEmailTemplateJson.length
230
+ ? JSON.parse(params.initialEmailTemplateJson)
231
+ : initialEmailTemplate,
232
+ });
233
+ },
234
+ deps:
235
+ createEmailTemplateAppDepsFactory<
236
+ AbandonedBasketPriceDropListExpressionDataSource,
237
+ AbandonedBasketPriceDropNumberExpressionDataSource,
238
+ AbandonedBasketPriceDropStringExpressionDataSource
239
+ >({
240
+ partnerId: params.partnerId,
241
+ localeKey: params.localeKey,
242
+ emailTemplatePreviews:
243
+ {
244
+ custom: [
245
+ ...params
246
+ .commonFavoritesTemplates
247
+ .map(o => ({
248
+ templateName: o.favoriteTemplateName,
249
+ previewTileComponent: createEmailTemplatePreviewTile({
250
+ template: JSON.parse(o.templateJson),
251
+ templateName: o.favoriteTemplateName
252
+ })
253
+ })),
254
+ ...params
255
+ .abandonedBasketPriceDropFavoritesTemplates
256
+ .map(o => ({
257
+ templateName: o.favoriteTemplateName,
258
+ previewTileComponent: createEmailTemplatePreviewTile({
259
+ template: JSON.parse(o.templateJson),
260
+ templateName: o.favoriteTemplateName
261
+ })
262
+ }))
263
+ ],
264
+ default: [
265
+ ...defaultTemplateLibraryFactory(params.localeKey)
266
+ .map(o => ({
267
+ templateName: o.favoriteTemplateName,
268
+ previewTileComponent: createEmailTemplatePreviewTile({
269
+ template: o.defaultTemplate as EmailTemplateType<
270
+ AbandonedBasketPriceDropListExpressionDataSource,
271
+ AbandonedBasketPriceDropNumberExpressionDataSource,
272
+ AbandonedBasketPriceDropStringExpressionDataSource
273
+ >,
274
+ templateName: o.favoriteTemplateName
275
+ })
276
+ }))
277
+ ]
278
+ },
279
+ initialEmailTemplate: params.initialEmailTemplateJson.length
280
+ ? JSON.parse(params.initialEmailTemplateJson)
281
+ : initialEmailTemplate,
282
+ exitLink: params.exitLink
283
+ }
284
+ )
285
+ }
286
+ );
287
+
288
+ app.use(createVuetify({
289
+ theme: false,
290
+ directives: {
291
+ ClickOutside
292
+ }
293
+ }));
294
+
295
+ app.mount(appTagId);
@@ -0,0 +1,32 @@
1
+ import type {
2
+ ComponentLibrarySectionItem,
3
+ } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
4
+ import type {
5
+ CustomComponentSectionItemType
6
+ } from '@easy-wizzy/core';
7
+ import {
8
+ abandonedBasketPriceDropEmailComponentFactory
9
+ } from '@/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropEmailComponentFactory';
10
+ import type {
11
+ AbandonedBasketPriceDropNumberExpressionDataSource
12
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
13
+ import type {
14
+ AbandonedBasketPriceDropListExpressionDataSource
15
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
16
+ import type {
17
+ AbandonedBasketPriceDropStringExpressionDataSource
18
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
19
+
20
+ export const abandonedBasketPriceDropComponentSectionItemFactory = (
21
+ componentLibrarySectionItem: ComponentLibrarySectionItem,
22
+ ): CustomComponentSectionItemType<
23
+ AbandonedBasketPriceDropListExpressionDataSource,
24
+ AbandonedBasketPriceDropNumberExpressionDataSource,
25
+ AbandonedBasketPriceDropStringExpressionDataSource
26
+ > => {
27
+ return {
28
+ sectionItemId: componentLibrarySectionItem.sectionItemId,
29
+ sectionItemName: componentLibrarySectionItem.sectionItemName,
30
+ componentTemplate: abandonedBasketPriceDropEmailComponentFactory(componentLibrarySectionItem.component),
31
+ };
32
+ };
@@ -0,0 +1,26 @@
1
+ import type { EmailComponentType } from '@easy-wizzy/core';
2
+ import type {
3
+ Component,
4
+ } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.addcomponentlibrarysectionitemmodalwindow/main';
5
+ import type {
6
+ AbandonedBasketPriceDropListExpressionDataSource
7
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
8
+ import type {
9
+ AbandonedBasketPriceDropNumberExpressionDataSource
10
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
11
+ import type {
12
+ AbandonedBasketPriceDropStringExpressionDataSource
13
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
14
+
15
+ export const abandonedBasketPriceDropEmailComponentFactory = (
16
+ component: Component
17
+ ): EmailComponentType<
18
+ AbandonedBasketPriceDropListExpressionDataSource,
19
+ AbandonedBasketPriceDropNumberExpressionDataSource,
20
+ AbandonedBasketPriceDropStringExpressionDataSource
21
+ > =>
22
+ {
23
+ return component.triggerAbandonedBasketPriceDrop
24
+ ? JSON.parse(component.triggerAbandonedBasketPriceDrop.componentJson)
25
+ : JSON.parse(component.common!.componentJson)
26
+ }
@@ -0,0 +1,29 @@
1
+ import type {
2
+ ComponentLibrarySection,
3
+ } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
4
+ import type {
5
+ CustomComponentLibraryType
6
+ } from '@easy-wizzy/core';
7
+ import type {
8
+ AbandonedBasketPriceDropListExpressionDataSource
9
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
10
+ import type {
11
+ AbandonedBasketPriceDropNumberExpressionDataSource
12
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
13
+ import type {
14
+ AbandonedBasketPriceDropStringExpressionDataSource
15
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
16
+ import {
17
+ abandonedBasketPriceDropSectionFactory
18
+ } from '@/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CustomComponentLibrary/abandonedBasketPriceDropSectionFactory';
19
+
20
+ export const abandonedBasketPriceDropComponentLibraryFactory = (
21
+ componentLibrary: Array<ComponentLibrarySection>
22
+ ): CustomComponentLibraryType<
23
+ AbandonedBasketPriceDropListExpressionDataSource,
24
+ AbandonedBasketPriceDropNumberExpressionDataSource,
25
+ AbandonedBasketPriceDropStringExpressionDataSource
26
+ > => {
27
+ return componentLibrary
28
+ .map(section => abandonedBasketPriceDropSectionFactory(section))
29
+ }
@@ -0,0 +1,34 @@
1
+ import type {
2
+ ComponentLibrarySection,
3
+ } from '@retailrocket/retailrocket.wysiwyg.bff.v2.apiclients.componentlibrary/main';
4
+ import type {
5
+ CustomComponentSectionType
6
+ } from '@easy-wizzy/core';
7
+ import type {
8
+ AbandonedBasketPriceDropListExpressionDataSource
9
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
10
+ import type {
11
+ AbandonedBasketPriceDropNumberExpressionDataSource
12
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
13
+ import type {
14
+ AbandonedBasketPriceDropStringExpressionDataSource
15
+ } from '@easy-wizzy/retailrocket-abandoned-basket-price-drop';
16
+ import {
17
+ abandonedBasketPriceDropComponentSectionItemFactory
18
+ } from '@/implementation/Apps/components/WysiwygTemplateEditor/AsideMenu/ComponentLibrary/CreateComponentLibrarySectionModalWindow/abandonedBasketPriceDropComponentSectionItemFactory';
19
+
20
+ export const abandonedBasketPriceDropSectionFactory = (
21
+ section: ComponentLibrarySection,
22
+ ): CustomComponentSectionType<
23
+ AbandonedBasketPriceDropListExpressionDataSource,
24
+ AbandonedBasketPriceDropNumberExpressionDataSource,
25
+ AbandonedBasketPriceDropStringExpressionDataSource
26
+ > => {
27
+ return {
28
+ sectionId: section.sectionId,
29
+ sectionName: section.sectionName,
30
+ componentList: section
31
+ .sectionItems
32
+ .map(component => abandonedBasketPriceDropComponentSectionItemFactory(component)),
33
+ };
34
+ };