@useinsider/guido 2.0.0-beta.cf2fe38 → 2.0.0-beta.d170da6

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 (103) hide show
  1. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +153 -69
  2. package/dist/extensions/Blocks/Recommendation/constants.js +9 -1
  3. package/dist/extensions/Blocks/Recommendation/control.js +74 -59
  4. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  5. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  6. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  7. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  8. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  9. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  10. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  11. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  12. package/dist/extensions/Blocks/Recommendation/extension.js +16 -42
  13. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -72
  14. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +85 -64
  15. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +54 -17
  16. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  17. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  18. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +47 -52
  19. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +50 -3
  20. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +32 -0
  21. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  22. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  23. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +592 -0
  24. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  25. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  26. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  27. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  28. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  29. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  30. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  31. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  32. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  33. package/dist/static/styles/components/wide-panel.css.js +0 -4
  34. package/dist/static/styles/customEditorStyle.css.js +13 -0
  35. package/package.json +1 -1
  36. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  37. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  38. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  39. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  40. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  41. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  42. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  43. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  44. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  45. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  46. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  47. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  48. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  49. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  50. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  51. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  52. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  53. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  54. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  55. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  56. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  57. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  58. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  59. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  60. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  61. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  62. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  63. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  64. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  65. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  66. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  67. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  68. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  69. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  70. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  71. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  72. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  73. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  74. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  75. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  76. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  77. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  78. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  79. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  80. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  81. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  82. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  83. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  84. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  85. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  86. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  87. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  88. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  89. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  90. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  91. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  92. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  93. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  94. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  95. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  96. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  97. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  98. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  99. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  100. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  101. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  102. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  103. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
@@ -0,0 +1,245 @@
1
+ import { createButtonAlignControl as c, createButtonBorderControl as _, createButtonBorderRadiusControl as T, createButtonColorControl as i, createButtonFitToContainerControl as B, createButtonFontFamilyControl as s, createButtonMarginsControl as S, createButtonPaddingsControl as E, createButtonTextControl as P, createButtonTextSizeControl as U, createButtonTextStyleAndFontColorControl as R, createImageMarginsControl as a, createImageSizeControl as M, createTextAlignControl as C, createTextBackgroundColorControl as r, createTextColorControl as O, createTextFontFamilyControl as I, createPaddingsControl as e, createTextSizeControl as N, createTextStyleControl as l } from "../../controlFactories.js";
2
+ import { RecommendationBlockId as o, RecommendationControlId as t } from "../constants.js";
3
+ const n = ".ins-recommendation-product-container", u = C(
4
+ t.NAME_ALIGN,
5
+ o.NAME,
6
+ n
7
+ ), d = O(
8
+ t.NAME_COLOR,
9
+ o.NAME,
10
+ n
11
+ ), m = N(
12
+ t.NAME_SIZE,
13
+ o.NAME,
14
+ n
15
+ ), L = l(
16
+ t.NAME_STYLE,
17
+ o.NAME,
18
+ n
19
+ ), F = I(
20
+ t.NAME_FONT_FAMILY,
21
+ o.NAME,
22
+ n
23
+ ), g = r(
24
+ t.NAME_BACKGROUND,
25
+ o.NAME,
26
+ n
27
+ ), G = e(
28
+ t.NAME_PADDINGS,
29
+ o.NAME,
30
+ n
31
+ ), y = C(
32
+ t.PRICE_ALIGN,
33
+ o.PRICE,
34
+ n
35
+ ), b = O(
36
+ t.PRICE_COLOR,
37
+ o.PRICE,
38
+ n
39
+ ), x = N(
40
+ t.PRICE_SIZE,
41
+ o.PRICE,
42
+ n
43
+ ), Y = l(
44
+ t.PRICE_STYLE,
45
+ o.PRICE,
46
+ n
47
+ ), z = I(
48
+ t.PRICE_FONT_FAMILY,
49
+ o.PRICE,
50
+ n
51
+ ), k = r(
52
+ t.PRICE_BACKGROUND,
53
+ o.PRICE,
54
+ n
55
+ ), Z = e(
56
+ t.PRICE_PADDINGS,
57
+ o.PRICE,
58
+ n
59
+ ), K = C(
60
+ t.OLD_PRICE_ALIGN,
61
+ o.OLD_PRICE,
62
+ n
63
+ ), p = O(
64
+ t.OLD_PRICE_COLOR,
65
+ o.OLD_PRICE,
66
+ n
67
+ ), X = N(
68
+ t.OLD_PRICE_SIZE,
69
+ o.OLD_PRICE,
70
+ n
71
+ ), f = l(
72
+ t.OLD_PRICE_STYLE,
73
+ o.OLD_PRICE,
74
+ n
75
+ ), h = I(
76
+ t.OLD_PRICE_FONT_FAMILY,
77
+ o.OLD_PRICE,
78
+ n
79
+ ), j = r(
80
+ t.OLD_PRICE_BACKGROUND,
81
+ o.OLD_PRICE,
82
+ n
83
+ ), q = e(
84
+ t.OLD_PRICE_PADDINGS,
85
+ o.OLD_PRICE,
86
+ n
87
+ ), v = C(
88
+ t.OMNIBUS_PRICE_ALIGN,
89
+ o.OMNIBUS_PRICE,
90
+ n
91
+ ), w = O(
92
+ t.OMNIBUS_PRICE_COLOR,
93
+ o.OMNIBUS_PRICE,
94
+ n
95
+ ), H = N(
96
+ t.OMNIBUS_PRICE_SIZE,
97
+ o.OMNIBUS_PRICE,
98
+ n
99
+ ), J = l(
100
+ t.OMNIBUS_PRICE_STYLE,
101
+ o.OMNIBUS_PRICE,
102
+ n
103
+ ), Q = I(
104
+ t.OMNIBUS_PRICE_FONT_FAMILY,
105
+ o.OMNIBUS_PRICE,
106
+ n
107
+ ), V = r(
108
+ t.OMNIBUS_PRICE_BACKGROUND,
109
+ o.OMNIBUS_PRICE,
110
+ n
111
+ ), W = e(
112
+ t.OMNIBUS_PRICE_PADDINGS,
113
+ o.OMNIBUS_PRICE,
114
+ n
115
+ ), $ = C(
116
+ t.OMNIBUS_DISCOUNT_ALIGN,
117
+ o.OMNIBUS_DISCOUNT,
118
+ n
119
+ ), oo = O(
120
+ t.OMNIBUS_DISCOUNT_COLOR,
121
+ o.OMNIBUS_DISCOUNT,
122
+ n
123
+ ), to = N(
124
+ t.OMNIBUS_DISCOUNT_SIZE,
125
+ o.OMNIBUS_DISCOUNT,
126
+ n
127
+ ), no = l(
128
+ t.OMNIBUS_DISCOUNT_STYLE,
129
+ o.OMNIBUS_DISCOUNT,
130
+ n
131
+ ), Co = I(
132
+ t.OMNIBUS_DISCOUNT_FONT_FAMILY,
133
+ o.OMNIBUS_DISCOUNT,
134
+ n
135
+ ), ro = r(
136
+ t.OMNIBUS_DISCOUNT_BACKGROUND,
137
+ o.OMNIBUS_DISCOUNT,
138
+ n
139
+ ), Oo = e(
140
+ t.OMNIBUS_DISCOUNT_PADDINGS,
141
+ o.OMNIBUS_DISCOUNT,
142
+ n
143
+ ), Io = c(
144
+ t.BUTTON_ALIGN,
145
+ o.BUTTON,
146
+ n
147
+ ), eo = _(
148
+ t.BUTTON_BORDER,
149
+ o.BUTTON,
150
+ n
151
+ ), No = T(
152
+ t.BUTTON_BORDER_RADIUS,
153
+ o.BUTTON,
154
+ n
155
+ ), lo = i(
156
+ t.BUTTON_COLOR,
157
+ o.BUTTON,
158
+ n
159
+ ), co = s(
160
+ t.BUTTON_FONT_FAMILY,
161
+ o.BUTTON,
162
+ n
163
+ ), _o = S(
164
+ t.BUTTON_MARGINS,
165
+ o.BUTTON,
166
+ n
167
+ ), To = E(
168
+ t.BUTTON_PADDINGS,
169
+ o.BUTTON,
170
+ n
171
+ ), io = P(
172
+ t.BUTTON_TEXT,
173
+ o.BUTTON,
174
+ n
175
+ ), Bo = U(
176
+ t.BUTTON_TEXT_SIZE,
177
+ o.BUTTON,
178
+ n
179
+ ), so = R(
180
+ t.BUTTON_TEXT_STYLE_AND_FONT_COLOR,
181
+ o.BUTTON,
182
+ n
183
+ ), So = B(
184
+ t.BUTTON_FIT_TO_CONTENT,
185
+ o.BUTTON,
186
+ n
187
+ ), Eo = M(
188
+ t.IMAGE_SIZE,
189
+ o.IMAGE,
190
+ n
191
+ ), Po = a(
192
+ t.IMAGE_MARGINS,
193
+ o.IMAGE,
194
+ n
195
+ );
196
+ export {
197
+ Io as ButtonAlignControl,
198
+ eo as ButtonBorderControl,
199
+ No as ButtonBorderRadiusControl,
200
+ lo as ButtonColorControl,
201
+ So as ButtonFitToContentControl,
202
+ co as ButtonFontFamilyControl,
203
+ _o as ButtonMarginsControl,
204
+ To as ButtonPaddingsControl,
205
+ io as ButtonTextControl,
206
+ Bo as ButtonTextSizeControl,
207
+ so as ButtonTextStyleAndFontColorControl,
208
+ Po as ImageMarginsControl,
209
+ Eo as ImageSizeControl,
210
+ u as NameAlignControl,
211
+ g as NameBackgroundControl,
212
+ d as NameColorControl,
213
+ F as NameFontFamilyControl,
214
+ G as NamePaddingsControl,
215
+ m as NameSizeControl,
216
+ L as NameStyleControl,
217
+ K as OldPriceAlignControl,
218
+ j as OldPriceBackgroundControl,
219
+ p as OldPriceColorControl,
220
+ h as OldPriceFontFamilyControl,
221
+ q as OldPricePaddingsControl,
222
+ X as OldPriceSizeControl,
223
+ f as OldPriceStyleControl,
224
+ $ as OmnibusDiscountAlignControl,
225
+ ro as OmnibusDiscountBackgroundControl,
226
+ oo as OmnibusDiscountColorControl,
227
+ Co as OmnibusDiscountFontFamilyControl,
228
+ Oo as OmnibusDiscountPaddingsControl,
229
+ to as OmnibusDiscountSizeControl,
230
+ no as OmnibusDiscountStyleControl,
231
+ v as OmnibusPriceAlignControl,
232
+ V as OmnibusPriceBackgroundControl,
233
+ w as OmnibusPriceColorControl,
234
+ Q as OmnibusPriceFontFamilyControl,
235
+ W as OmnibusPricePaddingsControl,
236
+ H as OmnibusPriceSizeControl,
237
+ J as OmnibusPriceStyleControl,
238
+ y as PriceAlignControl,
239
+ k as PriceBackgroundControl,
240
+ b as PriceColorControl,
241
+ z as PriceFontFamilyControl,
242
+ Z as PricePaddingsControl,
243
+ x as PriceSizeControl,
244
+ Y as PriceStyleControl
245
+ };
@@ -0,0 +1,74 @@
1
+ import { ModificationDescription as m } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as c } from "../../common-control.js";
3
+ import { RecommendationControlId as d, RecommendationBlockId as a } from "../constants.js";
4
+ const n = {
5
+ TEXT_TRIM_ENABLED: "textTrimEnabled"
6
+ }, r = "text-trim-enabled", l = ".ins-recommendation-product-container";
7
+ class E extends c {
8
+ getId() {
9
+ return d.NAME_TEXT_TRIM;
10
+ }
11
+ getTemplate() {
12
+ return `
13
+ <div class="name-text-trim-control-container">
14
+ ${this._GuTwoColumns([
15
+ this._GuLabel({ text: "Trim Long Text" }),
16
+ this._GuToggle(n.TEXT_TRIM_ENABLED)
17
+ ])}
18
+ </div>
19
+ `;
20
+ }
21
+ onRender() {
22
+ this._setFormValues(), this._listenToFormUpdates();
23
+ }
24
+ onTemplateNodeUpdated(e) {
25
+ super.onTemplateNodeUpdated(e), this._setFormValues();
26
+ }
27
+ _setFormValues() {
28
+ const e = this._getCurrentTrimState();
29
+ this.api.updateValues({
30
+ [n.TEXT_TRIM_ENABLED]: e
31
+ });
32
+ }
33
+ _getCurrentTrimState() {
34
+ if (!this.currentNode || !("hasClass" in this.currentNode))
35
+ return !1;
36
+ if (this.currentNode.hasClass(r))
37
+ return !0;
38
+ const e = this.currentNode.closest(l);
39
+ if (!e)
40
+ return !1;
41
+ const t = e.querySelector(
42
+ `[esd-extension-block-id="${a.NAME}"]`
43
+ );
44
+ return t && "hasClass" in t ? t.hasClass(r) : !1;
45
+ }
46
+ _onTextTrimChange(e) {
47
+ if (!this.currentNode || !("closest" in this.currentNode))
48
+ return;
49
+ const t = this.currentNode.closest(l);
50
+ if (!t || !("querySelectorAll" in t))
51
+ return;
52
+ const s = Array.from(
53
+ t.querySelectorAll(`[esd-extension-block-id="${a.NAME}"]`)
54
+ );
55
+ if (!s.length)
56
+ return;
57
+ const o = this.api.getDocumentModifier();
58
+ s.forEach((i) => {
59
+ e ? o.modifyHtml(i).setClass(r) : o.modifyHtml(i).removeClass(r);
60
+ }), o.apply(
61
+ new m(
62
+ e ? "Enable product name text trimming" : "Disable product name text trimming"
63
+ )
64
+ );
65
+ }
66
+ _listenToFormUpdates() {
67
+ this.api.onValueChanged(n.TEXT_TRIM_ENABLED, (e) => {
68
+ this._onTextTrimChange(e);
69
+ });
70
+ }
71
+ }
72
+ export {
73
+ E as NameTextTrimControl
74
+ };
@@ -0,0 +1,71 @@
1
+ import { ModificationDescription as a } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as m } from "../../common-control.js";
3
+ import { RecommendationControlId as l, RecommendationBlockId as d } from "../constants.js";
4
+ import { preserveTextStyles as T } from "../utils/preserveTextStyles.js";
5
+ const f = ".ins-recommendation-product-container", i = "data-text-after", u = "", p = ".omnibus-text-after";
6
+ class E extends m {
7
+ getId() {
8
+ return l.OMNIBUS_DISCOUNT_TEXT_AFTER;
9
+ }
10
+ getTemplate() {
11
+ return `
12
+ <div class="omnibus-discount-text-after-control-container">
13
+ ${this._GuTwoColumns([
14
+ this._GuLabel({ text: "Text After" }),
15
+ this._GuTextInput({
16
+ name: "omnibusDiscountTextAfter",
17
+ placeholder: "e.g., off!",
18
+ className: "es-180w"
19
+ })
20
+ ])}
21
+ </div>
22
+ `;
23
+ }
24
+ onRender() {
25
+ this._setFormValues(), this._listenToFormUpdates();
26
+ }
27
+ onTemplateNodeUpdated(t) {
28
+ super.onTemplateNodeUpdated(t), this._setFormValues();
29
+ }
30
+ _setFormValues() {
31
+ const t = this._getCurrentText();
32
+ this.api.updateValues({
33
+ omnibusDiscountTextAfter: t
34
+ });
35
+ }
36
+ _getCurrentText() {
37
+ if (!this.currentNode || !("getAttribute" in this.currentNode))
38
+ return u;
39
+ const t = this.currentNode.getAttribute(i);
40
+ return t === null ? u : t;
41
+ }
42
+ _onTextChange(t) {
43
+ if (!this.currentNode || !("closest" in this.currentNode))
44
+ return;
45
+ const e = this.currentNode.closest(f);
46
+ if (!e || !("querySelectorAll" in e))
47
+ return;
48
+ const n = Array.from(
49
+ e.querySelectorAll(`[esd-extension-block-id="${d.OMNIBUS_DISCOUNT}"]`)
50
+ );
51
+ if (!n.length)
52
+ return;
53
+ const o = this.api.getDocumentModifier();
54
+ n.forEach((s) => {
55
+ o.modifyHtml(s).setAttribute(i, t);
56
+ const r = s.querySelector(p);
57
+ if (r) {
58
+ const c = T(r, t);
59
+ o.modifyHtml(r).setInnerHtml(c);
60
+ }
61
+ }), o.apply(new a("Update omnibus discount text after"));
62
+ }
63
+ _listenToFormUpdates() {
64
+ this.api.onValueChanged("omnibusDiscountTextAfter", (t) => {
65
+ this._onTextChange(t);
66
+ });
67
+ }
68
+ }
69
+ export {
70
+ E as OmnibusDiscountTextAfterControl
71
+ };
@@ -0,0 +1,71 @@
1
+ import { ModificationDescription as m } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as a } from "../../common-control.js";
3
+ import { RecommendationControlId as l, RecommendationBlockId as d } from "../constants.js";
4
+ import { preserveTextStyles as T } from "../utils/preserveTextStyles.js";
5
+ const f = ".ins-recommendation-product-container", i = "data-text-before", u = "", p = ".omnibus-text-before";
6
+ class C extends a {
7
+ getId() {
8
+ return l.OMNIBUS_DISCOUNT_TEXT_BEFORE;
9
+ }
10
+ getTemplate() {
11
+ return `
12
+ <div class="omnibus-discount-text-before-control-container">
13
+ ${this._GuTwoColumns([
14
+ this._GuLabel({ text: "Text Before" }),
15
+ this._GuTextInput({
16
+ name: "omnibusDiscountTextBefore",
17
+ placeholder: "e.g., Save ",
18
+ className: "es-180w"
19
+ })
20
+ ])}
21
+ </div>
22
+ `;
23
+ }
24
+ onRender() {
25
+ this._setFormValues(), this._listenToFormUpdates();
26
+ }
27
+ onTemplateNodeUpdated(e) {
28
+ super.onTemplateNodeUpdated(e), this._setFormValues();
29
+ }
30
+ _setFormValues() {
31
+ const e = this._getCurrentText();
32
+ this.api.updateValues({
33
+ omnibusDiscountTextBefore: e
34
+ });
35
+ }
36
+ _getCurrentText() {
37
+ if (!this.currentNode || !("getAttribute" in this.currentNode))
38
+ return u;
39
+ const e = this.currentNode.getAttribute(i);
40
+ return e === null ? u : e;
41
+ }
42
+ _onTextChange(e) {
43
+ if (!this.currentNode || !("closest" in this.currentNode))
44
+ return;
45
+ const t = this.currentNode.closest(f);
46
+ if (!t || !("querySelectorAll" in t))
47
+ return;
48
+ const n = Array.from(
49
+ t.querySelectorAll(`[esd-extension-block-id="${d.OMNIBUS_DISCOUNT}"]`)
50
+ );
51
+ if (!n.length)
52
+ return;
53
+ const o = this.api.getDocumentModifier();
54
+ n.forEach((s) => {
55
+ o.modifyHtml(s).setAttribute(i, e);
56
+ const r = s.querySelector(p);
57
+ if (r) {
58
+ const c = T(r, e);
59
+ o.modifyHtml(r).setInnerHtml(c);
60
+ }
61
+ }), o.apply(new m("Update omnibus discount text before"));
62
+ }
63
+ _listenToFormUpdates() {
64
+ this.api.onValueChanged("omnibusDiscountTextBefore", (e) => {
65
+ this._onTextChange(e);
66
+ });
67
+ }
68
+ }
69
+ export {
70
+ C as OmnibusDiscountTextBeforeControl
71
+ };
@@ -0,0 +1,71 @@
1
+ import { ModificationDescription as a } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as m } from "../../common-control.js";
3
+ import { RecommendationControlId as l, RecommendationBlockId as d } from "../constants.js";
4
+ import { preserveTextStyles as T } from "../utils/preserveTextStyles.js";
5
+ const f = ".ins-recommendation-product-container", s = "data-text-after", c = "", p = ".omnibus-text-after";
6
+ class C extends m {
7
+ getId() {
8
+ return l.OMNIBUS_PRICE_TEXT_AFTER;
9
+ }
10
+ getTemplate() {
11
+ return `
12
+ <div class="omnibus-price-text-after-control-container">
13
+ ${this._GuTwoColumns([
14
+ this._GuLabel({ text: "Text After" }),
15
+ this._GuTextInput({
16
+ name: "omnibusPriceTextAfter",
17
+ placeholder: "e.g., (incl. VAT)",
18
+ className: "es-180w"
19
+ })
20
+ ])}
21
+ </div>
22
+ `;
23
+ }
24
+ onRender() {
25
+ this._setFormValues(), this._listenToFormUpdates();
26
+ }
27
+ onTemplateNodeUpdated(t) {
28
+ super.onTemplateNodeUpdated(t), this._setFormValues();
29
+ }
30
+ _setFormValues() {
31
+ const t = this._getCurrentText();
32
+ this.api.updateValues({
33
+ omnibusPriceTextAfter: t
34
+ });
35
+ }
36
+ _getCurrentText() {
37
+ if (!this.currentNode || !("getAttribute" in this.currentNode))
38
+ return c;
39
+ const t = this.currentNode.getAttribute(s);
40
+ return t === null ? c : t;
41
+ }
42
+ _onTextChange(t) {
43
+ if (!this.currentNode || !("closest" in this.currentNode))
44
+ return;
45
+ const e = this.currentNode.closest(f);
46
+ if (!e || !("querySelectorAll" in e))
47
+ return;
48
+ const n = Array.from(
49
+ e.querySelectorAll(`[esd-extension-block-id="${d.OMNIBUS_PRICE}"]`)
50
+ );
51
+ if (!n.length)
52
+ return;
53
+ const r = this.api.getDocumentModifier();
54
+ n.forEach((i) => {
55
+ r.modifyHtml(i).setAttribute(s, t);
56
+ const o = i.querySelector(p);
57
+ if (o) {
58
+ const u = T(o, t);
59
+ r.modifyHtml(o).setInnerHtml(u);
60
+ }
61
+ }), r.apply(new a("Update omnibus price text after"));
62
+ }
63
+ _listenToFormUpdates() {
64
+ this.api.onValueChanged("omnibusPriceTextAfter", (t) => {
65
+ this._onTextChange(t);
66
+ });
67
+ }
68
+ }
69
+ export {
70
+ C as OmnibusPriceTextAfterControl
71
+ };
@@ -0,0 +1,71 @@
1
+ import { ModificationDescription as m } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as a } from "../../common-control.js";
3
+ import { RecommendationControlId as l, RecommendationBlockId as d } from "../constants.js";
4
+ import { preserveTextStyles as T } from "../utils/preserveTextStyles.js";
5
+ const p = ".ins-recommendation-product-container", s = "data-text-before", c = "Lowest 30-day price: ", f = ".omnibus-text-before";
6
+ class C extends a {
7
+ getId() {
8
+ return l.OMNIBUS_PRICE_TEXT_BEFORE;
9
+ }
10
+ getTemplate() {
11
+ return `
12
+ <div class="omnibus-price-text-before-control-container">
13
+ ${this._GuTwoColumns([
14
+ this._GuLabel({ text: "Text Before" }),
15
+ this._GuTextInput({
16
+ name: "omnibusPriceTextBefore",
17
+ placeholder: "e.g., Lowest 30-day price: ",
18
+ className: "es-180w"
19
+ })
20
+ ])}
21
+ </div>
22
+ `;
23
+ }
24
+ onRender() {
25
+ this._setFormValues(), this._listenToFormUpdates();
26
+ }
27
+ onTemplateNodeUpdated(e) {
28
+ super.onTemplateNodeUpdated(e), this._setFormValues();
29
+ }
30
+ _setFormValues() {
31
+ const e = this._getCurrentText();
32
+ this.api.updateValues({
33
+ omnibusPriceTextBefore: e
34
+ });
35
+ }
36
+ _getCurrentText() {
37
+ if (!this.currentNode || !("getAttribute" in this.currentNode))
38
+ return c;
39
+ const e = this.currentNode.getAttribute(s);
40
+ return e === null ? c : e;
41
+ }
42
+ _onTextChange(e) {
43
+ if (!this.currentNode || !("closest" in this.currentNode))
44
+ return;
45
+ const t = this.currentNode.closest(p);
46
+ if (!t || !("querySelectorAll" in t))
47
+ return;
48
+ const n = Array.from(
49
+ t.querySelectorAll(`[esd-extension-block-id="${d.OMNIBUS_PRICE}"]`)
50
+ );
51
+ if (!n.length)
52
+ return;
53
+ const o = this.api.getDocumentModifier();
54
+ n.forEach((i) => {
55
+ o.modifyHtml(i).setAttribute(s, e);
56
+ const r = i.querySelector(f);
57
+ if (r) {
58
+ const u = T(r, e);
59
+ o.modifyHtml(r).setInnerHtml(u);
60
+ }
61
+ }), o.apply(new m("Update omnibus price text before"));
62
+ }
63
+ _listenToFormUpdates() {
64
+ this.api.onValueChanged("omnibusPriceTextBefore", (e) => {
65
+ this._onTextChange(e);
66
+ });
67
+ }
68
+ }
69
+ export {
70
+ C as OmnibusPriceTextBeforeControl
71
+ };