@useinsider/guido 3.1.1-beta.cdcd41d → 3.1.1-beta.d3c42de
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.
- package/README.md +1 -0
- package/dist/@types/config/schemas.js +69 -61
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +7 -7
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +12 -20
- package/dist/components/organisms/header/RightSlot.vue.js +10 -10
- package/dist/components/organisms/header/RightSlot.vue2.js +16 -13
- package/dist/composables/useHtmlCompiler.js +23 -21
- package/dist/composables/usePreviewMode.js +20 -16
- package/dist/composables/useSave.js +23 -15
- package/dist/composables/useStripo.js +32 -32
- package/dist/composables/validators/useLiquidValidator.js +36 -0
- package/dist/config/compiler/liquidCompilerRules.js +15 -0
- package/dist/config/compiler/utils/recommendationCompilerUtils.js +53 -55
- package/dist/config/migrator/checkboxMigrator.js +5 -3
- package/dist/config/migrator/radioButtonMigrator.js +14 -12
- package/dist/enums/recommendation.js +2 -2
- package/dist/extensions/Blocks/CouponBlock/template.js +24 -13
- package/dist/extensions/Blocks/Recommendation/block.js +1 -1
- package/dist/extensions/Blocks/Recommendation/constants/selectors.js +27 -11
- package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +185 -172
- package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +95 -93
- package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +75 -73
- package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +7 -5
- package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +30 -29
- package/dist/extensions/Blocks/Recommendation/templates/index.js +7 -7
- package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +3 -1
- package/dist/extensions/Blocks/Recommendation/templates/list/template.js +20 -20
- package/dist/extensions/Blocks/Recommendation/templates/utils.js +57 -50
- package/dist/extensions/Blocks/Recommendation/utils/tagName.js +6 -6
- package/dist/extensions/Blocks/Unsubscribe/settingsPanel.js +16 -17
- package/dist/guido.css +1 -1
- package/dist/src/@types/config/index.d.ts +1 -1
- package/dist/src/@types/config/schemas.d.ts +20 -0
- package/dist/src/@types/config/types.d.ts +3 -1
- package/dist/src/composables/useConfig.d.ts +8 -0
- package/dist/src/composables/validators/useLiquidValidator.d.ts +3 -0
- package/dist/src/config/compiler/liquidCompilerRules.d.ts +2 -0
- package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +1 -1
- package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +2 -0
- package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +1 -1
- package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +4 -4
- package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +3 -3
- package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +20 -3
- package/dist/src/stores/config.d.ts +72 -0
- package/dist/src/stores/preview.d.ts +3 -0
- package/dist/src/utils/htmlCompiler.d.ts +2 -1
- package/dist/stores/preview.js +4 -3
- package/dist/utils/htmlCompiler.js +48 -41
- package/dist/utils/templatePreparation.js +20 -20
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -143,6 +143,7 @@ const config: GuidoConfigInput = {
|
|
|
143
143
|
displayConditions?: boolean, // Default: true
|
|
144
144
|
unsubscribe?: boolean, // Default: true
|
|
145
145
|
modulesDisabled?: boolean, // Default: false - Disable modules panel
|
|
146
|
+
liquidSyntax?: boolean, // Default: false - Enable Liquid template syntax
|
|
146
147
|
},
|
|
147
148
|
|
|
148
149
|
// Optional: Callbacks
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ModuleFolderDefaults as b } from "../../enums/defaults.js";
|
|
2
|
-
import { object as o, number as p, optional as e, string as t, pipe as u, picklist as n, minLength as d, custom as S, boolean as a, array as c, literal as
|
|
2
|
+
import { object as o, number as p, optional as e, string as t, pipe as u, picklist as n, minLength as d, custom as S, boolean as a, array as c, literal as l, variant as k } from "../../node_modules/valibot/dist/index.js";
|
|
3
3
|
const m = {
|
|
4
4
|
/** Promotional/marketing emails */
|
|
5
5
|
PROMOTIONAL: 1,
|
|
@@ -26,6 +26,11 @@ const m = {
|
|
|
26
26
|
/** Optional variation ID for A/B testing */
|
|
27
27
|
variationId: e(t())
|
|
28
28
|
}), y = o({
|
|
29
|
+
/** Fallback font name (e.g., "Georgia") */
|
|
30
|
+
name: t(),
|
|
31
|
+
/** Fallback font family (e.g., "serif" or "sans-serif") */
|
|
32
|
+
family: t()
|
|
33
|
+
}), f = o({
|
|
29
34
|
/** Partner/organization name (required) */
|
|
30
35
|
name: u(
|
|
31
36
|
t(),
|
|
@@ -46,8 +51,10 @@ const m = {
|
|
|
46
51
|
m.PROMOTIONAL
|
|
47
52
|
),
|
|
48
53
|
/** Display name for the current user */
|
|
49
|
-
username: e(t(), "Guido User")
|
|
50
|
-
|
|
54
|
+
username: e(t(), "Guido User"),
|
|
55
|
+
/** Fallback font settings from partner settings — used to match backend size calculation */
|
|
56
|
+
fallbackFont: e(y)
|
|
57
|
+
}), A = o({
|
|
51
58
|
/** Display text for the dynamic content */
|
|
52
59
|
text: t(),
|
|
53
60
|
/** Template variable value (e.g., {{username}}) */
|
|
@@ -61,14 +68,14 @@ const m = {
|
|
|
61
68
|
value: t()
|
|
62
69
|
})
|
|
63
70
|
)
|
|
64
|
-
}),
|
|
71
|
+
}), R = o({
|
|
65
72
|
/** Initial HTML content */
|
|
66
73
|
html: e(t(), ""),
|
|
67
74
|
/** Initial CSS content */
|
|
68
75
|
css: e(t(), ""),
|
|
69
76
|
/** Preselected dynamic content items */
|
|
70
77
|
preselectedDynamicContent: e(
|
|
71
|
-
c(
|
|
78
|
+
c(A),
|
|
72
79
|
[]
|
|
73
80
|
),
|
|
74
81
|
/** Valid custom field attribute names from the partner's categorized fields */
|
|
@@ -77,12 +84,12 @@ const m = {
|
|
|
77
84
|
selectedUnsubscribePages: e(c(p()), []),
|
|
78
85
|
/** Force recreate template in Stripo storage (use true when updating externally modified templates) */
|
|
79
86
|
forceRecreate: e(a(), !1)
|
|
80
|
-
}),
|
|
87
|
+
}), C = o({
|
|
81
88
|
/** Sender display name */
|
|
82
89
|
senderName: e(t(), ""),
|
|
83
90
|
/** Email subject line */
|
|
84
91
|
subject: e(t(), "")
|
|
85
|
-
}),
|
|
92
|
+
}), T = o({
|
|
86
93
|
/** Locale for the editor UI */
|
|
87
94
|
locale: e(t(), "en"),
|
|
88
95
|
/** Path to translations object */
|
|
@@ -90,17 +97,17 @@ const m = {
|
|
|
90
97
|
/** Migration date for template compatibility */
|
|
91
98
|
migrationDate: e(p(), 1759696858),
|
|
92
99
|
/** Email header settings */
|
|
93
|
-
emailHeader: e(
|
|
100
|
+
emailHeader: e(C, { senderName: "", subject: "" }),
|
|
94
101
|
/** Folder name for user-saved modules (used by Stripo plugin panel for path construction) */
|
|
95
102
|
savedModulesFolderName: e(t(), b.SAVED_MODULES),
|
|
96
103
|
/** Folder name for default/prebuilt modules (used by Stripo plugin panel for path construction) */
|
|
97
104
|
defaultModulesFolderName: e(t(), b.DEFAULT_MODULES)
|
|
98
|
-
}),
|
|
105
|
+
}), I = o({
|
|
99
106
|
/** Whether to show the header bar */
|
|
100
107
|
showHeader: e(a(), !0),
|
|
101
108
|
/** Custom label for back button (if shown) */
|
|
102
109
|
backButtonLabel: e(t())
|
|
103
|
-
}),
|
|
110
|
+
}), E = o({
|
|
104
111
|
/** Enable dynamic content insertion */
|
|
105
112
|
dynamicContent: e(a(), !0),
|
|
106
113
|
/** Enable save as template functionality */
|
|
@@ -117,7 +124,7 @@ const m = {
|
|
|
117
124
|
modulesDisabled: e(a(), !1),
|
|
118
125
|
/** Enable Liquid template syntax */
|
|
119
126
|
liquidSyntax: e(a(), !1)
|
|
120
|
-
}),
|
|
127
|
+
}), g = n([
|
|
121
128
|
"amp-accordion",
|
|
122
129
|
"amp-carousel",
|
|
123
130
|
"amp-form-controls",
|
|
@@ -131,7 +138,7 @@ const m = {
|
|
|
131
138
|
"text-block",
|
|
132
139
|
"timer-block",
|
|
133
140
|
"video-block"
|
|
134
|
-
]),
|
|
141
|
+
]), O = n([
|
|
135
142
|
"dynamic-content",
|
|
136
143
|
"checkbox-block",
|
|
137
144
|
"radio-button-block",
|
|
@@ -139,66 +146,66 @@ const m = {
|
|
|
139
146
|
"unsubscribe-block",
|
|
140
147
|
"coupon-block",
|
|
141
148
|
"items-block"
|
|
142
|
-
]),
|
|
149
|
+
]), L = o({
|
|
143
150
|
/** Default blocks to exclude from the editor */
|
|
144
151
|
excludeDefaults: e(
|
|
145
|
-
c(
|
|
152
|
+
c(g),
|
|
146
153
|
[]
|
|
147
154
|
),
|
|
148
155
|
/** Custom blocks to include in the editor */
|
|
149
156
|
includeCustoms: e(
|
|
150
|
-
c(
|
|
157
|
+
c(O),
|
|
151
158
|
[]
|
|
152
159
|
)
|
|
153
|
-
}),
|
|
160
|
+
}), r = o({
|
|
154
161
|
/** Unique identifier for the rule */
|
|
155
162
|
id: t(),
|
|
156
163
|
/** Human-readable description */
|
|
157
164
|
description: e(t()),
|
|
158
165
|
/** Priority for rule ordering (lower = earlier) */
|
|
159
166
|
priority: p()
|
|
160
|
-
}),
|
|
161
|
-
...
|
|
162
|
-
type:
|
|
167
|
+
}), M = o({
|
|
168
|
+
...r.entries,
|
|
169
|
+
type: l("replace"),
|
|
163
170
|
/** String to search for */
|
|
164
171
|
search: t(),
|
|
165
172
|
/** Replacement string */
|
|
166
173
|
replacement: t(),
|
|
167
174
|
/** Replace all occurrences (default: false) */
|
|
168
175
|
replaceAll: e(a())
|
|
169
|
-
}),
|
|
170
|
-
...
|
|
171
|
-
type:
|
|
176
|
+
}), N = o({
|
|
177
|
+
...r.entries,
|
|
178
|
+
type: l("regex"),
|
|
172
179
|
/** Regex pattern string */
|
|
173
180
|
pattern: t(),
|
|
174
181
|
/** Replacement string (supports $1, $2, etc.) */
|
|
175
182
|
replacement: t(),
|
|
176
183
|
/** Regex flags (e.g., 'gi') */
|
|
177
184
|
flags: e(t())
|
|
178
|
-
}),
|
|
179
|
-
...
|
|
180
|
-
type:
|
|
185
|
+
}), D = o({
|
|
186
|
+
...r.entries,
|
|
187
|
+
type: l("remove"),
|
|
181
188
|
/** Strings or patterns to remove */
|
|
182
189
|
targets: c(t())
|
|
183
|
-
}),
|
|
184
|
-
...
|
|
185
|
-
type:
|
|
190
|
+
}), v = o({
|
|
191
|
+
...r.entries,
|
|
192
|
+
type: l("custom"),
|
|
186
193
|
/** Custom processor function */
|
|
187
194
|
processor: S(
|
|
188
195
|
(i) => typeof i == "function",
|
|
189
196
|
"processor must be a function"
|
|
190
197
|
)
|
|
191
|
-
}),
|
|
192
|
-
L,
|
|
198
|
+
}), x = k("type", [
|
|
193
199
|
M,
|
|
194
200
|
N,
|
|
195
|
-
D
|
|
196
|
-
|
|
201
|
+
D,
|
|
202
|
+
v
|
|
203
|
+
]), U = o({
|
|
197
204
|
/** Custom compiler rules to apply */
|
|
198
|
-
customRules: e(c(
|
|
205
|
+
customRules: e(c(x), []),
|
|
199
206
|
/** Skip default compiler rules */
|
|
200
207
|
ignoreDefaultRules: e(a(), !1)
|
|
201
|
-
}),
|
|
208
|
+
}), B = o({
|
|
202
209
|
/**
|
|
203
210
|
* External validation handler called before save completes.
|
|
204
211
|
* Return false to cancel the save operation.
|
|
@@ -209,48 +216,49 @@ const m = {
|
|
|
209
216
|
"externalValidation must be a function"
|
|
210
217
|
)
|
|
211
218
|
)
|
|
212
|
-
}),
|
|
219
|
+
}), H = o({
|
|
213
220
|
// Required sections
|
|
214
221
|
/** Identity configuration (required) */
|
|
215
222
|
identity: h,
|
|
216
223
|
/** Partner configuration (required) */
|
|
217
|
-
partner:
|
|
224
|
+
partner: f,
|
|
218
225
|
// Optional sections (with defaults)
|
|
219
226
|
/** Template content and presets */
|
|
220
|
-
template: e(
|
|
227
|
+
template: e(R, {}),
|
|
221
228
|
/** Editor settings */
|
|
222
|
-
editor: e(
|
|
229
|
+
editor: e(T, {}),
|
|
223
230
|
/** UI configuration */
|
|
224
|
-
ui: e(
|
|
231
|
+
ui: e(I, {}),
|
|
225
232
|
/** Feature toggles */
|
|
226
|
-
features: e(
|
|
233
|
+
features: e(E, {}),
|
|
227
234
|
/** Block configuration */
|
|
228
|
-
blocks: e(
|
|
235
|
+
blocks: e(L, {}),
|
|
229
236
|
/** Compiler configuration */
|
|
230
|
-
compiler: e(
|
|
237
|
+
compiler: e(U, {}),
|
|
231
238
|
/** Callbacks and event handlers */
|
|
232
|
-
callbacks: e(
|
|
239
|
+
callbacks: e(B, {})
|
|
233
240
|
});
|
|
234
241
|
export {
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
242
|
+
L as BlocksSchema,
|
|
243
|
+
B as CallbacksSchema,
|
|
244
|
+
x as CompilerRuleSchema,
|
|
245
|
+
U as CompilerSchema,
|
|
246
|
+
O as CustomBlockTypeSchema,
|
|
247
|
+
v as CustomRuleSchema,
|
|
248
|
+
g as DefaultBlockTypeSchema,
|
|
249
|
+
A as DynamicContentSchema,
|
|
250
|
+
T as EditorSchema,
|
|
251
|
+
C as EmailHeaderSchema,
|
|
252
|
+
y as FallbackFontSchema,
|
|
253
|
+
E as FeaturesSchema,
|
|
254
|
+
H as GuidoConfigSchema,
|
|
247
255
|
h as IdentitySchema,
|
|
248
256
|
m as MessageType,
|
|
249
|
-
|
|
257
|
+
f as PartnerSchema,
|
|
250
258
|
s as ProductType,
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
259
|
+
N as RegexRuleSchema,
|
|
260
|
+
D as RemoveRuleSchema,
|
|
261
|
+
M as ReplaceRuleSchema,
|
|
262
|
+
R as TemplateSchema,
|
|
263
|
+
I as UISchema
|
|
256
264
|
};
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import s from "./EmailSizeIndicator.vue2.js";
|
|
2
2
|
/* empty css */
|
|
3
|
-
import
|
|
4
|
-
var
|
|
5
|
-
var
|
|
6
|
-
return
|
|
7
|
-
}, a = [], n = /* @__PURE__ */
|
|
3
|
+
import o from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
4
|
+
var r = function() {
|
|
5
|
+
var i = this, e = i._self._c, t = i._self._setupProxy;
|
|
6
|
+
return e("div", { staticClass: "d-f a-i-c j-c-c" }, [t.previewStore.isLoaded ? [e(t.InProgress, { staticClass: "min-w-15-s", attrs: { id: "email-size-progress", "description-status": "", "description-position": "left", description: t.htmlSize, "max-value": t.MAX_EMAIL_SIZE_IN_KB, type: t.progress.type, value: t.progress.value } }), e(t.InTooltipV2, { attrs: { id: "email-size-tooltip", "icon-status": "", "static-position": "bottom center", "dynamic-position": !1, text: t.trans("email-editor.preview-design-size-tooltip") } })] : e(t.InSkeleton, { attrs: { sizing: { width: 200, height: 20 } } })], 2);
|
|
7
|
+
}, a = [], n = /* @__PURE__ */ o(
|
|
8
8
|
s,
|
|
9
|
-
|
|
9
|
+
r,
|
|
10
10
|
a,
|
|
11
11
|
!1,
|
|
12
12
|
null,
|
|
13
|
-
"
|
|
13
|
+
"2cb418af"
|
|
14
14
|
);
|
|
15
15
|
const m = n.exports;
|
|
16
16
|
export {
|
|
@@ -1,25 +1,17 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
import { useTranslations as
|
|
3
|
-
import { usePreviewStore as
|
|
4
|
-
import { InTooltipV2 as
|
|
5
|
-
const
|
|
1
|
+
import { defineComponent as i, computed as t } from "vue";
|
|
2
|
+
import { useTranslations as m } from "../../../../composables/useTranslations.js";
|
|
3
|
+
import { usePreviewStore as a } from "../../../../stores/preview.js";
|
|
4
|
+
import { InTooltipV2 as p, InSkeleton as c, InProgress as _ } from "@useinsider/design-system-vue";
|
|
5
|
+
const z = /* @__PURE__ */ i({
|
|
6
6
|
__name: "EmailSizeIndicator",
|
|
7
|
-
setup(
|
|
8
|
-
const
|
|
9
|
-
type: "success",
|
|
10
|
-
value:
|
|
11
|
-
})
|
|
12
|
-
|
|
13
|
-
e.value = Math.round(m / 1024), s.value = {
|
|
14
|
-
type: e.value < o ? "success" : "warning",
|
|
15
|
-
value: Math.min(e.value, o)
|
|
16
|
-
};
|
|
17
|
-
}, i = p();
|
|
18
|
-
return u(() => t.previewHtml, () => {
|
|
19
|
-
r();
|
|
20
|
-
}, { immediate: !0 }), { __sfc: !0, previewStore: t, MAX_EMAIL_SIZE_IN_KB: o, htmlKB: e, progress: s, htmlSize: a, calculateProgress: r, trans: i, InProgress: f, InTooltipV2: v };
|
|
7
|
+
setup(l) {
|
|
8
|
+
const e = a(), o = 102, r = t(() => `~${e.emailSizeKB} KB`), n = t(() => ({
|
|
9
|
+
type: e.emailSizeKB < o ? "success" : "warning",
|
|
10
|
+
value: Math.min(e.emailSizeKB, o)
|
|
11
|
+
})), s = m();
|
|
12
|
+
return { __sfc: !0, previewStore: e, MAX_EMAIL_SIZE_IN_KB: o, htmlSize: r, progress: n, trans: s, InProgress: _, InSkeleton: c, InTooltipV2: p };
|
|
21
13
|
}
|
|
22
14
|
});
|
|
23
15
|
export {
|
|
24
|
-
|
|
16
|
+
z as default
|
|
25
17
|
};
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
return
|
|
6
|
-
},
|
|
7
|
-
o,
|
|
8
|
-
n,
|
|
1
|
+
import i from "./RightSlot.vue2.js";
|
|
2
|
+
import r from "../../../_virtual/_plugin-vue2_normalizer.js";
|
|
3
|
+
var o = function() {
|
|
4
|
+
var s = this, e = s._self._c, t = s._self._setupProxy;
|
|
5
|
+
return e("div", { staticClass: "d-f a-i-c" }, [t.isLiquidEnabled && !t.editorStore.isVersionHistoryOpen ? e(t.InChips, { staticClass: "mr-3", attrs: { id: "guido__liquid-tag-chip", styles: "stroke", type: "default", value: "liquid-tags", "close-button": !1, "disabled-status": t.editorStore.loadingStatus, interactive: !1, text: t.trans("email-editor.liquid-tags-enabled") } }) : s._e(), t.editorStore.isVersionHistoryOpen ? e(t.RestoreButton) : e(t.EditorActions, { ref: "editorActionsRef" })], 1);
|
|
6
|
+
}, a = [], n = /* @__PURE__ */ r(
|
|
9
7
|
i,
|
|
8
|
+
o,
|
|
9
|
+
a,
|
|
10
10
|
!1,
|
|
11
11
|
null,
|
|
12
12
|
null
|
|
13
13
|
);
|
|
14
|
-
const
|
|
14
|
+
const u = n.exports;
|
|
15
15
|
export {
|
|
16
|
-
|
|
16
|
+
u as default
|
|
17
17
|
};
|
|
@@ -1,19 +1,22 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
|
|
1
|
+
import { defineComponent as a, ref as f, computed as p } from "vue";
|
|
2
|
+
import { useConfig as u } from "../../../composables/useConfig.js";
|
|
3
|
+
import { useTranslations as d } from "../../../composables/useTranslations.js";
|
|
4
|
+
import { useEditorStore as c } from "../../../stores/editor.js";
|
|
5
|
+
import { InChips as l } from "@useinsider/design-system-vue";
|
|
6
|
+
import _ from "./EditorActions.vue.js";
|
|
7
|
+
import S from "./version-history/RestoreButton.vue.js";
|
|
8
|
+
const x = /* @__PURE__ */ a({
|
|
6
9
|
__name: "RightSlot",
|
|
7
|
-
setup(
|
|
8
|
-
const
|
|
9
|
-
return
|
|
10
|
-
handleSave: (
|
|
11
|
-
var
|
|
12
|
-
return (
|
|
10
|
+
setup(h, { expose: r }) {
|
|
11
|
+
const { isFeatureEnabled: o } = u(), n = d(), i = c(), t = f(null), s = p(() => o("liquidSyntax"));
|
|
12
|
+
return r({
|
|
13
|
+
handleSave: (m) => {
|
|
14
|
+
var e;
|
|
15
|
+
return (e = t.value) == null ? void 0 : e.handleSave(m);
|
|
13
16
|
}
|
|
14
|
-
}), { __sfc: !0, editorStore:
|
|
17
|
+
}), { __sfc: !0, isFeatureEnabled: o, trans: n, editorStore: i, editorActionsRef: t, isLiquidEnabled: s, InChips: l, EditorActions: _, RestoreButton: S };
|
|
15
18
|
}
|
|
16
19
|
});
|
|
17
20
|
export {
|
|
18
|
-
|
|
21
|
+
x as default
|
|
19
22
|
};
|
|
@@ -1,28 +1,30 @@
|
|
|
1
|
-
import { defaultHtmlCompilerRules as
|
|
2
|
-
import { itemsCompilerRules as
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
...
|
|
15
|
-
...
|
|
16
|
-
...c,
|
|
1
|
+
import { defaultHtmlCompilerRules as c } from "../config/compiler/htmlCompilerRules.js";
|
|
2
|
+
import { itemsCompilerRules as f } from "../config/compiler/itemsCompilerRules.js";
|
|
3
|
+
import { liquidCompilerRules as R } from "../config/compiler/liquidCompilerRules.js";
|
|
4
|
+
import { outlookCompilerRules as C } from "../config/compiler/outlookCompilerRules.js";
|
|
5
|
+
import { recommendationCompilerRules as d } from "../config/compiler/recommendationCompilerRules.js";
|
|
6
|
+
import { socialCompilerRules as b } from "../config/compiler/socialCompilerRules.js";
|
|
7
|
+
import { unsubscribeCompilerRules as g } from "../config/compiler/unsubscribeCompilerRules.js";
|
|
8
|
+
import { createHtmlCompiler as H } from "../utils/htmlCompiler.js";
|
|
9
|
+
import { useConfig as v } from "./useConfig.js";
|
|
10
|
+
const w = () => {
|
|
11
|
+
var l, m, r;
|
|
12
|
+
const { compiler: e, isFeatureEnabled: t, partner: i } = v(), s = ((l = e.value) == null ? void 0 : l.customRules) || [], u = [
|
|
13
|
+
...!!((m = e.value) != null && m.ignoreDefaultRules) ? [] : c,
|
|
14
|
+
...d,
|
|
15
|
+
...g,
|
|
17
16
|
...f,
|
|
18
|
-
...
|
|
17
|
+
...C,
|
|
18
|
+
...b,
|
|
19
|
+
...t("liquidSyntax") ? R : [],
|
|
20
|
+
...s.map((o, a) => ({
|
|
19
21
|
...o,
|
|
20
|
-
priority: o.priority + 1e3 +
|
|
22
|
+
priority: o.priority + 1e3 + a
|
|
21
23
|
// Ensure additional rules run after default rules
|
|
22
24
|
}))
|
|
23
|
-
],
|
|
24
|
-
return { compileHtml: (o) =>
|
|
25
|
+
], p = H(u), n = (r = i.value) == null ? void 0 : r.fallbackFont;
|
|
26
|
+
return { compileHtml: (o) => p.compile(o, void 0, n) };
|
|
25
27
|
};
|
|
26
28
|
export {
|
|
27
|
-
|
|
29
|
+
w as useHtmlCompiler
|
|
28
30
|
};
|
|
@@ -1,31 +1,35 @@
|
|
|
1
|
-
import { useEditorStore as
|
|
2
|
-
import { usePreviewStore as
|
|
3
|
-
import { useActionsApi as
|
|
4
|
-
import { useCodeEditorApi as
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import { useEditorStore as d } from "../stores/editor.js";
|
|
2
|
+
import { usePreviewStore as n } from "../stores/preview.js";
|
|
3
|
+
import { useActionsApi as p } from "./useActionsApi.js";
|
|
4
|
+
import { useCodeEditorApi as c } from "./useCodeEditorApi.js";
|
|
5
|
+
import { useHtmlCompiler as u } from "./useHtmlCompiler.js";
|
|
6
|
+
const g = () => {
|
|
7
|
+
const t = d(), e = n(), { closeCodeEditor: i } = c(), { getPreviewData: a, getCompiledEmail: s } = p(), { compileHtml: m } = u(), r = () => {
|
|
8
|
+
t.isPreviewModeOpen = !1, e.$reset();
|
|
8
9
|
};
|
|
9
10
|
return {
|
|
10
11
|
closePreviewMode: r,
|
|
11
12
|
openPreviewMode: () => {
|
|
12
|
-
|
|
13
|
+
t.isCodeEditorOpen && i(), t.isPreviewModeOpen = !0;
|
|
13
14
|
},
|
|
14
15
|
loadPreviewData: async () => {
|
|
15
|
-
if (!(
|
|
16
|
-
|
|
16
|
+
if (!(t.loadingStatus || e.isLoaded)) {
|
|
17
|
+
t.loadingStatus = !0;
|
|
17
18
|
try {
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
const [o, l] = await Promise.all([
|
|
20
|
+
a(),
|
|
21
|
+
s({ minimize: !0, resetDataSavedFlag: !1 })
|
|
22
|
+
]);
|
|
23
|
+
e.templateHtml = o.html || "", e.ampHtml = o.ampHtml || "", e.ampErrors = o.ampErrors || [], e.setEmailFormat(o.ampHtml ? "AMP" : "html"), e.emailSizeKB = m(l.html).estimatedSizeKB, e.isLoaded = !0;
|
|
24
|
+
} catch (o) {
|
|
25
|
+
console.error("Failed to load preview data:", o), r();
|
|
22
26
|
} finally {
|
|
23
|
-
|
|
27
|
+
t.loadingStatus = !1;
|
|
24
28
|
}
|
|
25
29
|
}
|
|
26
30
|
}
|
|
27
31
|
};
|
|
28
32
|
};
|
|
29
33
|
export {
|
|
30
|
-
|
|
34
|
+
g as usePreviewMode
|
|
31
35
|
};
|
|
@@ -1,21 +1,29 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
import { useActionsApi as S } from "./useActionsApi.js";
|
|
2
|
+
import { useConfig as V } from "./useConfig.js";
|
|
3
|
+
import { useSaveStart as x, useSaveComplete as y } from "./useGuidoActions.js";
|
|
4
|
+
import { useSyncModuleExtractor as w } from "./useSyncModuleExtractor.js";
|
|
5
|
+
import { useStripoApi as b } from "../services/stripoApi.js";
|
|
6
|
+
import { useTemplatePreparation as q } from "../utils/templatePreparation.js";
|
|
7
|
+
import { useHtmlValidator as H } from "./useHtmlValidator.js";
|
|
8
|
+
import { useLiquidValidator as L } from "./validators/useLiquidValidator.js";
|
|
9
|
+
const F = () => {
|
|
10
|
+
const o = x(), s = y(), { validateHtml: r } = H(), { validateLiquidSyntax: n } = L(), { callbacks: a, isFeatureEnabled: l } = V(), { extractSyncModuleData: d } = w(), { setSyncModuleUnsubscriptionPages: u } = b(), { editorSave: c } = S();
|
|
11
|
+
return { save: async (m = !1) => {
|
|
12
|
+
var i;
|
|
11
13
|
o();
|
|
12
|
-
const { prepareTemplateDetails:
|
|
13
|
-
if (
|
|
14
|
+
const { prepareTemplateDetails: p } = q(), t = await p();
|
|
15
|
+
if (l("liquidSyntax")) {
|
|
16
|
+
if (!await n(t.compiledHtml))
|
|
17
|
+
return;
|
|
18
|
+
} else if (!await r(t.compiledHtml, t.dynamicContentList, !0))
|
|
14
19
|
return;
|
|
15
|
-
|
|
16
|
-
|
|
20
|
+
if ((i = a.value) != null && i.externalValidation && !await a.value.externalValidation(t))
|
|
21
|
+
return;
|
|
22
|
+
c();
|
|
23
|
+
const { unsubscribePayload: f, stripoModules: v } = d(t.rawHtml);
|
|
24
|
+
return await u(f), t.modules = v, m || s(t), t;
|
|
17
25
|
} };
|
|
18
26
|
};
|
|
19
27
|
export {
|
|
20
|
-
|
|
28
|
+
F as useSave
|
|
21
29
|
};
|