@useinsider/guido 2.0.0 → 2.1.0-beta.13ada05

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 (239) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +72 -54
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +15 -17
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  12. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +16 -15
  13. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  15. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +12 -11
  16. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  17. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  18. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  19. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  20. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  21. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  23. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  24. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  25. package/dist/components/organisms/header/LeftSlot.vue2.js +27 -23
  26. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  27. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  28. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  29. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  30. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  31. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  32. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  34. package/dist/composables/useActionsApi.js +37 -32
  35. package/dist/composables/useConfig.js +29 -27
  36. package/dist/composables/useSave.js +13 -11
  37. package/dist/composables/useStripo.js +57 -56
  38. package/dist/config/migrator/index.js +9 -8
  39. package/dist/config/migrator/itemsBlockMigrator.js +351 -0
  40. package/dist/enums/academy.js +8 -0
  41. package/dist/enums/onboarding.js +1 -2
  42. package/dist/enums/unsubscribe.js +20 -21
  43. package/dist/extensions/Blocks/CouponBlock/constants.js +4 -0
  44. package/dist/extensions/Blocks/CouponBlock/controls/index.js +29 -0
  45. package/dist/extensions/Blocks/CouponBlock/extension.js +5 -4
  46. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +20 -14
  47. package/dist/extensions/Blocks/CouponBlock/template.js +22 -11
  48. package/dist/extensions/Blocks/Items/block.js +28 -41
  49. package/dist/extensions/Blocks/Items/controls/button/link.js +18 -37
  50. package/dist/extensions/Blocks/Items/controls/cardComposition.js +164 -96
  51. package/dist/extensions/Blocks/Items/controls/image/link.js +16 -35
  52. package/dist/extensions/Blocks/Items/controls/name/trimming.js +30 -42
  53. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +35 -45
  54. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +56 -59
  55. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +45 -48
  56. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +23 -34
  57. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +47 -57
  58. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +75 -0
  59. package/dist/extensions/Blocks/Items/controls/settingsControl.js +198 -184
  60. package/dist/extensions/Blocks/Items/enums/controlEnums.js +2 -2
  61. package/dist/extensions/Blocks/Items/enums/productEnums.js +43 -45
  62. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +3 -6
  63. package/dist/extensions/Blocks/Items/extension.js +7 -6
  64. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +58 -49
  65. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +48 -59
  66. package/dist/extensions/Blocks/Items/settingsPanel.js +27 -26
  67. package/dist/extensions/Blocks/Items/template.js +397 -143
  68. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +176 -0
  69. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +153 -69
  70. package/dist/extensions/Blocks/Recommendation/constants.js +9 -1
  71. package/dist/extensions/Blocks/Recommendation/control.js +91 -61
  72. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  76. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  77. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  80. package/dist/extensions/Blocks/Recommendation/extension.js +16 -42
  81. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -72
  82. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +85 -64
  83. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +54 -17
  84. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  85. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  86. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  87. package/dist/extensions/Blocks/common-control.js +107 -110
  88. package/dist/extensions/Blocks/controlFactories.js +139 -118
  89. package/dist/guido.css +1 -1
  90. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +370 -291
  91. package/dist/package.json.js +1 -1
  92. package/dist/services/stripoApi.js +6 -10
  93. package/dist/src/@types/config/index.d.ts +2 -2
  94. package/dist/src/@types/config/schemas.d.ts +36 -2
  95. package/dist/src/@types/config/types.d.ts +7 -1
  96. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  97. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  98. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  99. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  100. package/dist/src/composables/useActionsApi.d.ts +1 -0
  101. package/dist/src/composables/useConfig.d.ts +10 -0
  102. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +6 -0
  103. package/dist/src/enums/academy.d.ts +12 -0
  104. package/dist/src/enums/onboarding.d.ts +0 -1
  105. package/dist/src/enums/unsubscribe.d.ts +0 -1
  106. package/dist/src/extensions/Blocks/CouponBlock/constants.d.ts +14 -0
  107. package/dist/src/extensions/Blocks/CouponBlock/controls/index.d.ts +108 -0
  108. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +1 -1
  109. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -1
  110. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -3
  111. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +13 -4
  112. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -3
  113. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  114. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  115. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  116. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  117. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  118. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -2
  119. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +13 -0
  120. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +10 -16
  121. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +1 -0
  122. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +24 -26
  123. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +1 -2
  124. package/dist/src/extensions/Blocks/Items/template.d.ts +22 -1
  125. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +77 -0
  126. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +50 -3
  127. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +32 -0
  128. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  129. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +592 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  133. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  137. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  138. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  139. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  140. package/dist/src/extensions/Blocks/common-control.d.ts +11 -13
  141. package/dist/src/extensions/Blocks/controlFactories.d.ts +30 -7
  142. package/dist/src/stores/config.d.ts +181 -1
  143. package/dist/src/stores/editor.d.ts +21 -0
  144. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  145. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  146. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  147. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  148. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  149. package/dist/static/styles/components/button.css.js +1 -1
  150. package/dist/static/styles/components/narrow-panel.css.js +0 -10
  151. package/dist/static/styles/components/wide-panel.css.js +1 -5
  152. package/dist/static/styles/customEditorStyle.css.js +13 -0
  153. package/dist/stores/config.js +7 -0
  154. package/dist/stores/editor.js +1 -0
  155. package/dist/utils/pairProductVariables.js +61 -58
  156. package/dist/utils/templatePreparation.js +17 -17
  157. package/package.json +3 -3
  158. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  159. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  160. package/dist/extensions/Blocks/Items/store/items-block.js +0 -75
  161. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +0 -17
  162. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +0 -28
  163. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +0 -76
  164. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +0 -46
  165. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  166. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  167. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  168. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  169. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  170. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  171. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  172. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  184. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  185. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  186. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  187. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  188. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  189. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  190. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  191. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  192. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  193. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  194. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  195. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  196. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  197. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  198. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  199. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -43
  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 -50
  203. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +0 -8
  204. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  205. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  206. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  207. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  208. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  209. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  210. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  211. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  212. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  224. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  225. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  226. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  227. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  228. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  229. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  230. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  231. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  232. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  233. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  234. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  235. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  236. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  237. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  238. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  239. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -1,18 +1,19 @@
1
- const R = {
1
+ import { ATTR_PRODUCT_IMAGE as h, ATTR_PRODUCT_NAME as C, ATTR_PRODUCT_OLD_PRICE as D, ATTR_PRODUCT_PRICE as b, ATTR_PRODUCT_OMNIBUS_PRICE as P, ATTR_PRODUCT_OMNIBUS_DISCOUNT as U, ATTR_PRODUCT_BUTTON as N } from "../constants.js";
2
+ const E = {
2
3
  TITLE: "You May Also Like!"
3
- }, O = `
4
+ }, I = `
4
5
  <tr>
5
- <td class="spacer" style="height: 20px;"></td>
6
+ <td class="spacer" style="height: 10px;"></td>
6
7
  </tr>
7
- `, w = `
8
- <tr>
8
+ `, A = `
9
+ <tr class="recommendation-product-row">
9
10
  <td>
10
11
  <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
11
12
  {-{-PRODUCTS-}-}
12
13
  </table>
13
14
  </td>
14
15
  </tr>
15
- `, i = `
16
+ `, o = `
16
17
  <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
17
18
  <table
18
19
  width="100%"
@@ -34,14 +35,24 @@ const R = {
34
35
  </tr>
35
36
  </table>
36
37
  </td>
37
- `, b = [
38
- "productImage",
39
- "productName",
40
- "productOldPrice",
41
- "productPrice",
42
- "productButton"
43
- ];
44
- function C() {
38
+ `, Y = [
39
+ h,
40
+ C,
41
+ D,
42
+ b,
43
+ P,
44
+ U,
45
+ N
46
+ ], S = {
47
+ [h]: !0,
48
+ [C]: !0,
49
+ [b]: !0,
50
+ [D]: !0,
51
+ [P]: !1,
52
+ [U]: !1,
53
+ [N]: !0
54
+ };
55
+ function M() {
45
56
  return [
46
57
  {
47
58
  name: "Product Name",
@@ -123,58 +134,76 @@ function C() {
123
134
  }
124
135
  ];
125
136
  }
126
- function N(p, r, e, l = b) {
127
- const n = (100 / r).toFixed(2), a = [];
128
- for (let o = 0; o < p.length; o += r)
129
- a.push(p.slice(o, o + r));
137
+ function f(a, r, e, l = Y) {
138
+ const s = (100 / r).toFixed(2), p = [];
139
+ for (let i = 0; i < a.length; i += r)
140
+ p.push(a.slice(i, i + r));
130
141
  let c = "";
131
- return a.forEach((o, _) => {
132
- _ > 0 && (c += O);
133
- let s = "", u = "", d = "", m = "", g = "";
134
- o.forEach((t) => {
135
- s += i.replace(
142
+ return p.forEach((i, w) => {
143
+ w > 0 && (c += I);
144
+ let n = "", u = "", d = "", T = "", m = "", _ = "", g = "";
145
+ i.forEach((t) => {
146
+ n += o.replace(
136
147
  "{-{-PRODUCT_CONTENT-}-}",
137
148
  e.productImage(t)
138
- ), u += i.replace(
149
+ ), u += o.replace(
139
150
  "{-{-PRODUCT_CONTENT-}-}",
140
151
  e.productName(t)
141
- ), d += i.replace(
152
+ ), d += o.replace(
142
153
  "{-{-PRODUCT_CONTENT-}-}",
143
154
  e.productPrice(t)
144
- ), m += i.replace(
155
+ ), T += o.replace(
145
156
  "{-{-PRODUCT_CONTENT-}-}",
146
157
  e.productOldPrice(t)
147
- ), g += i.replace(
158
+ ), m += o.replace(
159
+ "{-{-PRODUCT_CONTENT-}-}",
160
+ e.productOmnibusPrice(t)
161
+ ), _ += o.replace(
162
+ "{-{-PRODUCT_CONTENT-}-}",
163
+ e.productOmnibusDiscount(t)
164
+ ), g += o.replace(
148
165
  "{-{-PRODUCT_CONTENT-}-}",
149
166
  e.productButton(t)
150
167
  );
151
168
  });
152
- const T = {
153
- productImage: s,
169
+ const R = {
170
+ productImage: n,
154
171
  productName: u,
155
172
  productPrice: d,
156
- productOldPrice: m,
173
+ productOldPrice: T,
174
+ productOmnibusPrice: m,
175
+ productOmnibusDiscount: _,
157
176
  productButton: g
158
- }, h = l.filter((t) => !!T[t]).map((t) => `<tr>${T[t]}</tr>`).join("");
159
- c += w.replace("{-{-PRODUCTS-}-}", h);
160
- }), c.replaceAll("{-{-COLUMN_WIDTH-}-}", `${n}%`);
177
+ }, y = l.filter((t) => !!R[t]).map((t) => {
178
+ const O = S[t] ?? !0;
179
+ return `
180
+ <tr class="recommendation-attribute-row"
181
+ data-attribute-type="${t}"
182
+ data-visibility="${O ? "1" : "0"}"${O ? "" : ' style="display: none;"'}>
183
+ ${R[t]}
184
+ </tr>
185
+ `;
186
+ }).join("");
187
+ c += A.replace("{-{-PRODUCTS-}-}", y);
188
+ }), c.replaceAll("{-{-COLUMN_WIDTH-}-}", `${s}%`);
161
189
  }
162
- function P(p, r, e, l, n = R.TITLE, a) {
163
- const c = N(
190
+ function j(a, r, e, l, s = E.TITLE, p) {
191
+ const c = f(
164
192
  r,
165
193
  e,
166
194
  l,
167
- a
195
+ p
168
196
  );
169
- return p.replace("{-{-TITLE-}-}", n).replace("{-{-PRODUCT_ROWS-}-}", c);
197
+ return a.replace("{-{-TITLE-}-}", s).replace("{-{-PRODUCT_ROWS-}-}", c);
170
198
  }
171
199
  export {
172
- R as DEFAULTS,
173
- b as DEFAULT_CARD_COMPOSITION,
174
- P as generateTemplate,
175
- C as getDefaultProducts,
176
- N as prepareProductRows,
177
- i as productCardWrapper,
178
- w as productRow,
179
- O as spacer
200
+ E as DEFAULTS,
201
+ Y as DEFAULT_CARD_COMPOSITION,
202
+ S as DEFAULT_CARD_VISIBILITY,
203
+ j as generateTemplate,
204
+ M as getDefaultProducts,
205
+ f as prepareProductRows,
206
+ o as productCardWrapper,
207
+ A as productRow,
208
+ I as spacer
180
209
  };
@@ -0,0 +1,25 @@
1
+ function a(n) {
2
+ return "getInnerHTML" in n && typeof n.getInnerHTML == "function" ? n.getInnerHTML().trim() : "innerHTML" in n ? n.innerHTML : "";
3
+ }
4
+ function m(n, t) {
5
+ if (!n)
6
+ return t;
7
+ const r = a(n);
8
+ if (!r || r.trim() === "" || !/<(strong|em|u|s|b|i)\b/i.test(r))
9
+ return t;
10
+ const i = [], s = [];
11
+ let o = r.trim();
12
+ for (; ; ) {
13
+ const u = o.match(/^<(strong|em|u|s|b|i)(\s[^>]*)?>(.*)$/is);
14
+ if (!u)
15
+ break;
16
+ const [, e, f = "", g] = u, c = new RegExp(`</${e}>$`, "i");
17
+ if (!c.test(g))
18
+ break;
19
+ i.push(`<${e}${f}>`), s.unshift(`</${e}>`), o = g.replace(c, "").trim();
20
+ }
21
+ return i.length > 0 ? i.join("") + t + s.join("") : t;
22
+ }
23
+ export {
24
+ m as preserveTextStyles
25
+ };
@@ -1,21 +1,21 @@
1
1
  import { ExtensionBuilder as e } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
2
  import { UnsubscribeBlock as i } from "./block.js";
3
3
  import { UnsubscribeControl as t } from "./control.js";
4
- import { PreviewUIElement as o } from "./elements/preview.js";
5
- import { UnsubscribeIconsRegistry as r } from "./iconsRegistry.js";
6
- import { SettingsPanel as s } from "./settingsPanel.js";
4
+ import { PreviewUIElement as s } from "./elements/preview.js";
5
+ import { UnsubscribeIconsRegistry as o } from "./iconsRegistry.js";
6
+ import { SettingsPanel as r } from "./settingsPanel.js";
7
7
  import n from "./styles.css.js";
8
- import { UnsubscribeTagRegistry as l } from "./tagRegistry.js";
9
- const f = new e().addBlock(i).withSettingsPanelRegistry(s).addControl(t).addUiElement(o).addStyles(n).withLocalization({
8
+ import { UnsubscribeTagRegistry as c } from "./tagRegistry.js";
9
+ const g = new e().addBlock(i).withSettingsPanelRegistry(r).addControl(t).addUiElement(s).addStyles(n).withLocalization({
10
10
  en: {
11
- "Unsubscribe Block": "Unsubscribe Block",
12
- "Unsubscribe Block Description": "Add an unsubscribe link to your email",
11
+ "Unsubscribe Block": "Unsubscribe",
12
+ "Unsubscribe Block Description": "Unsubscribe lets you add an Unsubscribe Link to direct users to opt out of receiving your messages.",
13
13
  "Select Template": "Select Template",
14
14
  "Unsubscribe Template": "Unsubscribe Template",
15
15
  Showing: "Showing",
16
16
  of: "of"
17
17
  }
18
- }).withUiElementTagRegistry(l).withIconsRegistry(r).build();
18
+ }).withUiElementTagRegistry(c).withIconsRegistry(o).build();
19
19
  export {
20
- f as default
20
+ g as default
21
21
  };
@@ -1,12 +1,12 @@
1
- var c = Object.defineProperty;
2
- var I = (a, r, e) => r in a ? c(a, r, { enumerable: !0, configurable: !0, writable: !0, value: e }) : a[r] = e;
3
- var l = (a, r, e) => I(a, typeof r != "symbol" ? r + "" : r, e);
4
- import { Control as O, UIElementType as t, UEAttr as $ } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- class _ extends O {
1
+ var I = Object.defineProperty;
2
+ var O = (T, r, e) => r in T ? I(T, r, { enumerable: !0, configurable: !0, writable: !0, value: e }) : T[r] = e;
3
+ var u = (T, r, e) => O(T, typeof r != "symbol" ? r + "" : r, e);
4
+ import { Control as c, UIElementType as n, UEAttr as $ } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ class _ extends c {
6
6
  constructor() {
7
7
  super(...arguments);
8
- l(this, "currentNode");
9
- l(this, "lastBlockInstanceId", null);
8
+ u(this, "currentNode");
9
+ u(this, "lastBlockInstanceId", null);
10
10
  }
11
11
  getContainer() {
12
12
  var e;
@@ -19,117 +19,114 @@ class _ extends O {
19
19
  this.lastBlockInstanceId = null;
20
20
  }
21
21
  /**
22
- * Gets the config block element from the current node.
23
- * @returns The config block element or null if not found
22
+ * Gets the Items block container element from the current node.
23
+ * @returns The container element or null if not found
24
24
  */
25
- getConfigBlock() {
26
- if (!this.currentNode)
27
- return null;
28
- const e = this.currentNode.closest(".items-block-v2");
29
- return e ? e.querySelector("esd-config-block") : null;
25
+ getItemsBlockContainer() {
26
+ return this.currentNode ? this.currentNode.closest(".items-block-v2") : null;
30
27
  }
31
28
  /**
32
- * Gets the current block instance ID from the config block.
33
- * @param blockInstanceIdAttribute - The attribute name for block instance ID (default: 'data-block-instance-id')
29
+ * Gets the current block instance ID from the node config (Stripo V2).
34
30
  * @returns The block instance ID or null if not found
35
31
  */
36
- getBlockInstanceId(e = "data-block-instance-id") {
37
- const n = this.getConfigBlock();
38
- return n ? n.getAttribute(e) : null;
32
+ getBlockInstanceId() {
33
+ const e = this.getItemsBlockContainer();
34
+ if (!e)
35
+ return null;
36
+ const t = e.getNodeConfig();
37
+ return t && typeof t.blockInstanceId == "string" ? t.blockInstanceId : null;
39
38
  }
40
39
  /**
41
- * Handles block instance change detection and syncing.
42
- * This is a helper method for controls that need to sync attributes when switching between block instances.
43
- * @param syncFunction - Function to call when block instance changes (to sync from attributes)
44
- * @param updateUI - Function to call to update the UI (called both on change and when same block)
45
- * @param blockInstanceIdAttribute - The attribute name for block instance ID (default: 'data-block-instance-id')
40
+ * Handles block instance change detection and UI updates.
41
+ * This is a helper method for controls that need to update UI when switching between block instances.
42
+ * Uses Stripo V2 nodeConfig API for block instance tracking.
43
+ * @param updateUI - Function to call to update the UI (called on every update)
46
44
  * @returns true if block instance changed, false otherwise
47
45
  */
48
- handleBlockInstanceChange(e, n, E = "data-block-instance-id") {
49
- const o = this.getBlockInstanceId(E);
50
- if (!o)
46
+ handleBlockInstanceChange(e) {
47
+ const t = this.getBlockInstanceId();
48
+ if (!t)
51
49
  return !1;
52
- const T = o !== this.lastBlockInstanceId;
53
- return T ? (this.currentNode && e(this.currentNode), n(), this.lastBlockInstanceId = o) : n(), T;
50
+ const E = t !== this.lastBlockInstanceId;
51
+ return e(), E && (this.lastBlockInstanceId = t), E;
54
52
  }
55
- _GuLabel({ text: e, name: n = "", position: E = "top" }) {
53
+ _GuLabel({ text: e, name: t = "" }) {
56
54
  return `
57
- <${t.LABEL}
58
- style="${E === "top" ? "margin-bottom: 8px;" : ""}"
55
+ <${n.LABEL}
59
56
  ${$.LABEL.text}="${e}"
60
- ${$.LABEL.name}="${n || `${e} Label`}">
61
- </${t.LABEL}>
57
+ ${$.LABEL.name}="${t || `${e} Label`}">
58
+ </${n.LABEL}>
62
59
  `;
63
60
  }
64
61
  _GuToggle(e) {
65
62
  return `
66
- <${t.SWITCHER}
63
+ <${n.SWITCHER}
67
64
  ${$.SWITCHER.name}="${e}">
68
- </${t.SWITCHER}>
65
+ </${n.SWITCHER}>
69
66
  `;
70
67
  }
71
- _GuSelectItem({ text: e, value: n }) {
68
+ _GuSelectItem({ text: e, value: t }) {
72
69
  return `
73
- <${t.SELECT_ITEM}
70
+ <${n.SELECT_ITEM}
74
71
  ${$.SELECT_ITEM.text}="${e}"
75
- ${$.SELECT_ITEM.value}="${n}">
76
- </${t.SELECT_ITEM}>`;
72
+ ${$.SELECT_ITEM.value}="${t}">
73
+ </${n.SELECT_ITEM}>`;
77
74
  }
78
- _GuSelect({ name: e, placeholder: n, options: E, className: o = "es-180w" }) {
75
+ _GuSelect({ name: e, placeholder: t, options: E, className: o = "es-180w" }) {
79
76
  return `
80
- <${t.SELECTPICKER}
77
+ <${n.SELECTPICKER}
81
78
  class="${o}"
82
79
  ${$.SELECTPICKER.name}="${e}"
83
- ${$.SELECTPICKER.placeholder}="${n}">
84
- ${E.map((T) => this._GuSelectItem(T)).join("")}
85
- </${t.SELECTPICKER}>
80
+ ${$.SELECTPICKER.placeholder}="${t}">
81
+ ${E.map((a) => this._GuSelectItem(a)).join("")}
82
+ </${n.SELECTPICKER}>
86
83
  `;
87
84
  }
88
- _GuTextInput({ name: e, placeholder: n, className: E = "", disabled: o = !1 }) {
85
+ _GuTextInput({ name: e, placeholder: t, className: E = "", disabled: o = !1 }) {
89
86
  return `
90
- <${t.TEXT}
87
+ <${n.TEXT}
91
88
  class=${E}
92
89
  ${$.TEXT.name}="${e}"
93
- placeholder="${n || e}"
90
+ placeholder="${t || e}"
94
91
  ${o ? `${$.TEXT.disabled}="true"` : ""}>
95
- </${t.TEXT}>
92
+ </${n.TEXT}>
96
93
  `;
97
94
  }
98
- _GuCounter({ name: e, maxValue: n, minValue: E = 1, step: o = 1 }) {
95
+ _GuCounter({ name: e, maxValue: t, minValue: E = 1, step: o = 1 }) {
99
96
  return `
100
- <${t.COUNTER}
97
+ <${n.COUNTER}
101
98
  ${$.COUNTER.name}="${e}"
102
99
  ${$.COUNTER.minValue}="${E}"
103
- ${$.COUNTER.maxValue}="${n}"
100
+ ${$.COUNTER.maxValue}="${t}"
104
101
  ${$.COUNTER.step}="${o}">
105
- </${t.COUNTER}>
102
+ </${n.COUNTER}>
106
103
  `;
107
104
  }
108
- _GuRadioButtonItem({ text: e, value: n, icon: E }) {
105
+ _GuRadioButtonItem({ text: e, value: t, icon: E }) {
109
106
  return `
110
- <${t.RADIO_ITEM}
111
- ${$.RADIO_ITEM.value}="${n}"
107
+ <${n.RADIO_ITEM}
108
+ ${$.RADIO_ITEM.value}="${t}"
112
109
  ${e ? `${$.RADIO_ITEM.text}="${e}"` : ""}
113
110
  ${E ? `${$.RADIO_ITEM.icon}="${E}"` : ""}>
114
- </${t.RADIO_ITEM}>
111
+ </${n.RADIO_ITEM}>
115
112
  `;
116
113
  }
117
- _GuRadioButton({ name: e, buttons: n, id: E = "" }) {
114
+ _GuRadioButton({ name: e, buttons: t, id: E = "" }) {
118
115
  return `
119
- <${t.RADIO_BUTTONS}
116
+ <${n.RADIO_BUTTONS}
120
117
  ${E ? `id="${E}"` : ""}
121
118
  ${$.RADIO_BUTTONS.name}="${e}">
122
- ${n.map((o) => this._GuRadioButtonItem(o)).join("")}
123
- </${t.RADIO_BUTTONS}>
119
+ ${t.map((o) => this._GuRadioButtonItem(o)).join("")}
120
+ </${n.RADIO_BUTTONS}>
124
121
  `;
125
122
  }
126
- _GuButton({ name: e, label: n, id: E = "" }) {
123
+ _GuButton({ name: e, label: t, id: E = "" }) {
127
124
  return `
128
- <${t.BUTTON}
125
+ <${n.BUTTON}
129
126
  ${$.BUTTON.name}="${e}"
130
127
  ${E ? `id="${E}"` : ""}
131
- ${$.BUTTON.caption}="${n}"}>
132
- </${t.BUTTON}>
128
+ ${$.BUTTON.caption}="${t}"}>
129
+ </${n.BUTTON}>
133
130
  `;
134
131
  }
135
132
  /**
@@ -137,25 +134,25 @@ class _ extends O {
137
134
  * @param param0
138
135
  * @returns It returns a button with an icon.
139
136
  */
140
- _GuIconButton({ name: e, icon: n, className: E = "" }) {
137
+ _GuIconButton({ name: e, icon: t, className: E = "" }) {
141
138
  return `
142
- <${t.BUTTON}
139
+ <${n.BUTTON}
143
140
  class="${E}"
144
141
  ${$.BUTTON.name}="${e}"
145
- ${$.BUTTON.icon}="${n}">
146
- </${t.BUTTON}>
142
+ ${$.BUTTON.icon}="${t}">
143
+ </${n.BUTTON}>
147
144
  `;
148
145
  }
149
- _GuOneColumn(e, n = "") {
146
+ _GuOneColumn(e, t = "") {
150
147
  return `
151
- <div class="container one-column ${n}">
148
+ <div class="container one-column ${t}">
152
149
  ${e.join("")}
153
150
  </div>
154
151
  `;
155
152
  }
156
- _GuTwoColumns(e, n = "") {
153
+ _GuTwoColumns(e, t = "") {
157
154
  return `
158
- <div class="container two-columns ${n}">
155
+ <div class="container two-columns ${t}">
159
156
  ${e.join("")}
160
157
  </div>
161
158
  `;
@@ -167,79 +164,79 @@ class _ extends O {
167
164
  * @param itemLabels - Optional array of objects with key and label properties for display
168
165
  * @returns HTML string for the orderable control
169
166
  */
170
- _GuOrderable(e, n) {
167
+ _GuOrderable(e, t) {
171
168
  let E = "";
172
- n.forEach((T) => {
173
- const u = $.ORDERABLE_ITEM && "name" in $.ORDERABLE_ITEM ? $.ORDERABLE_ITEM.name : "name";
169
+ t.forEach((a) => {
170
+ const l = $.ORDERABLE_ITEM && "name" in $.ORDERABLE_ITEM ? $.ORDERABLE_ITEM.name : "name";
174
171
  E += `
175
- <${t.ORDERABLE_ITEM} ${u}="${T.key}">
176
- ${T.content}
177
- </${t.ORDERABLE_ITEM}>
172
+ <${n.ORDERABLE_ITEM} ${l}="${a.key}">
173
+ ${a.content}
174
+ </${n.ORDERABLE_ITEM}>
178
175
  `;
179
176
  });
180
177
  const o = $.ORDERABLE && "name" in $.ORDERABLE ? $.ORDERABLE.name : "name";
181
178
  return `
182
- <${t.ORDERABLE} ${o}="${e}">
179
+ <${n.ORDERABLE} ${o}="${e}">
183
180
  ${E}
184
- </${t.ORDERABLE}>
181
+ </${n.ORDERABLE}>
185
182
  `;
186
183
  }
187
- _GuNestedControl(e, n) {
184
+ _GuNestedControl(e, t) {
188
185
  return `
189
- <${t.NESTED_CONTROL} ${$.NESTED_CONTROL.controlId}="${e}">
190
- ${n}
191
- </${t.NESTED_CONTROL}>
186
+ <${n.NESTED_CONTROL} ${$.NESTED_CONTROL.controlId}="${e}">
187
+ ${t}
188
+ </${n.NESTED_CONTROL}>
192
189
  `;
193
190
  }
194
- _GuExpandable(e, n) {
191
+ _GuExpandable(e, t) {
195
192
  return `
196
- <${t.EXPANDABLE}>
197
- <${t.EXPANDABLE_HEADER}>
198
- <${t.LABEL} ${$.LABEL.text}="${e}"></${t.LABEL}>
199
- </${t.EXPANDABLE_HEADER}>
200
- <${t.EXPANDABLE_CONTENT}>
193
+ <${n.EXPANDABLE}>
194
+ <${n.EXPANDABLE_HEADER}>
195
+ <${n.LABEL} ${$.LABEL.text}="${e}"></${n.LABEL}>
196
+ </${n.EXPANDABLE_HEADER}>
197
+ <${n.EXPANDABLE_CONTENT}>
201
198
 
202
- ${n}
199
+ ${t}
203
200
 
204
- </${t.EXPANDABLE_CONTENT}>
205
- </${t.EXPANDABLE}>
201
+ </${n.EXPANDABLE_CONTENT}>
202
+ </${n.EXPANDABLE}>
206
203
  `;
207
204
  }
208
205
  _GuColorPicker(e) {
209
206
  return `
210
- <${t.COLOR}
207
+ <${n.COLOR}
211
208
  ${$.COLOR.name}="${e}">
212
- </${t.COLOR}>
209
+ </${n.COLOR}>
213
210
  `;
214
211
  }
215
- _GuFontFamily(e, n = "Select Font") {
212
+ _GuFontFamily(e, t = "Select Font") {
216
213
  return `
217
- <${t.FONT_FAMILY_SELECT}
214
+ <${n.FONT_FAMILY_SELECT}
218
215
  ${$.FONT_FAMILY_SELECT.name}="${e}"
219
- ${$.FONT_FAMILY_SELECT.placeholder}="${n}">
220
- </${t.FONT_FAMILY_SELECT}>
216
+ ${$.FONT_FAMILY_SELECT.placeholder}="${t}">
217
+ </${n.FONT_FAMILY_SELECT}>
221
218
  `;
222
219
  }
223
- _GuRadioButtons(e, n) {
224
- const E = n.map((o) => `
225
- <${t.RADIO_ITEM}
220
+ _GuRadioButtons(e, t) {
221
+ const E = t.map((o) => `
222
+ <${n.RADIO_ITEM}
226
223
  ${$.RADIO_ITEM.text}="${o.text}"
227
224
  ${$.RADIO_ITEM.value}="${o.value}">
228
- </${t.RADIO_ITEM}>
225
+ </${n.RADIO_ITEM}>
229
226
  `).join("");
230
227
  return `
231
- <${t.RADIO_BUTTONS}
228
+ <${n.RADIO_BUTTONS}
232
229
  ${$.RADIO_BUTTONS.name}="${e}">
233
230
  ${E}
234
- </${t.RADIO_BUTTONS}>
231
+ </${n.RADIO_BUTTONS}>
235
232
  `;
236
233
  }
237
- _GuCheckbox(e, n) {
234
+ _GuCheckbox(e, t) {
238
235
  return `
239
- <${t.CHECKBOX}
236
+ <${n.CHECKBOX}
240
237
  ${$.CHECKBOX.name}="${e}"
241
- ${$.CHECKBOX.caption}="${n}">
242
- </${t.CHECKBOX}>
238
+ ${$.CHECKBOX.caption}="${t}">
239
+ </${n.CHECKBOX}>
243
240
  `;
244
241
  }
245
242
  }