@brunoalz/smartgesti-site-editor 1.0.0 → 1.2.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.
Files changed (219) hide show
  1. package/dist/editor/BlockSelector.d.ts.map +1 -1
  2. package/dist/editor/BlockSelector.js +60 -57
  3. package/dist/editor/BlockSelector.js.map +1 -1
  4. package/dist/editor/LandingPageEditor.d.ts.map +1 -1
  5. package/dist/editor/LandingPageEditor.js +145 -128
  6. package/dist/editor/LandingPageEditor.js.map +1 -1
  7. package/dist/editor/PageTabBar.d.ts +4 -1
  8. package/dist/editor/PageTabBar.d.ts.map +1 -1
  9. package/dist/editor/PageTabBar.js +179 -41
  10. package/dist/editor/PageTabBar.js.map +1 -1
  11. package/dist/editor/PropertyEditor/BlockPropertyEditor.d.ts +2 -0
  12. package/dist/editor/PropertyEditor/BlockPropertyEditor.d.ts.map +1 -1
  13. package/dist/editor/PropertyEditor/BlockPropertyEditor.js +53 -45
  14. package/dist/editor/PropertyEditor/BlockPropertyEditor.js.map +1 -1
  15. package/dist/editor/PropertyEditor/CollapsiblePropertyGroup.d.ts +2 -0
  16. package/dist/editor/PropertyEditor/CollapsiblePropertyGroup.d.ts.map +1 -1
  17. package/dist/editor/PropertyEditor/CollapsiblePropertyGroup.js +47 -33
  18. package/dist/editor/PropertyEditor/CollapsiblePropertyGroup.js.map +1 -1
  19. package/dist/editor/PropertyEditor/VariationSelector.d.ts.map +1 -1
  20. package/dist/editor/PropertyEditor/VariationSelector.js +10 -6
  21. package/dist/editor/PropertyEditor/VariationSelector.js.map +1 -1
  22. package/dist/editor/PropertyEditor/index.js +20 -18
  23. package/dist/editor/PropertyEditor/index.js.map +1 -1
  24. package/dist/editor/PropertyEditor/inputs/CarouselImagesInput.d.ts +16 -0
  25. package/dist/editor/PropertyEditor/inputs/CarouselImagesInput.d.ts.map +1 -0
  26. package/dist/editor/PropertyEditor/inputs/CarouselImagesInput.js +170 -0
  27. package/dist/editor/PropertyEditor/inputs/CarouselImagesInput.js.map +1 -0
  28. package/dist/editor/PropertyEditor/inputs/ImageGridInput.d.ts.map +1 -1
  29. package/dist/editor/PropertyEditor/inputs/ImageGridInput.js +148 -121
  30. package/dist/editor/PropertyEditor/inputs/ImageGridInput.js.map +1 -1
  31. package/dist/editor/PropertyEditor/inputs/index.d.ts +1 -0
  32. package/dist/editor/PropertyEditor/inputs/index.d.ts.map +1 -1
  33. package/dist/editor/PropertyEditor/renderPropertyInput.d.ts.map +1 -1
  34. package/dist/editor/PropertyEditor/renderPropertyInput.js +167 -139
  35. package/dist/editor/PropertyEditor/renderPropertyInput.js.map +1 -1
  36. package/dist/editor/components/CenterPanel.d.ts +9 -1
  37. package/dist/editor/components/CenterPanel.d.ts.map +1 -1
  38. package/dist/editor/components/CenterPanel.js +24 -14
  39. package/dist/editor/components/CenterPanel.js.map +1 -1
  40. package/dist/editor/components/RightPanel.d.ts +5 -0
  41. package/dist/editor/components/RightPanel.d.ts.map +1 -1
  42. package/dist/editor/components/RightPanel.js +18 -12
  43. package/dist/editor/components/RightPanel.js.map +1 -1
  44. package/dist/editor/components/Toolbar.d.ts +3 -0
  45. package/dist/editor/components/Toolbar.d.ts.map +1 -1
  46. package/dist/editor/components/Toolbar.js +54 -35
  47. package/dist/editor/components/Toolbar.js.map +1 -1
  48. package/dist/engine/export/exportHtml.d.ts.map +1 -1
  49. package/dist/engine/export/exportHtml.js +50 -50
  50. package/dist/engine/export/exportHtml.js.map +1 -1
  51. package/dist/engine/export/exporters/sections/BlogPostExporters.d.ts +6 -0
  52. package/dist/engine/export/exporters/sections/BlogPostExporters.d.ts.map +1 -0
  53. package/dist/engine/export/exporters/sections/BlogPostExporters.js +101 -0
  54. package/dist/engine/export/exporters/sections/BlogPostExporters.js.map +1 -0
  55. package/dist/engine/export/exporters/sections/FooterExporter.js +22 -22
  56. package/dist/engine/export/exporters/sections/FooterExporter.js.map +1 -1
  57. package/dist/engine/export/exporters/sections/HeroExporter.d.ts.map +1 -1
  58. package/dist/engine/export/exporters/sections/HeroExporter.js +222 -205
  59. package/dist/engine/export/exporters/sections/HeroExporter.js.map +1 -1
  60. package/dist/engine/export/exporters/sections/MarketingExporters.js +88 -88
  61. package/dist/engine/export/exporters/sections/MarketingExporters.js.map +1 -1
  62. package/dist/engine/export/exporters/sections/NavbarExporter.js +34 -34
  63. package/dist/engine/export/exporters/sections/NavbarExporter.js.map +1 -1
  64. package/dist/engine/export/exporters/sections/index.d.ts.map +1 -1
  65. package/dist/engine/export/exporters/sections/index.js +29 -22
  66. package/dist/engine/export/exporters/sections/index.js.map +1 -1
  67. package/dist/engine/index.d.ts +3 -0
  68. package/dist/engine/index.d.ts.map +1 -1
  69. package/dist/engine/index.js +99 -87
  70. package/dist/engine/index.js.map +1 -1
  71. package/dist/engine/plugins/builtin/blog/index.d.ts +3 -0
  72. package/dist/engine/plugins/builtin/blog/index.d.ts.map +1 -0
  73. package/dist/engine/plugins/builtin/blog/manifest.d.ts +3 -0
  74. package/dist/engine/plugins/builtin/blog/manifest.d.ts.map +1 -0
  75. package/dist/engine/plugins/builtin/blog/manifest.js +273 -0
  76. package/dist/engine/plugins/builtin/blog/manifest.js.map +1 -0
  77. package/dist/engine/plugins/builtin/blog/mockContentProvider.d.ts +7 -0
  78. package/dist/engine/plugins/builtin/blog/mockContentProvider.d.ts.map +1 -0
  79. package/dist/engine/plugins/builtin/blog/mockContentProvider.js +135 -0
  80. package/dist/engine/plugins/builtin/blog/mockContentProvider.js.map +1 -0
  81. package/dist/engine/plugins/contentHydration.d.ts +17 -0
  82. package/dist/engine/plugins/contentHydration.d.ts.map +1 -0
  83. package/dist/engine/plugins/contentHydration.js +121 -0
  84. package/dist/engine/plugins/contentHydration.js.map +1 -0
  85. package/dist/engine/plugins/dynamicPageResolver.d.ts +25 -0
  86. package/dist/engine/plugins/dynamicPageResolver.d.ts.map +1 -0
  87. package/dist/engine/plugins/dynamicPageResolver.js +32 -0
  88. package/dist/engine/plugins/dynamicPageResolver.js.map +1 -0
  89. package/dist/engine/plugins/index.d.ts +11 -0
  90. package/dist/engine/plugins/index.d.ts.map +1 -0
  91. package/dist/engine/plugins/pluginRegistry.d.ts +37 -0
  92. package/dist/engine/plugins/pluginRegistry.d.ts.map +1 -0
  93. package/dist/engine/plugins/pluginRegistry.js +134 -0
  94. package/dist/engine/plugins/pluginRegistry.js.map +1 -0
  95. package/dist/engine/plugins/types.d.ts +180 -0
  96. package/dist/engine/plugins/types.d.ts.map +1 -0
  97. package/dist/engine/presets/heroVariations.d.ts +5 -0
  98. package/dist/engine/presets/heroVariations.d.ts.map +1 -1
  99. package/dist/engine/presets/heroVariations.js +50 -6
  100. package/dist/engine/presets/heroVariations.js.map +1 -1
  101. package/dist/engine/preview/Preview.d.ts +6 -2
  102. package/dist/engine/preview/Preview.d.ts.map +1 -1
  103. package/dist/engine/preview/Preview.js +295 -125
  104. package/dist/engine/preview/Preview.js.map +1 -1
  105. package/dist/engine/registry/blocks/sections/blogPostCard.d.ts +3 -0
  106. package/dist/engine/registry/blocks/sections/blogPostCard.d.ts.map +1 -0
  107. package/dist/engine/registry/blocks/sections/blogPostCard.js +53 -0
  108. package/dist/engine/registry/blocks/sections/blogPostCard.js.map +1 -0
  109. package/dist/engine/registry/blocks/sections/blogPostDetail.d.ts +3 -0
  110. package/dist/engine/registry/blocks/sections/blogPostDetail.d.ts.map +1 -0
  111. package/dist/engine/registry/blocks/sections/blogPostDetail.js +49 -0
  112. package/dist/engine/registry/blocks/sections/blogPostDetail.js.map +1 -0
  113. package/dist/engine/registry/blocks/sections/blogPostGrid.d.ts +3 -0
  114. package/dist/engine/registry/blocks/sections/blogPostGrid.d.ts.map +1 -0
  115. package/dist/engine/registry/blocks/sections/blogPostGrid.js +89 -0
  116. package/dist/engine/registry/blocks/sections/blogPostGrid.js.map +1 -0
  117. package/dist/engine/registry/blocks/sections/hero.d.ts.map +1 -1
  118. package/dist/engine/registry/blocks/sections/hero.js +67 -14
  119. package/dist/engine/registry/blocks/sections/hero.js.map +1 -1
  120. package/dist/engine/registry/blocks/sections/index.d.ts +3 -0
  121. package/dist/engine/registry/blocks/sections/index.d.ts.map +1 -1
  122. package/dist/engine/registry/blocks/sections/navbar.d.ts.map +1 -1
  123. package/dist/engine/registry/blocks/sections/navbar.js +2 -1
  124. package/dist/engine/registry/blocks/sections/navbar.js.map +1 -1
  125. package/dist/engine/registry/registry.d.ts.map +1 -1
  126. package/dist/engine/registry/registry.js +16 -12
  127. package/dist/engine/registry/registry.js.map +1 -1
  128. package/dist/engine/registry/types.d.ts +10 -6
  129. package/dist/engine/registry/types.d.ts.map +1 -1
  130. package/dist/engine/render/renderers/sections/BlogPostCardRenderer.d.ts +3 -0
  131. package/dist/engine/render/renderers/sections/BlogPostCardRenderer.d.ts.map +1 -0
  132. package/dist/engine/render/renderers/sections/BlogPostCardRenderer.js +199 -0
  133. package/dist/engine/render/renderers/sections/BlogPostCardRenderer.js.map +1 -0
  134. package/dist/engine/render/renderers/sections/BlogPostDetailRenderer.d.ts +3 -0
  135. package/dist/engine/render/renderers/sections/BlogPostDetailRenderer.d.ts.map +1 -0
  136. package/dist/engine/render/renderers/sections/BlogPostDetailRenderer.js +293 -0
  137. package/dist/engine/render/renderers/sections/BlogPostDetailRenderer.js.map +1 -0
  138. package/dist/engine/render/renderers/sections/BlogPostGridRenderer.d.ts +3 -0
  139. package/dist/engine/render/renderers/sections/BlogPostGridRenderer.d.ts.map +1 -0
  140. package/dist/engine/render/renderers/sections/BlogPostGridRenderer.js +101 -0
  141. package/dist/engine/render/renderers/sections/BlogPostGridRenderer.js.map +1 -0
  142. package/dist/engine/render/renderers/sections/CtaRenderer.d.ts.map +1 -1
  143. package/dist/engine/render/renderers/sections/CtaRenderer.js +33 -31
  144. package/dist/engine/render/renderers/sections/CtaRenderer.js.map +1 -1
  145. package/dist/engine/render/renderers/sections/FaqItemRenderer.d.ts.map +1 -1
  146. package/dist/engine/render/renderers/sections/FaqItemRenderer.js +7 -6
  147. package/dist/engine/render/renderers/sections/FaqItemRenderer.js.map +1 -1
  148. package/dist/engine/render/renderers/sections/FaqRenderer.js +7 -7
  149. package/dist/engine/render/renderers/sections/FaqRenderer.js.map +1 -1
  150. package/dist/engine/render/renderers/sections/FeatureGridRenderer.d.ts.map +1 -1
  151. package/dist/engine/render/renderers/sections/FeatureGridRenderer.js +19 -18
  152. package/dist/engine/render/renderers/sections/FeatureGridRenderer.js.map +1 -1
  153. package/dist/engine/render/renderers/sections/FeatureRenderer.d.ts.map +1 -1
  154. package/dist/engine/render/renderers/sections/FeatureRenderer.js +5 -4
  155. package/dist/engine/render/renderers/sections/FeatureRenderer.js.map +1 -1
  156. package/dist/engine/render/renderers/sections/FooterRenderer.d.ts.map +1 -1
  157. package/dist/engine/render/renderers/sections/FooterRenderer.js +8 -7
  158. package/dist/engine/render/renderers/sections/FooterRenderer.js.map +1 -1
  159. package/dist/engine/render/renderers/sections/HeroRenderer.d.ts.map +1 -1
  160. package/dist/engine/render/renderers/sections/HeroRenderer.js +295 -218
  161. package/dist/engine/render/renderers/sections/HeroRenderer.js.map +1 -1
  162. package/dist/engine/render/renderers/sections/NavbarRenderer.d.ts.map +1 -1
  163. package/dist/engine/render/renderers/sections/NavbarRenderer.js +23 -22
  164. package/dist/engine/render/renderers/sections/NavbarRenderer.js.map +1 -1
  165. package/dist/engine/render/renderers/sections/PricingCardRenderer.d.ts.map +1 -1
  166. package/dist/engine/render/renderers/sections/PricingCardRenderer.js +7 -6
  167. package/dist/engine/render/renderers/sections/PricingCardRenderer.js.map +1 -1
  168. package/dist/engine/render/renderers/sections/PricingRenderer.js +9 -9
  169. package/dist/engine/render/renderers/sections/PricingRenderer.js.map +1 -1
  170. package/dist/engine/render/renderers/sections/TestimonialGridRenderer.d.ts.map +1 -1
  171. package/dist/engine/render/renderers/sections/TestimonialGridRenderer.js +17 -16
  172. package/dist/engine/render/renderers/sections/TestimonialGridRenderer.js.map +1 -1
  173. package/dist/engine/render/renderers/sections/TestimonialRenderer.d.ts.map +1 -1
  174. package/dist/engine/render/renderers/sections/TestimonialRenderer.js +11 -10
  175. package/dist/engine/render/renderers/sections/TestimonialRenderer.js.map +1 -1
  176. package/dist/engine/render/renderers/sections/index.js +24 -18
  177. package/dist/engine/render/renderers/sections/index.js.map +1 -1
  178. package/dist/engine/schema/siteDocument.d.ts +104 -3
  179. package/dist/engine/schema/siteDocument.d.ts.map +1 -1
  180. package/dist/engine/schema/siteDocument.js.map +1 -1
  181. package/dist/engine/shared/carouselAnimation.d.ts +20 -0
  182. package/dist/engine/shared/carouselAnimation.d.ts.map +1 -0
  183. package/dist/engine/shared/carouselAnimation.js +62 -0
  184. package/dist/engine/shared/carouselAnimation.js.map +1 -0
  185. package/dist/engine/shared/imageGrid/types.d.ts +2 -0
  186. package/dist/engine/shared/imageGrid/types.d.ts.map +1 -1
  187. package/dist/engine/shared/showWhen.d.ts +44 -0
  188. package/dist/engine/shared/showWhen.d.ts.map +1 -0
  189. package/dist/engine/shared/showWhen.js +33 -0
  190. package/dist/engine/shared/showWhen.js.map +1 -0
  191. package/dist/hooks/useEditorState.d.ts +3 -0
  192. package/dist/hooks/useEditorState.d.ts.map +1 -1
  193. package/dist/hooks/useEditorState.js +106 -84
  194. package/dist/hooks/useEditorState.js.map +1 -1
  195. package/dist/index.d.ts +13 -2
  196. package/dist/index.d.ts.map +1 -1
  197. package/dist/index.js +109 -93
  198. package/dist/index.js.map +1 -1
  199. package/dist/shared/templates/escola-blog.d.ts +3 -0
  200. package/dist/shared/templates/escola-blog.d.ts.map +1 -0
  201. package/dist/shared/templates/escola-blog.js +160 -0
  202. package/dist/shared/templates/escola-blog.js.map +1 -0
  203. package/dist/shared/templates/index.d.ts +2 -0
  204. package/dist/shared/templates/index.d.ts.map +1 -1
  205. package/dist/shared/templates/index.js +30 -12
  206. package/dist/shared/templates/index.js.map +1 -1
  207. package/dist/utils/changeDetector.d.ts +2 -1
  208. package/dist/utils/changeDetector.d.ts.map +1 -1
  209. package/dist/utils/changeDetector.js +39 -39
  210. package/dist/utils/changeDetector.js.map +1 -1
  211. package/dist/utils/sharedTemplateToEngine.d.ts +4 -5
  212. package/dist/utils/sharedTemplateToEngine.d.ts.map +1 -1
  213. package/dist/utils/sharedTemplateToEngine.js +14 -87
  214. package/dist/utils/sharedTemplateToEngine.js.map +1 -1
  215. package/dist/viewer/LandingPageViewer.d.ts +13 -6
  216. package/dist/viewer/LandingPageViewer.d.ts.map +1 -1
  217. package/dist/viewer/LandingPageViewer.js +220 -122
  218. package/dist/viewer/LandingPageViewer.js.map +1 -1
  219. package/package.json +3 -2
@@ -1,140 +1,150 @@
1
- import { jsx as s } from "react/jsx-runtime";
2
- import { TypographyInput as w } from "./inputs/TypographyInput.js";
3
- import { ImageGridInput as M } from "./inputs/ImageGridInput.js";
4
- import { IconGridInput as S } from "./inputs/IconGridInput.js";
5
- import { ToggleButton as x } from "./inputs/ToggleButton.js";
6
- import { ImageInput as G } from "./inputs/ImageInput.js";
7
- import { ColorInput as g } from "./inputs/ColorInput.js";
8
- import { SliderInput as z } from "./inputs/SliderInput.js";
9
- import { ButtonGroupInput as k } from "./inputs/ButtonGroupInput.js";
10
- import { SelectInput as B } from "./inputs/SelectInput.js";
11
- import { NumberInput as F } from "./inputs/NumberInput.js";
12
- import { TextAreaInput as j } from "./inputs/TextAreaInput.js";
13
- import { TextInput as q } from "./inputs/TextInput.js";
14
- function T(t, I, e, i, d, l) {
15
- const { label: r, description: u, inputType: y, options: n, min: a, max: f, step: p, size: h } = I;
16
- switch (y) {
1
+ import { jsxs as h, jsx as e } from "react/jsx-runtime";
2
+ import { TypographyInput as M } from "./inputs/TypographyInput.js";
3
+ import { CarouselImagesInput as U } from "./inputs/CarouselImagesInput.js";
4
+ import { ImageGridInput as k } from "./inputs/ImageGridInput.js";
5
+ import { IconGridInput as z } from "./inputs/IconGridInput.js";
6
+ import { ToggleButton as S } from "./inputs/ToggleButton.js";
7
+ import { ImageInput as x } from "./inputs/ImageInput.js";
8
+ import { ColorInput as b } from "./inputs/ColorInput.js";
9
+ import { SliderInput as B } from "./inputs/SliderInput.js";
10
+ import { ButtonGroupInput as V } from "./inputs/ButtonGroupInput.js";
11
+ import { SelectInput as j } from "./inputs/SelectInput.js";
12
+ import { NumberInput as v } from "./inputs/NumberInput.js";
13
+ import { TextAreaInput as F } from "./inputs/TextAreaInput.js";
14
+ import { TextInput as H } from "./inputs/TextInput.js";
15
+ function G(r, c, i, s, d, a) {
16
+ const { label: t, description: l, inputType: T, options: n, min: f, max: p, step: y, size: P } = c;
17
+ if (c.readOnly)
18
+ return /* @__PURE__ */ h("div", { className: "relative", children: [
19
+ /* @__PURE__ */ h("div", { className: "flex items-center gap-1 mb-1", children: [
20
+ /* @__PURE__ */ e("svg", { className: "w-3 h-3 text-gray-400", viewBox: "0 0 16 16", fill: "currentColor", children: /* @__PURE__ */ e("path", { d: "M8 1a4 4 0 0 0-4 4v2H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1h-1V5a4 4 0 0 0-4-4zm2 6H6V5a2 2 0 1 1 4 0v2z" }) }),
21
+ /* @__PURE__ */ e("span", { className: "text-xs font-medium text-gray-400", children: t })
22
+ ] }),
23
+ /* @__PURE__ */ e("div", { className: "px-2 py-1.5 text-xs text-gray-500 dark:text-gray-400 bg-gray-100 dark:bg-gray-800 rounded border border-gray-200 dark:border-gray-700 cursor-not-allowed select-none truncate", children: i != null ? String(i) : "—" }),
24
+ l && /* @__PURE__ */ e("p", { className: "text-xs text-gray-400 mt-0.5 italic", children: l })
25
+ ] }, r);
26
+ switch (T) {
17
27
  case "text":
18
- return /* @__PURE__ */ s(
19
- q,
28
+ return /* @__PURE__ */ e(
29
+ H,
20
30
  {
21
- value: e || "",
22
- onChange: i,
23
- label: r,
24
- description: u,
25
- placeholder: r
31
+ value: i || "",
32
+ onChange: s,
33
+ label: t,
34
+ description: l,
35
+ placeholder: t
26
36
  },
27
- t
37
+ r
28
38
  );
29
39
  case "textarea":
30
- return /* @__PURE__ */ s(
31
- j,
40
+ return /* @__PURE__ */ e(
41
+ F,
32
42
  {
33
- value: e || "",
34
- onChange: i,
35
- label: r,
36
- description: u,
37
- placeholder: r,
43
+ value: i || "",
44
+ onChange: s,
45
+ label: t,
46
+ description: l,
47
+ placeholder: t,
38
48
  rows: 3
39
49
  },
40
- t
50
+ r
41
51
  );
42
52
  case "number":
43
- return /* @__PURE__ */ s(
44
- F,
53
+ return /* @__PURE__ */ e(
54
+ v,
45
55
  {
46
- value: e,
47
- onChange: i,
48
- label: r,
49
- description: u,
50
- placeholder: r,
51
- min: a,
52
- max: f,
53
- step: p
56
+ value: i,
57
+ onChange: s,
58
+ label: t,
59
+ description: l,
60
+ placeholder: t,
61
+ min: f,
62
+ max: p,
63
+ step: y
54
64
  },
55
- t
65
+ r
56
66
  );
57
67
  case "color":
58
- return /* @__PURE__ */ s(
59
- g,
68
+ return /* @__PURE__ */ e(
69
+ b,
60
70
  {
61
- value: e,
62
- onChange: i,
63
- label: r,
64
- description: u
71
+ value: i,
72
+ onChange: s,
73
+ label: t,
74
+ description: l
65
75
  },
66
- t
76
+ r
67
77
  );
68
78
  case "select":
69
- return !n || n.length === 0 ? T(
70
- t,
71
- { ...I, inputType: "text" },
72
- e,
79
+ return !n || n.length === 0 ? G(
80
+ r,
81
+ { ...c, inputType: "text" },
73
82
  i,
83
+ s,
74
84
  d
75
- ) : n.length <= 3 ? /* @__PURE__ */ s(
76
- k,
85
+ ) : n.length <= 3 ? /* @__PURE__ */ e(
86
+ V,
77
87
  {
78
- value: e,
79
- onChange: i,
80
- label: r,
81
- description: u,
88
+ value: i,
89
+ onChange: s,
90
+ label: t,
91
+ description: l,
82
92
  options: n
83
93
  },
84
- t
85
- ) : /* @__PURE__ */ s(
86
- B,
94
+ r
95
+ ) : /* @__PURE__ */ e(
96
+ j,
87
97
  {
88
- value: e,
89
- onChange: i,
90
- label: r,
91
- description: u,
98
+ value: i,
99
+ onChange: s,
100
+ label: t,
101
+ description: l,
92
102
  options: n
93
103
  },
94
- t
104
+ r
95
105
  );
96
106
  case "slider":
97
- return /* @__PURE__ */ s(
98
- z,
107
+ return /* @__PURE__ */ e(
108
+ B,
99
109
  {
100
- value: e,
101
- onChange: i,
102
- label: r,
103
- description: u,
104
- min: a,
105
- max: f,
106
- step: p
110
+ value: i,
111
+ onChange: s,
112
+ label: t,
113
+ description: l,
114
+ min: f,
115
+ max: p,
116
+ step: y
107
117
  },
108
- t
118
+ r
109
119
  );
110
120
  case "image":
111
- return /* @__PURE__ */ s(
112
- G,
121
+ return /* @__PURE__ */ e(
122
+ x,
113
123
  {
114
- value: e || "",
115
- onChange: i,
116
- label: r
124
+ value: i || "",
125
+ onChange: s,
126
+ label: t
117
127
  },
118
- t
128
+ r
119
129
  );
120
130
  case "color-advanced":
121
- return /* @__PURE__ */ s(
122
- g,
131
+ return /* @__PURE__ */ e(
132
+ b,
123
133
  {
124
- value: e || "",
125
- onChange: i,
126
- label: r,
127
- description: u
134
+ value: i || "",
135
+ onChange: s,
136
+ label: t,
137
+ description: l
128
138
  },
129
- t
139
+ r
130
140
  );
131
141
  case "image-upload":
132
- return /* @__PURE__ */ s(
133
- G,
142
+ return /* @__PURE__ */ e(
143
+ x,
134
144
  {
135
- value: e || "",
136
- onChange: i,
137
- label: r,
145
+ value: i || "",
146
+ onChange: s,
147
+ label: t,
138
148
  size: { width: 160, height: 80 },
139
149
  showUrlInput: !1,
140
150
  maxSizeMB: 10,
@@ -145,81 +155,99 @@ function T(t, I, e, i, d, l) {
145
155
  assetType: "image",
146
156
  deferUpload: !0
147
157
  },
148
- t
158
+ r
149
159
  );
150
160
  case "checkbox":
151
- return /* @__PURE__ */ s(
152
- x,
161
+ return /* @__PURE__ */ e(
162
+ S,
153
163
  {
154
- value: !!e,
155
- onChange: i,
156
- label: r,
157
- description: u,
158
- size: h
164
+ value: !!i,
165
+ onChange: s,
166
+ label: t,
167
+ description: l,
168
+ size: P
159
169
  },
160
- t
170
+ r
161
171
  );
162
172
  case "icon-grid":
163
- return /* @__PURE__ */ s(
164
- S,
173
+ return /* @__PURE__ */ e(
174
+ z,
165
175
  {
166
- value: e || "arrow-right",
167
- onChange: i,
168
- label: r,
169
- description: u
176
+ value: i || "arrow-right",
177
+ onChange: s,
178
+ label: t,
179
+ description: l
170
180
  },
171
- t
181
+ r
172
182
  );
173
183
  case "image-grid":
174
- if (l?.allProps && l?.onMultiUpdate) {
175
- const P = l.allProps.imageGridPreset || "four-equal", b = l.allProps.imageGridImages || [], U = l.allProps.imageGridGap ?? 8;
176
- return /* @__PURE__ */ s(
177
- M,
184
+ if (a?.allProps && a?.onMultiUpdate) {
185
+ const g = a.allProps.imageGridPreset || "four-equal", I = a.allProps.imageGridImages || [], w = a.allProps.imageGridGap ?? 8;
186
+ return /* @__PURE__ */ e(
187
+ k,
178
188
  {
179
- preset: P,
180
- images: b,
181
- gap: U,
182
- onPresetChange: (c) => {
183
- l.onMultiUpdate({ imageGridPreset: c });
189
+ preset: g,
190
+ images: I,
191
+ gap: w,
192
+ onPresetChange: (u) => {
193
+ a.onMultiUpdate({ imageGridPreset: u });
184
194
  },
185
- onImagesChange: (c) => {
186
- l.onMultiUpdate({ imageGridImages: c });
195
+ onImagesChange: (u) => {
196
+ a.onMultiUpdate({ imageGridImages: u });
187
197
  },
188
- onGapChange: (c) => {
189
- l.onMultiUpdate({ imageGridGap: c });
198
+ onGapChange: (u) => {
199
+ a.onMultiUpdate({ imageGridGap: u });
200
+ },
201
+ label: t,
202
+ description: l,
203
+ uploadConfig: d
204
+ },
205
+ r
206
+ );
207
+ }
208
+ return null;
209
+ case "carousel-images":
210
+ if (a?.allProps && a?.onMultiUpdate) {
211
+ const g = a.allProps.carouselImages || [];
212
+ return /* @__PURE__ */ e(
213
+ U,
214
+ {
215
+ images: g,
216
+ onImagesChange: (I) => {
217
+ a.onMultiUpdate({ carouselImages: I });
190
218
  },
191
- label: r,
192
- description: u,
219
+ label: t,
220
+ description: l,
193
221
  uploadConfig: d
194
222
  },
195
- t
223
+ r
196
224
  );
197
225
  }
198
226
  return null;
199
227
  case "typography":
200
228
  let o = 16, m = "normal";
201
- return t.includes("title") || t.includes("Title") ? (o = 48, m = "bold") : t.includes("subtitle") || t.includes("Subtitle") ? (o = 24, m = "medium") : (t.includes("description") || t.includes("Description")) && (o = 16, m = "normal"), /* @__PURE__ */ s(
202
- w,
229
+ return r.includes("title") || r.includes("Title") ? (o = 48, m = "bold") : r.includes("subtitle") || r.includes("Subtitle") ? (o = 24, m = "medium") : (r.includes("description") || r.includes("Description")) && (o = 16, m = "normal"), /* @__PURE__ */ e(
230
+ M,
203
231
  {
204
- value: e,
205
- onChange: i,
206
- label: r,
232
+ value: i,
233
+ onChange: s,
234
+ label: t,
207
235
  defaultFontSize: o,
208
236
  defaultFontWeight: m
209
237
  },
210
- t
238
+ r
211
239
  );
212
240
  default:
213
- return T(
214
- t,
215
- { ...I, inputType: "text" },
216
- e,
241
+ return G(
242
+ r,
243
+ { ...c, inputType: "text" },
217
244
  i,
245
+ s,
218
246
  d
219
247
  );
220
248
  }
221
249
  }
222
250
  export {
223
- T as renderPropertyInput
251
+ G as renderPropertyInput
224
252
  };
225
253
  //# sourceMappingURL=renderPropertyInput.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"renderPropertyInput.js","sources":["../../../src/editor/PropertyEditor/renderPropertyInput.tsx"],"sourcesContent":["import React from \"react\";\nimport { InspectorMeta } from \"../../engine\";\nimport {\n TextInput,\n TextAreaInput,\n ColorInput,\n NumberInput,\n SelectInput,\n SliderInput,\n ToggleButton,\n ButtonGroupInput,\n IconGridInput,\n ImageGridInput,\n TypographyInput,\n ImageInput,\n} from \"./inputs\";\nimport type { UploadConfig } from \"../LandingPageEditor\";\n\n/**\n * Extended context for special input types that need to update multiple props\n */\nexport interface RenderInputContext {\n /** All current prop values (for inputs that read multiple props) */\n allProps?: Record<string, any>;\n /** Callback to update multiple props at once */\n onMultiUpdate?: (updates: Record<string, any>) => void;\n}\n\n/**\n * Renderiza um input baseado no tipo especificado em inspectorMeta\n */\nexport function renderPropertyInput(\n propName: string,\n meta: InspectorMeta,\n value: any,\n onChange: (value: any) => void,\n uploadConfig?: UploadConfig,\n context?: RenderInputContext,\n): React.ReactNode {\n const { label, description, inputType, options, min, max, step, size } = meta;\n\n switch (inputType) {\n case \"text\":\n return (\n <TextInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n />\n );\n\n case \"textarea\":\n return (\n <TextAreaInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n rows={3}\n />\n );\n\n case \"number\":\n return (\n <NumberInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n min={min}\n max={max}\n step={step}\n />\n );\n\n case \"color\":\n return (\n <ColorInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"select\":\n if (!options || options.length === 0) {\n // Fallback para text input\n return renderPropertyInput(\n propName,\n { ...meta, inputType: \"text\" },\n value,\n onChange,\n uploadConfig,\n );\n }\n // Usar ButtonGroup para 2-3 opções, Select para 4+\n if (options.length <= 3) {\n return (\n <ButtonGroupInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n options={options}\n />\n );\n }\n return (\n <SelectInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n options={options}\n />\n );\n\n case \"slider\":\n return (\n <SliderInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n min={min}\n max={max}\n step={step}\n />\n );\n\n case \"image\":\n return (\n <ImageInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n />\n );\n\n case \"color-advanced\":\n // Usar o mesmo ColorInput simples - funciona melhor que o picker avançado\n return (\n <ColorInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"image-upload\":\n return (\n <ImageInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n size={{ width: 160, height: 80 }}\n showUrlInput={false}\n maxSizeMB={10}\n tenantId={uploadConfig?.tenantId}\n schoolId={uploadConfig?.schoolId}\n siteId={uploadConfig?.siteId || undefined}\n authToken={uploadConfig?.authToken}\n assetType=\"image\"\n deferUpload={true}\n />\n );\n\n case \"checkbox\":\n return (\n <ToggleButton\n key={propName}\n value={!!value}\n onChange={onChange}\n label={label}\n description={description}\n size={size}\n />\n );\n\n case \"icon-grid\":\n return (\n <IconGridInput\n key={propName}\n value={value || \"arrow-right\"}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"image-grid\":\n // Image grid needs to read/write multiple props (preset, images, gap)\n // We use the extended context if available\n if (context?.allProps && context?.onMultiUpdate) {\n const preset = context.allProps.imageGridPreset || \"four-equal\";\n const images = context.allProps.imageGridImages || [];\n const gap = context.allProps.imageGridGap ?? 8;\n\n return (\n <ImageGridInput\n key={propName}\n preset={preset}\n images={images}\n gap={gap}\n onPresetChange={(newPreset) => {\n context.onMultiUpdate!({ imageGridPreset: newPreset });\n }}\n onImagesChange={(newImages) => {\n context.onMultiUpdate!({ imageGridImages: newImages });\n }}\n onGapChange={(newGap) => {\n context.onMultiUpdate!({ imageGridGap: newGap });\n }}\n label={label}\n description={description}\n uploadConfig={uploadConfig}\n />\n );\n }\n // Fallback: single-value mode (shouldn't happen in practice)\n return null;\n\n case \"typography\":\n // Determina defaults baseado no nome da prop\n let defaultFontSize = 16;\n let defaultFontWeight: \"light\" | \"normal\" | \"medium\" | \"semibold\" | \"bold\" = \"normal\";\n\n if (propName.includes(\"title\") || propName.includes(\"Title\")) {\n defaultFontSize = 48;\n defaultFontWeight = \"bold\";\n } else if (propName.includes(\"subtitle\") || propName.includes(\"Subtitle\")) {\n defaultFontSize = 24;\n defaultFontWeight = \"medium\";\n } else if (propName.includes(\"description\") || propName.includes(\"Description\")) {\n defaultFontSize = 16;\n defaultFontWeight = \"normal\";\n }\n\n return (\n <TypographyInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n defaultFontSize={defaultFontSize}\n defaultFontWeight={defaultFontWeight}\n />\n );\n\n default:\n // Fallback para text input\n return renderPropertyInput(\n propName,\n { ...meta, inputType: \"text\" },\n value,\n onChange,\n uploadConfig,\n );\n }\n}\n"],"names":["renderPropertyInput","propName","meta","value","onChange","uploadConfig","context","label","description","inputType","options","min","max","step","size","jsx","TextInput","TextAreaInput","NumberInput","ColorInput","ButtonGroupInput","SelectInput","SliderInput","ImageInput","ToggleButton","IconGridInput","preset","images","gap","ImageGridInput","newPreset","newImages","newGap","defaultFontSize","defaultFontWeight","TypographyInput"],"mappings":"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"}
1
+ {"version":3,"file":"renderPropertyInput.js","sources":["../../../src/editor/PropertyEditor/renderPropertyInput.tsx"],"sourcesContent":["import React from \"react\";\nimport { InspectorMeta } from \"../../engine\";\nimport {\n TextInput,\n TextAreaInput,\n ColorInput,\n NumberInput,\n SelectInput,\n SliderInput,\n ToggleButton,\n ButtonGroupInput,\n IconGridInput,\n ImageGridInput,\n TypographyInput,\n ImageInput,\n CarouselImagesInput,\n} from \"./inputs\";\nimport type { UploadConfig } from \"../LandingPageEditor\";\n\n/**\n * Extended context for special input types that need to update multiple props\n */\nexport interface RenderInputContext {\n /** All current prop values (for inputs that read multiple props) */\n allProps?: Record<string, any>;\n /** Callback to update multiple props at once */\n onMultiUpdate?: (updates: Record<string, any>) => void;\n}\n\n/**\n * Renderiza um input baseado no tipo especificado em inspectorMeta\n */\nexport function renderPropertyInput(\n propName: string,\n meta: InspectorMeta,\n value: any,\n onChange: (value: any) => void,\n uploadConfig?: UploadConfig,\n context?: RenderInputContext,\n): React.ReactNode {\n const { label, description, inputType, options, min, max, step, size } = meta;\n\n // Campo readOnly: mostrar valor com overlay de bloqueio\n if (meta.readOnly) {\n return (\n <div key={propName} className=\"relative\">\n <div className=\"flex items-center gap-1 mb-1\">\n <svg className=\"w-3 h-3 text-gray-400\" viewBox=\"0 0 16 16\" fill=\"currentColor\">\n <path d=\"M8 1a4 4 0 0 0-4 4v2H3a1 1 0 0 0-1 1v6a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V8a1 1 0 0 0-1-1h-1V5a4 4 0 0 0-4-4zm2 6H6V5a2 2 0 1 1 4 0v2z\"/>\n </svg>\n <span className=\"text-xs font-medium text-gray-400\">{label}</span>\n </div>\n <div className=\"px-2 py-1.5 text-xs text-gray-500 dark:text-gray-400 bg-gray-100 dark:bg-gray-800 rounded border border-gray-200 dark:border-gray-700 cursor-not-allowed select-none truncate\">\n {value !== undefined && value !== null ? String(value) : \"—\"}\n </div>\n {description && (\n <p className=\"text-xs text-gray-400 mt-0.5 italic\">{description}</p>\n )}\n </div>\n );\n }\n\n switch (inputType) {\n case \"text\":\n return (\n <TextInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n />\n );\n\n case \"textarea\":\n return (\n <TextAreaInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n rows={3}\n />\n );\n\n case \"number\":\n return (\n <NumberInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n placeholder={label}\n min={min}\n max={max}\n step={step}\n />\n );\n\n case \"color\":\n return (\n <ColorInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"select\":\n if (!options || options.length === 0) {\n // Fallback para text input\n return renderPropertyInput(\n propName,\n { ...meta, inputType: \"text\" },\n value,\n onChange,\n uploadConfig,\n );\n }\n // Usar ButtonGroup para 2-3 opções, Select para 4+\n if (options.length <= 3) {\n return (\n <ButtonGroupInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n options={options}\n />\n );\n }\n return (\n <SelectInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n options={options}\n />\n );\n\n case \"slider\":\n return (\n <SliderInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n description={description}\n min={min}\n max={max}\n step={step}\n />\n );\n\n case \"image\":\n return (\n <ImageInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n />\n );\n\n case \"color-advanced\":\n // Usar o mesmo ColorInput simples - funciona melhor que o picker avançado\n return (\n <ColorInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"image-upload\":\n return (\n <ImageInput\n key={propName}\n value={value || \"\"}\n onChange={onChange}\n label={label}\n size={{ width: 160, height: 80 }}\n showUrlInput={false}\n maxSizeMB={10}\n tenantId={uploadConfig?.tenantId}\n schoolId={uploadConfig?.schoolId}\n siteId={uploadConfig?.siteId || undefined}\n authToken={uploadConfig?.authToken}\n assetType=\"image\"\n deferUpload={true}\n />\n );\n\n case \"checkbox\":\n return (\n <ToggleButton\n key={propName}\n value={!!value}\n onChange={onChange}\n label={label}\n description={description}\n size={size}\n />\n );\n\n case \"icon-grid\":\n return (\n <IconGridInput\n key={propName}\n value={value || \"arrow-right\"}\n onChange={onChange}\n label={label}\n description={description}\n />\n );\n\n case \"image-grid\":\n // Image grid needs to read/write multiple props (preset, images, gap)\n // We use the extended context if available\n if (context?.allProps && context?.onMultiUpdate) {\n const preset = context.allProps.imageGridPreset || \"four-equal\";\n const images = context.allProps.imageGridImages || [];\n const gap = context.allProps.imageGridGap ?? 8;\n\n return (\n <ImageGridInput\n key={propName}\n preset={preset}\n images={images}\n gap={gap}\n onPresetChange={(newPreset) => {\n context.onMultiUpdate!({ imageGridPreset: newPreset });\n }}\n onImagesChange={(newImages) => {\n context.onMultiUpdate!({ imageGridImages: newImages });\n }}\n onGapChange={(newGap) => {\n context.onMultiUpdate!({ imageGridGap: newGap });\n }}\n label={label}\n description={description}\n uploadConfig={uploadConfig}\n />\n );\n }\n // Fallback: single-value mode (shouldn't happen in practice)\n return null;\n\n case \"carousel-images\":\n // Carousel images needs to read/write carouselImages via multi-prop context\n if (context?.allProps && context?.onMultiUpdate) {\n const images = context.allProps.carouselImages || [];\n\n return (\n <CarouselImagesInput\n key={propName}\n images={images}\n onImagesChange={(newImages) => {\n context.onMultiUpdate!({ carouselImages: newImages });\n }}\n label={label}\n description={description}\n uploadConfig={uploadConfig}\n />\n );\n }\n return null;\n\n case \"typography\":\n // Determina defaults baseado no nome da prop\n let defaultFontSize = 16;\n let defaultFontWeight: \"light\" | \"normal\" | \"medium\" | \"semibold\" | \"bold\" = \"normal\";\n\n if (propName.includes(\"title\") || propName.includes(\"Title\")) {\n defaultFontSize = 48;\n defaultFontWeight = \"bold\";\n } else if (propName.includes(\"subtitle\") || propName.includes(\"Subtitle\")) {\n defaultFontSize = 24;\n defaultFontWeight = \"medium\";\n } else if (propName.includes(\"description\") || propName.includes(\"Description\")) {\n defaultFontSize = 16;\n defaultFontWeight = \"normal\";\n }\n\n return (\n <TypographyInput\n key={propName}\n value={value}\n onChange={onChange}\n label={label}\n defaultFontSize={defaultFontSize}\n defaultFontWeight={defaultFontWeight}\n />\n );\n\n default:\n // Fallback para text input\n return renderPropertyInput(\n propName,\n { ...meta, inputType: \"text\" },\n value,\n onChange,\n uploadConfig,\n );\n }\n}\n"],"names":["renderPropertyInput","propName","meta","value","onChange","uploadConfig","context","label","description","inputType","options","min","max","step","size","jsxs","jsx","TextInput","TextAreaInput","NumberInput","ColorInput","ButtonGroupInput","SelectInput","SliderInput","ImageInput","ToggleButton","IconGridInput","preset","images","gap","ImageGridInput","newPreset","newImages","newGap","CarouselImagesInput","defaultFontSize","defaultFontWeight","TypographyInput"],"mappings":"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"}
@@ -5,13 +5,21 @@ interface CenterPanelProps {
5
5
  currentPageId: string;
6
6
  currentPage: any;
7
7
  selectedBlockId: string | null;
8
- onBlockClick: (id: string) => void;
8
+ onBlockClick: (id: string, group?: string) => void;
9
9
  onSelectPage: (id: string) => void;
10
10
  onAddPage: () => void;
11
11
  onRemovePage: (id: string) => void;
12
12
  canRemovePage: (id: string) => boolean;
13
13
  /** Callback ao atualizar um bloco específico */
14
14
  onUpdateBlock?: (blockId: string, updates: Record<string, any>) => void;
15
+ /** Plugin integration */
16
+ activePlugins: string[];
17
+ onActivatePlugin: (pluginId: string) => void;
18
+ onDeactivatePlugin: (pluginId: string) => void;
19
+ /** Exibe hover e label de seleção nos blocos do preview */
20
+ showSelectionOverlay?: boolean;
21
+ /** Grupo focado para indicador visual no preview */
22
+ focusedGroup?: string | null;
15
23
  }
16
24
  export declare const CenterPanel: React.NamedExoticComponent<CenterPanelProps>;
17
25
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"CenterPanel.d.ts","sourceRoot":"","sources":["../../../src/editor/components/CenterPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyB,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAS5C,UAAU,gBAAgB;IACxB,QAAQ,EAAE,YAAY,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,GAAG,CAAC;IACjB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,aAAa,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC;IACvC,gDAAgD;IAChD,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;CACzE;AAED,eAAO,MAAM,WAAW,8CA2CtB,CAAC"}
1
+ {"version":3,"file":"CenterPanel.d.ts","sourceRoot":"","sources":["../../../src/editor/components/CenterPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyB,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAS5C,UAAU,gBAAgB;IACxB,QAAQ,EAAE,YAAY,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,GAAG,CAAC;IACjB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IACnD,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,aAAa,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC;IACvC,gDAAgD;IAChD,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;IACxE,yBAAyB;IACzB,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,gBAAgB,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,kBAAkB,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/C,2DAA2D;IAC3D,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,oDAAoD;IACpD,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,eAAO,MAAM,WAAW,8CAqDtB,CAAC"}
@@ -1,10 +1,10 @@
1
- import { jsxs as f, jsx as e } from "react/jsx-runtime";
2
- import m, { Suspense as h, lazy as p } from "react";
3
- import { PageTabBar as g } from "../PageTabBar.js";
4
- import { LoadingSpinner as v } from "./LoadingSpinner.js";
5
- const x = p(
1
+ import { jsxs as v, jsx as e } from "react/jsx-runtime";
2
+ import x, { Suspense as y, lazy as u } from "react";
3
+ import { PageTabBar as w } from "../PageTabBar.js";
4
+ import { LoadingSpinner as N } from "./LoadingSpinner.js";
5
+ const b = u(
6
6
  () => import("../../engine/index.js").then((r) => ({ default: r.Preview }))
7
- ), b = m.memo(function({
7
+ ), S = x.memo(function({
8
8
  document: a,
9
9
  currentPageId: i,
10
10
  currentPage: l,
@@ -13,33 +13,43 @@ const x = p(
13
13
  onSelectPage: o,
14
14
  onAddPage: s,
15
15
  onRemovePage: d,
16
- canRemovePage: c
16
+ canRemovePage: c,
17
+ activePlugins: f,
18
+ onActivatePlugin: m,
19
+ onDeactivatePlugin: h,
20
+ showSelectionOverlay: p,
21
+ focusedGroup: g
17
22
  }) {
18
- return /* @__PURE__ */ f("div", { className: "flex-1 flex flex-col overflow-hidden bg-gray-50/30 dark:bg-gray-900/30", children: [
23
+ return /* @__PURE__ */ v("div", { className: "flex-1 flex flex-col overflow-hidden bg-gray-50/30 dark:bg-gray-900/30", children: [
19
24
  /* @__PURE__ */ e(
20
- g,
25
+ w,
21
26
  {
22
27
  pages: a.pages,
23
28
  currentPageId: i,
24
29
  onSelectPage: o,
25
30
  onAddPage: s,
26
31
  onRemovePage: d,
27
- canRemovePage: c
32
+ canRemovePage: c,
33
+ activePlugins: f,
34
+ onActivatePlugin: m,
35
+ onDeactivatePlugin: h
28
36
  }
29
37
  ),
30
- /* @__PURE__ */ e("div", { className: "flex-1 overflow-hidden relative", children: l ? /* @__PURE__ */ e(h, { fallback: /* @__PURE__ */ e(v, {}), children: /* @__PURE__ */ e(
31
- x,
38
+ /* @__PURE__ */ e("div", { className: "flex-1 overflow-hidden relative", children: l ? /* @__PURE__ */ e(y, { fallback: /* @__PURE__ */ e(N, {}), children: /* @__PURE__ */ e(
39
+ b,
32
40
  {
33
41
  document: a,
34
42
  pageId: i,
35
43
  style: { height: "100%", width: "100%" },
36
44
  onBlockClick: t,
37
- selectedBlockId: n
45
+ selectedBlockId: n,
46
+ showSelectionOverlay: p,
47
+ focusedGroup: g
38
48
  }
39
49
  ) }) : /* @__PURE__ */ e("div", { className: "flex items-center justify-center h-full", children: /* @__PURE__ */ e("div", { className: "text-gray-500", children: "Nenhuma página encontrada" }) }) })
40
50
  ] });
41
51
  });
42
52
  export {
43
- b as CenterPanel
53
+ S as CenterPanel
44
54
  };
45
55
  //# sourceMappingURL=CenterPanel.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CenterPanel.js","sources":["../../../src/editor/components/CenterPanel.tsx"],"sourcesContent":["import React, { lazy, Suspense } from \"react\";\nimport { SiteDocument } from \"../../engine\";\nimport { PageTabBar } from \"../PageTabBar\";\nimport { LoadingSpinner } from \"./LoadingSpinner\";\n\n// Lazy load Preview (componente pesado)\nconst Preview = lazy(() =>\n import(\"../../engine\").then(module => ({ default: module.Preview }))\n);\n\ninterface CenterPanelProps {\n document: SiteDocument;\n currentPageId: string;\n currentPage: any;\n selectedBlockId: string | null;\n onBlockClick: (id: string) => void;\n onSelectPage: (id: string) => void;\n onAddPage: () => void;\n onRemovePage: (id: string) => void;\n canRemovePage: (id: string) => boolean;\n /** Callback ao atualizar um bloco específico */\n onUpdateBlock?: (blockId: string, updates: Record<string, any>) => void;\n}\n\nexport const CenterPanel = React.memo(function CenterPanel({\n document,\n currentPageId,\n currentPage,\n selectedBlockId,\n onBlockClick,\n onSelectPage,\n onAddPage,\n onRemovePage,\n canRemovePage,\n}: CenterPanelProps) {\n return (\n <div className=\"flex-1 flex flex-col overflow-hidden bg-gray-50/30 dark:bg-gray-900/30\">\n {/* Barra de abas das páginas */}\n <PageTabBar\n pages={document.pages}\n currentPageId={currentPageId}\n onSelectPage={onSelectPage}\n onAddPage={onAddPage}\n onRemovePage={onRemovePage}\n canRemovePage={canRemovePage}\n />\n\n {/* Preview */}\n <div className=\"flex-1 overflow-hidden relative\">\n {currentPage ? (\n <Suspense fallback={<LoadingSpinner />}>\n <Preview\n document={document}\n pageId={currentPageId}\n style={{ height: \"100%\", width: \"100%\" }}\n onBlockClick={onBlockClick}\n selectedBlockId={selectedBlockId}\n />\n </Suspense>\n ) : (\n <div className=\"flex items-center justify-center h-full\">\n <div className=\"text-gray-500\">Nenhuma página encontrada</div>\n </div>\n )}\n </div>\n </div>\n );\n});\n"],"names":["Preview","lazy","module","CenterPanel","React","document","currentPageId","currentPage","selectedBlockId","onBlockClick","onSelectPage","onAddPage","onRemovePage","canRemovePage","jsxs","jsx","PageTabBar","Suspense","LoadingSpinner"],"mappings":";;;;AAMA,MAAMA,IAAUC;AAAA,EAAK,MACnB,OAAO,uBAAc,EAAE,KAAK,QAAW,EAAE,SAASC,EAAO,UAAU;AACrE,GAgBaC,IAAcC,EAAM,KAAK,SAAqB;AAAA,EACzD,UAAAC;AAAA,EACA,eAAAC;AAAA,EACA,aAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,cAAAC;AAAA,EACA,cAAAC;AAAA,EACA,WAAAC;AAAA,EACA,cAAAC;AAAA,EACA,eAAAC;AACF,GAAqB;AACnB,SACE,gBAAAC,EAAC,OAAA,EAAI,WAAU,0EAEb,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,OAAOX,EAAS;AAAA,QAChB,eAAAC;AAAA,QACA,cAAAI;AAAA,QACA,WAAAC;AAAA,QACA,cAAAC;AAAA,QACA,eAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,IAIF,gBAAAE,EAAC,OAAA,EAAI,WAAU,mCACZ,UAAAR,sBACEU,GAAA,EAAS,UAAU,gBAAAF,EAACG,GAAA,CAAA,CAAe,GAClC,UAAA,gBAAAH;AAAA,MAACf;AAAA,MAAA;AAAA,QACC,UAAAK;AAAA,QACA,QAAQC;AAAA,QACR,OAAO,EAAE,QAAQ,QAAQ,OAAO,OAAA;AAAA,QAChC,cAAAG;AAAA,QACA,iBAAAD;AAAA,MAAA;AAAA,IAAA,EACF,CACF,IAEA,gBAAAO,EAAC,OAAA,EAAI,WAAU,2CACb,UAAA,gBAAAA,EAAC,OAAA,EAAI,WAAU,iBAAgB,UAAA,4BAAA,CAAyB,EAAA,CAC1D,EAAA,CAEJ;AAAA,EAAA,GACF;AAEJ,CAAC;"}
1
+ {"version":3,"file":"CenterPanel.js","sources":["../../../src/editor/components/CenterPanel.tsx"],"sourcesContent":["import React, { lazy, Suspense } from \"react\";\nimport { SiteDocument } from \"../../engine\";\nimport { PageTabBar } from \"../PageTabBar\";\nimport { LoadingSpinner } from \"./LoadingSpinner\";\n\n// Lazy load Preview (componente pesado)\nconst Preview = lazy(() =>\n import(\"../../engine\").then(module => ({ default: module.Preview }))\n);\n\ninterface CenterPanelProps {\n document: SiteDocument;\n currentPageId: string;\n currentPage: any;\n selectedBlockId: string | null;\n onBlockClick: (id: string, group?: string) => void;\n onSelectPage: (id: string) => void;\n onAddPage: () => void;\n onRemovePage: (id: string) => void;\n canRemovePage: (id: string) => boolean;\n /** Callback ao atualizar um bloco específico */\n onUpdateBlock?: (blockId: string, updates: Record<string, any>) => void;\n /** Plugin integration */\n activePlugins: string[];\n onActivatePlugin: (pluginId: string) => void;\n onDeactivatePlugin: (pluginId: string) => void;\n /** Exibe hover e label de seleção nos blocos do preview */\n showSelectionOverlay?: boolean;\n /** Grupo focado para indicador visual no preview */\n focusedGroup?: string | null;\n}\n\nexport const CenterPanel = React.memo(function CenterPanel({\n document,\n currentPageId,\n currentPage,\n selectedBlockId,\n onBlockClick,\n onSelectPage,\n onAddPage,\n onRemovePage,\n canRemovePage,\n activePlugins,\n onActivatePlugin,\n onDeactivatePlugin,\n showSelectionOverlay,\n focusedGroup,\n}: CenterPanelProps) {\n return (\n <div className=\"flex-1 flex flex-col overflow-hidden bg-gray-50/30 dark:bg-gray-900/30\">\n {/* Barra de abas das páginas */}\n <PageTabBar\n pages={document.pages}\n currentPageId={currentPageId}\n onSelectPage={onSelectPage}\n onAddPage={onAddPage}\n onRemovePage={onRemovePage}\n canRemovePage={canRemovePage}\n activePlugins={activePlugins}\n onActivatePlugin={onActivatePlugin}\n onDeactivatePlugin={onDeactivatePlugin}\n />\n\n {/* Preview */}\n <div className=\"flex-1 overflow-hidden relative\">\n {currentPage ? (\n <Suspense fallback={<LoadingSpinner />}>\n <Preview\n document={document}\n pageId={currentPageId}\n style={{ height: \"100%\", width: \"100%\" }}\n onBlockClick={onBlockClick}\n selectedBlockId={selectedBlockId}\n showSelectionOverlay={showSelectionOverlay}\n focusedGroup={focusedGroup}\n />\n </Suspense>\n ) : (\n <div className=\"flex items-center justify-center h-full\">\n <div className=\"text-gray-500\">Nenhuma página encontrada</div>\n </div>\n )}\n </div>\n </div>\n );\n});\n"],"names":["Preview","lazy","module","CenterPanel","React","document","currentPageId","currentPage","selectedBlockId","onBlockClick","onSelectPage","onAddPage","onRemovePage","canRemovePage","activePlugins","onActivatePlugin","onDeactivatePlugin","showSelectionOverlay","focusedGroup","jsxs","jsx","PageTabBar","Suspense","LoadingSpinner"],"mappings":";;;;AAMA,MAAMA,IAAUC;AAAA,EAAK,MACnB,OAAO,uBAAc,EAAE,KAAK,QAAW,EAAE,SAASC,EAAO,UAAU;AACrE,GAwBaC,IAAcC,EAAM,KAAK,SAAqB;AAAA,EACzD,UAAAC;AAAA,EACA,eAAAC;AAAA,EACA,aAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,cAAAC;AAAA,EACA,cAAAC;AAAA,EACA,WAAAC;AAAA,EACA,cAAAC;AAAA,EACA,eAAAC;AAAA,EACA,eAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,sBAAAC;AAAA,EACA,cAAAC;AACF,GAAqB;AACnB,SACE,gBAAAC,EAAC,OAAA,EAAI,WAAU,0EAEb,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,OAAOhB,EAAS;AAAA,QAChB,eAAAC;AAAA,QACA,cAAAI;AAAA,QACA,WAAAC;AAAA,QACA,cAAAC;AAAA,QACA,eAAAC;AAAA,QACA,eAAAC;AAAA,QACA,kBAAAC;AAAA,QACA,oBAAAC;AAAA,MAAA;AAAA,IAAA;AAAA,IAIF,gBAAAI,EAAC,OAAA,EAAI,WAAU,mCACZ,UAAAb,sBACEe,GAAA,EAAS,UAAU,gBAAAF,EAACG,GAAA,CAAA,CAAe,GAClC,UAAA,gBAAAH;AAAA,MAACpB;AAAA,MAAA;AAAA,QACC,UAAAK;AAAA,QACA,QAAQC;AAAA,QACR,OAAO,EAAE,QAAQ,QAAQ,OAAO,OAAA;AAAA,QAChC,cAAAG;AAAA,QACA,iBAAAD;AAAA,QACA,sBAAAS;AAAA,QACA,cAAAC;AAAA,MAAA;AAAA,IAAA,EACF,CACF,IAEA,gBAAAE,EAAC,OAAA,EAAI,WAAU,2CACb,UAAA,gBAAAA,EAAC,OAAA,EAAI,WAAU,iBAAgB,UAAA,4BAAA,CAAyB,EAAA,CAC1D,EAAA,CAEJ;AAAA,EAAA,GACF;AAEJ,CAAC;"}
@@ -1,11 +1,16 @@
1
1
  import { default as React } from 'react';
2
2
  import { UploadConfig } from '../LandingPageEditor';
3
+ import { SiteDocument } from '../../engine';
3
4
  interface RightPanelProps {
4
5
  isPaletteSelected: boolean;
5
6
  selectedBlock: any;
6
7
  onPaletteChange: (palette: any) => void;
7
8
  onUpdateBlock: (updates: Record<string, any>) => void;
8
9
  uploadConfig?: UploadConfig;
10
+ document?: SiteDocument;
11
+ currentPageId?: string;
12
+ /** When set, the matching property group opens and scrolls into view */
13
+ focusedGroup?: string | null;
9
14
  }
10
15
  export declare const RightPanel: React.NamedExoticComponent<RightPanelProps>;
11
16
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"RightPanel.d.ts","sourceRoot":"","sources":["../../../src/editor/components/RightPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyB,MAAM,OAAO,CAAC;AAE9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAUzD,UAAU,eAAe;IACvB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;IACxC,aAAa,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;IACtD,YAAY,CAAC,EAAE,YAAY,CAAC;CAC7B;AAED,eAAO,MAAM,UAAU,6CAoCrB,CAAC"}
1
+ {"version":3,"file":"RightPanel.d.ts","sourceRoot":"","sources":["../../../src/editor/components/RightPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyB,MAAM,OAAO,CAAC;AAE9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAUjD,UAAU,eAAe;IACvB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;IACxC,aAAa,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;IACtD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,QAAQ,CAAC,EAAE,YAAY,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,wEAAwE;IACxE,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,eAAO,MAAM,UAAU,6CA0CrB,CAAC"}