@useinsider/guido 1.0.2-beta.4e8474b → 1.0.2-beta.585f2fc

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 (132) hide show
  1. package/README.md +1 -1
  2. package/dist/components/Guido.vue.js +8 -8
  3. package/dist/components/Guido.vue2.js +36 -35
  4. package/dist/composables/useHtmlValidator.d.ts +2 -1
  5. package/dist/composables/useHtmlValidator.js +122 -94
  6. package/dist/composables/useSave.js +6 -6
  7. package/dist/composables/useStripo.js +32 -26
  8. package/dist/config/migrator/checkboxMigrator.d.ts +1 -0
  9. package/dist/config/migrator/checkboxMigrator.js +83 -0
  10. package/dist/config/migrator/index.d.ts +1 -0
  11. package/dist/config/migrator/index.js +9 -0
  12. package/dist/config/migrator/radioButtonMigrator.d.ts +1 -0
  13. package/dist/config/migrator/radioButtonMigrator.js +86 -0
  14. package/dist/extensions/Blocks/Checkbox/block.d.ts +10 -0
  15. package/dist/extensions/Blocks/Checkbox/block.js +39 -0
  16. package/dist/extensions/Blocks/Checkbox/control.d.ts +22 -0
  17. package/dist/extensions/Blocks/Checkbox/control.js +104 -0
  18. package/dist/extensions/Blocks/Checkbox/extension.d.ts +2 -0
  19. package/dist/extensions/Blocks/Checkbox/extension.js +20 -0
  20. package/dist/extensions/Blocks/Checkbox/settingsPanel.d.ts +4 -0
  21. package/dist/extensions/Blocks/Checkbox/settingsPanel.js +38 -0
  22. package/dist/extensions/Blocks/Checkbox/template.d.ts +6 -0
  23. package/dist/extensions/Blocks/Checkbox/template.js +75 -0
  24. package/dist/extensions/Blocks/RadioButton/block.d.ts +10 -0
  25. package/dist/extensions/Blocks/RadioButton/block.js +39 -0
  26. package/dist/extensions/Blocks/RadioButton/control.d.ts +17 -0
  27. package/dist/extensions/Blocks/RadioButton/control.js +104 -0
  28. package/dist/extensions/Blocks/RadioButton/extension.d.ts +2 -0
  29. package/dist/extensions/Blocks/RadioButton/extension.js +20 -0
  30. package/dist/extensions/Blocks/RadioButton/settingsPanel.d.ts +4 -0
  31. package/dist/extensions/Blocks/RadioButton/settingsPanel.js +39 -0
  32. package/dist/extensions/Blocks/RadioButton/template.d.ts +6 -0
  33. package/dist/extensions/Blocks/RadioButton/template.js +160 -0
  34. package/dist/extensions/Blocks/_Boilerplate/block.d.ts +10 -0
  35. package/dist/extensions/Blocks/_Boilerplate/control.d.ts +17 -0
  36. package/dist/extensions/Blocks/_Boilerplate/extension.d.ts +2 -0
  37. package/dist/extensions/Blocks/_Boilerplate/settingsPanel.d.ts +4 -0
  38. package/dist/extensions/Blocks/_Boilerplate/template.d.ts +6 -0
  39. package/dist/extensions/DynamicContent/dynamic-content.js +41 -27
  40. package/dist/extensions/DynamicContent/extension.js +18 -6
  41. package/dist/guido.css +1 -1
  42. package/dist/mock/api/unsubscribe.d.ts +2 -0
  43. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/Extension.js +72 -48
  44. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ExtensionBuilder.js +74 -49
  45. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/Block.js +120 -38
  46. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js +5 -11
  47. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js +5 -11
  48. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js +12 -0
  49. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js +5 -11
  50. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js +116 -101
  51. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js +5 -11
  52. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js +5 -11
  53. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js +5 -11
  54. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js +12 -0
  55. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js +5 -11
  56. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js +5 -11
  57. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js +5 -11
  58. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementsAttributes.js +22 -43
  59. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/Control.js +21 -17
  60. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelRegistry.js +8 -15
  61. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelTab.js +30 -29
  62. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/modifications/ModificationDescription.js +19 -23
  63. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElement.js +37 -19
  64. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElementTagRegistry.js +2 -15
  65. package/package.json +2 -2
  66. package/dist/_virtual/AddCustomFont.js +0 -4
  67. package/dist/_virtual/AiAssistantValueType.js +0 -4
  68. package/dist/_virtual/BackgroundColorBuiltInControl.js +0 -4
  69. package/dist/_virtual/BackgroundImageBuiltInControl.js +0 -4
  70. package/dist/_virtual/Block.js +0 -4
  71. package/dist/_virtual/BlockAttributes.js +0 -4
  72. package/dist/_virtual/BlockCompositionType.js +0 -4
  73. package/dist/_virtual/BlockPaddingsBuiltInControl.js +0 -4
  74. package/dist/_virtual/BlockRenderer.js +0 -4
  75. package/dist/_virtual/BlockType.js +0 -4
  76. package/dist/_virtual/BlocksPanel.js +0 -4
  77. package/dist/_virtual/BuiltInControl.js +0 -4
  78. package/dist/_virtual/BuiltInControlTypes.js +0 -4
  79. package/dist/_virtual/ButtonBorderBuiltInControl.js +0 -4
  80. package/dist/_virtual/ButtonColorBuiltInControl.js +0 -4
  81. package/dist/_virtual/ButtonFontColorBuiltInControl.js +0 -4
  82. package/dist/_virtual/ButtonInternalIndentsBuiltInControl.js +0 -4
  83. package/dist/_virtual/ButtonTextBuiltInControl.js +0 -4
  84. package/dist/_virtual/ContextAction.js +0 -4
  85. package/dist/_virtual/ContextActionType.js +0 -4
  86. package/dist/_virtual/Control.js +0 -4
  87. package/dist/_virtual/EditorStatePropertyType.js +0 -4
  88. package/dist/_virtual/Extension.js +0 -4
  89. package/dist/_virtual/ExtensionBuilder.js +0 -4
  90. package/dist/_virtual/FontFamilyBuiltInControl.js +0 -4
  91. package/dist/_virtual/LinkColorBuiltInControl.js +0 -4
  92. package/dist/_virtual/ModificationDescription.js +0 -4
  93. package/dist/_virtual/PanelPosition.js +0 -4
  94. package/dist/_virtual/PreviewDeviceMode.js +0 -4
  95. package/dist/_virtual/SettingsPanelRegistry.js +0 -4
  96. package/dist/_virtual/SettingsPanelTab.js +0 -4
  97. package/dist/_virtual/SettingsTab.js +0 -4
  98. package/dist/_virtual/StructureBorderBuiltInControl.js +0 -4
  99. package/dist/_virtual/StructurePaddingsBuiltInControl.js +0 -4
  100. package/dist/_virtual/TextColorBuiltInControl.js +0 -4
  101. package/dist/_virtual/TextLineSpacingBuiltInControl.js +0 -4
  102. package/dist/_virtual/TextSizeBuiltInControl.js +0 -4
  103. package/dist/_virtual/TextStyleBuiltInControl.js +0 -4
  104. package/dist/_virtual/UIElement.js +0 -4
  105. package/dist/_virtual/UIElementTagRegistry.js +0 -4
  106. package/dist/_virtual/UIElementType.js +0 -4
  107. package/dist/_virtual/UIElementsAttributes.js +0 -4
  108. package/dist/_virtual/index.js +0 -5
  109. package/dist/_virtual/index2.js +0 -4
  110. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlockRenderer.js +0 -18
  111. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlocksPanel.js +0 -32
  112. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/ContextAction.js +0 -18
  113. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/AddCustomFont.js +0 -8
  114. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockAttributes.js +0 -34
  115. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundColorBuiltInControl.js +0 -43
  116. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundImageBuiltInControl.js +0 -46
  117. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BlockPaddingsBuiltInControl.js +0 -44
  118. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BuiltInControl.js +0 -22
  119. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonBorderBuiltInControl.js +0 -46
  120. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonColorBuiltInControl.js +0 -46
  121. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonFontColorBuiltInControl.js +0 -45
  122. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonInternalIndentsBuiltInControl.js +0 -45
  123. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonTextBuiltInControl.js +0 -45
  124. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/FontFamilyBuiltInControl.js +0 -43
  125. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/LinkColorBuiltInControl.js +0 -45
  126. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructureBorderBuiltInControl.js +0 -46
  127. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructurePaddingsBuiltInControl.js +0 -44
  128. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextColorBuiltInControl.js +0 -43
  129. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextLineSpacingBuiltInControl.js +0 -43
  130. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextSizeBuiltInControl.js +0 -45
  131. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextStyleBuiltInControl.js +0 -43
  132. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/index.js +0 -266
@@ -0,0 +1,83 @@
1
+ var x = Object.defineProperty;
2
+ var y = (s, t, e) => t in s ? x(s, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : s[t] = e;
3
+ var m = (s, t, e) => y(s, typeof t != "symbol" ? t + "" : t, e);
4
+ import b from "../../extensions/Blocks/Checkbox/template.js";
5
+ class f {
6
+ constructor() {
7
+ m(this, "parser");
8
+ this.parser = new DOMParser();
9
+ }
10
+ migrate(t) {
11
+ try {
12
+ const e = this.parser.parseFromString(t, "text/html"), i = e.querySelectorAll("td.checkbox-block");
13
+ return i.length === 0 ? t : (i.forEach((r) => {
14
+ const n = r.getAttribute("id"), l = this.extractTextFromElement(r, "ins-title"), c = this.extractTextFromElement(r, "ins-description"), a = this.buildTextBlock(l), p = this.buildTextBlock(c), g = b.replace("{-{-TITLE-}-}", a).replace("{-{-DESCRIPTION-}-}", p), o = this.parser.parseFromString(
15
+ `<table id="tempDoc"><tbody><tr>${g}</tr></tbody></table>`,
16
+ "text/html"
17
+ ).querySelector(".checkbox-block-v2");
18
+ o && r.parentNode && (o.setAttribute("id", n || ""), r.parentNode.replaceChild(o, r));
19
+ }), e.documentElement.outerHTML);
20
+ } catch (e) {
21
+ return console.error("CheckboxMigrator failed:", e), t;
22
+ }
23
+ }
24
+ extractTextFromElement(t, e) {
25
+ var o, u;
26
+ const i = t.querySelector(`.${e}`);
27
+ if (!i)
28
+ return {
29
+ text: e === "ins-title" ? "Title" : "Description",
30
+ isBold: !1,
31
+ isItalic: !1,
32
+ align: "left",
33
+ styles: ""
34
+ };
35
+ const r = i.querySelector("p");
36
+ if (!r)
37
+ return {
38
+ text: ((o = i.textContent) == null ? void 0 : o.trim()) || (e === "ins-title" ? "Title" : "Description"),
39
+ isBold: !1,
40
+ isItalic: !1,
41
+ align: i.getAttribute("align") || "left",
42
+ styles: ""
43
+ };
44
+ const n = ((u = r.textContent) == null ? void 0 : u.trim()) || (e === "ins-title" ? "Title" : "Description"), l = r.getAttribute("style") || "", c = i.getAttribute("align") || r.getAttribute("align") || "left", a = /font-weight\s*:\s*bold/i.test(l) || !!r.querySelector("b, strong"), p = /font-style\s*:\s*italic/i.test(l) || !!r.querySelector("i, em"), g = this.removeStyleProperties(l, ["font-weight", "font-style"]), d = this.convertInlineToBlock(g);
45
+ return {
46
+ text: n,
47
+ isBold: a,
48
+ isItalic: p,
49
+ align: c,
50
+ styles: d
51
+ };
52
+ }
53
+ buildTextBlock(t) {
54
+ let e = t.text;
55
+ t.isBold && t.isItalic ? e = `<strong path="1,0"><em path="1,0,0">${e}</em></strong>` : t.isBold ? e = `<strong path="1,0">${e}</strong>` : t.isItalic && (e = `<em path="1,0">${e}</em>`);
56
+ const i = t.align ? ` align="${t.align}"` : "", r = t.styles ? ` style="${t.styles}"` : "";
57
+ return `
58
+ <td class="esd-block-text" ${i}>
59
+ <p path="1" ${r}>
60
+ ${e}
61
+ </p>
62
+ </td>
63
+ `;
64
+ }
65
+ removeStyleProperties(t, e) {
66
+ return t ? e.reduce((r, n) => {
67
+ const l = new RegExp(`${n}\\s*:\\s*[^;]*;?`, "gi");
68
+ return r.replace(l, "");
69
+ }, t).replace(/;\s*;/g, ";").replace(/^;|;$/g, "").trim() : "";
70
+ }
71
+ convertInlineToBlock(t) {
72
+ if (!t)
73
+ return "";
74
+ let e = t.replace(/display\s*:\s*inline/gi, "display: block");
75
+ return /display\s*:/i.test(e) || (e = e ? `${e}; display: block` : "display: block"), e.replace(/;\s*;/g, ";").replace(/^;|;$/g, "").trim();
76
+ }
77
+ }
78
+ function k(s) {
79
+ return new f().migrate(s);
80
+ }
81
+ export {
82
+ k as migrateCheckbox
83
+ };
@@ -0,0 +1 @@
1
+ export declare const migrate: (html: string) => string;
@@ -0,0 +1,9 @@
1
+ import { migrateCheckbox as o } from "./checkboxMigrator.js";
2
+ import { migrateRadioButton as e } from "./radioButtonMigrator.js";
3
+ const a = (r) => {
4
+ let t = r;
5
+ return t = o(r), t = e(r), t;
6
+ };
7
+ export {
8
+ a as migrate
9
+ };
@@ -0,0 +1 @@
1
+ export declare function migrateRadioButton(html: string): string;
@@ -0,0 +1,86 @@
1
+ var b = Object.defineProperty;
2
+ var f = (r, t, e) => t in r ? b(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
3
+ var x = (r, t, e) => f(r, typeof t != "symbol" ? t + "" : t, e);
4
+ import h from "../../extensions/Blocks/RadioButton/template.js";
5
+ class T {
6
+ constructor() {
7
+ x(this, "parser");
8
+ this.parser = new DOMParser();
9
+ }
10
+ migrate(t) {
11
+ try {
12
+ const e = this.parser.parseFromString(t, "text/html"), i = e.querySelectorAll("td.radio-button-block");
13
+ return i.length === 0 ? t : (i.forEach((s) => {
14
+ const o = s.getAttribute("id"), l = this.extractTextFromElement(s, "ins-title"), a = this.extractTextFromElement(s, "ins-description"), p = this.extractTextFromElement(s, "ins-subscribe"), u = this.extractTextFromElement(s, "ins-unsubscribe"), d = this.buildTextBlock(l), g = this.buildTextBlock(a), m = this.buildTextBlock({ ...p, classList: "" }), n = this.buildTextBlock({ ...u, classList: "" }), c = h.replace("{-{-TITLE-}-}", d).replace("{-{-DESCRIPTION-}-}", g).replace("{-{-YES-}-}", m).replace("{-{-NO-}-}", n), y = this.parser.parseFromString(
15
+ `<table id="tempDoc"><tbody><tr>${c}</tr></tbody></table>`,
16
+ "text/html"
17
+ ).querySelector(".radio-button-v2");
18
+ y && s.parentNode && (y.setAttribute("id", o || ""), s.parentNode.replaceChild(y, s));
19
+ }), e.documentElement.outerHTML);
20
+ } catch (e) {
21
+ return console.error("RadioButtonMigrator failed:", e), t;
22
+ }
23
+ }
24
+ extractTextFromElement(t, e) {
25
+ var n, c;
26
+ const i = t.querySelector(`.${e}`);
27
+ if (!i)
28
+ return {
29
+ text: e === "ins-title" ? "Title" : "Description",
30
+ isBold: !1,
31
+ isItalic: !1,
32
+ align: "left",
33
+ styles: "",
34
+ classList: ""
35
+ };
36
+ const s = i.querySelector("p");
37
+ if (!s)
38
+ return {
39
+ text: ((n = i.textContent) == null ? void 0 : n.trim()) || (e === "ins-title" ? "Title" : "Description"),
40
+ isBold: !1,
41
+ isItalic: !1,
42
+ align: i.getAttribute("align") || "left",
43
+ styles: "",
44
+ classList: ""
45
+ };
46
+ const o = ((c = s.textContent) == null ? void 0 : c.trim()) || (e === "ins-title" ? "Title" : "Description"), l = s.getAttribute("style") || "", a = i.getAttribute("align") || s.getAttribute("align") || "left", p = /font-weight\s*:\s*bold/i.test(l) || !!s.querySelector("b, strong"), u = /font-style\s*:\s*italic/i.test(l) || !!s.querySelector("i, em"), d = this.removeStyleProperties(l, ["font-weight", "font-style"]), g = this.convertInlineToBlock(d), m = i.getAttribute("class") || "";
47
+ return {
48
+ text: o,
49
+ isBold: p,
50
+ isItalic: u,
51
+ align: a,
52
+ styles: g,
53
+ classList: m
54
+ };
55
+ }
56
+ buildTextBlock(t) {
57
+ let e = t.text;
58
+ t.isBold && t.isItalic ? e = `<strong path="1,0"><em path="1,0,0">${e}</em></strong>` : t.isBold ? e = `<strong path="1,0">${e}</strong>` : t.isItalic && (e = `<em path="1,0">${e}</em>`);
59
+ const i = t.align ? ` align="${t.align}"` : "", s = t.styles ? ` style="${t.styles.replaceAll('"', "'")}"` : "";
60
+ return `
61
+ <td class="esd-block-text ${t.classList}" ${i}>
62
+ <p path="1" ${s}>
63
+ ${e}
64
+ </p>
65
+ </td>
66
+ `;
67
+ }
68
+ removeStyleProperties(t, e) {
69
+ return t ? e.reduce((s, o) => {
70
+ const l = new RegExp(`${o}\\s*:\\s*[^;]*;?`, "gi");
71
+ return s.replace(l, "");
72
+ }, t).replace(/;\s*;/g, ";").replace(/^;|;$/g, "").trim() : "";
73
+ }
74
+ convertInlineToBlock(t) {
75
+ if (!t)
76
+ return "";
77
+ let e = t.replace(/display\s*:\s*inline/gi, "display: block");
78
+ return /display\s*:/i.test(e) || (e = e ? `${e}; display: block` : "display: block"), e.replace(/;\s*;/g, ";").replace(/^;|;$/g, "").trim();
79
+ }
80
+ }
81
+ function A(r) {
82
+ return new T().migrate(r);
83
+ }
84
+ export {
85
+ A as migrateRadioButton
86
+ };
@@ -0,0 +1,10 @@
1
+ import { Block, BlockCompositionType } from '@stripoinc/ui-editor-extensions';
2
+ export declare const CHECKBOX_BLOCK_ID = "checkbox-block";
3
+ export declare class CheckboxBlock extends Block {
4
+ getId(): string;
5
+ getIcon(): string;
6
+ getBlockCompositionType(): BlockCompositionType;
7
+ getName(): string;
8
+ getDescription(): string;
9
+ getTemplate(): string;
10
+ }
@@ -0,0 +1,39 @@
1
+ import { Block as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/blocks/Block.js";
2
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
3
+ import { BlockCompositionType as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
4
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
5
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
11
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
13
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
14
+ import { getDefaultTemplate as r } from "./template.js";
15
+ const e = "checkbox-block";
16
+ class x extends t {
17
+ getId() {
18
+ return e;
19
+ }
20
+ getIcon() {
21
+ return "check-circle";
22
+ }
23
+ getBlockCompositionType() {
24
+ return o.BLOCK;
25
+ }
26
+ getName() {
27
+ return this.api.translate("Checkbox block");
28
+ }
29
+ getDescription() {
30
+ return this.api.translate("Checkbox block description");
31
+ }
32
+ getTemplate() {
33
+ return r();
34
+ }
35
+ }
36
+ export {
37
+ e as CHECKBOX_BLOCK_ID,
38
+ x as CheckboxBlock
39
+ };
@@ -0,0 +1,22 @@
1
+ import { Control, ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ export declare const CHECKBOX_CONTROL_BLOCK_ID = "ui-elements-checkbox";
3
+ interface UnsubOption {
4
+ name: string;
5
+ sendGridId: string;
6
+ }
7
+ export declare class CheckboxControl extends Control {
8
+ private currentNode?;
9
+ private selectedUnsubGroup?;
10
+ unsubList: UnsubOption[];
11
+ getId(): string;
12
+ _setFormValues(): void;
13
+ _getLabel(text: string, name?: string): string;
14
+ _getSelectItem(text: string, value: string): string;
15
+ _getSelect(): string;
16
+ getTemplate(): string;
17
+ _onSelectChange(value: string | number): void;
18
+ _listenToFormUpdates(): void;
19
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
20
+ onRender(): Promise<void>;
21
+ }
22
+ export {};
@@ -0,0 +1,104 @@
1
+ var E = Object.defineProperty;
2
+ var c = (o, s, t) => s in o ? E(o, s, { enumerable: !0, configurable: !0, writable: !0, value: t }) : o[s] = t;
3
+ var a = (o, s, t) => c(o, typeof s != "symbol" ? s + "" : s, t);
4
+ import { useHttp as p } from "../../../composables/useHttp.js";
5
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
11
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
13
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
14
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
15
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
16
+ import { UEAttr as e } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementsAttributes.js";
17
+ import { UIElementType as r } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
18
+ import { Control as m } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/controls/Control.js";
19
+ import { ModificationDescription as l } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/modifications/ModificationDescription.js";
20
+ const d = "ui-elements-checkbox", n = "select", { get: L } = p();
21
+ class K extends m {
22
+ constructor() {
23
+ super(...arguments);
24
+ a(this, "currentNode");
25
+ a(this, "selectedUnsubGroup");
26
+ a(this, "unsubList", []);
27
+ }
28
+ getId() {
29
+ return d;
30
+ }
31
+ _setFormValues() {
32
+ this.api.updateValues({
33
+ [n]: ""
34
+ });
35
+ }
36
+ _getLabel(t, i = `${Math.random()}`) {
37
+ return `
38
+ <${r.LABEL}
39
+ ${e.LABEL.text}="${t}"
40
+ ${e.LABEL.name}="${i}">
41
+ </${r.LABEL}>
42
+ `;
43
+ }
44
+ _getSelectItem(t, i) {
45
+ return `
46
+ <${r.SELECT_ITEM}
47
+ ${e.SELECT_ITEM.text}="${t}"
48
+ ${e.SELECT_ITEM.value}="${i}">
49
+ </${r.SELECT_ITEM}>`;
50
+ }
51
+ _getSelect() {
52
+ return this.unsubList.map((t) => this._getSelectItem(t.name, t.sendGridId)).join("");
53
+ }
54
+ getTemplate() {
55
+ return `
56
+ <div class="checkbox-controls-container">
57
+ <div class="checkbox-select-container container two-columns stretch">
58
+ <${r.LABEL}
59
+ ${e.LABEL.text}="${this.api.translate("Unsubscribe Group")}"
60
+ ${e.LABEL.name}="${Math.random()}">
61
+ </${r.LABEL}>
62
+
63
+ <${r.SELECTPICKER}
64
+ ${e.SELECTPICKER.name}="${n}"
65
+ ${e.SELECTPICKER.placeholder}="${this.api.translate("Select Unsubscribe Group")}">
66
+ ${this._getSelect()}
67
+ </${r.SELECTPICKER}>
68
+ </div>
69
+ </div>
70
+ `;
71
+ }
72
+ _onSelectChange(t) {
73
+ this.currentNode && this.api.getDocumentModifier().modifyHtml(this.currentNode).setAttribute("id", t.toString()).apply(new l(`Updated text to ${t}`));
74
+ }
75
+ _listenToFormUpdates() {
76
+ this.api.onValueChanged(n, (t) => this._onSelectChange(t));
77
+ }
78
+ onTemplateNodeUpdated(t) {
79
+ if (this.currentNode = t, "getAttribute" in t) {
80
+ const i = Number(t.getAttribute("id"));
81
+ i && (this.selectedUnsubGroup = i, this.api.updateValues({
82
+ [n]: this.selectedUnsubGroup
83
+ }));
84
+ }
85
+ }
86
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
87
+ async onRender() {
88
+ const t = await L(
89
+ "/unsubscribe-groups/unsubscribe-list"
90
+ ), i = t.data.map((u) => ({
91
+ [e.SELECT_ITEM.text]: u.name,
92
+ [e.SELECT_ITEM.value]: u.sendGridId
93
+ }));
94
+ this.unsubList = t.data, this.api.setUIEAttribute(
95
+ n,
96
+ e.SELECTPICKER.items,
97
+ i
98
+ ), this._setFormValues(), this._listenToFormUpdates();
99
+ }
100
+ }
101
+ export {
102
+ d as CHECKBOX_CONTROL_BLOCK_ID,
103
+ K as CheckboxControl
104
+ };
@@ -0,0 +1,2 @@
1
+ declare const _default: import("@stripoinc/ui-editor-extensions").Extension;
2
+ export default _default;
@@ -0,0 +1,20 @@
1
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
2
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
3
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
4
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
5
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
11
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
13
+ import { ExtensionBuilder as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/ExtensionBuilder.js";
14
+ import { CheckboxBlock as t } from "./block.js";
15
+ import { CheckboxControl as r } from "./control.js";
16
+ import { CheckboxBlockSettings as i } from "./settingsPanel.js";
17
+ const g = new o().addBlock(t).withSettingsPanelRegistry(i).addControl(r).build();
18
+ export {
19
+ g as default
20
+ };
@@ -0,0 +1,4 @@
1
+ import { SettingsPanelRegistry, SettingsPanelTab } from '@stripoinc/ui-editor-extensions';
2
+ export declare class CheckboxBlockSettings extends SettingsPanelRegistry {
3
+ registerBlockControls(blockControlsMap: Record<string, SettingsPanelTab[]>): void;
4
+ }
@@ -0,0 +1,38 @@
1
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
2
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
3
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
4
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
5
+ import { ContainerControls as i, TextControls as m } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
11
+ import { SettingsTab as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
13
+ import { SettingsPanelRegistry as e } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelRegistry.js";
14
+ import { SettingsPanelTab as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelTab.js";
15
+ import { CHECKBOX_BLOCK_ID as p } from "./block.js";
16
+ import { CHECKBOX_CONTROL_BLOCK_ID as C } from "./control.js";
17
+ class x extends e {
18
+ registerBlockControls(r) {
19
+ r[p] = [
20
+ new t(
21
+ o.SETTINGS,
22
+ [
23
+ C,
24
+ i.EXTERNAL_INDENTS
25
+ ]
26
+ ),
27
+ new t(
28
+ o.STYLES,
29
+ [
30
+ m.TEXT_BLOCK_BACKGROUND_COLOR
31
+ ]
32
+ )
33
+ ];
34
+ }
35
+ }
36
+ export {
37
+ x as CheckboxBlockSettings
38
+ };
@@ -0,0 +1,6 @@
1
+ declare const migrationTemplate = "\n <td \n align=\"left\" \n esd-extension-block-id=\"checkbox-block\" \n class=\"checkbox-block-v2 esd-block-checkbox esd-checkbox-block esd-extension-block es-p20\"\n >\n <table cellpadding=\"0\" cellspacing=\"0\" role=\"presentation\" width=\"100%\">\n <tbody>\n <tr>\n <td align=\"left\" width=\"39\" style=\"vertical-align: top\">\n <input type=\"checkbox\">\n </td>\n <td align=\"left\" width=\"816\" style=\"vertical-align: top\">\n <table cellpadding=\"0\" cellspacing=\"0\" role=\"presentation\" width=\"100%\">\n <tbody>\n <tr>\n {-{-TITLE-}-}\n </tr>\n <tr>\n {-{-DESCRIPTION-}-}\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n";
2
+ /**
3
+ * @returns The template for the default checkbox block
4
+ */
5
+ export declare function getDefaultTemplate(): string;
6
+ export default migrationTemplate;
@@ -0,0 +1,75 @@
1
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
2
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
3
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
4
+ import { BlockType as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
5
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
11
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
13
+ const e = {
14
+ TITLE: "Unsubscribe From All Email Lists",
15
+ DESCRIPTION: "You will still receive important transactional and billing-related emails."
16
+ }, l = `
17
+ <td align="left" class="checkbox-block-v2 esd-block-checkbox es-p20">
18
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
19
+ <tbody>
20
+ <tr>
21
+ <td align="left" width="39" style="vertical-align: top;">
22
+ <input type="checkbox">
23
+ </td>
24
+ <td align="left" width="816" style="vertical-align: top;">
25
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
26
+ <tbody>
27
+ <${t.BLOCK_TEXT}>
28
+ {-{-TITLE-}-}
29
+ </${t.BLOCK_TEXT}>
30
+ <${t.BLOCK_TEXT}>
31
+ {-{-DESCRIPTION-}-}
32
+ </${t.BLOCK_TEXT}>
33
+ </tbody>
34
+ </table>
35
+ </td>
36
+ </tr>
37
+ </tbody>
38
+ </table>
39
+ </td>
40
+ `, m = `
41
+ <td
42
+ align="left"
43
+ esd-extension-block-id="checkbox-block"
44
+ class="checkbox-block-v2 esd-block-checkbox esd-checkbox-block esd-extension-block es-p20"
45
+ >
46
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
47
+ <tbody>
48
+ <tr>
49
+ <td align="left" width="39" style="vertical-align: top">
50
+ <input type="checkbox">
51
+ </td>
52
+ <td align="left" width="816" style="vertical-align: top">
53
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
54
+ <tbody>
55
+ <tr>
56
+ {-{-TITLE-}-}
57
+ </tr>
58
+ <tr>
59
+ {-{-DESCRIPTION-}-}
60
+ </tr>
61
+ </tbody>
62
+ </table>
63
+ </td>
64
+ </tr>
65
+ </tbody>
66
+ </table>
67
+ </td>
68
+ `;
69
+ function h() {
70
+ return l.replace("{-{-TITLE-}-}", `<p path="1">${e.TITLE}</p>`).replace("{-{-DESCRIPTION-}-}", `<p path="1">${e.DESCRIPTION}</p>`);
71
+ }
72
+ export {
73
+ m as default,
74
+ h as getDefaultTemplate
75
+ };
@@ -0,0 +1,10 @@
1
+ import { Block, BlockCompositionType } from '@stripoinc/ui-editor-extensions';
2
+ export declare const BLOCK_ID = "radio-button-block";
3
+ export declare class RadioButtonCustomBlock extends Block {
4
+ getId(): string;
5
+ getIcon(): string;
6
+ getBlockCompositionType(): BlockCompositionType;
7
+ getName(): string;
8
+ getDescription(): string;
9
+ getTemplate(): string;
10
+ }
@@ -0,0 +1,39 @@
1
+ import { Block as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/blocks/Block.js";
2
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js";
3
+ import { BlockCompositionType as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js";
4
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockName.js";
5
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js";
6
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js";
7
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js";
8
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js";
9
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js";
10
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/Popover.js";
11
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js";
12
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js";
13
+ import "../../../node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js";
14
+ import { getDefaultTemplate as r } from "./template.js";
15
+ const i = "radio-button-block";
16
+ class D extends t {
17
+ getId() {
18
+ return i;
19
+ }
20
+ getIcon() {
21
+ return "circle";
22
+ }
23
+ getBlockCompositionType() {
24
+ return o.BLOCK;
25
+ }
26
+ getName() {
27
+ return this.api.translate("Radio Button Block");
28
+ }
29
+ getDescription() {
30
+ return this.api.translate("Radio Button Block Description");
31
+ }
32
+ getTemplate() {
33
+ return r();
34
+ }
35
+ }
36
+ export {
37
+ i as BLOCK_ID,
38
+ D as RadioButtonCustomBlock
39
+ };
@@ -0,0 +1,17 @@
1
+ import { Control, ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ export declare const CONTROL_BLOCK_ID = "ui-elements-radio-button";
3
+ export declare class RadioButtonControl extends Control {
4
+ private currentNode?;
5
+ private selectedUnsubGroup?;
6
+ private unsubList;
7
+ getId(): string;
8
+ _setFormValues(): void;
9
+ _getLabel(text: string, name?: string): string;
10
+ _getSelectItem(text: string, value: string): string;
11
+ _getSelect(): string;
12
+ getTemplate(): string;
13
+ _onSelectChange(value: string | number): void;
14
+ _listenToFormUpdates(): void;
15
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
16
+ onRender(): Promise<void>;
17
+ }