@useinsider/guido 1.0.3-beta.09a6feb → 1.0.3-beta.0cd9180

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 (193) hide show
  1. package/README.md +5 -0
  2. package/dist/components/Guido.vue.js +1 -1
  3. package/dist/components/Guido.vue2.js +64 -61
  4. package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +21 -0
  5. package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +99 -0
  6. package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +20 -18
  7. package/dist/composables/useActionsApi.js +1 -1
  8. package/dist/composables/useBlocksConfig.js +1 -2
  9. package/dist/composables/useHtmlCompiler.js +15 -13
  10. package/dist/composables/useHtmlValidator.js +36 -35
  11. package/dist/composables/useStripo.js +47 -41
  12. package/dist/config/compiler/itemsCompilerRules.js +14 -0
  13. package/dist/enums/defaults.js +7 -5
  14. package/dist/enums/extensions/recommendationBlock.js +2 -2
  15. package/dist/enums/onboarding.js +7 -3
  16. package/dist/enums/unsubscribe.js +27 -26
  17. package/dist/extensions/Blocks/Checkbox/block.js +5 -2
  18. package/dist/extensions/Blocks/Checkbox/control.js +15 -14
  19. package/dist/extensions/Blocks/Checkbox/template.js +14 -9
  20. package/dist/extensions/Blocks/Items/block.js +67 -0
  21. package/dist/extensions/Blocks/Items/controls/button/link.js +68 -0
  22. package/dist/extensions/Blocks/Items/controls/cardComposition.js +193 -0
  23. package/dist/extensions/Blocks/Items/controls/image/link.js +68 -0
  24. package/dist/extensions/Blocks/Items/controls/index.js +217 -0
  25. package/dist/extensions/Blocks/Items/controls/name/trimming.js +70 -0
  26. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +107 -0
  27. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +123 -0
  28. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +76 -0
  29. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +61 -0
  30. package/dist/extensions/Blocks/Items/controls/settingsControl.js +312 -0
  31. package/dist/extensions/Blocks/Items/enums/controlEnums.js +5 -0
  32. package/dist/extensions/Blocks/Items/enums/productEnums.js +273 -0
  33. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +76 -0
  34. package/dist/extensions/Blocks/Items/extension.js +19 -0
  35. package/dist/extensions/Blocks/Items/iconsRegistry.js +32 -0
  36. package/dist/extensions/Blocks/Items/items.css.js +23 -0
  37. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +62 -0
  38. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +60 -0
  39. package/dist/extensions/Blocks/Items/settingsPanel.js +131 -0
  40. package/dist/extensions/Blocks/Items/store/items-block.js +71 -0
  41. package/dist/extensions/Blocks/Items/template.js +189 -0
  42. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
  43. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
  44. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +67 -0
  45. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +44 -0
  46. package/dist/extensions/Blocks/RadioButton/block.js +5 -2
  47. package/dist/extensions/Blocks/RadioButton/control.js +18 -17
  48. package/dist/extensions/Blocks/RadioButton/template.js +18 -9
  49. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +43 -43
  50. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +1 -1
  51. package/dist/extensions/Blocks/Unsubscribe/block.js +27 -27
  52. package/dist/extensions/Blocks/common-control.js +174 -110
  53. package/dist/extensions/Blocks/controlFactories.js +223 -0
  54. package/dist/extensions/DynamicContent/dynamic-content-modal.js +25 -19
  55. package/dist/extensions/DynamicContent/dynamic-content.js +128 -33
  56. package/dist/guido.css +1 -1
  57. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +213 -168
  58. package/dist/node_modules/lodash-es/_DataView.js +6 -0
  59. package/dist/node_modules/lodash-es/_Promise.js +6 -0
  60. package/dist/node_modules/lodash-es/_Set.js +6 -0
  61. package/dist/node_modules/lodash-es/_SetCache.js +13 -0
  62. package/dist/node_modules/lodash-es/_WeakMap.js +6 -0
  63. package/dist/node_modules/lodash-es/_arrayFilter.js +10 -0
  64. package/dist/node_modules/lodash-es/_arrayLikeKeys.js +13 -12
  65. package/dist/node_modules/lodash-es/_arrayMap.js +8 -0
  66. package/dist/node_modules/lodash-es/_arrayPush.js +8 -0
  67. package/dist/node_modules/lodash-es/_arraySome.js +9 -0
  68. package/dist/node_modules/lodash-es/_baseEach.js +6 -0
  69. package/dist/node_modules/lodash-es/_baseFlatten.js +13 -0
  70. package/dist/node_modules/lodash-es/_baseForOwn.js +8 -0
  71. package/dist/node_modules/lodash-es/_baseGet.js +11 -0
  72. package/dist/node_modules/lodash-es/_baseGetAllKeys.js +9 -0
  73. package/dist/node_modules/lodash-es/_baseHasIn.js +6 -0
  74. package/dist/node_modules/lodash-es/_baseIsEqual.js +8 -0
  75. package/dist/node_modules/lodash-es/_baseIsEqualDeep.js +32 -0
  76. package/dist/node_modules/lodash-es/_baseIsMatch.js +29 -0
  77. package/dist/node_modules/lodash-es/_baseIteratee.js +11 -0
  78. package/dist/node_modules/lodash-es/_baseKeys.js +14 -0
  79. package/dist/node_modules/lodash-es/_baseMap.js +11 -0
  80. package/dist/node_modules/lodash-es/_baseMatches.js +12 -0
  81. package/dist/node_modules/lodash-es/_baseMatchesProperty.js +17 -0
  82. package/dist/node_modules/lodash-es/_baseProperty.js +8 -0
  83. package/dist/node_modules/lodash-es/_basePropertyDeep.js +9 -0
  84. package/dist/node_modules/lodash-es/_baseRange.js +9 -0
  85. package/dist/node_modules/lodash-es/_baseToString.js +18 -0
  86. package/dist/node_modules/lodash-es/_baseTrim.js +8 -0
  87. package/dist/node_modules/lodash-es/_cacheHas.js +6 -0
  88. package/dist/node_modules/lodash-es/_castPath.js +10 -0
  89. package/dist/node_modules/lodash-es/_createBaseEach.js +15 -0
  90. package/dist/node_modules/lodash-es/_createRange.js +11 -0
  91. package/dist/node_modules/lodash-es/_equalArrays.js +40 -0
  92. package/dist/node_modules/lodash-es/_equalByTag.js +45 -0
  93. package/dist/node_modules/lodash-es/_equalObjects.js +36 -0
  94. package/dist/node_modules/lodash-es/_getAllKeys.js +9 -0
  95. package/dist/node_modules/lodash-es/_getMatchData.js +12 -0
  96. package/dist/node_modules/lodash-es/_getSymbols.js +10 -0
  97. package/dist/node_modules/lodash-es/_getTag.js +28 -0
  98. package/dist/node_modules/lodash-es/_hasPath.js +19 -0
  99. package/dist/node_modules/lodash-es/_isFlattenable.js +10 -0
  100. package/dist/node_modules/lodash-es/_isKey.js +12 -0
  101. package/dist/node_modules/lodash-es/_isStrictComparable.js +7 -0
  102. package/dist/node_modules/lodash-es/_mapToArray.js +9 -0
  103. package/dist/node_modules/lodash-es/_matchesStrictComparable.js +8 -0
  104. package/dist/node_modules/lodash-es/_memoizeCapped.js +11 -0
  105. package/dist/node_modules/lodash-es/_nativeKeys.js +5 -0
  106. package/dist/node_modules/lodash-es/_setCacheAdd.js +7 -0
  107. package/dist/node_modules/lodash-es/_setCacheHas.js +6 -0
  108. package/dist/node_modules/lodash-es/_setToArray.js +9 -0
  109. package/dist/node_modules/lodash-es/_stringToPath.js +10 -0
  110. package/dist/node_modules/lodash-es/_toKey.js +10 -0
  111. package/dist/node_modules/lodash-es/_trimmedEndIndex.js +9 -0
  112. package/dist/node_modules/lodash-es/flatMap.js +8 -0
  113. package/dist/node_modules/lodash-es/get.js +8 -0
  114. package/dist/node_modules/lodash-es/hasIn.js +8 -0
  115. package/dist/node_modules/lodash-es/isSymbol.js +9 -0
  116. package/dist/node_modules/lodash-es/keys.js +9 -0
  117. package/dist/node_modules/lodash-es/keysIn.js +3 -3
  118. package/dist/node_modules/lodash-es/map.js +11 -0
  119. package/dist/node_modules/lodash-es/property.js +10 -0
  120. package/dist/node_modules/lodash-es/range.js +5 -0
  121. package/dist/node_modules/lodash-es/stubArray.js +6 -0
  122. package/dist/node_modules/lodash-es/toFinite.js +14 -0
  123. package/dist/node_modules/lodash-es/toNumber.js +22 -0
  124. package/dist/node_modules/lodash-es/toString.js +7 -0
  125. package/dist/package.json.js +1 -1
  126. package/dist/services/recommendationApi.js +13 -19
  127. package/dist/services/stripoApi.js +11 -10
  128. package/dist/src/@types/generic.d.ts +27 -6
  129. package/dist/src/components/Guido.vue.d.ts +2 -2
  130. package/dist/src/components/organisms/onboarding/ItemsOnboarding.vue.d.ts +2 -0
  131. package/dist/src/config/compiler/itemsCompilerRules.d.ts +2 -0
  132. package/dist/src/enums/defaults.d.ts +1 -0
  133. package/dist/src/enums/onboarding.d.ts +4 -0
  134. package/dist/src/extensions/Blocks/Checkbox/block.d.ts +1 -0
  135. package/dist/src/extensions/Blocks/Checkbox/template.d.ts +1 -1
  136. package/dist/src/extensions/Blocks/Items/block.d.ts +27 -0
  137. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +14 -0
  138. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +33 -0
  139. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +14 -0
  140. package/dist/src/extensions/Blocks/Items/controls/index.d.ts +501 -0
  141. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +14 -0
  142. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +19 -0
  143. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +21 -0
  144. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +14 -0
  145. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +13 -0
  146. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +48 -0
  147. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +61 -0
  148. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +162 -0
  149. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +49 -0
  150. package/dist/src/extensions/Blocks/Items/extension.d.ts +2 -0
  151. package/dist/src/extensions/Blocks/Items/iconsRegistry.d.ts +4 -0
  152. package/dist/src/extensions/Blocks/Items/settingsPanel.d.ts +4 -0
  153. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +41 -0
  154. package/dist/src/extensions/Blocks/Items/template.d.ts +24 -0
  155. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
  156. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
  157. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +44 -0
  158. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
  159. package/dist/src/extensions/Blocks/RadioButton/block.d.ts +1 -0
  160. package/dist/src/extensions/Blocks/RadioButton/template.d.ts +1 -1
  161. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -1
  162. package/dist/src/extensions/Blocks/common-control.d.ts +44 -7
  163. package/dist/src/extensions/Blocks/controlFactories.d.ts +312 -0
  164. package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +9 -2
  165. package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +52 -2
  166. package/dist/src/stores/config.d.ts +3 -2
  167. package/dist/src/stores/dynamic-content.d.ts +3 -3
  168. package/dist/src/stores/editor.d.ts +1 -1
  169. package/dist/src/stores/onboarding.d.ts +335 -1
  170. package/dist/src/stores/preview.d.ts +1 -1
  171. package/dist/src/stores/recommendation.d.ts +1 -1
  172. package/dist/src/stores/save-as-template.d.ts +1 -1
  173. package/dist/src/stores/toaster.d.ts +1 -1
  174. package/dist/src/stores/unsubscribe.d.ts +1 -1
  175. package/dist/src/stores/version-history.d.ts +1 -1
  176. package/dist/src/utils/environmentUtil.d.ts +5 -0
  177. package/dist/src/utils/genericUtil.d.ts +1 -0
  178. package/dist/src/utils/pairProductVariables.d.ts +7 -0
  179. package/dist/static/styles/customEditorStyle.css.js +1 -1
  180. package/dist/stores/config.js +5 -5
  181. package/dist/stores/dynamic-content.js +2 -2
  182. package/dist/stores/editor.js +1 -1
  183. package/dist/stores/onboarding.js +44 -36
  184. package/dist/stores/preview.js +1 -1
  185. package/dist/stores/recommendation.js +3 -3
  186. package/dist/stores/save-as-template.js +2 -2
  187. package/dist/stores/toaster.js +1 -1
  188. package/dist/stores/unsubscribe.js +1 -1
  189. package/dist/stores/version-history.js +4 -4
  190. package/dist/utils/environmentUtil.js +4 -0
  191. package/dist/utils/genericUtil.js +18 -8
  192. package/dist/utils/pairProductVariables.js +136 -0
  193. package/package.json +4 -4
@@ -1,23 +1,25 @@
1
- import { useActionsApi as y } from "./useActionsApi.js";
2
- import { useBlocksConfig as E } from "./useBlocksConfig.js";
3
- import { useCustomInterfaceAppearance as w } from "./useCustomInterfaceAppearance.js";
4
- import { useStripoEventHandler as h } from "./useStripoEventHandler.js";
5
- import { useToaster as b } from "./useToaster.js";
6
- import { displayConditions as k } from "../enums/displayConditions.js";
7
- import { useStripoApi as B } from "../services/stripoApi.js";
8
- import V from "../static/styles/customEditorStyle.css.js";
9
- import { useEditorStore as _ } from "../stores/editor.js";
10
- import { dynamicContentToMergeTags as F } from "../utils/genericUtil.js";
11
- import A from "../package.json.js";
12
- const L = (d) => {
13
- const { handleError: u } = b(), { getToken: p, getCustomFonts: m } = B(), { handleEvent: g } = h(), { getStripoBlocksConfig: f } = E(), S = async (r, i = []) => {
14
- const t = _(), { html: n, css: l, forceRecreate: a } = r, { baseBlocks: e, extensions: c } = await f();
1
+ import { useActionsApi as w } from "./useActionsApi.js";
2
+ import { useBlocksConfig as b } from "./useBlocksConfig.js";
3
+ import { useConfig as k } from "./useConfig.js";
4
+ import { useCustomInterfaceAppearance as V } from "./useCustomInterfaceAppearance.js";
5
+ import { useStripoEventHandler as _ } from "./useStripoEventHandler.js";
6
+ import { useToaster as B } from "./useToaster.js";
7
+ import { displayConditions as T } from "../enums/displayConditions.js";
8
+ import { useStripoApi as A } from "../services/stripoApi.js";
9
+ import F from "../static/styles/customEditorStyle.css.js";
10
+ import { useEditorStore as M } from "../stores/editor.js";
11
+ import { dynamicContentToMergeTags as U } from "../utils/genericUtil.js";
12
+ import v from "../package.json.js";
13
+ const J = (c) => {
14
+ const { config: u } = k(), { handleError: l } = B(), { getToken: f, getCustomFonts: y } = A(), { handleEvent: S } = _(), { getStripoBlocksConfig: C } = b(), E = async (i, r = []) => {
15
+ var m, g;
16
+ const t = M(), { html: n, css: p, forceRecreate: a } = i, { baseBlocks: e, extensions: d } = await C();
15
17
  window.UIEditor.initEditor(
16
18
  document.querySelector("#guido-editor"),
17
19
  {
18
- metadata: d,
20
+ metadata: c,
19
21
  html: n,
20
- css: l,
22
+ css: p,
21
23
  forceRecreate: a,
22
24
  locale: "en",
23
25
  undoButtonSelector: "#guido__undo-button",
@@ -28,40 +30,44 @@ const L = (d) => {
28
30
  customAppearanceMergetags: !0,
29
31
  customAppearanceMergetagsBorderColor: "#f1f3fe",
30
32
  customAppearanceMergetagsBackgroundColor: "#f1f3fe",
31
- customViewStyles: V,
32
- conditionsEnabled: !0,
33
- customConditionsEnabled: !0,
34
- conditionCategories: k,
33
+ customViewStyles: F,
34
+ conditionsEnabled: ((m = u.features) == null ? void 0 : m.displayConditions) ?? !0,
35
+ customConditionsEnabled: ((g = u.features) == null ? void 0 : g.displayConditions) ?? !0,
36
+ conditionCategories: T,
35
37
  enableXSSSecurity: !0,
36
- messageSettingsEnabled: !1,
37
- selectBlockAfterDropFromSettingsPanel: !0,
38
+ messageSettingsEnabled: !0,
39
+ displayGmailAnnotations: !0,
40
+ displayHiddenPreheader: !1,
41
+ displayTitle: !1,
42
+ displayUTM: !1,
43
+ selectElementAfterDrop: !0,
38
44
  ...e ? { baseBlocks: e } : {},
39
45
  editorFonts: {
40
46
  showDefaultStandardFonts: !0,
41
47
  showDefaultNotStandardFonts: !0,
42
- customFonts: i
48
+ customFonts: r
43
49
  },
44
50
  mergeTags: [
45
51
  {
46
- entries: F(d.preselectedDynamicContentList)
52
+ entries: U(c.preselectedDynamicContentList)
47
53
  }
48
54
  ],
49
55
  async onTokenRefreshRequest(o) {
50
56
  try {
51
- const s = await p();
57
+ const s = await f();
52
58
  o(s);
53
59
  } catch (s) {
54
- u(s, "Failed to refresh token");
60
+ l(s, "Failed to refresh token");
55
61
  }
56
62
  },
57
63
  onTemplateLoaded() {
58
64
  try {
59
- const { importCss: o } = w(), { activateCustomViewStyles: s } = y();
60
- o(), s(), d.onReady(), t.isStripoInitialized = !0, t.loadingStatus = !1, setTimeout(() => {
65
+ const { importCss: o } = V(), { activateCustomViewStyles: s } = w();
66
+ o(), s(), c.onReady(), t.isStripoInitialized = !0, t.loadingStatus = !1, setTimeout(() => {
61
67
  t.hasChanges = !1;
62
68
  }, 1e3);
63
69
  } catch (o) {
64
- u(o, "Failed to load custom interface appearance");
70
+ l(o, "Failed to load custom interface appearance");
65
71
  }
66
72
  },
67
73
  onCodeEditorVisibilityChanged(o) {
@@ -76,35 +82,35 @@ const L = (d) => {
76
82
  onDataChanged() {
77
83
  t.hasChanges = !0;
78
84
  },
79
- onEvent: g,
85
+ onEvent: S,
80
86
  ignoreClickOutsideSelectors: [
81
87
  "#guido-dynamic-content-modal",
82
88
  ".in-on-board-wrapper",
83
89
  ".in-drawer__container"
84
90
  ],
85
- extensions: c
91
+ extensions: d
86
92
  }
87
93
  );
88
- }, C = (r) => new Promise((i, t) => {
89
- var c;
94
+ }, h = (i) => new Promise((r, t) => {
95
+ var d;
90
96
  if (document.getElementById("UiEditorScript")) {
91
- r(), i();
97
+ i(), r();
92
98
  return;
93
99
  }
94
- const n = A.guido, a = `https://email-static.useinsider.com/guido/${(c = n == null ? void 0 : n.stripo) == null ? void 0 : c.version}/UIEditor.js`, e = document.createElement("script");
100
+ const n = v.guido, a = `https://email-static.useinsider.com/guido/${(d = n == null ? void 0 : n.stripo) == null ? void 0 : d.version}/UIEditor.js`, e = document.createElement("script");
95
101
  e.id = "UiEditorScript", e.type = "module", e.src = a, e.onload = () => {
96
- r(), i();
102
+ i(), r();
97
103
  }, e.onerror = () => {
98
104
  t(new Error(`Failed to load Stripo UIEditor script from S3: ${a}`));
99
105
  }, document.body.appendChild(e);
100
106
  });
101
- return { initPlugin: async (r) => {
102
- await C(async () => {
103
- const i = await m();
104
- await S(r, i);
107
+ return { initPlugin: async (i) => {
108
+ await h(async () => {
109
+ const r = await y();
110
+ await E(i, r);
105
111
  });
106
112
  } };
107
113
  };
108
114
  export {
109
- L as useStripo
115
+ J as useStripo
110
116
  };
@@ -0,0 +1,14 @@
1
+ import { pairProductVariables as r } from "../../utils/pairProductVariables.js";
2
+ const t = [
3
+ {
4
+ id: "pair-product-variables",
5
+ description: "Replace product default values with template variables",
6
+ type: "custom",
7
+ processor: r,
8
+ priority: 60
9
+ // After recommendation rules (priority 50-53)
10
+ }
11
+ ];
12
+ export {
13
+ t as itemsCompilerRules
14
+ };
@@ -16,17 +16,18 @@ const e = {
16
16
  dynamicContent: !0,
17
17
  saveAsTemplate: !0,
18
18
  versionHistory: !0,
19
- testMessage: !0
19
+ testMessage: !0,
20
+ displayConditions: !0
20
21
  },
21
22
  useHeader: !0
22
23
  }, t = {
23
24
  promotional: 1,
24
25
  transactional: 2
25
- }, a = "email", o = "Guido User", s = t.promotional, n = 2, i = {
26
+ }, a = "email", o = "Guido User", s = t.promotional, n = 2, i = 13, u = {
26
27
  email: 60,
27
28
  architect: 49,
28
29
  unsubscribePages: 97
29
- }, u = [
30
+ }, r = [
30
31
  "alfredtesting",
31
32
  "electio",
32
33
  "eurekatest",
@@ -64,7 +65,8 @@ export {
64
65
  a as DefaultProductType,
65
66
  o as DefaultUsername,
66
67
  n as EditorType,
67
- i as ProductIds,
68
- u as TEST_PARTNER_LIST,
68
+ i as MAX_DEFAULT_TEMPLATE_ID,
69
+ u as ProductIds,
70
+ r as TEST_PARTNER_LIST,
69
71
  t as TemplateTypes
70
72
  };
@@ -12,8 +12,8 @@ const s = {
12
12
  { id: 61, key: "mostPopular", name: "Most Popular Items", path: "most-popular" },
13
13
  { id: 62, key: "mostPurchased", name: "Top Sellers", path: "top-sellers" }
14
14
  ], u = ["discount", "omnibus_price", "omnibus_discount", "price", "original_price"], l = [
15
- { text: "after the amount", value: "1" },
16
- { text: "before the amount", value: "0" }
15
+ { text: "before the amount", value: "0" },
16
+ { text: "after the amount", value: "1" }
17
17
  ], c = [
18
18
  { text: "dot(.)", value: "." },
19
19
  { text: "comma(,)", value: "," }
@@ -2,8 +2,12 @@ const e = [
2
2
  ".service-element.stacked-panel-item.ng-tns-c1014751574-3.level-bottom-0.ng-star-inserted",
3
3
  ".service-element.stacked-panel-item.ng-tns-c1014751574-3.level-bottom-1.ng-star-inserted",
4
4
  ".service-element.stacked-panel-item.ng-tns-c1014751574-3.level-bottom-2.ng-star-inserted"
5
- ], t = "https://academy.useinsider.com/docs/email-drag-drop-editor";
5
+ ], t = "ui-editor", n = 'button[role="tab"][aria-label="Card Composition"]', s = 'button[role="tab"][aria-label="Settings"]', o = ".in-ribbons-wrapper", a = "https://academy.useinsider.com/docs/email-drag-drop-editor";
6
6
  export {
7
- t as ACADEMY_LINK,
8
- e as SERVICE_HOVER_SELECTORS
7
+ a as ACADEMY_LINK,
8
+ n as CARD_COMPOSITION_TAB_SELECTOR,
9
+ o as RIBBON_SELECTOR,
10
+ e as SERVICE_HOVER_SELECTORS,
11
+ s as SETTINGS_TAB_SELECTOR,
12
+ t as UI_EDITOR_SELECTOR
9
13
  };
@@ -1,25 +1,26 @@
1
- import { useTranslations as e } from "../composables/useTranslations.js";
2
- const s = e(), R = {
1
+ import { useTranslations as n } from "../composables/useTranslations.js";
2
+ import { getEnvironmentPrefix as R } from "../utils/environmentUtil.js";
3
+ const e = n(), I = {
3
4
  UNSUBSCRIBE_LINK_TYPE: 1,
4
5
  PREFERENCES_LINK_TYPE: 3
5
- }, S = {
6
+ }, r = {
6
7
  UNSUBSCRIBE_LINK_REGEX: /{{ins-unsubscribe-link}}/g,
7
8
  DATA_OGSB_BUTTON_CSS_REGEX: "\\[data-ogsb\\]\\s*\\.es-button\\.es-button-[0-9]+\\s*\\{(?:[^\\}]*)\\}",
8
9
  GLOBAL_UNSUBSCRIBE_LINK_REGEX: /{{ins-global-unsubscribe-link}}/g,
9
10
  PREFERENCES_UNSUBSCRIBE_LINK_REGEX: /{{ins-preferences-unsubscribe-link}}/g
10
- }, N = {
11
- UNSUBSCRIBE_URL: "https://mail.useinsider.com/user/v1/unsub",
12
- PREFERENCES_URL: "https://mail.useinsider.com/user/v1/prefs"
13
- }, I = "iid", _ = {
11
+ }, s = R(), _ = {
12
+ UNSUBSCRIBE_URL: `https://mail.${s}.com/user/v1/unsub`,
13
+ PREFERENCES_URL: `https://mail.${s}.com/user/v1/prefs`
14
+ }, i = "iid", B = {
14
15
  name: "Global Unsubscribe",
15
16
  sendGridId: "G"
16
- }, i = "https://academy.useinsider.com/docs/global-unsubscribe-preference-center", r = "/email/unsubscribe-pages", E = {
17
+ }, C = "https://academy.useinsider.com/docs/global-unsubscribe-preference-center", c = "/email/unsubscribe-pages", E = {
17
18
  GLOBAL_UNSUBSCRIBE: 1,
18
19
  GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE: 2,
19
20
  SUBSCRIPTION_PREFERENCE_CENTER: 3,
20
21
  SUBSCRIPTION_PREFERENCE_CONFIRMATION: 4,
21
22
  RESUBSCRIBE: 5
22
- }, B = {
23
+ }, t = {
23
24
  [E.GLOBAL_UNSUBSCRIBE]: [
24
25
  E.GLOBAL_UNSUBSCRIBE,
25
26
  E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE,
@@ -29,27 +30,27 @@ const s = e(), R = {
29
30
  E.SUBSCRIPTION_PREFERENCE_CENTER,
30
31
  E.SUBSCRIPTION_PREFERENCE_CONFIRMATION
31
32
  ]
32
- }, C = {
33
- [E.GLOBAL_UNSUBSCRIBE]: s("unsubscription-preference.type-global-unsubscribe"),
34
- [E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE]: s("unsubscription-preference.type-global-unsubscription-confirmation"),
35
- [E.RESUBSCRIBE]: s("unsubscription-preference.type-resubscribe"),
36
- [E.SUBSCRIPTION_PREFERENCE_CENTER]: s("unsubscription-preference.type-subscription-preferences-center"),
37
- [E.SUBSCRIPTION_PREFERENCE_CONFIRMATION]: s("unsubscription-preference.type-subscription-preferences-confirmation")
38
- }, c = {
33
+ }, U = {
34
+ [E.GLOBAL_UNSUBSCRIBE]: e("unsubscription-preference.type-global-unsubscribe"),
35
+ [E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE]: e("unsubscription-preference.type-global-unsubscription-confirmation"),
36
+ [E.RESUBSCRIBE]: e("unsubscription-preference.type-resubscribe"),
37
+ [E.SUBSCRIPTION_PREFERENCE_CENTER]: e("unsubscription-preference.type-subscription-preferences-center"),
38
+ [E.SUBSCRIPTION_PREFERENCE_CONFIRMATION]: e("unsubscription-preference.type-subscription-preferences-confirmation")
39
+ }, o = {
39
40
  default: "{{ins-unsubscribe-link}}",
40
41
  [E.GLOBAL_UNSUBSCRIBE]: "{{ins-global-unsubscribe-link}}",
41
42
  [E.SUBSCRIPTION_PREFERENCE_CENTER]: "{{ins-preferences-unsubscribe-link}}"
42
43
  };
43
44
  export {
44
- i as ACADEMY_LINK,
45
- _ as DEFAULT_UNSUBSCRIBE_GROUP,
46
- I as INSIDER_ID,
47
- S as LINK_REGEXES,
48
- R as LINK_TYPES,
49
- c as MERGE_TAGS,
45
+ C as ACADEMY_LINK,
46
+ B as DEFAULT_UNSUBSCRIBE_GROUP,
47
+ i as INSIDER_ID,
48
+ r as LINK_REGEXES,
49
+ I as LINK_TYPES,
50
+ o as MERGE_TAGS,
50
51
  E as PAGE_TYPES,
51
- B as TYPE_COLLECTIONS,
52
- C as TYPE_TRANSLATIONS,
53
- r as UNSUBSCRIBE_PAGES_LINK,
54
- N as URLS
52
+ t as TYPE_COLLECTIONS,
53
+ U as TYPE_TRANSLATIONS,
54
+ c as UNSUBSCRIBE_PAGES_LINK,
55
+ _ as URLS
55
56
  };
@@ -1,7 +1,7 @@
1
1
  import { Block as e, BlockCompositionType as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
2
  import { getDefaultTemplate as o } from "./template.js";
3
3
  const r = "checkbox-block";
4
- class p extends e {
4
+ class s extends e {
5
5
  constructor() {
6
6
  super();
7
7
  }
@@ -23,8 +23,11 @@ class p extends e {
23
23
  getTemplate() {
24
24
  return o();
25
25
  }
26
+ allowInnerBlocksDND() {
27
+ return !1;
28
+ }
26
29
  }
27
30
  export {
28
31
  r as CHECKBOX_BLOCK_ID,
29
- p as CheckboxBlock
32
+ s as CheckboxBlock
30
33
  };
@@ -2,9 +2,9 @@ var d = Object.defineProperty;
2
2
  var l = (r, n, e) => n in r ? d(r, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[n] = e;
3
3
  var o = (r, n, e) => l(r, typeof n != "symbol" ? n + "" : n, e);
4
4
  import { useHttp as L } from "../../../composables/useHttp.js";
5
- import { DEFAULT_UNSUBSCRIBE_GROUP as u } from "../../../enums/unsubscribe.js";
5
+ import { DEFAULT_UNSUBSCRIBE_GROUP as c } from "../../../enums/unsubscribe.js";
6
6
  import { Control as h, UIElementType as i, UEAttr as t, ModificationDescription as p } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
7
- const m = "ui-elements-checkbox", a = "select", { get: C } = L();
7
+ const m = "ui-elements-checkbox", u = "select", { get: C } = L();
8
8
  class S extends h {
9
9
  constructor() {
10
10
  super(...arguments);
@@ -16,15 +16,16 @@ class S extends h {
16
16
  return m;
17
17
  }
18
18
  _setFormValues() {
19
- if (this.currentNode && "getAttribute" in this.currentNode) {
19
+ if (this.selectedUnsubGroup = "", this.currentNode && "getAttribute" in this.currentNode) {
20
20
  const e = this.currentNode.getAttribute("id");
21
21
  if (e) {
22
- const s = e === u.sendGridId ? e : Number(e);
23
- s && (this.selectedUnsubGroup = s, this.api.updateValues({
24
- [a]: this.selectedUnsubGroup
25
- }));
22
+ const s = e === c.sendGridId ? e : Number(e);
23
+ s && (this.selectedUnsubGroup = s);
26
24
  }
27
25
  }
26
+ this.api.updateValues({
27
+ [u]: this.selectedUnsubGroup
28
+ });
28
29
  }
29
30
  _getLabel(e, s = `${Math.random()}`) {
30
31
  return `
@@ -54,7 +55,7 @@ class S extends h {
54
55
  </${i.LABEL}>
55
56
 
56
57
  <${i.SELECTPICKER}
57
- ${t.SELECTPICKER.name}="${a}"
58
+ ${t.SELECTPICKER.name}="${u}"
58
59
  ${t.SELECTPICKER.placeholder}="${this.api.translate("Select Unsubscribe Group")}">
59
60
  ${this._getSelect()}
60
61
  </${i.SELECTPICKER}>
@@ -66,21 +67,21 @@ class S extends h {
66
67
  this.currentNode && this.api.getDocumentModifier().modifyHtml(this.currentNode).setAttribute("id", e.toString()).apply(new p(`Updated text to ${e}`));
67
68
  }
68
69
  _listenToFormUpdates() {
69
- this.api.onValueChanged(a, (e) => this._onSelectChange(e));
70
+ this.api.onValueChanged(u, (e) => this._onSelectChange(e));
70
71
  }
71
72
  onTemplateNodeUpdated(e) {
72
- this.currentNode = e;
73
+ this.currentNode = e, this._setFormValues();
73
74
  }
74
75
  // eslint-disable-next-line @typescript-eslint/no-misused-promises
75
76
  async onRender() {
76
77
  const e = await C(
77
78
  "/unsubscribe-groups/unsubscribe-list"
78
- ), s = [u, ...e.data], E = s.map((c) => ({
79
- [t.SELECT_ITEM.text]: c.name,
80
- [t.SELECT_ITEM.value]: c.sendGridId
79
+ ), s = [c, ...e.data], E = s.map((a) => ({
80
+ [t.SELECT_ITEM.text]: a.name,
81
+ [t.SELECT_ITEM.value]: a.sendGridId
81
82
  }));
82
83
  this.unsubList = s, this.api.setUIEAttribute(
83
- a,
84
+ u,
84
85
  t.SELECTPICKER.items,
85
86
  E
86
87
  ), this._setFormValues(), this._listenToFormUpdates();
@@ -3,7 +3,7 @@ const e = {
3
3
  TITLE: "Unsubscribe From All Email Lists",
4
4
  DESCRIPTION: "You will still receive important transactional and billing-related emails."
5
5
  }, l = `
6
- <td align="left" class="checkbox-block-v2 esd-block-checkbox es-p20">
6
+ <td align="left" class="checkbox-block checkbox-block-v2 esd-block-checkbox es-p20">
7
7
  <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
8
8
  <tbody>
9
9
  <tr>
@@ -26,11 +26,16 @@ const e = {
26
26
  </tbody>
27
27
  </table>
28
28
  </td>
29
- `, i = `
30
- <td
31
- align="left"
32
- esd-extension-block-id="checkbox-block"
33
- class="checkbox-block-v2 esd-block-checkbox esd-checkbox-block esd-extension-block es-p20"
29
+ `, o = `
30
+ <td
31
+ align="left"
32
+ esd-extension-block-id="checkbox-block"
33
+ class="
34
+ checkbox-block
35
+ checkbox-block-v2
36
+ esd-block-checkbox
37
+ esd-checkbox-block
38
+ esd-extension-block es-p20"
34
39
  >
35
40
  <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
36
41
  <tbody>
@@ -55,10 +60,10 @@ const e = {
55
60
  </table>
56
61
  </td>
57
62
  `;
58
- function c() {
63
+ function a() {
59
64
  return l.replace("{-{-TITLE-}-}", `<p path="1">${e.TITLE}</p>`).replace("{-{-DESCRIPTION-}-}", `<p path="1">${e.DESCRIPTION}</p>`);
60
65
  }
61
66
  export {
62
- i as default,
63
- c as getDefaultTemplate
67
+ o as default,
68
+ a as getDefaultTemplate
64
69
  };
@@ -0,0 +1,67 @@
1
+ import { useOnboardingStore as y } from "../../../stores/onboarding.js";
2
+ import { Block as R, BlockCompositionType as L, ModificationDescription as a } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
3
+ import { configAttributes as t } from "./enums/productEnums.js";
4
+ import { DefaultConfigValues as e, SETTINGS_ENUMS as l } from "./enums/settingsEnums.js";
5
+ import { useItemsBlockStore as S } from "./store/items-block.js";
6
+ import { getDefaultTemplate as V } from "./template.js";
7
+ import { syncCurrencySymbolFromAttributes as B, syncCurrencyLocationFromAttributes as U, syncFormattedPriceFromAttributes as k } from "./utils/syncAttributesFromConfigBlock.js";
8
+ const M = "items-block";
9
+ class x extends R {
10
+ getId() {
11
+ return M;
12
+ }
13
+ getIcon() {
14
+ return "items-icon";
15
+ }
16
+ getBlockCompositionType() {
17
+ return L.CONTAINER;
18
+ }
19
+ getName() {
20
+ return this.api.translate("Items");
21
+ }
22
+ getDescription() {
23
+ return this.api.translate("Items lets you display personalized products based on user behavior.");
24
+ }
25
+ getTemplate() {
26
+ return V({
27
+ orientation: l.ORIENTATION.HORIZONTAL,
28
+ itemsType: l.ITEMS_TYPE.CART_ITEMS,
29
+ itemId: "{{Abandoned Cart Item (1) Url}}",
30
+ currencySymbol: e.productPriceCurrencySymbolControlValue,
31
+ currencyLocation: e.productPriceCurrencyLocationControlValue,
32
+ formattedPrice: e.productPriceFormattedControlValue === "1"
33
+ });
34
+ }
35
+ allowInnerBlocksDND() {
36
+ return !1;
37
+ }
38
+ onCreated(r) {
39
+ const n = r.querySelector("esd-config-block");
40
+ if (!n)
41
+ return;
42
+ const o = n, s = o.getAttribute("data-initialized") || "0", u = o.getAttribute(t.BLOCK_INSTANCE_ID), c = () => String(Date.now() + Math.floor(Math.random() * 1e3));
43
+ if (Number(s)) {
44
+ if (!u) {
45
+ const i = c();
46
+ this.api.getDocumentModifier().modifyHtml(o).setAttribute(t.BLOCK_INSTANCE_ID, i).apply(new a("Assign block instance ID to legacy block"));
47
+ }
48
+ } else {
49
+ const i = e.itemsType, I = e.cartItemsSelectControlValue, d = e.cardOrientationControlValue, m = e.productNameTrimmingControlValue, C = e.productPriceHideDiscountControlValue, b = e.productPriceFormattedControlValue, T = e.productPriceCurrencySymbolControlValue, A = e.productPriceCurrencyLocationControlValue, E = e.productButtonLinkControlValue, O = e.productImageLinkControlValue, _ = e.productImageVisible, p = e.productNameVisible, N = e.productQuantityVisible, f = e.productPriceVisible, g = e.productOriginalPriceVisible, D = e.productButtonVisible, P = c();
50
+ this.api.getDocumentModifier().modifyHtml(o).setAttribute("data-source", i).setAttribute(t.TYPE, i).setAttribute(t.ITEMS_INDEX_SELECT_CONTROL_VALUE, I).setAttribute(t.ORIENTATION, d).setAttribute(t.PRODUCT_NAME_TRIMMING, m).setAttribute(t.PRODUCT_PRICE_HIDE_DISCOUNT, C).setAttribute(t.PRODUCT_PRICE_FORMATTED, b).setAttribute(t.PRODUCT_PRICE_CURRENCY_SYMBOL, T).setAttribute(t.PRODUCT_PRICE_CURRENCY_LOCATION, A).setAttribute(t.PRODUCT_BUTTON_LINK, E).setAttribute(t.PRODUCT_IMAGE_LINK, O).setAttribute(t.BLOCK_INSTANCE_ID, P).setAttribute("data-initialized", "1").setAttribute(t.NAME_CONTROL_ENABLED, e.productNameControlEnabled).setAttribute(
51
+ t.QUANTITY_CONTROL_ENABLED,
52
+ e.productQuantityControlEnabled
53
+ ).setAttribute(t.PRICE_CONTROL_OPENED, e.productPriceControlOpened).setAttribute(t.PRODUCT_IMAGE_VISIBLE, _).setAttribute(t.PRODUCT_NAME_VISIBLE, p).setAttribute(t.PRODUCT_QUANTITY_VISIBLE, N).setAttribute(t.PRODUCT_PRICE_VISIBLE, f).setAttribute(t.PRODUCT_ORIGINAL_PRICE_VISIBLE, g).setAttribute(t.PRODUCT_BUTTON_VISIBLE, D).apply(new a("Initialize config block attributes with defaults")), y().startOnboarding("itemsOnboarding");
54
+ }
55
+ }
56
+ onSelect(r) {
57
+ const n = r.querySelector("esd-config-block"), o = S();
58
+ if (!n)
59
+ return;
60
+ const s = n, u = s.getAttribute(t.TYPE) || e.itemsType, c = s.getAttribute(t.ITEMS_INDEX_SELECT_CONTROL_VALUE) || e.cartItemsSelectControlValue, i = s.getAttribute(t.ORIENTATION) || e.cardOrientationControlValue;
61
+ o.setItemsType(u), o.setItemIds(c), o.setOrientation(i), B(r), U(r), k(r);
62
+ }
63
+ }
64
+ export {
65
+ M as BLOCK_ID,
66
+ x as ItemsBlock
67
+ };
@@ -0,0 +1,68 @@
1
+ var r = Object.defineProperty;
2
+ var a = (o, e, t) => e in o ? r(o, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : o[e] = t;
3
+ var s = (o, e, t) => a(o, typeof e != "symbol" ? e + "" : e, t);
4
+ import { CommonControl as u } from "../../../common-control.js";
5
+ import { ItemsBlockControlId as d } from "../../enums/controlEnums.js";
6
+ import { useItemsBlockStore as l } from "../../store/items-block.js";
7
+ import { syncButtonLinkFromAttributes as h } from "../../utils/syncAttributesFromConfigBlock.js";
8
+ import { updateConfigBlockAttributes as m } from "../../utils/updateAttributes.js";
9
+ const i = d.BUTTON_LINK, n = {
10
+ LINK: "link"
11
+ };
12
+ class C extends u {
13
+ constructor() {
14
+ super(...arguments);
15
+ s(this, "store", l());
16
+ }
17
+ getId() {
18
+ return i;
19
+ }
20
+ getTemplate() {
21
+ return `
22
+ <div class="${i}">
23
+ ${this._getLink()}
24
+ </div>
25
+ `;
26
+ }
27
+ onRender() {
28
+ this.api.updateValues({
29
+ [n.LINK]: this.store.buttonLink
30
+ }), this._listenToFormUpdates();
31
+ }
32
+ onTemplateNodeUpdated(t) {
33
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
34
+ () => h(this.currentNode),
35
+ () => {
36
+ this.api.updateValues({
37
+ [n.LINK]: this.store.buttonLink
38
+ });
39
+ }
40
+ );
41
+ }
42
+ _listenToFormUpdates() {
43
+ this.api.onValueChanged(
44
+ n.LINK,
45
+ (t) => this._onLinkChange(t)
46
+ );
47
+ }
48
+ _onLinkChange(t) {
49
+ console.debug("Button link changed to: ", t), this.store.setButtonLink(t), m(this.currentNode, this.api);
50
+ }
51
+ _getLink() {
52
+ return `
53
+ ${this._GuOneColumn([
54
+ this._GuLabel({ text: "Link" }),
55
+ this._GuTextInput({
56
+ name: n.LINK,
57
+ placeholder: "Enter Link",
58
+ className: "es-100",
59
+ disabled: !0
60
+ })
61
+ ])}
62
+ `;
63
+ }
64
+ }
65
+ export {
66
+ C as ButtonLinkControl,
67
+ i as CONTROL_BLOCK_ID
68
+ };