@useinsider/guido 1.0.3-beta.0cd9180 → 1.0.3-beta.0d0bb85

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 (208) hide show
  1. package/README.md +3 -143
  2. package/dist/components/Guido.vue.js +1 -1
  3. package/dist/components/Guido.vue2.js +73 -79
  4. package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
  5. package/dist/components/organisms/header/LeftSlot.vue2.js +15 -16
  6. package/dist/components/organisms/header/RightSlot.vue.js +11 -11
  7. package/dist/components/organisms/header/RightSlot.vue2.js +22 -23
  8. package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +18 -20
  9. package/dist/composables/useActionsApi.js +1 -1
  10. package/dist/composables/useGuidoActions.js +9 -19
  11. package/dist/composables/useHtmlCompiler.js +13 -15
  12. package/dist/composables/useHtmlValidator.js +35 -36
  13. package/dist/composables/useStripo.js +60 -55
  14. package/dist/config/compiler/unsubscribeCompilerRules.js +28 -33
  15. package/dist/enums/defaults.js +11 -19
  16. package/dist/enums/extensions/recommendationBlock.js +2 -2
  17. package/dist/enums/onboarding.js +3 -7
  18. package/dist/enums/unsubscribe.js +25 -27
  19. package/dist/extensions/Blocks/Checkbox/block.js +2 -5
  20. package/dist/extensions/Blocks/Checkbox/control.js +14 -15
  21. package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
  22. package/dist/extensions/Blocks/Checkbox/template.js +9 -14
  23. package/dist/extensions/Blocks/CouponBlock/extension.js +2 -2
  24. package/dist/extensions/Blocks/RadioButton/block.js +2 -5
  25. package/dist/extensions/Blocks/RadioButton/control.js +17 -18
  26. package/dist/extensions/Blocks/RadioButton/template.js +9 -18
  27. package/dist/extensions/Blocks/Recommendation/extension.js +4 -4
  28. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +43 -43
  29. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +1 -1
  30. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +4 -4
  31. package/dist/extensions/Blocks/Unsubscribe/block.js +27 -27
  32. package/dist/extensions/Blocks/common-control.js +110 -174
  33. package/dist/extensions/DynamicContent/dynamic-content-modal.js +19 -25
  34. package/dist/extensions/DynamicContent/dynamic-content.js +33 -128
  35. package/dist/guido.css +1 -1
  36. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +168 -213
  37. package/dist/node_modules/lodash-es/_arrayLikeKeys.js +12 -13
  38. package/dist/node_modules/lodash-es/keysIn.js +3 -3
  39. package/dist/package.json.js +1 -1
  40. package/dist/services/recommendationApi.js +19 -13
  41. package/dist/services/stripoApi.js +10 -11
  42. package/dist/src/@types/generic.d.ts +6 -36
  43. package/dist/src/components/Guido.vue.d.ts +2 -3
  44. package/dist/src/components/wrappers/WpModal.vue.d.ts +1 -1
  45. package/dist/src/composables/useGuidoActions.d.ts +0 -9
  46. package/dist/src/enums/defaults.d.ts +0 -1
  47. package/dist/src/enums/onboarding.d.ts +0 -4
  48. package/dist/src/extensions/Blocks/Checkbox/block.d.ts +0 -1
  49. package/dist/src/extensions/Blocks/Checkbox/template.d.ts +1 -1
  50. package/dist/src/extensions/Blocks/RadioButton/block.d.ts +0 -1
  51. package/dist/src/extensions/Blocks/RadioButton/template.d.ts +1 -1
  52. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -1
  53. package/dist/src/extensions/Blocks/common-control.d.ts +7 -44
  54. package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +2 -9
  55. package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +2 -52
  56. package/dist/src/stores/config.d.ts +2 -9
  57. package/dist/src/stores/dynamic-content.d.ts +3 -3
  58. package/dist/src/stores/editor.d.ts +1 -1
  59. package/dist/src/stores/onboarding.d.ts +1 -335
  60. package/dist/src/stores/preview.d.ts +1 -1
  61. package/dist/src/stores/recommendation.d.ts +1 -1
  62. package/dist/src/stores/save-as-template.d.ts +1 -1
  63. package/dist/src/stores/toaster.d.ts +1 -1
  64. package/dist/src/stores/unsubscribe.d.ts +1 -1
  65. package/dist/src/stores/version-history.d.ts +1 -1
  66. package/dist/src/utils/arrayUtil.d.ts +5 -0
  67. package/dist/src/utils/genericUtil.d.ts +0 -1
  68. package/dist/static/styles/components/narrow-panel.css.js +0 -10
  69. package/dist/static/styles/customEditorStyle.css.js +1 -1
  70. package/dist/stores/config.js +5 -5
  71. package/dist/stores/dynamic-content.js +2 -2
  72. package/dist/stores/editor.js +1 -1
  73. package/dist/stores/onboarding.js +36 -44
  74. package/dist/stores/preview.js +1 -1
  75. package/dist/stores/recommendation.js +3 -3
  76. package/dist/stores/save-as-template.js +2 -2
  77. package/dist/stores/toaster.js +1 -1
  78. package/dist/stores/unsubscribe.js +1 -1
  79. package/dist/stores/version-history.js +4 -4
  80. package/dist/utils/genericUtil.js +8 -18
  81. package/package.json +4 -4
  82. package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +0 -21
  83. package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +0 -99
  84. package/dist/composables/useBlocksConfig.js +0 -48
  85. package/dist/config/compiler/itemsCompilerRules.js +0 -14
  86. package/dist/extensions/Blocks/Items/block.js +0 -67
  87. package/dist/extensions/Blocks/Items/controls/button/link.js +0 -68
  88. package/dist/extensions/Blocks/Items/controls/cardComposition.js +0 -193
  89. package/dist/extensions/Blocks/Items/controls/image/link.js +0 -68
  90. package/dist/extensions/Blocks/Items/controls/index.js +0 -217
  91. package/dist/extensions/Blocks/Items/controls/name/trimming.js +0 -70
  92. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +0 -107
  93. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +0 -123
  94. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +0 -76
  95. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +0 -61
  96. package/dist/extensions/Blocks/Items/controls/settingsControl.js +0 -312
  97. package/dist/extensions/Blocks/Items/enums/controlEnums.js +0 -5
  98. package/dist/extensions/Blocks/Items/enums/productEnums.js +0 -273
  99. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +0 -76
  100. package/dist/extensions/Blocks/Items/extension.js +0 -19
  101. package/dist/extensions/Blocks/Items/iconsRegistry.js +0 -32
  102. package/dist/extensions/Blocks/Items/items.css.js +0 -23
  103. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +0 -62
  104. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +0 -60
  105. package/dist/extensions/Blocks/Items/settingsPanel.js +0 -131
  106. package/dist/extensions/Blocks/Items/store/items-block.js +0 -71
  107. package/dist/extensions/Blocks/Items/template.js +0 -189
  108. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +0 -17
  109. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +0 -28
  110. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +0 -67
  111. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +0 -44
  112. package/dist/extensions/Blocks/controlFactories.js +0 -223
  113. package/dist/node_modules/lodash-es/_DataView.js +0 -6
  114. package/dist/node_modules/lodash-es/_Promise.js +0 -6
  115. package/dist/node_modules/lodash-es/_Set.js +0 -6
  116. package/dist/node_modules/lodash-es/_SetCache.js +0 -13
  117. package/dist/node_modules/lodash-es/_WeakMap.js +0 -6
  118. package/dist/node_modules/lodash-es/_arrayFilter.js +0 -10
  119. package/dist/node_modules/lodash-es/_arrayMap.js +0 -8
  120. package/dist/node_modules/lodash-es/_arrayPush.js +0 -8
  121. package/dist/node_modules/lodash-es/_arraySome.js +0 -9
  122. package/dist/node_modules/lodash-es/_baseEach.js +0 -6
  123. package/dist/node_modules/lodash-es/_baseFlatten.js +0 -13
  124. package/dist/node_modules/lodash-es/_baseForOwn.js +0 -8
  125. package/dist/node_modules/lodash-es/_baseGet.js +0 -11
  126. package/dist/node_modules/lodash-es/_baseGetAllKeys.js +0 -9
  127. package/dist/node_modules/lodash-es/_baseHasIn.js +0 -6
  128. package/dist/node_modules/lodash-es/_baseIsEqual.js +0 -8
  129. package/dist/node_modules/lodash-es/_baseIsEqualDeep.js +0 -32
  130. package/dist/node_modules/lodash-es/_baseIsMatch.js +0 -29
  131. package/dist/node_modules/lodash-es/_baseIteratee.js +0 -11
  132. package/dist/node_modules/lodash-es/_baseKeys.js +0 -14
  133. package/dist/node_modules/lodash-es/_baseMap.js +0 -11
  134. package/dist/node_modules/lodash-es/_baseMatches.js +0 -12
  135. package/dist/node_modules/lodash-es/_baseMatchesProperty.js +0 -17
  136. package/dist/node_modules/lodash-es/_baseProperty.js +0 -8
  137. package/dist/node_modules/lodash-es/_basePropertyDeep.js +0 -9
  138. package/dist/node_modules/lodash-es/_baseRange.js +0 -9
  139. package/dist/node_modules/lodash-es/_baseToString.js +0 -18
  140. package/dist/node_modules/lodash-es/_baseTrim.js +0 -8
  141. package/dist/node_modules/lodash-es/_cacheHas.js +0 -6
  142. package/dist/node_modules/lodash-es/_castPath.js +0 -10
  143. package/dist/node_modules/lodash-es/_createBaseEach.js +0 -15
  144. package/dist/node_modules/lodash-es/_createRange.js +0 -11
  145. package/dist/node_modules/lodash-es/_equalArrays.js +0 -40
  146. package/dist/node_modules/lodash-es/_equalByTag.js +0 -45
  147. package/dist/node_modules/lodash-es/_equalObjects.js +0 -36
  148. package/dist/node_modules/lodash-es/_getAllKeys.js +0 -9
  149. package/dist/node_modules/lodash-es/_getMatchData.js +0 -12
  150. package/dist/node_modules/lodash-es/_getSymbols.js +0 -10
  151. package/dist/node_modules/lodash-es/_getTag.js +0 -28
  152. package/dist/node_modules/lodash-es/_hasPath.js +0 -19
  153. package/dist/node_modules/lodash-es/_isFlattenable.js +0 -10
  154. package/dist/node_modules/lodash-es/_isKey.js +0 -12
  155. package/dist/node_modules/lodash-es/_isStrictComparable.js +0 -7
  156. package/dist/node_modules/lodash-es/_mapToArray.js +0 -9
  157. package/dist/node_modules/lodash-es/_matchesStrictComparable.js +0 -8
  158. package/dist/node_modules/lodash-es/_memoizeCapped.js +0 -11
  159. package/dist/node_modules/lodash-es/_nativeKeys.js +0 -5
  160. package/dist/node_modules/lodash-es/_setCacheAdd.js +0 -7
  161. package/dist/node_modules/lodash-es/_setCacheHas.js +0 -6
  162. package/dist/node_modules/lodash-es/_setToArray.js +0 -9
  163. package/dist/node_modules/lodash-es/_stringToPath.js +0 -10
  164. package/dist/node_modules/lodash-es/_toKey.js +0 -10
  165. package/dist/node_modules/lodash-es/_trimmedEndIndex.js +0 -9
  166. package/dist/node_modules/lodash-es/flatMap.js +0 -8
  167. package/dist/node_modules/lodash-es/get.js +0 -8
  168. package/dist/node_modules/lodash-es/hasIn.js +0 -8
  169. package/dist/node_modules/lodash-es/isSymbol.js +0 -9
  170. package/dist/node_modules/lodash-es/keys.js +0 -9
  171. package/dist/node_modules/lodash-es/map.js +0 -11
  172. package/dist/node_modules/lodash-es/property.js +0 -10
  173. package/dist/node_modules/lodash-es/range.js +0 -5
  174. package/dist/node_modules/lodash-es/stubArray.js +0 -6
  175. package/dist/node_modules/lodash-es/toFinite.js +0 -14
  176. package/dist/node_modules/lodash-es/toNumber.js +0 -22
  177. package/dist/node_modules/lodash-es/toString.js +0 -7
  178. package/dist/src/components/organisms/onboarding/ItemsOnboarding.vue.d.ts +0 -2
  179. package/dist/src/composables/useBlocksConfig.d.ts +0 -11
  180. package/dist/src/config/compiler/itemsCompilerRules.d.ts +0 -2
  181. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -27
  182. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -14
  183. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +0 -33
  184. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -14
  185. package/dist/src/extensions/Blocks/Items/controls/index.d.ts +0 -501
  186. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -14
  187. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -19
  188. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -21
  189. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -14
  190. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -13
  191. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +0 -48
  192. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +0 -61
  193. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +0 -162
  194. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +0 -49
  195. package/dist/src/extensions/Blocks/Items/extension.d.ts +0 -2
  196. package/dist/src/extensions/Blocks/Items/iconsRegistry.d.ts +0 -4
  197. package/dist/src/extensions/Blocks/Items/settingsPanel.d.ts +0 -4
  198. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -41
  199. package/dist/src/extensions/Blocks/Items/template.d.ts +0 -24
  200. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +0 -23
  201. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +0 -32
  202. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +0 -44
  203. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +0 -8
  204. package/dist/src/extensions/Blocks/controlFactories.d.ts +0 -312
  205. package/dist/src/utils/environmentUtil.d.ts +0 -5
  206. package/dist/src/utils/pairProductVariables.d.ts +0 -7
  207. package/dist/utils/environmentUtil.js +0 -4
  208. package/dist/utils/pairProductVariables.js +0 -136
@@ -1,6 +1,6 @@
1
1
  import { provideValue as o, useInjectedValue as t } from "./useProvideInject.js";
2
- const r = Symbol.for("guido.back"), n = Symbol.for("guido.save.start"), c = Symbol.for("guido.save.complete"), a = Symbol.for("guido.test.email.click"), i = (e) => {
3
- o(r, e.onBack), o(n, e.onSaveStart), o(c, e.onSaveComplete), o(a, e.onTestEmailClick);
2
+ const r = Symbol.for("guido.back"), n = Symbol.for("guido.save.start"), a = Symbol.for("guido.save.complete"), s = (e) => {
3
+ o(r, e.onBack), o(n, e.onSaveStart), o(a, e.onSaveComplete);
4
4
  }, u = () => {
5
5
  try {
6
6
  return t(r);
@@ -9,7 +9,7 @@ const r = Symbol.for("guido.back"), n = Symbol.for("guido.save.start"), c = Symb
9
9
  "useBack: No back handler provided. Make sure Guido component is in the component tree."
10
10
  );
11
11
  }
12
- }, l = () => {
12
+ }, d = () => {
13
13
  try {
14
14
  return t(n);
15
15
  } catch {
@@ -17,31 +17,21 @@ const r = Symbol.for("guido.back"), n = Symbol.for("guido.save.start"), c = Symb
17
17
  "useSaveStart: No save start handler provided. Make sure Guido component is in the component tree."
18
18
  );
19
19
  }
20
- }, d = () => {
21
- try {
22
- return t(c);
23
- } catch {
24
- throw new Error(
25
- "useSaveComplete: No save complete handler provided. Make sure Guido component is in the component tree."
26
- );
27
- }
28
- }, m = () => {
20
+ }, i = () => {
29
21
  try {
30
22
  return t(a);
31
23
  } catch {
32
24
  throw new Error(
33
- "useTestEmailClick: No test email click handler provided. Make sure Guido component is in the component tree."
25
+ "useSaveComplete: No save complete handler provided. Make sure Guido component is in the component tree."
34
26
  );
35
27
  }
36
28
  };
37
29
  export {
38
30
  r as BACK_KEY,
39
- c as SAVE_COMPLETE_KEY,
31
+ a as SAVE_COMPLETE_KEY,
40
32
  n as SAVE_START_KEY,
41
- a as TEST_EMAIL_CLICK_KEY,
42
- i as provideGuidoActions,
33
+ s as provideGuidoActions,
43
34
  u as useBack,
44
- d as useSaveComplete,
45
- l as useSaveStart,
46
- m as useTestEmailClick
35
+ i as useSaveComplete,
36
+ d as useSaveStart
47
37
  };
@@ -1,27 +1,25 @@
1
1
  import { defaultHtmlCompilerRules as t } from "../config/compiler/htmlCompilerRules.js";
2
- import { itemsCompilerRules as p } from "../config/compiler/itemsCompilerRules.js";
3
- import { outlookCompilerRules as s } from "../config/compiler/outlookCompilerRules.js";
4
- import { recommendationCompilerRules as u } from "../config/compiler/recommendationCompilerRules.js";
5
- import { socialCompilerRules as n } from "../config/compiler/socialCompilerRules.js";
6
- import { unsubscribeCompilerRules as c } from "../config/compiler/unsubscribeCompilerRules.js";
7
- import { createHtmlCompiler as f } from "../utils/htmlCompiler.js";
8
- import { useConfig as R } from "./useConfig.js";
9
- const x = () => {
10
- const { config: e } = R(), m = e.htmlCompilerRules || [], l = [
2
+ import { outlookCompilerRules as p } from "../config/compiler/outlookCompilerRules.js";
3
+ import { recommendationCompilerRules as s } from "../config/compiler/recommendationCompilerRules.js";
4
+ import { socialCompilerRules as u } from "../config/compiler/socialCompilerRules.js";
5
+ import { unsubscribeCompilerRules as n } from "../config/compiler/unsubscribeCompilerRules.js";
6
+ import { createHtmlCompiler as c } from "../utils/htmlCompiler.js";
7
+ import { useConfig as f } from "./useConfig.js";
8
+ const h = () => {
9
+ const { config: e } = f(), l = e.htmlCompilerRules || [], m = [
11
10
  ...!!e.ignoreDefaultHtmlCompilerRules ? [] : t,
12
- ...u,
13
- ...c,
14
- ...p,
15
11
  ...s,
16
12
  ...n,
17
- ...m.map((o, i) => ({
13
+ ...p,
14
+ ...u,
15
+ ...l.map((o, i) => ({
18
16
  ...o,
19
17
  priority: o.priority + 1e3 + i
20
18
  // Ensure additional rules run after default rules
21
19
  }))
22
- ], r = f(l);
20
+ ], r = c(m);
23
21
  return { compileHtml: (o) => r.compile(o) };
24
22
  };
25
23
  export {
26
- x as useHtmlCompiler
24
+ h as useHtmlCompiler
27
25
  };
@@ -1,19 +1,18 @@
1
- import { useConfig as V } from "./useConfig.js";
2
- import { TemplateTypes as D } from "../enums/defaults.js";
3
- import { DISPLAY_CONDITIONS_REGEX as H, DISPLAY_CONDITIONS_EXCEPTIONS_REGEX as P, CampaignCouldNotBeSavedKey as R, CanNotMakeAnyChangesForRunningKey as _ } from "../enums/html-validator.js";
1
+ import { useConfig as H } from "./useConfig.js";
2
+ import { TemplateTypes as V } from "../enums/defaults.js";
3
+ import { DISPLAY_CONDITIONS_REGEX as D, DISPLAY_CONDITIONS_EXCEPTIONS_REGEX as P, CampaignCouldNotBeSavedKey as R, CanNotMakeAnyChangesForRunningKey as _ } from "../enums/html-validator.js";
4
4
  import { ToasterTypeOptions as l } from "../enums/toaster.js";
5
- import { itemsBlockDynamicVariables as G } from "../extensions/Blocks/Items/enums/productEnums.js";
6
- import { useRecommendationStore as $ } from "../stores/recommendation.js";
7
- import { base64EncodeWithSpecialChars as j } from "../utils/base64.js";
8
- import { useHttp as q } from "./useHttp.js";
9
- import { useToaster as M } from "./useToaster.js";
10
- import { useTranslations as X } from "./useTranslations.js";
11
- const ie = () => {
5
+ import { useRecommendationStore as G } from "../stores/recommendation.js";
6
+ import { base64EncodeWithSpecialChars as $ } from "../utils/base64.js";
7
+ import { useHttp as j } from "./useHttp.js";
8
+ import { useToaster as q } from "./useToaster.js";
9
+ import { useTranslations as M } from "./useTranslations.js";
10
+ const se = () => {
12
11
  var d;
13
- const { showToaster: c } = M(), { post: y } = q(), { config: h } = V(), a = X(), m = $(), u = ((d = h.partner) == null ? void 0 : d.messageType) === D.transactional, v = async (e) => {
12
+ const { showToaster: c } = q(), { post: y } = j(), { config: h } = H(), a = M(), m = G(), u = ((d = h.partner) == null ? void 0 : d.messageType) === V.transactional, v = async (e) => {
14
13
  const t = await y(
15
14
  "/newsletter/template-library/check-template-html-body",
16
- { html: j(e) }
15
+ { html: $(e) }
17
16
  ), { status: n, message: r } = t.data;
18
17
  return n || c({
19
18
  type: l.Alert,
@@ -26,10 +25,10 @@ const ie = () => {
26
25
  const t = e.match(/({%(.*?)%})/g);
27
26
  let n = !0;
28
27
  return t !== null && !u && t.forEach((r) => {
29
- const i = r.slice(2, -2).trim().match(/(".*?"|[^"\s]+)(?=\s*|\s*$)/g);
30
- if (i && i.length > 0) {
31
- const [o] = i;
32
- C(o) && !s.includes(o) && (c({
28
+ const o = r.slice(2, -2).trim().match(/(".*?"|[^"\s]+)(?=\s*|\s*$)/g);
29
+ if (o && o.length > 0) {
30
+ const [i] = o;
31
+ C(i) && !s.includes(i) && (c({
33
32
  type: l.Warning,
34
33
  message: a("custom-fields.invalid-custom-fields")
35
34
  }), n = !1);
@@ -59,19 +58,19 @@ const ie = () => {
59
58
  }, k = (e, s) => {
60
59
  const t = e.match(/{{([a-zA-Z0-9_\s]*)}}/gm);
61
60
  if (t && !u) {
62
- const n = new Set(s.map((i) => i.toLowerCase())), r = [];
63
- if (t.forEach((i) => {
64
- const o = i.slice(2, -2).trim().toLowerCase();
65
- (!n.has(o) || o === "") && r.push(o);
61
+ const n = new Set(s.map((o) => o.toLowerCase())), r = [];
62
+ if (t.forEach((o) => {
63
+ const i = o.slice(2, -2).trim().toLowerCase();
64
+ (!n.has(i) || i === "") && r.push(i);
66
65
  }), r.length > 0) {
67
- const i = `
66
+ const o = `
68
67
  <ul>
69
- ${r.map((o) => `<li>${o}</li>`).join("")}
68
+ ${r.map((i) => `<li>${i}</li>`).join("")}
70
69
  </ul>
71
70
  `;
72
71
  return c({
73
72
  type: l.Alert,
74
- message: a("custom-fields.invalid-custom-fields") + i
73
+ message: a("custom-fields.invalid-custom-fields") + o
75
74
  }), !1;
76
75
  }
77
76
  }
@@ -80,11 +79,11 @@ const ie = () => {
80
79
  const s = e.match(/{%(.*?)%}/g), t = [];
81
80
  let n = !0;
82
81
  if (s && s.forEach((r) => {
83
- const i = r.match(H), o = r.match(P), B = (i == null ? void 0 : i.join("")) || "";
84
- (!i || r !== B) && !o && (c({
82
+ const o = r.match(D), i = r.match(P), B = (o == null ? void 0 : o.join("")) || "";
83
+ (!o || r !== B) && !i && (c({
85
84
  type: l.Alert,
86
85
  message: a("newsletter.display-conditions-invalid-syntax")
87
- }), n = !1), i && i.forEach((f) => {
86
+ }), n = !1), o && o.forEach((f) => {
88
87
  f.trim() === "=" && (c({
89
88
  type: l.Alert,
90
89
  message: a("custom-conditions.wrong-equality-operators")
@@ -95,8 +94,8 @@ const ie = () => {
95
94
  });
96
95
  });
97
96
  }), t.length) {
98
- const r = t.filter((o) => o === "if"), i = t.filter((o) => o === "endif");
99
- r.length !== i.length && (c({
97
+ const r = t.filter((i) => i === "if"), o = t.filter((i) => i === "endif");
98
+ r.length !== o.length && (c({
100
99
  type: l.Alert,
101
100
  message: a("custom-conditions.missing-if-endif-tag")
102
101
  }), n = !1);
@@ -122,28 +121,28 @@ const ie = () => {
122
121
  }), !1);
123
122
  }, N = (e) => {
124
123
  const n = new DOMParser().parseFromString(e, "text/html").querySelectorAll(".checkbox-block-v2");
125
- return Array.from(n).find((i) => {
126
- var o;
127
- return !((o = i.id) != null && o.trim());
124
+ return Array.from(n).find((o) => {
125
+ var i;
126
+ return !((i = o.id) != null && i.trim());
128
127
  }) ? (c({
129
128
  type: l.Alert,
130
129
  message: a("unsubscribe-templates.select-checkbox-groups")
131
130
  }), !1) : !0;
132
131
  }, O = (e) => {
133
132
  const n = new DOMParser().parseFromString(e, "text/html").querySelectorAll(".radio-button-v2");
134
- return Array.from(n).find((i) => {
135
- var o;
136
- return !((o = i.id) != null && o.trim());
133
+ return Array.from(n).find((o) => {
134
+ var i;
135
+ return !((i = o.id) != null && i.trim());
137
136
  }) ? (c({
138
137
  type: l.Alert,
139
138
  message: a("unsubscribe-templates.select-radio-button-groups")
140
139
  }), !1) : !0;
141
140
  };
142
141
  return { validateHtml: async (e, s, t = !1) => {
143
- const n = [...s.map((i) => i.value), ...G];
142
+ const n = s.map((o) => o.value);
144
143
  return await b(e, n, t) && E(e) && A(e) && x(e) && k(e, n) && T(e) && F(e) && I(e) && W() && L(e) && N(e) && O(e);
145
144
  } };
146
145
  };
147
146
  export {
148
- ie as useHtmlValidator
147
+ se as useHtmlValidator
149
148
  };
@@ -1,26 +1,29 @@
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();
1
+ import { useActionsApi as f } from "./useActionsApi.js";
2
+ import { useCustomInterfaceAppearance as E } from "./useCustomInterfaceAppearance.js";
3
+ import { useStripoEventHandler as S } from "./useStripoEventHandler.js";
4
+ import { useToaster as C } from "./useToaster.js";
5
+ import { displayConditions as y } from "../enums/displayConditions.js";
6
+ import h from "../extensions/Blocks/Checkbox/extension.js";
7
+ import w from "../extensions/Blocks/CouponBlock/extension.js";
8
+ import b from "../extensions/Blocks/RadioButton/extension.js";
9
+ import V from "../extensions/Blocks/Recommendation/extension.js";
10
+ import _ from "../extensions/Blocks/Unsubscribe/extension.js";
11
+ import k from "../extensions/DynamicContent/extension.js";
12
+ import { useStripoApi as B } from "../services/stripoApi.js";
13
+ import x from "../static/styles/customEditorStyle.css.js";
14
+ import { useEditorStore as F } from "../stores/editor.js";
15
+ import { dynamicContentToMergeTags as A } from "../utils/genericUtil.js";
16
+ import T from "../package.json.js";
17
+ const G = (a) => {
18
+ const { handleError: d } = C(), { getToken: u, getCustomFonts: m } = B(), { handleEvent: p } = S(), l = (r, i = []) => {
19
+ const t = F(), { html: n, css: c, forceRecreate: s } = r;
17
20
  window.UIEditor.initEditor(
18
21
  document.querySelector("#guido-editor"),
19
22
  {
20
- metadata: c,
23
+ metadata: a,
21
24
  html: n,
22
- css: p,
23
- forceRecreate: a,
25
+ css: c,
26
+ forceRecreate: s,
24
27
  locale: "en",
25
28
  undoButtonSelector: "#guido__undo-button",
26
29
  redoButtonSelector: "#guido__redo-button",
@@ -30,44 +33,39 @@ const J = (c) => {
30
33
  customAppearanceMergetags: !0,
31
34
  customAppearanceMergetagsBorderColor: "#f1f3fe",
32
35
  customAppearanceMergetagsBackgroundColor: "#f1f3fe",
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,
36
+ customViewStyles: x,
37
+ conditionsEnabled: !0,
38
+ customConditionsEnabled: !0,
39
+ conditionCategories: y,
37
40
  enableXSSSecurity: !0,
38
- messageSettingsEnabled: !0,
39
- displayGmailAnnotations: !0,
40
- displayHiddenPreheader: !1,
41
- displayTitle: !1,
42
- displayUTM: !1,
43
- selectElementAfterDrop: !0,
44
- ...e ? { baseBlocks: e } : {},
41
+ messageSettingsEnabled: !1,
42
+ selectBlockAfterDropFromSettingsPanel: !0,
45
43
  editorFonts: {
46
44
  showDefaultStandardFonts: !0,
47
45
  showDefaultNotStandardFonts: !0,
48
- customFonts: r
46
+ customFonts: i
49
47
  },
50
48
  mergeTags: [
51
49
  {
52
- entries: U(c.preselectedDynamicContentList)
50
+ entries: A(a.preselectedDynamicContentList)
53
51
  }
54
52
  ],
55
53
  async onTokenRefreshRequest(o) {
56
54
  try {
57
- const s = await f();
58
- o(s);
59
- } catch (s) {
60
- l(s, "Failed to refresh token");
55
+ const e = await u();
56
+ o(e);
57
+ } catch (e) {
58
+ d(e, "Failed to refresh token");
61
59
  }
62
60
  },
63
61
  onTemplateLoaded() {
64
62
  try {
65
- const { importCss: o } = V(), { activateCustomViewStyles: s } = w();
66
- o(), s(), c.onReady(), t.isStripoInitialized = !0, t.loadingStatus = !1, setTimeout(() => {
63
+ const { importCss: o } = E(), { activateCustomViewStyles: e } = f();
64
+ o(), e(), a.onReady(), t.isStripoInitialized = !0, t.loadingStatus = !1, setTimeout(() => {
67
65
  t.hasChanges = !1;
68
66
  }, 1e3);
69
67
  } catch (o) {
70
- l(o, "Failed to load custom interface appearance");
68
+ d(o, "Failed to load custom interface appearance");
71
69
  }
72
70
  },
73
71
  onCodeEditorVisibilityChanged(o) {
@@ -82,35 +80,42 @@ const J = (c) => {
82
80
  onDataChanged() {
83
81
  t.hasChanges = !0;
84
82
  },
85
- onEvent: S,
83
+ onEvent: p,
86
84
  ignoreClickOutsideSelectors: [
87
85
  "#guido-dynamic-content-modal",
88
86
  ".in-on-board-wrapper",
89
87
  ".in-drawer__container"
90
88
  ],
91
- extensions: d
89
+ extensions: [
90
+ k,
91
+ h,
92
+ b,
93
+ V,
94
+ _,
95
+ w
96
+ ]
92
97
  }
93
98
  );
94
- }, h = (i) => new Promise((r, t) => {
95
- var d;
99
+ }, g = (r) => new Promise((i, t) => {
100
+ var e;
96
101
  if (document.getElementById("UiEditorScript")) {
97
- i(), r();
102
+ r(), i();
98
103
  return;
99
104
  }
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");
101
- e.id = "UiEditorScript", e.type = "module", e.src = a, e.onload = () => {
102
- i(), r();
103
- }, e.onerror = () => {
104
- t(new Error(`Failed to load Stripo UIEditor script from S3: ${a}`));
105
- }, document.body.appendChild(e);
105
+ const n = T.guido, s = `https://email-static.useinsider.com/guido/${(e = n == null ? void 0 : n.stripo) == null ? void 0 : e.version}/UIEditor.js`, o = document.createElement("script");
106
+ o.id = "UiEditorScript", o.type = "module", o.src = s, o.onload = () => {
107
+ r(), i();
108
+ }, o.onerror = () => {
109
+ t(new Error(`Failed to load Stripo UIEditor script from S3: ${s}`));
110
+ }, document.body.appendChild(o);
106
111
  });
107
- return { initPlugin: async (i) => {
108
- await h(async () => {
109
- const r = await y();
110
- await E(i, r);
112
+ return { initPlugin: async (r) => {
113
+ await g(async () => {
114
+ const i = await m();
115
+ l(r, i);
111
116
  });
112
117
  } };
113
118
  };
114
119
  export {
115
- J as useStripo
120
+ G as useStripo
116
121
  };
@@ -1,41 +1,36 @@
1
- import { usePartner as N } from "../../composables/usePartner.js";
2
- import { LINK_REGEXES as l, LINK_TYPES as g, INSIDER_ID as f, URLS as S } from "../../enums/unsubscribe.js";
3
- import { parsePageList as U } from "../../extensions/Blocks/Unsubscribe/utils/utils.js";
4
- import { useConfigStore as B } from "../../stores/config.js";
5
- import { useDynamicContentStore as y } from "../../stores/dynamic-content.js";
6
- import { useUnsubscribeStore as L } from "../../stores/unsubscribe.js";
7
- const D = [
1
+ import { usePartner as U } from "../../composables/usePartner.js";
2
+ import { LINK_REGEXES as l, LINK_TYPES as b, URLS as f } from "../../enums/unsubscribe.js";
3
+ import { parsePageList as B } from "../../extensions/Blocks/Unsubscribe/utils/utils.js";
4
+ import { useConfigStore as N } from "../../stores/config.js";
5
+ import { useUnsubscribeStore as I } from "../../stores/unsubscribe.js";
6
+ const T = [
8
7
  {
9
8
  id: "add-unsubscribe-link-values",
10
9
  description: "Adding unsubscribe link values",
11
10
  type: "custom",
12
11
  processor: (t) => {
13
- const { getPartnerName: i } = N(), c = B(), n = y(), u = L(), a = c.getVariationId;
14
- if (!a)
12
+ const { getPartnerName: i } = U(), a = N(), n = I(), u = a.getVariationId;
13
+ if (!u)
15
14
  return t;
16
- let e = t;
17
- const r = `/${i()}/email/${a}?user={{iid}}`;
18
- return new DOMParser().parseFromString(e, "text/html").querySelectorAll(".unsubscribe-block-v2[data-unsubscribe-page-list]").forEach((p) => {
19
- var b;
20
- const m = p.getAttribute("data-unsubscribe-page-list");
21
- if (!m)
15
+ let o = t;
16
+ const e = `/${i()}/email/${u}?user={{iid}}`;
17
+ return new DOMParser().parseFromString(o, "text/html").querySelectorAll(".unsubscribe-block-v2[data-unsubscribe-page-list]").forEach((p) => {
18
+ var g;
19
+ const d = p.getAttribute("data-unsubscribe-page-list");
20
+ if (!d)
22
21
  return;
23
- const R = U(m), d = ((b = u.templates) == null ? void 0 : b.filter(
24
- (o) => R.includes(o.id)
25
- )) ?? [], _ = d.some((o) => o.type === g.UNSUBSCRIBE_LINK_TYPE), I = d.some((o) => o.type === g.PREFERENCES_LINK_TYPE), E = p.outerHTML;
22
+ const S = B(d), m = ((g = n.templates) == null ? void 0 : g.filter(
23
+ (c) => S.includes(c.id)
24
+ )) ?? [], R = m.some((c) => c.type === b.UNSUBSCRIBE_LINK_TYPE), _ = m.some((c) => c.type === b.PREFERENCES_LINK_TYPE), E = p.outerHTML;
26
25
  let s = E;
27
- _ && (n.selectedDynamicContentList.push({
28
- text: f,
29
- value: f,
30
- fallback: ""
31
- }), s = s.replace(
26
+ R && (s = s.replace(
32
27
  l.GLOBAL_UNSUBSCRIBE_LINK_REGEX,
33
- S.UNSUBSCRIBE_URL + r
34
- )), I && (s = s.replace(
28
+ f.UNSUBSCRIBE_URL + e
29
+ )), _ && (s = s.replace(
35
30
  l.PREFERENCES_UNSUBSCRIBE_LINK_REGEX,
36
- S.PREFERENCES_URL + r
37
- )), s = s.replace(l.UNSUBSCRIBE_LINK_REGEX, ""), e = e.replace(E, s);
38
- }), e;
31
+ f.PREFERENCES_URL + e
32
+ )), s = s.replace(l.UNSUBSCRIBE_LINK_REGEX, ""), o = o.replace(E, s);
33
+ }), o;
39
34
  },
40
35
  priority: 60
41
36
  },
@@ -61,16 +56,16 @@ const D = [
61
56
  type: "custom",
62
57
  processor: (t) => {
63
58
  let i = t;
64
- const c = i.match(/<a[^>]+>(.*?)<\/a>/gm);
65
- return c && c.forEach((n) => {
59
+ const a = i.match(/<a[^>]+>(.*?)<\/a>/gm);
60
+ return a && a.forEach((n) => {
66
61
  if (n.includes("insEmail=1"))
67
62
  return;
68
63
  if (n.match(/<a\s+(?:[^>]*?\s+)?href=(["'`”])(.*?)\1\s+(?:[^>]*?\s+)?universal=(["'`”])true\3/gm)) {
69
- const a = n.replace(/href=(["'`”])(.*?)\1/gm, (e) => {
64
+ const o = n.replace(/href=(["'`”])(.*?)\1/gm, (e) => {
70
65
  const r = e.slice(6, e.length - 1).trim();
71
66
  return e.includes("?") || e.includes("#") ? r.slice(-1) === "&" ? e.replace(r, `${r}insEmail=1`) : e.replace(r, `${r}&insEmail=1`) : e.replace(r, `${r}?insEmail=1`);
72
67
  });
73
- i = i.replace(n, a);
68
+ i = i.replace(n, o);
74
69
  }
75
70
  }), i;
76
71
  },
@@ -78,5 +73,5 @@ const D = [
78
73
  }
79
74
  ];
80
75
  export {
81
- D as unsubscribeCompilerRules
76
+ T as unsubscribeCompilerRules
82
77
  };
@@ -1,4 +1,4 @@
1
- const e = {
1
+ const a = {
2
2
  translationsPath: "window.trans.en",
3
3
  migrationDate: 1759696858,
4
4
  emailHeader: {
@@ -8,26 +8,19 @@ const e = {
8
8
  extensions: {
9
9
  unsubscribe: !0
10
10
  },
11
- blocks: {
12
- excludeDefaults: [],
13
- includeCustoms: []
14
- },
15
11
  features: {
16
12
  dynamicContent: !0,
17
13
  saveAsTemplate: !0,
18
- versionHistory: !0,
19
- testMessage: !0,
20
- displayConditions: !0
14
+ versionHistory: !0
21
15
  },
22
16
  useHeader: !0
23
17
  }, t = {
24
18
  promotional: 1,
25
19
  transactional: 2
26
- }, a = "email", o = "Guido User", s = t.promotional, n = 2, i = 13, u = {
20
+ }, e = "email", o = "Guido User", n = t.promotional, i = 2, s = {
27
21
  email: 60,
28
- architect: 49,
29
- unsubscribePages: 97
30
- }, r = [
22
+ architect: 49
23
+ }, u = [
31
24
  "alfredtesting",
32
25
  "electio",
33
26
  "eurekatest",
@@ -60,13 +53,12 @@ const e = {
60
53
  "stripoeditorlivetest"
61
54
  ];
62
55
  export {
63
- e as DefaultGuidoConfig,
64
- s as DefaultMessageType,
65
- a as DefaultProductType,
56
+ a as DefaultGuidoConfig,
57
+ n as DefaultMessageType,
58
+ e as DefaultProductType,
66
59
  o as DefaultUsername,
67
- n as EditorType,
68
- i as MAX_DEFAULT_TEMPLATE_ID,
69
- u as ProductIds,
70
- r as TEST_PARTNER_LIST,
60
+ i as EditorType,
61
+ s as ProductIds,
62
+ u as TEST_PARTNER_LIST,
71
63
  t as TemplateTypes
72
64
  };
@@ -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: "before the amount", value: "0" },
16
- { text: "after the amount", value: "1" }
15
+ { text: "after the amount", value: "1" },
16
+ { text: "before the amount", value: "0" }
17
17
  ], c = [
18
18
  { text: "dot(.)", value: "." },
19
19
  { text: "comma(,)", value: "," }
@@ -2,12 +2,8 @@ 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 = "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";
5
+ ], t = "https://academy.useinsider.com/docs/email-drag-drop-editor";
6
6
  export {
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
7
+ t as ACADEMY_LINK,
8
+ e as SERVICE_HOVER_SELECTORS
13
9
  };