@brunoalz/smartgesti-site-editor 1.2.0 → 1.3.0
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/dist/editor/BlockSelector.js +5 -2
- package/dist/editor/BlockSelector.js.map +1 -1
- package/dist/editor/LandingPageEditor.d.ts.map +1 -1
- package/dist/editor/LandingPageEditor.js +163 -151
- package/dist/editor/LandingPageEditor.js.map +1 -1
- package/dist/editor/PropertyEditor/BlockPropertyEditor.d.ts.map +1 -1
- package/dist/editor/PropertyEditor/BlockPropertyEditor.js +86 -48
- package/dist/editor/PropertyEditor/BlockPropertyEditor.js.map +1 -1
- package/dist/engine/export/exporters/sections/AdminSectionExporters.d.ts +6 -0
- package/dist/engine/export/exporters/sections/AdminSectionExporters.d.ts.map +1 -0
- package/dist/engine/export/exporters/sections/AdminSectionExporters.js +157 -0
- package/dist/engine/export/exporters/sections/AdminSectionExporters.js.map +1 -0
- package/dist/engine/export/exporters/sections/index.d.ts.map +1 -1
- package/dist/engine/export/exporters/sections/index.js +37 -33
- package/dist/engine/export/exporters/sections/index.js.map +1 -1
- package/dist/engine/index.js +98 -95
- package/dist/engine/index.js.map +1 -1
- package/dist/engine/preview/Preview.d.ts.map +1 -1
- package/dist/engine/preview/Preview.js +165 -160
- package/dist/engine/preview/Preview.js.map +1 -1
- package/dist/engine/registry/blocks/sections/aboutSection.d.ts +3 -0
- package/dist/engine/registry/blocks/sections/aboutSection.d.ts.map +1 -0
- package/dist/engine/registry/blocks/sections/aboutSection.js +117 -0
- package/dist/engine/registry/blocks/sections/aboutSection.js.map +1 -0
- package/dist/engine/registry/blocks/sections/contactSection.d.ts +3 -0
- package/dist/engine/registry/blocks/sections/contactSection.d.ts.map +1 -0
- package/dist/engine/registry/blocks/sections/contactSection.js +118 -0
- package/dist/engine/registry/blocks/sections/contactSection.js.map +1 -0
- package/dist/engine/registry/blocks/sections/index.d.ts +3 -0
- package/dist/engine/registry/blocks/sections/index.d.ts.map +1 -1
- package/dist/engine/registry/blocks/sections/productShowcase.d.ts +3 -0
- package/dist/engine/registry/blocks/sections/productShowcase.d.ts.map +1 -0
- package/dist/engine/registry/blocks/sections/productShowcase.js +108 -0
- package/dist/engine/registry/blocks/sections/productShowcase.js.map +1 -0
- package/dist/engine/render/renderers/sections/AboutSectionRenderer.d.ts +3 -0
- package/dist/engine/render/renderers/sections/AboutSectionRenderer.d.ts.map +1 -0
- package/dist/engine/render/renderers/sections/AboutSectionRenderer.js +246 -0
- package/dist/engine/render/renderers/sections/AboutSectionRenderer.js.map +1 -0
- package/dist/engine/render/renderers/sections/ContactSectionRenderer.d.ts +3 -0
- package/dist/engine/render/renderers/sections/ContactSectionRenderer.d.ts.map +1 -0
- package/dist/engine/render/renderers/sections/ContactSectionRenderer.js +287 -0
- package/dist/engine/render/renderers/sections/ContactSectionRenderer.js.map +1 -0
- package/dist/engine/render/renderers/sections/ProductShowcaseRenderer.d.ts +3 -0
- package/dist/engine/render/renderers/sections/ProductShowcaseRenderer.d.ts.map +1 -0
- package/dist/engine/render/renderers/sections/ProductShowcaseRenderer.js +287 -0
- package/dist/engine/render/renderers/sections/ProductShowcaseRenderer.js.map +1 -0
- package/dist/engine/render/renderers/sections/index.js +26 -20
- package/dist/engine/render/renderers/sections/index.js.map +1 -1
- package/dist/engine/schema/siteDocument.d.ts +96 -2
- package/dist/engine/schema/siteDocument.d.ts.map +1 -1
- package/dist/engine/schema/siteDocument.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +109 -106
- package/dist/index.js.map +1 -1
- package/dist/shared/schema.d.ts +1 -1
- package/dist/shared/schema.d.ts.map +1 -1
- package/dist/shared/schema.js +7 -4
- package/dist/shared/schema.js.map +1 -1
- package/dist/shared/templates/index.d.ts +2 -0
- package/dist/shared/templates/index.d.ts.map +1 -1
- package/dist/shared/templates/index.js +42 -23
- package/dist/shared/templates/index.js.map +1 -1
- package/dist/shared/templates/smartgesti-admin.d.ts +3 -0
- package/dist/shared/templates/smartgesti-admin.d.ts.map +1 -0
- package/dist/shared/templates/smartgesti-admin.js +426 -0
- package/dist/shared/templates/smartgesti-admin.js.map +1 -0
- package/dist/utils/blockIcons.d.ts.map +1 -1
- package/dist/utils/blockIcons.js +3 -0
- package/dist/utils/blockIcons.js.map +1 -1
- package/dist/viewer/LandingPageViewer.d.ts.map +1 -1
- package/dist/viewer/LandingPageViewer.js +66 -65
- package/dist/viewer/LandingPageViewer.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,287 @@
|
|
|
1
|
+
import { jsxs as t, Fragment as C, jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { generateButtonHoverStyles as b, generateButtonOverlayCSS as v, getButtonHoverKeyframes as k } from "../../../shared/hoverEffects/buttonHover.js";
|
|
3
|
+
function $(o) {
|
|
4
|
+
const {
|
|
5
|
+
title: l,
|
|
6
|
+
subtitle: d,
|
|
7
|
+
products: m = [],
|
|
8
|
+
variant: h = "alternating",
|
|
9
|
+
bg: p,
|
|
10
|
+
buttonHoverEffect: g = "none",
|
|
11
|
+
buttonHoverIntensity: y = 50,
|
|
12
|
+
buttonHoverOverlay: s = "none",
|
|
13
|
+
buttonHoverIconName: f = "arrow-right"
|
|
14
|
+
} = o.props, u = h === "grid", i = `[data-block-id="${o.id}"]`;
|
|
15
|
+
let n = "";
|
|
16
|
+
if (g !== "none") {
|
|
17
|
+
const e = b({
|
|
18
|
+
effect: g,
|
|
19
|
+
intensity: y,
|
|
20
|
+
buttonColor: "#6366f1",
|
|
21
|
+
variant: "solid"
|
|
22
|
+
}), a = b({
|
|
23
|
+
effect: g,
|
|
24
|
+
intensity: y,
|
|
25
|
+
buttonColor: "#6366f1",
|
|
26
|
+
variant: "outline"
|
|
27
|
+
});
|
|
28
|
+
e.base && (n += `${i} .sg-showcase__btn--primary { ${e.base} }`), a.base && (n += `${i} .sg-showcase__btn--secondary { ${a.base} }`), n += `${i} .sg-showcase__btn--primary:hover { ${e.hover} }`, n += `${i} .sg-showcase__btn--secondary:hover { ${a.hover} }`, n += k();
|
|
29
|
+
}
|
|
30
|
+
s && s !== "none" && (n += v(`${i} .sg-showcase__btn--primary`, {
|
|
31
|
+
overlay: s,
|
|
32
|
+
primaryColor: "#6366f1",
|
|
33
|
+
iconName: f,
|
|
34
|
+
textColor: "#fff"
|
|
35
|
+
}), n += v(`${i} .sg-showcase__btn--secondary`, {
|
|
36
|
+
overlay: s,
|
|
37
|
+
primaryColor: "#6366f1",
|
|
38
|
+
iconName: f,
|
|
39
|
+
textColor: "#6366f1"
|
|
40
|
+
}));
|
|
41
|
+
const x = n.length > 0, c = {
|
|
42
|
+
position: "relative",
|
|
43
|
+
overflow: "hidden",
|
|
44
|
+
transition: "all 0.2s ease"
|
|
45
|
+
};
|
|
46
|
+
return /* @__PURE__ */ t(C, { children: [
|
|
47
|
+
x && /* @__PURE__ */ r("style", { children: n }),
|
|
48
|
+
/* @__PURE__ */ r(
|
|
49
|
+
"section",
|
|
50
|
+
{
|
|
51
|
+
"data-block-id": o.id,
|
|
52
|
+
style: {
|
|
53
|
+
padding: "var(--sg-section-padding-md, 4rem 0)",
|
|
54
|
+
backgroundColor: p || "var(--sg-bg)"
|
|
55
|
+
},
|
|
56
|
+
children: /* @__PURE__ */ t("div", { style: { maxWidth: "1200px", margin: "0 auto", padding: "0 1rem" }, children: [
|
|
57
|
+
(l || d) && /* @__PURE__ */ t("div", { "data-block-group": "Conteúdo", style: { textAlign: "center", marginBottom: "3rem" }, children: [
|
|
58
|
+
d && /* @__PURE__ */ r(
|
|
59
|
+
"span",
|
|
60
|
+
{
|
|
61
|
+
style: {
|
|
62
|
+
display: "inline-block",
|
|
63
|
+
padding: "0.25rem 0.75rem",
|
|
64
|
+
backgroundColor: "var(--sg-primary)",
|
|
65
|
+
color: "#fff",
|
|
66
|
+
borderRadius: "9999px",
|
|
67
|
+
fontSize: "0.75rem",
|
|
68
|
+
fontWeight: 600,
|
|
69
|
+
textTransform: "uppercase",
|
|
70
|
+
letterSpacing: "0.05em",
|
|
71
|
+
marginBottom: "0.75rem"
|
|
72
|
+
},
|
|
73
|
+
children: d
|
|
74
|
+
}
|
|
75
|
+
),
|
|
76
|
+
l && /* @__PURE__ */ r("h2", { style: { fontSize: "var(--sg-heading-h2)", marginBottom: "0.5rem" }, children: l })
|
|
77
|
+
] }),
|
|
78
|
+
u ? /* @__PURE__ */ r(
|
|
79
|
+
"div",
|
|
80
|
+
{
|
|
81
|
+
"data-block-group": "Layout",
|
|
82
|
+
style: {
|
|
83
|
+
display: "grid",
|
|
84
|
+
gridTemplateColumns: `repeat(${Math.min(m.length, 3)}, 1fr)`,
|
|
85
|
+
gap: "2rem"
|
|
86
|
+
},
|
|
87
|
+
children: m.map((e, a) => /* @__PURE__ */ t(
|
|
88
|
+
"div",
|
|
89
|
+
{
|
|
90
|
+
style: {
|
|
91
|
+
backgroundColor: "var(--sg-surface)",
|
|
92
|
+
borderRadius: "var(--sg-card-radius, 0.75rem)",
|
|
93
|
+
overflow: "hidden",
|
|
94
|
+
boxShadow: "var(--sg-card-shadow)"
|
|
95
|
+
},
|
|
96
|
+
children: [
|
|
97
|
+
e.image && /* @__PURE__ */ r(
|
|
98
|
+
"div",
|
|
99
|
+
{
|
|
100
|
+
style: {
|
|
101
|
+
width: "100%",
|
|
102
|
+
height: "200px",
|
|
103
|
+
backgroundImage: `url(${e.image})`,
|
|
104
|
+
backgroundSize: "cover",
|
|
105
|
+
backgroundPosition: "center"
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
),
|
|
109
|
+
/* @__PURE__ */ t("div", { style: { padding: "1.5rem" }, children: [
|
|
110
|
+
e.badge && /* @__PURE__ */ r(
|
|
111
|
+
"span",
|
|
112
|
+
{
|
|
113
|
+
style: {
|
|
114
|
+
display: "inline-block",
|
|
115
|
+
padding: "0.125rem 0.5rem",
|
|
116
|
+
backgroundColor: "var(--sg-primary)",
|
|
117
|
+
color: "#fff",
|
|
118
|
+
borderRadius: "9999px",
|
|
119
|
+
fontSize: "0.7rem",
|
|
120
|
+
fontWeight: 600,
|
|
121
|
+
marginBottom: "0.5rem"
|
|
122
|
+
},
|
|
123
|
+
children: e.badge
|
|
124
|
+
}
|
|
125
|
+
),
|
|
126
|
+
/* @__PURE__ */ t("h3", { style: { fontSize: "1.25rem", fontWeight: 600, marginBottom: "0.5rem" }, children: [
|
|
127
|
+
e.icon && /* @__PURE__ */ r("span", { style: { marginRight: "0.5rem" }, children: e.icon }),
|
|
128
|
+
e.name
|
|
129
|
+
] }),
|
|
130
|
+
/* @__PURE__ */ r("p", { style: { color: "var(--sg-muted-text)", fontSize: "0.875rem" }, children: e.description }),
|
|
131
|
+
e.primaryButton && /* @__PURE__ */ r(
|
|
132
|
+
"a",
|
|
133
|
+
{
|
|
134
|
+
href: e.primaryButton.href || "#",
|
|
135
|
+
className: "sg-showcase__btn sg-showcase__btn--primary",
|
|
136
|
+
style: {
|
|
137
|
+
display: "inline-block",
|
|
138
|
+
marginTop: "1rem",
|
|
139
|
+
padding: "0.5rem 1rem",
|
|
140
|
+
backgroundColor: "var(--sg-primary)",
|
|
141
|
+
color: "var(--sg-primary-text)",
|
|
142
|
+
borderRadius: "var(--sg-button-radius, 0.5rem)",
|
|
143
|
+
textDecoration: "none",
|
|
144
|
+
fontWeight: 500,
|
|
145
|
+
fontSize: "0.875rem",
|
|
146
|
+
...c
|
|
147
|
+
},
|
|
148
|
+
children: e.primaryButton.text
|
|
149
|
+
}
|
|
150
|
+
)
|
|
151
|
+
] })
|
|
152
|
+
]
|
|
153
|
+
},
|
|
154
|
+
a
|
|
155
|
+
))
|
|
156
|
+
}
|
|
157
|
+
) : /* @__PURE__ */ r("div", { "data-block-group": "Layout", style: { display: "flex", flexDirection: "column", gap: "4rem" }, children: m.map((e, a) => {
|
|
158
|
+
const _ = h === "alternating" && a % 2 === 1;
|
|
159
|
+
return /* @__PURE__ */ t(
|
|
160
|
+
"div",
|
|
161
|
+
{
|
|
162
|
+
style: {
|
|
163
|
+
display: "flex",
|
|
164
|
+
gap: "3rem",
|
|
165
|
+
alignItems: "center",
|
|
166
|
+
flexDirection: _ ? "row-reverse" : "row"
|
|
167
|
+
},
|
|
168
|
+
children: [
|
|
169
|
+
/* @__PURE__ */ r("div", { style: { flex: "1 1 50%" }, children: e.image ? /* @__PURE__ */ r(
|
|
170
|
+
"img",
|
|
171
|
+
{
|
|
172
|
+
src: e.image,
|
|
173
|
+
alt: e.name,
|
|
174
|
+
style: {
|
|
175
|
+
width: "100%",
|
|
176
|
+
borderRadius: "var(--sg-card-radius, 0.75rem)",
|
|
177
|
+
objectFit: "cover"
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
) : /* @__PURE__ */ r(
|
|
181
|
+
"div",
|
|
182
|
+
{
|
|
183
|
+
style: {
|
|
184
|
+
width: "100%",
|
|
185
|
+
height: "300px",
|
|
186
|
+
backgroundColor: "var(--sg-surface)",
|
|
187
|
+
borderRadius: "var(--sg-card-radius, 0.75rem)",
|
|
188
|
+
display: "flex",
|
|
189
|
+
alignItems: "center",
|
|
190
|
+
justifyContent: "center",
|
|
191
|
+
fontSize: "4rem"
|
|
192
|
+
},
|
|
193
|
+
children: e.icon || "📦"
|
|
194
|
+
}
|
|
195
|
+
) }),
|
|
196
|
+
/* @__PURE__ */ t("div", { style: { flex: "1 1 50%" }, children: [
|
|
197
|
+
e.badge && /* @__PURE__ */ r(
|
|
198
|
+
"span",
|
|
199
|
+
{
|
|
200
|
+
style: {
|
|
201
|
+
display: "inline-block",
|
|
202
|
+
padding: "0.25rem 0.75rem",
|
|
203
|
+
backgroundColor: "var(--sg-primary)",
|
|
204
|
+
color: "#fff",
|
|
205
|
+
borderRadius: "9999px",
|
|
206
|
+
fontSize: "0.75rem",
|
|
207
|
+
fontWeight: 600,
|
|
208
|
+
marginBottom: "0.75rem"
|
|
209
|
+
},
|
|
210
|
+
children: e.badge
|
|
211
|
+
}
|
|
212
|
+
),
|
|
213
|
+
/* @__PURE__ */ t("h3", { style: { fontSize: "1.5rem", fontWeight: 700, marginBottom: "0.75rem" }, children: [
|
|
214
|
+
e.icon && /* @__PURE__ */ r("span", { style: { marginRight: "0.5rem" }, children: e.icon }),
|
|
215
|
+
e.name
|
|
216
|
+
] }),
|
|
217
|
+
/* @__PURE__ */ r("p", { style: { color: "var(--sg-muted-text)", marginBottom: "1rem", lineHeight: 1.7 }, children: e.longDescription || e.description }),
|
|
218
|
+
e.features && e.features.length > 0 && /* @__PURE__ */ r("ul", { style: { listStyle: "none", padding: 0, margin: "0 0 1.5rem 0" }, children: e.features.map((w, B) => /* @__PURE__ */ t(
|
|
219
|
+
"li",
|
|
220
|
+
{
|
|
221
|
+
style: {
|
|
222
|
+
display: "flex",
|
|
223
|
+
alignItems: "center",
|
|
224
|
+
gap: "0.5rem",
|
|
225
|
+
marginBottom: "0.5rem",
|
|
226
|
+
color: "var(--sg-text)"
|
|
227
|
+
},
|
|
228
|
+
children: [
|
|
229
|
+
/* @__PURE__ */ r("span", { style: { color: "#10b981", fontWeight: 700 }, children: "✓" }),
|
|
230
|
+
w
|
|
231
|
+
]
|
|
232
|
+
},
|
|
233
|
+
B
|
|
234
|
+
)) }),
|
|
235
|
+
/* @__PURE__ */ t("div", { style: { display: "flex", gap: "0.75rem" }, children: [
|
|
236
|
+
e.primaryButton && /* @__PURE__ */ r(
|
|
237
|
+
"a",
|
|
238
|
+
{
|
|
239
|
+
href: e.primaryButton.href || "#",
|
|
240
|
+
className: "sg-showcase__btn sg-showcase__btn--primary",
|
|
241
|
+
style: {
|
|
242
|
+
padding: "0.625rem 1.25rem",
|
|
243
|
+
backgroundColor: "var(--sg-primary)",
|
|
244
|
+
color: "var(--sg-primary-text)",
|
|
245
|
+
borderRadius: "var(--sg-button-radius, 0.5rem)",
|
|
246
|
+
textDecoration: "none",
|
|
247
|
+
fontWeight: 500,
|
|
248
|
+
...c
|
|
249
|
+
},
|
|
250
|
+
children: e.primaryButton.text
|
|
251
|
+
}
|
|
252
|
+
),
|
|
253
|
+
e.secondaryButton && /* @__PURE__ */ r(
|
|
254
|
+
"a",
|
|
255
|
+
{
|
|
256
|
+
href: e.secondaryButton.href || "#",
|
|
257
|
+
className: "sg-showcase__btn sg-showcase__btn--secondary",
|
|
258
|
+
style: {
|
|
259
|
+
padding: "0.625rem 1.25rem",
|
|
260
|
+
backgroundColor: "transparent",
|
|
261
|
+
color: "var(--sg-primary)",
|
|
262
|
+
border: "1px solid var(--sg-primary)",
|
|
263
|
+
borderRadius: "var(--sg-button-radius, 0.5rem)",
|
|
264
|
+
textDecoration: "none",
|
|
265
|
+
fontWeight: 500,
|
|
266
|
+
...c
|
|
267
|
+
},
|
|
268
|
+
children: e.secondaryButton.text
|
|
269
|
+
}
|
|
270
|
+
)
|
|
271
|
+
] })
|
|
272
|
+
] })
|
|
273
|
+
]
|
|
274
|
+
},
|
|
275
|
+
a
|
|
276
|
+
);
|
|
277
|
+
}) })
|
|
278
|
+
] })
|
|
279
|
+
},
|
|
280
|
+
o.id
|
|
281
|
+
)
|
|
282
|
+
] });
|
|
283
|
+
}
|
|
284
|
+
export {
|
|
285
|
+
$ as renderProductShowcase
|
|
286
|
+
};
|
|
287
|
+
//# sourceMappingURL=ProductShowcaseRenderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductShowcaseRenderer.js","sources":["../../../../../src/engine/render/renderers/sections/ProductShowcaseRenderer.tsx"],"sourcesContent":["/**\n * ProductShowcase Renderer\n * Renderiza vitrine de produtos com layouts alternado, grid ou empilhado\n */\n\nimport React from \"react\";\nimport {\n generateButtonHoverStyles,\n generateButtonOverlayCSS,\n getButtonHoverKeyframes,\n type ButtonHoverEffect,\n type ButtonHoverOverlay,\n} from \"../../../shared/hoverEffects\";\n\nexport function renderProductShowcase(block: any): React.ReactNode {\n const {\n title,\n subtitle,\n products = [],\n variant = \"alternating\",\n bg,\n buttonHoverEffect = \"none\",\n buttonHoverIntensity = 50,\n buttonHoverOverlay = \"none\",\n buttonHoverIconName = \"arrow-right\",\n } = block.props;\n\n const isGrid = variant === \"grid\";\n\n // Generate hover CSS\n const scope = `[data-block-id=\"${block.id}\"]`;\n let hoverCss = \"\";\n\n if (buttonHoverEffect !== \"none\") {\n const primaryResult = generateButtonHoverStyles({\n effect: buttonHoverEffect as ButtonHoverEffect,\n intensity: buttonHoverIntensity,\n buttonColor: \"#6366f1\",\n variant: \"solid\",\n });\n const outlineResult = generateButtonHoverStyles({\n effect: buttonHoverEffect as ButtonHoverEffect,\n intensity: buttonHoverIntensity,\n buttonColor: \"#6366f1\",\n variant: \"outline\",\n });\n if (primaryResult.base) {\n hoverCss += `${scope} .sg-showcase__btn--primary { ${primaryResult.base} }`;\n }\n if (outlineResult.base) {\n hoverCss += `${scope} .sg-showcase__btn--secondary { ${outlineResult.base} }`;\n }\n hoverCss += `${scope} .sg-showcase__btn--primary:hover { ${primaryResult.hover} }`;\n hoverCss += `${scope} .sg-showcase__btn--secondary:hover { ${outlineResult.hover} }`;\n hoverCss += getButtonHoverKeyframes();\n }\n\n if (buttonHoverOverlay && buttonHoverOverlay !== \"none\") {\n hoverCss += generateButtonOverlayCSS(`${scope} .sg-showcase__btn--primary`, {\n overlay: buttonHoverOverlay as ButtonHoverOverlay,\n primaryColor: \"#6366f1\",\n iconName: buttonHoverIconName,\n textColor: \"#fff\",\n });\n hoverCss += generateButtonOverlayCSS(`${scope} .sg-showcase__btn--secondary`, {\n overlay: buttonHoverOverlay as ButtonHoverOverlay,\n primaryColor: \"#6366f1\",\n iconName: buttonHoverIconName,\n textColor: \"#6366f1\",\n });\n }\n\n const hasHover = hoverCss.length > 0;\n const btnBaseStyle: React.CSSProperties = {\n position: \"relative\",\n overflow: \"hidden\",\n transition: \"all 0.2s ease\",\n };\n\n return (\n <>\n {hasHover && <style>{hoverCss}</style>}\n <section\n key={block.id}\n data-block-id={block.id}\n style={{\n padding: \"var(--sg-section-padding-md, 4rem 0)\",\n backgroundColor: bg || \"var(--sg-bg)\",\n }}\n >\n <div style={{ maxWidth: \"1200px\", margin: \"0 auto\", padding: \"0 1rem\" }}>\n {(title || subtitle) && (\n <div data-block-group=\"Conteúdo\" style={{ textAlign: \"center\", marginBottom: \"3rem\" }}>\n {subtitle && (\n <span\n style={{\n display: \"inline-block\",\n padding: \"0.25rem 0.75rem\",\n backgroundColor: \"var(--sg-primary)\",\n color: \"#fff\",\n borderRadius: \"9999px\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n textTransform: \"uppercase\",\n letterSpacing: \"0.05em\",\n marginBottom: \"0.75rem\",\n }}\n >\n {subtitle}\n </span>\n )}\n {title && (\n <h2 style={{ fontSize: \"var(--sg-heading-h2)\", marginBottom: \"0.5rem\" }}>\n {title}\n </h2>\n )}\n </div>\n )}\n\n {isGrid ? (\n <div\n data-block-group=\"Layout\"\n style={{\n display: \"grid\",\n gridTemplateColumns: `repeat(${Math.min(products.length, 3)}, 1fr)`,\n gap: \"2rem\",\n }}\n >\n {products.map((product: any, index: number) => (\n <div\n key={index}\n style={{\n backgroundColor: \"var(--sg-surface)\",\n borderRadius: \"var(--sg-card-radius, 0.75rem)\",\n overflow: \"hidden\",\n boxShadow: \"var(--sg-card-shadow)\",\n }}\n >\n {product.image && (\n <div\n style={{\n width: \"100%\",\n height: \"200px\",\n backgroundImage: `url(${product.image})`,\n backgroundSize: \"cover\",\n backgroundPosition: \"center\",\n }}\n />\n )}\n <div style={{ padding: \"1.5rem\" }}>\n {product.badge && (\n <span\n style={{\n display: \"inline-block\",\n padding: \"0.125rem 0.5rem\",\n backgroundColor: \"var(--sg-primary)\",\n color: \"#fff\",\n borderRadius: \"9999px\",\n fontSize: \"0.7rem\",\n fontWeight: 600,\n marginBottom: \"0.5rem\",\n }}\n >\n {product.badge}\n </span>\n )}\n <h3 style={{ fontSize: \"1.25rem\", fontWeight: 600, marginBottom: \"0.5rem\" }}>\n {product.icon && <span style={{ marginRight: \"0.5rem\" }}>{product.icon}</span>}\n {product.name}\n </h3>\n <p style={{ color: \"var(--sg-muted-text)\", fontSize: \"0.875rem\" }}>\n {product.description}\n </p>\n {product.primaryButton && (\n <a\n href={product.primaryButton.href || \"#\"}\n className=\"sg-showcase__btn sg-showcase__btn--primary\"\n style={{\n display: \"inline-block\",\n marginTop: \"1rem\",\n padding: \"0.5rem 1rem\",\n backgroundColor: \"var(--sg-primary)\",\n color: \"var(--sg-primary-text)\",\n borderRadius: \"var(--sg-button-radius, 0.5rem)\",\n textDecoration: \"none\",\n fontWeight: 500,\n fontSize: \"0.875rem\",\n ...btnBaseStyle,\n }}\n >\n {product.primaryButton.text}\n </a>\n )}\n </div>\n </div>\n ))}\n </div>\n ) : (\n <div data-block-group=\"Layout\" style={{ display: \"flex\", flexDirection: \"column\", gap: \"4rem\" }}>\n {products.map((product: any, index: number) => {\n const isReversed = variant === \"alternating\" && index % 2 === 1;\n return (\n <div\n key={index}\n style={{\n display: \"flex\",\n gap: \"3rem\",\n alignItems: \"center\",\n flexDirection: isReversed ? \"row-reverse\" : \"row\",\n }}\n >\n {/* Image side */}\n <div style={{ flex: \"1 1 50%\" }}>\n {product.image ? (\n <img\n src={product.image}\n alt={product.name}\n style={{\n width: \"100%\",\n borderRadius: \"var(--sg-card-radius, 0.75rem)\",\n objectFit: \"cover\",\n }}\n />\n ) : (\n <div\n style={{\n width: \"100%\",\n height: \"300px\",\n backgroundColor: \"var(--sg-surface)\",\n borderRadius: \"var(--sg-card-radius, 0.75rem)\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n fontSize: \"4rem\",\n }}\n >\n {product.icon || \"📦\"}\n </div>\n )}\n </div>\n\n {/* Content side */}\n <div style={{ flex: \"1 1 50%\" }}>\n {product.badge && (\n <span\n style={{\n display: \"inline-block\",\n padding: \"0.25rem 0.75rem\",\n backgroundColor: \"var(--sg-primary)\",\n color: \"#fff\",\n borderRadius: \"9999px\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n marginBottom: \"0.75rem\",\n }}\n >\n {product.badge}\n </span>\n )}\n <h3 style={{ fontSize: \"1.5rem\", fontWeight: 700, marginBottom: \"0.75rem\" }}>\n {product.icon && <span style={{ marginRight: \"0.5rem\" }}>{product.icon}</span>}\n {product.name}\n </h3>\n <p style={{ color: \"var(--sg-muted-text)\", marginBottom: \"1rem\", lineHeight: 1.7 }}>\n {product.longDescription || product.description}\n </p>\n {product.features && product.features.length > 0 && (\n <ul style={{ listStyle: \"none\", padding: 0, margin: \"0 0 1.5rem 0\" }}>\n {product.features.map((feat: string, fi: number) => (\n <li\n key={fi}\n style={{\n display: \"flex\",\n alignItems: \"center\",\n gap: \"0.5rem\",\n marginBottom: \"0.5rem\",\n color: \"var(--sg-text)\",\n }}\n >\n <span style={{ color: \"#10b981\", fontWeight: 700 }}>✓</span>\n {feat}\n </li>\n ))}\n </ul>\n )}\n <div style={{ display: \"flex\", gap: \"0.75rem\" }}>\n {product.primaryButton && (\n <a\n href={product.primaryButton.href || \"#\"}\n className=\"sg-showcase__btn sg-showcase__btn--primary\"\n style={{\n padding: \"0.625rem 1.25rem\",\n backgroundColor: \"var(--sg-primary)\",\n color: \"var(--sg-primary-text)\",\n borderRadius: \"var(--sg-button-radius, 0.5rem)\",\n textDecoration: \"none\",\n fontWeight: 500,\n ...btnBaseStyle,\n }}\n >\n {product.primaryButton.text}\n </a>\n )}\n {product.secondaryButton && (\n <a\n href={product.secondaryButton.href || \"#\"}\n className=\"sg-showcase__btn sg-showcase__btn--secondary\"\n style={{\n padding: \"0.625rem 1.25rem\",\n backgroundColor: \"transparent\",\n color: \"var(--sg-primary)\",\n border: \"1px solid var(--sg-primary)\",\n borderRadius: \"var(--sg-button-radius, 0.5rem)\",\n textDecoration: \"none\",\n fontWeight: 500,\n ...btnBaseStyle,\n }}\n >\n {product.secondaryButton.text}\n </a>\n )}\n </div>\n </div>\n </div>\n );\n })}\n </div>\n )}\n </div>\n </section>\n </>\n );\n}\n"],"names":["renderProductShowcase","block","title","subtitle","products","variant","bg","buttonHoverEffect","buttonHoverIntensity","buttonHoverOverlay","buttonHoverIconName","isGrid","scope","hoverCss","primaryResult","generateButtonHoverStyles","outlineResult","getButtonHoverKeyframes","generateButtonOverlayCSS","hasHover","btnBaseStyle","jsxs","Fragment","jsx","product","index","isReversed","feat","fi"],"mappings":"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"}
|
|
@@ -5,34 +5,40 @@ import { renderFeatureGrid as o } from "./FeatureGridRenderer.js";
|
|
|
5
5
|
import { renderPricing as i } from "./PricingRenderer.js";
|
|
6
6
|
import { renderPricingCard as m } from "./PricingCardRenderer.js";
|
|
7
7
|
import { renderTestimonial as s } from "./TestimonialRenderer.js";
|
|
8
|
-
import { renderTestimonialGrid as
|
|
9
|
-
import { renderFaq as
|
|
10
|
-
import { renderFaqItem as
|
|
11
|
-
import { renderCta as
|
|
8
|
+
import { renderTestimonialGrid as n } from "./TestimonialGridRenderer.js";
|
|
9
|
+
import { renderFaq as d } from "./FaqRenderer.js";
|
|
10
|
+
import { renderFaqItem as g } from "./FaqItemRenderer.js";
|
|
11
|
+
import { renderCta as a } from "./CtaRenderer.js";
|
|
12
12
|
import { renderStats as f } from "./StatsRenderer.js";
|
|
13
13
|
import { renderStatItem as p } from "./StatItemRenderer.js";
|
|
14
|
-
import { renderLogoCloud as
|
|
15
|
-
import { renderNavbar as
|
|
16
|
-
import { renderFooter as
|
|
17
|
-
import { renderBlogPostCard as
|
|
18
|
-
import { renderBlogPostGrid as
|
|
19
|
-
import { renderBlogPostDetail as
|
|
14
|
+
import { renderLogoCloud as c } from "./LogoCloudRenderer.js";
|
|
15
|
+
import { renderNavbar as l } from "./NavbarRenderer.js";
|
|
16
|
+
import { renderFooter as u } from "./FooterRenderer.js";
|
|
17
|
+
import { renderBlogPostCard as P } from "./BlogPostCardRenderer.js";
|
|
18
|
+
import { renderBlogPostGrid as C } from "./BlogPostGridRenderer.js";
|
|
19
|
+
import { renderBlogPostDetail as S } from "./BlogPostDetailRenderer.js";
|
|
20
|
+
import { renderProductShowcase as b } from "./ProductShowcaseRenderer.js";
|
|
21
|
+
import { renderAboutSection as G } from "./AboutSectionRenderer.js";
|
|
22
|
+
import { renderContactSection as F } from "./ContactSectionRenderer.js";
|
|
20
23
|
r.register("hero", e);
|
|
21
24
|
r.register("feature", t);
|
|
22
25
|
r.register("featureGrid", o);
|
|
23
26
|
r.register("pricing", i);
|
|
24
27
|
r.register("pricingCard", m);
|
|
25
28
|
r.register("testimonial", s);
|
|
26
|
-
r.register("testimonialGrid",
|
|
27
|
-
r.register("faq",
|
|
28
|
-
r.register("faqItem",
|
|
29
|
-
r.register("cta",
|
|
29
|
+
r.register("testimonialGrid", n);
|
|
30
|
+
r.register("faq", d);
|
|
31
|
+
r.register("faqItem", g);
|
|
32
|
+
r.register("cta", a);
|
|
30
33
|
r.register("stats", f);
|
|
31
34
|
r.register("statItem", p);
|
|
32
|
-
r.register("logoCloud",
|
|
33
|
-
r.register("navbar",
|
|
34
|
-
r.register("footer",
|
|
35
|
-
r.register("blogPostCard",
|
|
36
|
-
r.register("blogPostGrid",
|
|
37
|
-
r.register("blogPostDetail",
|
|
35
|
+
r.register("logoCloud", c);
|
|
36
|
+
r.register("navbar", l);
|
|
37
|
+
r.register("footer", u);
|
|
38
|
+
r.register("blogPostCard", P);
|
|
39
|
+
r.register("blogPostGrid", C);
|
|
40
|
+
r.register("blogPostDetail", S);
|
|
41
|
+
r.register("productShowcase", b);
|
|
42
|
+
r.register("aboutSection", G);
|
|
43
|
+
r.register("contactSection", F);
|
|
38
44
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../../src/engine/render/renderers/sections/index.ts"],"sourcesContent":["/**\n * Section Renderers\n * Auto-registra todos os renderizadores de seções\n */\n\nimport { renderRegistry } from \"../../registry/renderRegistry\";\nimport { renderHero } from \"./HeroRenderer\";\nimport { renderFeature } from \"./FeatureRenderer\";\nimport { renderFeatureGrid } from \"./FeatureGridRenderer\";\nimport { renderPricing } from \"./PricingRenderer\";\nimport { renderPricingCard } from \"./PricingCardRenderer\";\nimport { renderTestimonial } from \"./TestimonialRenderer\";\nimport { renderTestimonialGrid } from \"./TestimonialGridRenderer\";\nimport { renderFaq } from \"./FaqRenderer\";\nimport { renderFaqItem } from \"./FaqItemRenderer\";\nimport { renderCta } from \"./CtaRenderer\";\nimport { renderStats } from \"./StatsRenderer\";\nimport { renderStatItem } from \"./StatItemRenderer\";\nimport { renderLogoCloud } from \"./LogoCloudRenderer\";\nimport { renderNavbar } from \"./NavbarRenderer\";\nimport { renderFooter } from \"./FooterRenderer\";\nimport { renderBlogPostCard } from \"./BlogPostCardRenderer\";\nimport { renderBlogPostGrid } from \"./BlogPostGridRenderer\";\nimport { renderBlogPostDetail } from \"./BlogPostDetailRenderer\";\n\n// Registrar renderizadores\nrenderRegistry.register(\"hero\", renderHero);\nrenderRegistry.register(\"feature\", renderFeature);\nrenderRegistry.register(\"featureGrid\", renderFeatureGrid);\nrenderRegistry.register(\"pricing\", renderPricing);\nrenderRegistry.register(\"pricingCard\", renderPricingCard);\nrenderRegistry.register(\"testimonial\", renderTestimonial);\nrenderRegistry.register(\"testimonialGrid\", renderTestimonialGrid);\nrenderRegistry.register(\"faq\", renderFaq);\nrenderRegistry.register(\"faqItem\", renderFaqItem);\nrenderRegistry.register(\"cta\", renderCta);\nrenderRegistry.register(\"stats\", renderStats);\nrenderRegistry.register(\"statItem\", renderStatItem);\nrenderRegistry.register(\"logoCloud\", renderLogoCloud);\nrenderRegistry.register(\"navbar\", renderNavbar);\nrenderRegistry.register(\"footer\", renderFooter);\nrenderRegistry.register(\"blogPostCard\", renderBlogPostCard);\nrenderRegistry.register(\"blogPostGrid\", renderBlogPostGrid);\nrenderRegistry.register(\"blogPostDetail\", renderBlogPostDetail);\n"],"names":["renderRegistry","renderHero","renderFeature","renderFeatureGrid","renderPricing","renderPricingCard","renderTestimonial","renderTestimonialGrid","renderFaq","renderFaqItem","renderCta","renderStats","renderStatItem","renderLogoCloud","renderNavbar","renderFooter","renderBlogPostCard","renderBlogPostGrid","renderBlogPostDetail"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/engine/render/renderers/sections/index.ts"],"sourcesContent":["/**\n * Section Renderers\n * Auto-registra todos os renderizadores de seções\n */\n\nimport { renderRegistry } from \"../../registry/renderRegistry\";\nimport { renderHero } from \"./HeroRenderer\";\nimport { renderFeature } from \"./FeatureRenderer\";\nimport { renderFeatureGrid } from \"./FeatureGridRenderer\";\nimport { renderPricing } from \"./PricingRenderer\";\nimport { renderPricingCard } from \"./PricingCardRenderer\";\nimport { renderTestimonial } from \"./TestimonialRenderer\";\nimport { renderTestimonialGrid } from \"./TestimonialGridRenderer\";\nimport { renderFaq } from \"./FaqRenderer\";\nimport { renderFaqItem } from \"./FaqItemRenderer\";\nimport { renderCta } from \"./CtaRenderer\";\nimport { renderStats } from \"./StatsRenderer\";\nimport { renderStatItem } from \"./StatItemRenderer\";\nimport { renderLogoCloud } from \"./LogoCloudRenderer\";\nimport { renderNavbar } from \"./NavbarRenderer\";\nimport { renderFooter } from \"./FooterRenderer\";\nimport { renderBlogPostCard } from \"./BlogPostCardRenderer\";\nimport { renderBlogPostGrid } from \"./BlogPostGridRenderer\";\nimport { renderBlogPostDetail } from \"./BlogPostDetailRenderer\";\nimport { renderProductShowcase } from \"./ProductShowcaseRenderer\";\nimport { renderAboutSection } from \"./AboutSectionRenderer\";\nimport { renderContactSection } from \"./ContactSectionRenderer\";\n\n// Registrar renderizadores\nrenderRegistry.register(\"hero\", renderHero);\nrenderRegistry.register(\"feature\", renderFeature);\nrenderRegistry.register(\"featureGrid\", renderFeatureGrid);\nrenderRegistry.register(\"pricing\", renderPricing);\nrenderRegistry.register(\"pricingCard\", renderPricingCard);\nrenderRegistry.register(\"testimonial\", renderTestimonial);\nrenderRegistry.register(\"testimonialGrid\", renderTestimonialGrid);\nrenderRegistry.register(\"faq\", renderFaq);\nrenderRegistry.register(\"faqItem\", renderFaqItem);\nrenderRegistry.register(\"cta\", renderCta);\nrenderRegistry.register(\"stats\", renderStats);\nrenderRegistry.register(\"statItem\", renderStatItem);\nrenderRegistry.register(\"logoCloud\", renderLogoCloud);\nrenderRegistry.register(\"navbar\", renderNavbar);\nrenderRegistry.register(\"footer\", renderFooter);\nrenderRegistry.register(\"blogPostCard\", renderBlogPostCard);\nrenderRegistry.register(\"blogPostGrid\", renderBlogPostGrid);\nrenderRegistry.register(\"blogPostDetail\", renderBlogPostDetail);\nrenderRegistry.register(\"productShowcase\", renderProductShowcase);\nrenderRegistry.register(\"aboutSection\", renderAboutSection);\nrenderRegistry.register(\"contactSection\", renderContactSection);\n"],"names":["renderRegistry","renderHero","renderFeature","renderFeatureGrid","renderPricing","renderPricingCard","renderTestimonial","renderTestimonialGrid","renderFaq","renderFaqItem","renderCta","renderStats","renderStatItem","renderLogoCloud","renderNavbar","renderFooter","renderBlogPostCard","renderBlogPostGrid","renderBlogPostDetail","renderProductShowcase","renderAboutSection","renderContactSection"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AA6BAA,EAAe,SAAS,QAAQC,CAAU;AAC1CD,EAAe,SAAS,WAAWE,CAAa;AAChDF,EAAe,SAAS,eAAeG,CAAiB;AACxDH,EAAe,SAAS,WAAWI,CAAa;AAChDJ,EAAe,SAAS,eAAeK,CAAiB;AACxDL,EAAe,SAAS,eAAeM,CAAiB;AACxDN,EAAe,SAAS,mBAAmBO,CAAqB;AAChEP,EAAe,SAAS,OAAOQ,CAAS;AACxCR,EAAe,SAAS,WAAWS,CAAa;AAChDT,EAAe,SAAS,OAAOU,CAAS;AACxCV,EAAe,SAAS,SAASW,CAAW;AAC5CX,EAAe,SAAS,YAAYY,CAAc;AAClDZ,EAAe,SAAS,aAAaa,CAAe;AACpDb,EAAe,SAAS,UAAUc,CAAY;AAC9Cd,EAAe,SAAS,UAAUe,CAAY;AAC9Cf,EAAe,SAAS,gBAAgBgB,CAAkB;AAC1DhB,EAAe,SAAS,gBAAgBiB,CAAkB;AAC1DjB,EAAe,SAAS,kBAAkBkB,CAAoB;AAC9DlB,EAAe,SAAS,mBAAmBmB,CAAqB;AAChEnB,EAAe,SAAS,gBAAgBoB,CAAkB;AAC1DpB,EAAe,SAAS,kBAAkBqB,CAAoB;"}
|
|
@@ -7,7 +7,7 @@ export type { TypographyConfig } from '../shared/typography';
|
|
|
7
7
|
/**
|
|
8
8
|
* Tipos de blocos disponíveis
|
|
9
9
|
*/
|
|
10
|
-
export type BlockType = "container" | "stack" | "grid" | "box" | "spacer" | "heading" | "text" | "image" | "button" | "link" | "divider" | "badge" | "icon" | "avatar" | "video" | "socialLinks" | "card" | "section" | "hero" | "feature" | "featureGrid" | "pricing" | "pricingCard" | "testimonial" | "testimonialGrid" | "faq" | "faqItem" | "cta" | "stats" | "statItem" | "logoCloud" | "navbar" | "footer" | "countdown" | "carousel" | "blogCard" | "blogCardGrid" | "teamCard" | "teamGrid" | "courseCardGrid" | "categoryCardGrid" | "blogPostCard" | "blogPostGrid" | "blogPostDetail" | "form" | "input" | "textarea" | "formSelect";
|
|
10
|
+
export type BlockType = "container" | "stack" | "grid" | "box" | "spacer" | "heading" | "text" | "image" | "button" | "link" | "divider" | "badge" | "icon" | "avatar" | "video" | "socialLinks" | "card" | "section" | "hero" | "feature" | "featureGrid" | "pricing" | "pricingCard" | "testimonial" | "testimonialGrid" | "faq" | "faqItem" | "cta" | "stats" | "statItem" | "logoCloud" | "navbar" | "footer" | "countdown" | "carousel" | "blogCard" | "blogCardGrid" | "teamCard" | "teamGrid" | "courseCardGrid" | "categoryCardGrid" | "blogPostCard" | "blogPostGrid" | "blogPostDetail" | "productShowcase" | "aboutSection" | "contactSection" | "form" | "input" | "textarea" | "formSelect";
|
|
11
11
|
/**
|
|
12
12
|
* Props base de um bloco
|
|
13
13
|
*/
|
|
@@ -915,6 +915,100 @@ export interface BlogPostDetailBlock extends BlockBase {
|
|
|
915
915
|
contentMaxWidth?: string;
|
|
916
916
|
};
|
|
917
917
|
}
|
|
918
|
+
/**
|
|
919
|
+
* ProductShowcase - Seção de produtos com layout alternado
|
|
920
|
+
*/
|
|
921
|
+
export interface ProductShowcaseBlock extends BlockBase {
|
|
922
|
+
type: "productShowcase";
|
|
923
|
+
props: {
|
|
924
|
+
title?: string;
|
|
925
|
+
subtitle?: string;
|
|
926
|
+
products: Array<{
|
|
927
|
+
image?: string;
|
|
928
|
+
icon?: string;
|
|
929
|
+
badge?: string;
|
|
930
|
+
name: string;
|
|
931
|
+
description: string;
|
|
932
|
+
longDescription?: string;
|
|
933
|
+
features?: string[];
|
|
934
|
+
primaryButton?: {
|
|
935
|
+
text: string;
|
|
936
|
+
href?: string;
|
|
937
|
+
};
|
|
938
|
+
secondaryButton?: {
|
|
939
|
+
text: string;
|
|
940
|
+
href?: string;
|
|
941
|
+
};
|
|
942
|
+
}>;
|
|
943
|
+
variant?: "alternating" | "grid" | "stacked";
|
|
944
|
+
bg?: string;
|
|
945
|
+
buttonHoverEffect?: "none" | "darken" | "lighten" | "scale" | "glow" | "shadow" | "pulse";
|
|
946
|
+
buttonHoverIntensity?: number;
|
|
947
|
+
buttonHoverOverlay?: "none" | "shine" | "fill" | "bounce" | "icon" | "border-glow";
|
|
948
|
+
buttonHoverIconName?: string;
|
|
949
|
+
};
|
|
950
|
+
}
|
|
951
|
+
/**
|
|
952
|
+
* AboutSection - Seção sobre com imagem decorativa + texto + achievements
|
|
953
|
+
*/
|
|
954
|
+
export interface AboutSectionBlock extends BlockBase {
|
|
955
|
+
type: "aboutSection";
|
|
956
|
+
props: {
|
|
957
|
+
title?: string;
|
|
958
|
+
subtitle?: string;
|
|
959
|
+
description?: string;
|
|
960
|
+
secondaryDescription?: string;
|
|
961
|
+
image?: string;
|
|
962
|
+
achievements?: Array<{
|
|
963
|
+
text: string;
|
|
964
|
+
}>;
|
|
965
|
+
primaryButton?: {
|
|
966
|
+
text: string;
|
|
967
|
+
href?: string;
|
|
968
|
+
};
|
|
969
|
+
variant?: "image-left" | "image-right" | "centered";
|
|
970
|
+
bg?: string;
|
|
971
|
+
stats?: Array<{
|
|
972
|
+
value: string;
|
|
973
|
+
label: string;
|
|
974
|
+
}>;
|
|
975
|
+
buttonHoverEffect?: "none" | "darken" | "lighten" | "scale" | "glow" | "shadow" | "pulse";
|
|
976
|
+
buttonHoverIntensity?: number;
|
|
977
|
+
buttonHoverOverlay?: "none" | "shine" | "fill" | "bounce" | "icon" | "border-glow";
|
|
978
|
+
buttonHoverIconName?: string;
|
|
979
|
+
};
|
|
980
|
+
}
|
|
981
|
+
/**
|
|
982
|
+
* ContactSection - Seção de contato com info cards + formulário
|
|
983
|
+
*/
|
|
984
|
+
export interface ContactSectionBlock extends BlockBase {
|
|
985
|
+
type: "contactSection";
|
|
986
|
+
props: {
|
|
987
|
+
title?: string;
|
|
988
|
+
subtitle?: string;
|
|
989
|
+
description?: string;
|
|
990
|
+
contactInfo?: Array<{
|
|
991
|
+
icon?: string;
|
|
992
|
+
label: string;
|
|
993
|
+
value: string;
|
|
994
|
+
}>;
|
|
995
|
+
formTitle?: string;
|
|
996
|
+
formFields?: Array<{
|
|
997
|
+
name: string;
|
|
998
|
+
label: string;
|
|
999
|
+
type: "text" | "email" | "tel" | "textarea";
|
|
1000
|
+
placeholder?: string;
|
|
1001
|
+
required?: boolean;
|
|
1002
|
+
}>;
|
|
1003
|
+
submitText?: string;
|
|
1004
|
+
variant?: "split" | "stacked" | "form-only";
|
|
1005
|
+
bg?: string;
|
|
1006
|
+
buttonHoverEffect?: "none" | "darken" | "lighten" | "scale" | "glow" | "shadow" | "pulse";
|
|
1007
|
+
buttonHoverIntensity?: number;
|
|
1008
|
+
buttonHoverOverlay?: "none" | "shine" | "fill" | "bounce" | "icon" | "border-glow";
|
|
1009
|
+
buttonHoverIconName?: string;
|
|
1010
|
+
};
|
|
1011
|
+
}
|
|
918
1012
|
/**
|
|
919
1013
|
* Form - Container de formulário
|
|
920
1014
|
*/
|
|
@@ -972,7 +1066,7 @@ export interface FormSelectBlock extends BlockBase {
|
|
|
972
1066
|
/**
|
|
973
1067
|
* Union type de todos os blocos
|
|
974
1068
|
*/
|
|
975
|
-
export type Block = ContainerBlock | StackBlock | GridBlock | BoxBlock | SpacerBlock | HeadingBlock | TextBlock | ImageBlock | ButtonBlock | LinkBlock | DividerBlock | BadgeBlock | IconBlock | AvatarBlock | VideoBlock | SocialLinksBlock | CardBlock | SectionBlock | HeroBlock | FeatureBlock | FeatureGridBlock | PricingBlock | PricingCardBlock | TestimonialBlock | TestimonialGridBlock | FaqBlock | FaqItemBlock | CtaBlock | StatsBlock | StatItemBlock | LogoCloudBlock | NavbarBlock | FooterBlock | CountdownBlock | CarouselBlock | BlogCardBlock | BlogCardGridBlock | TeamCardBlock | TeamGridBlock | CourseCardGridBlock | CategoryCardGridBlock | BlogPostCardBlock | BlogPostGridBlock | BlogPostDetailBlock | FormBlock | InputBlock | TextareaBlock | FormSelectBlock;
|
|
1069
|
+
export type Block = ContainerBlock | StackBlock | GridBlock | BoxBlock | SpacerBlock | HeadingBlock | TextBlock | ImageBlock | ButtonBlock | LinkBlock | DividerBlock | BadgeBlock | IconBlock | AvatarBlock | VideoBlock | SocialLinksBlock | CardBlock | SectionBlock | HeroBlock | FeatureBlock | FeatureGridBlock | PricingBlock | PricingCardBlock | TestimonialBlock | TestimonialGridBlock | FaqBlock | FaqItemBlock | CtaBlock | StatsBlock | StatItemBlock | LogoCloudBlock | NavbarBlock | FooterBlock | CountdownBlock | CarouselBlock | BlogCardBlock | BlogCardGridBlock | TeamCardBlock | TeamGridBlock | CourseCardGridBlock | CategoryCardGridBlock | BlogPostCardBlock | BlogPostGridBlock | BlogPostDetailBlock | ProductShowcaseBlock | AboutSectionBlock | ContactSectionBlock | FormBlock | InputBlock | TextareaBlock | FormSelectBlock;
|
|
976
1070
|
/**
|
|
977
1071
|
* Utility type: extract the block interface for a given BlockType
|
|
978
1072
|
*/
|