@grapesjs/studio-sdk-plugins 1.0.36 → 1.0.37

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 (91) hide show
  1. package/dist/accordionComponent/index.cjs.js +4 -4
  2. package/dist/accordionComponent/index.es.js +83 -70
  3. package/dist/accordionComponent/index.umd.js +4 -4
  4. package/dist/aiChat/clientToolsProcessors.d.ts +1 -2
  5. package/dist/aiChat/components/utils.d.ts +1 -0
  6. package/dist/aiChat/components/utilsTw.d.ts +11 -0
  7. package/dist/aiChat/index.cjs.js +70 -70
  8. package/dist/aiChat/index.es.js +8627 -8161
  9. package/dist/aiChat/index.js +70 -70
  10. package/dist/aiChat/index.umd.js +70 -70
  11. package/dist/aiChat/projectGeneration.d.ts +17 -0
  12. package/dist/animationComponent/index.cjs.js +3 -3
  13. package/dist/animationComponent/index.es.js +55 -42
  14. package/dist/animationComponent/index.umd.js +3 -3
  15. package/dist/canvasAbsoluteMode/index.cjs.js +1 -1
  16. package/dist/canvasAbsoluteMode/index.es.js +67 -54
  17. package/dist/canvasAbsoluteMode/index.umd.js +1 -1
  18. package/dist/canvasEmptyState/index.cjs.js +1 -1
  19. package/dist/canvasEmptyState/index.es.js +59 -46
  20. package/dist/canvasEmptyState/index.umd.js +1 -1
  21. package/dist/canvasFullSize/index.cjs.js +4 -4
  22. package/dist/canvasFullSize/index.es.js +59 -46
  23. package/dist/canvasFullSize/index.umd.js +4 -4
  24. package/dist/canvasGridMode/index.cjs.js +2 -2
  25. package/dist/canvasGridMode/index.es.js +70 -57
  26. package/dist/canvasGridMode/index.umd.js +4 -4
  27. package/dist/canvasScreenshot/index.cjs.js +1 -1
  28. package/dist/canvasScreenshot/index.es.js +37 -24
  29. package/dist/canvasScreenshot/index.umd.js +1 -1
  30. package/dist/dataSourceEjs/index.cjs.js +3 -3
  31. package/dist/dataSourceEjs/index.es.js +51 -38
  32. package/dist/dataSourceEjs/index.umd.js +3 -3
  33. package/dist/dataSourceHandlebars/index.cjs.js +2 -2
  34. package/dist/dataSourceHandlebars/index.es.js +50 -37
  35. package/dist/dataSourceHandlebars/index.umd.js +6 -6
  36. package/dist/dialogComponent/index.cjs.js +9 -9
  37. package/dist/dialogComponent/index.es.js +58 -45
  38. package/dist/dialogComponent/index.umd.js +3 -3
  39. package/dist/flexComponent/index.cjs.js +6 -6
  40. package/dist/flexComponent/index.es.js +82 -69
  41. package/dist/flexComponent/index.umd.js +6 -6
  42. package/dist/fsLightboxComponent/index.cjs.js +2 -2
  43. package/dist/fsLightboxComponent/index.es.js +70 -57
  44. package/dist/fsLightboxComponent/index.umd.js +2 -2
  45. package/dist/googleFontsAssetProvider/index.cjs.js +1 -1
  46. package/dist/googleFontsAssetProvider/index.es.js +84 -71
  47. package/dist/googleFontsAssetProvider/index.umd.js +1 -1
  48. package/dist/iconifyComponent/index.cjs.js +2 -2
  49. package/dist/iconifyComponent/index.es.js +82 -69
  50. package/dist/iconifyComponent/index.umd.js +2 -2
  51. package/dist/index.cjs.js +36 -36
  52. package/dist/index.es.js +843 -830
  53. package/dist/index.umd.js +36 -36
  54. package/dist/layoutSidebarButtons/index.cjs.js +1 -1
  55. package/dist/layoutSidebarButtons/index.es.js +81 -68
  56. package/dist/layoutSidebarButtons/index.umd.js +1 -1
  57. package/dist/lightGalleryComponent/index.cjs.js +1 -1
  58. package/dist/lightGalleryComponent/index.es.js +86 -73
  59. package/dist/lightGalleryComponent/index.umd.js +1 -1
  60. package/dist/linkImageComponent/index.cjs.js +2 -2
  61. package/dist/linkImageComponent/index.es.js +70 -57
  62. package/dist/linkImageComponent/index.umd.js +2 -2
  63. package/dist/listPagesComponent/index.cjs.js +3 -3
  64. package/dist/listPagesComponent/index.es.js +49 -36
  65. package/dist/listPagesComponent/index.umd.js +3 -3
  66. package/dist/presetPrintable/index.cjs.js +3 -3
  67. package/dist/presetPrintable/index.es.js +130 -117
  68. package/dist/presetPrintable/index.umd.js +3 -3
  69. package/dist/prosemirror/index.cjs.js +1 -1
  70. package/dist/prosemirror/index.es.js +96 -83
  71. package/dist/prosemirror/index.umd.js +1 -1
  72. package/dist/rendererReact/index.cjs.js +1 -1
  73. package/dist/rendererReact/index.es.js +143 -131
  74. package/dist/rendererReact/index.js +1 -1
  75. package/dist/rendererReact/index.umd.js +1 -1
  76. package/dist/rteTinyMce/index.cjs.js +2 -2
  77. package/dist/rteTinyMce/index.es.js +74 -61
  78. package/dist/rteTinyMce/index.umd.js +2 -2
  79. package/dist/shapeDividerComponent/index.cjs.js +3 -3
  80. package/dist/shapeDividerComponent/index.es.js +33 -20
  81. package/dist/shapeDividerComponent/index.umd.js +3 -3
  82. package/dist/swiperComponent/index.cjs.js +5 -5
  83. package/dist/swiperComponent/index.es.js +105 -92
  84. package/dist/swiperComponent/index.umd.js +5 -5
  85. package/dist/tableComponent/index.cjs.js +1 -1
  86. package/dist/tableComponent/index.es.js +163 -150
  87. package/dist/tableComponent/index.umd.js +1 -1
  88. package/dist/youtubeAssetProvider/index.cjs.js +1 -1
  89. package/dist/youtubeAssetProvider/index.es.js +36 -23
  90. package/dist/youtubeAssetProvider/index.umd.js +1 -1
  91. package/package.json +2 -2
@@ -1,7 +1,7 @@
1
- const Y = "app.grapesjs.com", H = "app-stage.grapesjs.com", rt = "app2.grapesjs.com", st = "app-stage2.grapesjs.com", j = [
2
- Y,
3
- rt,
1
+ const H = "app.grapesjs.com", Y = "app-stage.grapesjs.com", rt = "app2.grapesjs.com", st = "app-stage2.grapesjs.com", j = [
4
2
  H,
3
+ rt,
4
+ Y,
5
5
  st,
6
6
  "localhost",
7
7
  "127.0.0.1",
@@ -9,20 +9,33 @@ const Y = "app.grapesjs.com", H = "app-stage.grapesjs.com", rt = "app2.grapesjs.
9
9
  // For stackblitz.com demos
10
10
  ".local.webcontainer.io",
11
11
  // For stackblitz.com demos
12
- "-sandpack.codesandbox.io"
12
+ "-sandpack.codesandbox.io",
13
13
  // For Sandpack demos
14
+ ".claudemcpcontent.com",
15
+ // For Claude mcp app
16
+ ".web-sandbox.oaiusercontent.com"
17
+ // For OpenAI mcp app
14
18
  ], at = "license:check:end", it = () => typeof window < "u", lt = ({
15
19
  isDev: t,
16
20
  isStage: e,
17
21
  isPlatform: r
18
- }) => `${t ? "" : `https://${e ? H : Y}`}/${r ? "platform-api" : "api"}`, ct = () => {
19
- const t = it() && window.location.hostname;
22
+ }) => `${t ? "" : `https://${e ? Y : H}`}/${r ? "platform-api" : "api"}`, ct = () => {
23
+ if (!it()) return "";
24
+ const { hostname: t } = window.location;
25
+ if (t) return t;
26
+ try {
27
+ return window.parent.location.hostname || "";
28
+ } catch {
29
+ return "";
30
+ }
31
+ }, pt = () => {
32
+ const t = ct();
20
33
  return !!t && (j.includes(t) || j.some((e) => t.endsWith(e)));
21
34
  };
22
35
  function X(t) {
23
36
  return typeof t == "function";
24
37
  }
25
- async function pt({
38
+ async function dt({
26
39
  path: t,
27
40
  baseApiUrl: e,
28
41
  method: r = "GET",
@@ -50,12 +63,12 @@ const W = {
50
63
  [G.business]: 20,
51
64
  [G.enterprise]: 30
52
65
  };
53
- function dt(t) {
66
+ function gt(t) {
54
67
  const e = t;
55
68
  return e.init = (r) => (n) => t(n, r), e;
56
69
  }
57
- const gt = (t) => /* @__PURE__ */ dt(t);
58
- async function ut({
70
+ const ut = (t) => /* @__PURE__ */ gt(t);
71
+ async function ft({
59
72
  editor: t,
60
73
  plan: e,
61
74
  pluginName: r,
@@ -82,9 +95,9 @@ async function ut({
82
95
  };
83
96
  if (!a) {
84
97
  t.onReady(async () => {
85
- if (!ct())
98
+ if (!pt())
86
99
  if (n) {
87
- const l = await mt({ licenseKey: n, pluginName: r, baseApiUrl: s });
100
+ const l = await yt({ licenseKey: n, pluginName: r, baseApiUrl: s });
88
101
  c(l);
89
102
  } else
90
103
  p("The `licenseKey` option not provided");
@@ -92,22 +105,22 @@ async function ut({
92
105
  return;
93
106
  }
94
107
  if (a.licensePlan || a.licenseError) {
95
- const l = ft(a);
108
+ const l = mt(a);
96
109
  c(l);
97
110
  return;
98
111
  }
99
112
  t.on(at, (l) => c(l));
100
113
  }
101
- const ft = (t) => ({
114
+ const mt = (t) => ({
102
115
  sdkLicense: t.license,
103
116
  license: t.license,
104
117
  error: t.licenseError,
105
118
  plan: t.licensePlan
106
119
  });
107
- async function mt(t) {
120
+ async function yt(t) {
108
121
  const { licenseKey: e, pluginName: r, baseApiUrl: n } = t;
109
122
  try {
110
- return (await pt({
123
+ return (await dt({
111
124
  baseApiUrl: n,
112
125
  path: `/sdk/${e || "na"}`,
113
126
  method: "POST",
@@ -120,7 +133,7 @@ async function mt(t) {
120
133
  return console.error("Error during SDK license check:", o), !1;
121
134
  }
122
135
  }
123
- const N = "canvasGridMode", yt = G.startup, F = "component-grid-mode", D = "grid-mode", M = "gjs-drag-grid-spot", K = `${M}__grid-item`, J = `${M}__grid-target`, Q = `${M}__snapped`, ht = `${M}__container`, wt = () => {
136
+ const N = "canvasGridMode", ht = G.startup, F = "component-grid-mode", D = "grid-mode", M = "gjs-drag-grid-spot", K = `${M}__grid-item`, J = `${M}__grid-target`, Q = `${M}__snapped`, wt = `${M}__container`, bt = () => {
124
137
  const t = "data-gjs-drag-grid-style", e = document, r = "var(--gs-theme-cl-cmp-bg1, var(--gjs-color-highlight))", n = "var(--gs-theme-cl-cmp-bg2, var(--gjs-color-blue))", o = e.querySelector(`style[${t}]`) || e.createElement("style");
125
138
  o.setAttribute(t, "true"), o.innerHTML = `
126
139
  .${K} {
@@ -150,7 +163,7 @@ const N = "canvasGridMode", yt = G.startup, F = "component-grid-mode", D = "grid
150
163
  `, e.head.appendChild(o);
151
164
  };
152
165
  function Z(t) {
153
- const { editor: e, type: r } = t, n = Rt(e, t.component), o = O(e, n.component);
166
+ const { editor: e, type: r } = t, n = xt(e, t.component), o = O(e, n.component);
154
167
  if (!Tt(e, n, o, r))
155
168
  return {
156
169
  target: n,
@@ -167,7 +180,7 @@ function Z(t) {
167
180
  }
168
181
  function V(t) {
169
182
  const { editor: e, shadowTargetEl: r, shadowSnappedEl: n, shadowContainerEl: o, spotEl: i, target: s, container: a } = t, { Canvas: p } = e, d = e.config.stylePrefix;
170
- i == null || i.appendChild(o), o == null || o.appendChild(r), o == null || o.appendChild(n), bt(o, a), vt(r, s, a), $t(n, s), St(o, a.el), s.el.style.opacity = "0";
183
+ i == null || i.appendChild(o), o == null || o.appendChild(r), o == null || o.appendChild(n), vt(o, a), $t(r, s, a), St(n, s), Rt(o, a.el), s.el.style.opacity = "0";
171
184
  const c = p.getSpots().filter((l) => l.type !== D);
172
185
  e.em.stopDefault({ preserveSelected: !0 }), p.removeSpots(c), p.startAutoscroll(), p.getBody().classList.add(`${d}is__grabbing`);
173
186
  }
@@ -183,7 +196,7 @@ function tt(t) {
183
196
  }
184
197
  o.el.style.opacity = "", n.contains(r) && (n == null || n.removeChild(r)), e.getModel().runDefault({ preserveSelected: 1 }), s.stopAutoscroll(), s.getBody().classList.remove(`${a}is__grabbing`), s.removeSpots({ type: D }), e.select(p);
185
198
  }
186
- function bt(t, {
199
+ function vt(t, {
187
200
  rows: e,
188
201
  columns: r
189
202
  }) {
@@ -197,16 +210,16 @@ function bt(t, {
197
210
  }
198
211
  return n;
199
212
  }
200
- function vt(t, e, r) {
213
+ function $t(t, e, r) {
201
214
  return t.className = J, t.style.top = `${e.offset.top - r.offset.top}px`, t.style.left = `${e.offset.left - r.offset.left}px`, t.style.width = `${e.offset.width + e.margin.left + e.margin.right}px`, t.style.height = `${e.offset.height + e.margin.top + e.margin.bottom}px`, t;
202
215
  }
203
- function $t(t, e) {
216
+ function St(t, e) {
204
217
  const r = nt(e.el, e.computedStyles);
205
218
  return t.className = Q, t.style.gridArea = `${r.row.start} / ${r.column.start} / ${r.row.end} / ${r.column.end}`, t;
206
219
  }
207
- function St(t, e) {
220
+ function Rt(t, e) {
208
221
  const r = window.getComputedStyle(e);
209
- t.className = ht, t.style.position = "relative", t.style.display = r.display, t.style.gap = r.gap, t.style.padding = r.padding, t.style.border = r.border, t.style.gridTemplateColumns = r.gridTemplateColumns, t.style.gridTemplateRows = r.gridTemplateRows;
222
+ t.className = wt, t.style.position = "relative", t.style.display = r.display, t.style.gap = r.gap, t.style.padding = r.padding, t.style.border = r.border, t.style.gridTemplateColumns = r.gridTemplateColumns, t.style.gridTemplateRows = r.gridTemplateRows;
210
223
  }
211
224
  function et(t, e) {
212
225
  if (e) {
@@ -215,7 +228,7 @@ function et(t, e) {
215
228
  } else return [...t.getSelectedAll()].pop();
216
229
  return e;
217
230
  }
218
- function Rt(t, e) {
231
+ function xt(t, e) {
219
232
  const r = et(t, e), n = r.getEl(), o = window.getComputedStyle(n);
220
233
  return {
221
234
  component: r,
@@ -251,7 +264,7 @@ function O(t, e) {
251
264
  }
252
265
  };
253
266
  }
254
- function T(t, e, r, n, o = 1) {
267
+ function x(t, e, r, n, o = 1) {
255
268
  let i = 0;
256
269
  for (let s = e; s <= t.length; s++) {
257
270
  if (i + (t[s - 1] + n) * o > r)
@@ -298,13 +311,13 @@ function nt(t, e) {
298
311
  end: parseInt(n.gridColumnEnd)
299
312
  }
300
313
  };
301
- const s = t.parentElement, a = r.getComputedStyle(s), p = parseFloat(a.columnGap) || 0, d = parseFloat(a.rowGap) || 0, c = U(a.gridTemplateColumns), l = U(a.gridTemplateRows), g = parseFloat(a.paddingLeft) || 0, u = parseFloat(a.paddingTop) || 0, h = s.getBoundingClientRect(), m = t.getBoundingClientRect(), w = (b, $, x, S, C) => {
314
+ const s = t.parentElement, a = r.getComputedStyle(s), p = parseFloat(a.columnGap) || 0, d = parseFloat(a.rowGap) || 0, c = U(a.gridTemplateColumns), l = U(a.gridTemplateRows), g = parseFloat(a.paddingLeft) || 0, u = parseFloat(a.paddingTop) || 0, h = s.getBoundingClientRect(), m = t.getBoundingClientRect(), w = (b, $, T, S, C) => {
302
315
  let E = 1, P = S + C;
303
316
  for (let A = 0; A < $.length; A++) {
304
317
  const I = $[A], z = P + I;
305
318
  if (b >= P && b < z)
306
319
  return E;
307
- P = z + x, E++;
320
+ P = z + T, E++;
308
321
  }
309
322
  return -1;
310
323
  }, v = w(m.left, c, p, h.left, g), R = w(m.right - 1, c, p, h.left, g) + 1, y = w(m.top, l, d, h.top, u), f = w(m.bottom - 1, l, d, h.top, u) + 1;
@@ -320,7 +333,7 @@ function nt(t, e) {
320
333
  }
321
334
  };
322
335
  }
323
- function xt(t) {
336
+ function Pt(t) {
324
337
  t.Commands.add(F, {
325
338
  stop() {
326
339
  },
@@ -357,17 +370,17 @@ function xt(t) {
357
370
  }), this.stopCommand(), e.em.set("_cmpDrag", 1);
358
371
  },
359
372
  setPosition: ({ x: h, y: m }) => {
360
- const { scroll: w } = ot(e), { columns: v, rows: R, gap: y, offset: f, padding: b } = l, { offset: $, margin: x } = s, S = $.top - f.top - b.top - x.top + m - c.top + w.top, C = $.left - f.left - b.left - x.left + h - c.left + w.left, E = Math.min(T(v, 1, C, y.column, 0.5), v.length), P = Math.min(T(R, 1, S, y.row, 0.5), R.length), A = Math.min(
361
- T(v, E, $.width, y.column) + 1,
373
+ const { scroll: w } = ot(e), { columns: v, rows: R, gap: y, offset: f, padding: b } = l, { offset: $, margin: T } = s, S = $.top - f.top - b.top - T.top + m - c.top + w.top, C = $.left - f.left - b.left - T.left + h - c.left + w.left, E = Math.min(x(v, 1, C, y.column, 0.5), v.length), P = Math.min(x(R, 1, S, y.row, 0.5), R.length), A = Math.min(
374
+ x(v, E, $.width, y.column) + 1,
362
375
  v.length + 1
363
- ), I = Math.min(T(R, P, $.height, y.row) + 1, R.length + 1);
376
+ ), I = Math.min(x(R, P, $.height, y.row) + 1, R.length + 1);
364
377
  p.style.gridArea = `${P} / ${E} / ${I} / ${A}`, d.style.top = `${S + b.top}px`, d.style.left = `${C + b.left}px`;
365
378
  }
366
379
  }).start(n.event);
367
380
  }
368
381
  });
369
382
  }
370
- function Pt(t, e) {
383
+ function Gt(t, e) {
371
384
  const r = Z({ editor: t, component: e.component, type: "resizable" });
372
385
  if (!r)
373
386
  return;
@@ -385,48 +398,48 @@ function Pt(t, e) {
385
398
  target: s,
386
399
  container: c
387
400
  }), c = O(t, s.component);
388
- }, 10), t.trigger("component:resize", { ...s, type: "start" });
401
+ }, 10), t.trigger("component:resize", { ...s || {}, type: "start" });
389
402
  },
390
403
  onEnd: (u, h) => {
391
404
  const { startDim: m, rectDim: w } = h.resizer, v = JSON.stringify(m) === JSON.stringify(w);
392
405
  clearTimeout(g), tt({ editor: t, shadowSnappedEl: p, shadowContainerEl: a, target: s, cancelled: v }), o == null || o(u, h);
393
406
  },
394
407
  onMove: (u, h) => {
395
- const m = nt(p), w = s.margin.left, v = s.margin.top, R = s.margin.bottom, y = s.margin.right, { w: f, t: b, l: $, h: x } = h.resizer.rectDim, S = {
408
+ const m = nt(p), w = s.margin.left, v = s.margin.top, R = s.margin.bottom, y = s.margin.right, { w: f, t: b, l: $, h: T } = h.resizer.rectDim, S = {
396
409
  t: b - v,
397
410
  l: $ - w,
398
- h: x + v + R,
411
+ h: T + v + R,
399
412
  w: f + w + y
400
413
  };
401
- l.endsWith("l") && (m.column.start = T(
414
+ l.endsWith("l") && (m.column.start = x(
402
415
  c.columns,
403
416
  1,
404
417
  S.l - c.offset.left - c.padding.left,
405
418
  c.gap.column,
406
419
  0.5
407
- )), l.startsWith("t") && (m.row.start = T(
420
+ )), l.startsWith("t") && (m.row.start = x(
408
421
  c.rows,
409
422
  1,
410
423
  S.t - c.offset.top - c.padding.top,
411
424
  c.gap.row,
412
425
  0.5
413
426
  )), l.endsWith("r") && (m.column.end = Math.max(
414
- T(c.columns, m.column.start, S.w, c.gap.column, 0.5),
427
+ x(c.columns, m.column.start, S.w, c.gap.column, 0.5),
415
428
  m.column.start + 1
416
429
  )), l.startsWith("b") && (m.row.end = Math.max(
417
- T(c.rows, m.row.start, S.h, c.gap.row, 0.5),
430
+ x(c.rows, m.row.start, S.h, c.gap.row, 0.5),
418
431
  m.row.start + 1
419
432
  )), p.style.gridArea = `${m.row.start} / ${m.column.start} / ${m.row.end} / ${m.column.end}`, d.style.width = `${S.w}px`, d.style.height = `${S.h}px`, d.style.left = `${S.l - c.offset.left}px`, d.style.top = `${S.t - c.offset.top}px`, n == null || n(u, h);
420
433
  }
421
434
  };
422
435
  }
423
- const k = ["px", "%", "em", "rem", "vw", "vh"], Gt = (t, e) => {
436
+ const k = ["px", "%", "em", "rem", "vw", "vh"], Et = (t, e) => {
424
437
  const r = t.Styles.getSectors().find((n) => !!n.getProperty(e));
425
438
  return {
426
439
  sector: r,
427
440
  property: r ? r.getProperty(e) : void 0
428
441
  };
429
- }, Et = (t, e) => Gt(t, e), At = (t, { x: e, y: r, mergable: n } = {}) => {
442
+ }, At = (t, e) => Et(t, e), Dt = (t, { x: e, y: r, mergable: n } = {}) => {
430
443
  const o = {
431
444
  property: `${t}-x`,
432
445
  type: "integer",
@@ -459,7 +472,7 @@ const k = ["px", "%", "em", "rem", "vw", "vh"], Gt = (t, e) => {
459
472
  }
460
473
  };
461
474
  }, B = { display: ["grid"] };
462
- function Dt(t = "") {
475
+ function Mt(t = "") {
463
476
  const e = /^repeat\(\s*(\d+)\s*,\s*(.+)\s*\)$/i, r = /^minmax\(\s*(.+?)\s*,\s*(.+?)\s*\)$/i, n = t.match(e);
464
477
  if (!n)
465
478
  return null;
@@ -472,7 +485,7 @@ function Dt(t = "") {
472
485
  max: a
473
486
  };
474
487
  }
475
- function Mt(t = {}) {
488
+ function Ct(t = {}) {
476
489
  let e = "", r = "", n = "", o = "";
477
490
  const i = (m) => m.split("/").map((w) => w.trim()).filter(Boolean), s = t["grid-area"] || "", a = t["grid-column"] || "", p = t["grid-row"] || "", d = i(s), c = i(a), l = i(p), g = d.length, u = c.length, h = l.length;
478
491
  return g === 4 ? (n = d[0], e = d[1], o = d[2], r = d[3]) : g === 3 ? (n = d[0], e = d[1], o = d[2]) : g === 2 ? (n = d[0], e = d[1]) : g === 1 && (n = d[0]), u === 2 ? (e = c[0], r = c[1]) : u === 1 && (e = c[0]), h === 2 ? (n = l[0], o = l[1]) : h === 1 && (n = l[0]), {
@@ -517,7 +530,7 @@ function q(t) {
517
530
  }
518
531
  ],
519
532
  fromStyle(i, s) {
520
- const { name: a, property: p } = s, [d, c, l] = p.getProperties(), g = i[a], u = Dt(g), h = (u == null ? void 0 : u.max) ?? o;
533
+ const { name: a, property: p } = s, [d, c, l] = p.getProperties(), g = i[a], u = Mt(g), h = (u == null ? void 0 : u.max) ?? o;
521
534
  return {
522
535
  [d.id]: (u == null ? void 0 : u.total) ?? n,
523
536
  [c.id]: (u == null ? void 0 : u.min) ?? "",
@@ -532,9 +545,9 @@ function q(t) {
532
545
  }
533
546
  };
534
547
  }
535
- function Ct(t, e) {
548
+ function It(t, e) {
536
549
  if (!e.styleableGrid) return;
537
- const { property: r, ...n } = Et(t, "display");
550
+ const { property: r, ...n } = At(t, "display");
538
551
  if (!r) return;
539
552
  const o = r.getOption("grid"), i = n.sector;
540
553
  o || r.addOption({ id: "grid", label: "Grid" }), i.addProperty(
@@ -553,7 +566,7 @@ function Ct(t, e) {
553
566
  {
554
567
  id: "grid-gap",
555
568
  requires: B,
556
- ...At("gap", {
569
+ ...Dt("gap", {
557
570
  x: { id: "grid-row-gap", label: "Row", property: "row-gap", min: 0, default: "0" },
558
571
  y: { id: "grid-column-gap", label: "Column", property: "column-gap", min: 0, default: "0" },
559
572
  mergable: !0
@@ -595,7 +608,7 @@ function Ct(t, e) {
595
608
  }
596
609
  ],
597
610
  fromStyle(s) {
598
- const a = Mt(s);
611
+ const a = Ct(s);
599
612
  return {
600
613
  "grid-column-start": s["grid-column-start"] || a.columnStart,
601
614
  "grid-column-end": s["grid-column-end"] || a.columnEnd,
@@ -613,18 +626,18 @@ function Ct(t, e) {
613
626
  {}
614
627
  );
615
628
  }
616
- const It = function(t, e = {}) {
629
+ const Lt = function(t, e = {}) {
617
630
  const r = {
618
631
  itemResizable: !0,
619
632
  ...e
620
633
  }, { Canvas: n, Commands: o, Components: i } = t, { itemResizable: s } = r, a = n.events, p = o.events, d = i.events, c = `${p.runBeforeCommand}tlb-move`, l = `${p.runBeforeCommand}resize`;
621
634
  let g;
622
- xt(t);
635
+ Pt(t);
623
636
  const u = ({ options: y }) => {
624
637
  L(t, y.target, r) && (t.runCommand(F, { ...y }), y.abort = !0);
625
638
  }, h = (y) => {
626
639
  const { options: f } = y;
627
- L(t, f.component, r) && (f.options = Object.assign(f.options || {}, Pt(t, f)));
640
+ L(t, f.component, r) && (f.options = Object.assign(f.options || {}, Gt(t, f)));
628
641
  }, m = () => {
629
642
  const y = n.getSpots({
630
643
  type: D
@@ -668,21 +681,21 @@ const It = function(t, e = {}) {
668
681
  v.forEach(([y, f]) => {
669
682
  t.on(y, f);
670
683
  }), t.onReady(() => {
671
- g = n.getSpotsEl(), wt(), Ct(t, r);
684
+ g = n.getSpotsEl(), bt(), It(t, r);
672
685
  });
673
686
  const R = () => {
674
687
  delete t.Commands.commands[F], v.forEach(([y, f]) => {
675
688
  t.off(y, f);
676
689
  });
677
690
  };
678
- ut({
691
+ ft({
679
692
  editor: t,
680
693
  licenseKey: r.licenseKey,
681
- plan: yt,
694
+ plan: ht,
682
695
  pluginName: N,
683
696
  cleanup: R
684
697
  });
685
- }, Lt = gt(It);
698
+ }, _t = ut(Lt);
686
699
  export {
687
- Lt as default
700
+ _t as default
688
701
  };
@@ -1,4 +1,4 @@
1
- (function(x,P){typeof exports=="object"&&typeof module<"u"?module.exports=P():typeof define=="function"&&define.amd?define(P):(x=typeof globalThis<"u"?globalThis:x||self,x.StudioSdkPlugins_canvasGridMode=P())})(this,function(){"use strict";const x="app.grapesjs.com",P="app-stage.grapesjs.com",W=[x,"app2.grapesjs.com",P,"app-stage2.grapesjs.com","localhost","127.0.0.1",".local-credentialless.webcontainer.io",".local.webcontainer.io","-sandpack.codesandbox.io"],rt="license:check:end",st=()=>typeof window<"u",at=({isDev:t,isStage:e,isPlatform:r})=>`${t?"":`https://${e?P:x}`}/${r?"platform-api":"api"}`,it=()=>{const t=st()&&window.location.hostname;return!!t&&(W.includes(t)||W.some(e=>t.endsWith(e)))};function U(t){return typeof t=="function"}async function lt({path:t,baseApiUrl:e,method:r="GET",headers:n={},params:o,body:i}){const a=`${e||at({isDev:!1,isStage:!1})}${t}`,p={method:r,headers:{"Content-Type":"application/json",...n}};i&&(p.body=JSON.stringify(i));const d=o?new URLSearchParams(o).toString():"",c=d?`?${d}`:"",l=await fetch(`${a}${c}`,p);if(!l.ok)throw new Error(`HTTP error! status: ${l.status}`);return l.json()}var G=(t=>(t.free="free",t.startup="startup",t.business="business",t.enterprise="enterprise",t))(G||{}),L=(t=>(t.toastAdd="studio:toastAdd",t.toastRemove="studio:toastRemove",t.dialogOpen="studio:dialogOpen",t.dialogClose="studio:dialogClose",t.dialogExportCode="studio:dialogExportCode",t.dialogImportCode="studio:dialogImportCode",t.sidebarLeftSet="studio:sidebarLeft:set",t.sidebarLeftGet="studio:sidebarLeft:get",t.sidebarLeftToggle="studio:sidebarLeft:toggle",t.sidebarRightSet="studio:sidebarRight:set",t.sidebarRightGet="studio:sidebarRight:get",t.sidebarRightToggle="studio:sidebarRight:toggle",t.sidebarTopSet="studio:sidebarTop:set",t.sidebarTopGet="studio:sidebarTop:get",t.sidebarTopToggle="studio:sidebarTop:toggle",t.sidebarBottomSet="studio:sidebarBottom:set",t.sidebarBottomGet="studio:sidebarBottom:get",t.sidebarBottomToggle="studio:sidebarBottom:toggle",t.symbolAdd="studio:symbolAdd",t.symbolDetach="studio:symbolDetach",t.symbolOverride="studio:symbolOverride",t.symbolPropagateStyles="studio:propagateStyles",t.getPagesConfig="studio:getPagesConfig",t.setPagesConfig="studio:setPagesConfig",t.getPageSettings="studio:getPageSettings",t.setPageSettings="studio:setPageSettings",t.clearPage="studio:clearPage",t.projectFiles="studio:projectFiles",t.validateCode="studio:validateCode",t.canvasReload="studio:canvasReload",t.getBlocksPanel="studio:getBlocksPanel",t.setBlocksPanel="studio:setBlocksPanel",t.getStateContextMenu="studio:getStateContextMenu",t.setStateContextMenu="studio:setStateContextMenu",t.contextMenuComponent="studio:contextMenuComponent",t.layoutAdd="studio:layoutAdd",t.layoutRemove="studio:layoutRemove",t.layoutToggle="studio:layoutToggle",t.layoutUpdate="studio:layoutUpdate",t.layoutGet="studio:layoutGet",t.layoutConfigGet="studio:layoutConfigGet",t.layoutConfigSet="studio:layoutConfigSet",t.layoutComponentAdd="studio:layoutComponentAdd",t.layoutComponentGet="studio:layoutComponentGet",t.layoutComponentRemove="studio:layoutComponentRemove",t.layoutComponentRender="studio:layoutComponentRender",t.getStateTheme="studio:getStateTheme",t.setStateTheme="studio:setStateTheme",t.settings="studio:settings",t.assetProviderGet="studio:assetProviderGet",t.assetProviderAdd="studio:assetProviderAdd",t.assetProviderRemove="studio:assetProviderRemove",t.fontGet="studio:fontGet",t.fontAdd="studio:fontAdd",t.fontRemove="studio:fontRemove",t.fontManagerOpen="studio:fontManagerOpen",t.menuFontLoad="studio:menuFontLoad",t.toggleStateDataSource="studio:toggleStateDataSource",t.getStateDataSource="studio:getStateDataSource",t.dataSourceSetGlobalData="studio:dataSourceSetGlobalData",t.dataSourceSetImporter="studio:dataSourceSetImporter",t.dataSourceSetExporter="studio:dataSourceSetExporter",t.setDragAbsolute="studio:setDragAbsolute",t))(L||{});const k={[G.free]:0,[G.startup]:10,[G.business]:20,[G.enterprise]:30};function ct(t){const e=t;return e.init=r=>n=>t(n,r),e}const pt=t=>ct(t);async function dt({editor:t,plan:e,pluginName:r,licenseKey:n,onLicenseCheckResponse:o,cleanup:i}){let s="",a;const p=l=>{console.warn("Cleanup plugin:",r,"Reason:",l),i()},d=(l={})=>{var w;const{error:g,sdkLicense:u}=l,h=(w=l.plan)==null?void 0:w.category;if(!(u||l.license)||g)p(g||"Invalid license");else if(h){const v=k[e],R=k[h];v>R&&p({pluginRequiredPlan:e,licensePlan:h})}};t.Commands.has(L.settings)&&(a=t.runCommand(L.settings),s=(a==null?void 0:a.baseUrl)||"");const c=l=>{o==null||o(l),l&&d(l)};if(!a){t.onReady(async()=>{if(!it())if(n){const l=await ut({licenseKey:n,pluginName:r,baseApiUrl:s});c(l)}else p("The `licenseKey` option not provided")});return}if(a.licensePlan||a.licenseError){const l=gt(a);c(l);return}t.on(rt,l=>c(l))}const gt=t=>({sdkLicense:t.license,license:t.license,error:t.licenseError,plan:t.licensePlan});async function ut(t){const{licenseKey:e,pluginName:r,baseApiUrl:n}=t;try{return(await lt({baseApiUrl:n,path:`/sdk/${e||"na"}`,method:"POST",params:{d:window.location.hostname,pn:r}})).result||{}}catch(o){return console.error("Error during SDK license check:",o),!1}}const N="canvasGridMode",ft=G.startup,O="component-grid-mode",D="grid-mode",M="gjs-drag-grid-spot",q=`${M}__grid-item`,Y=`${M}__grid-target`,H=`${M}__snapped`,mt=`${M}__container`,yt=()=>{const t="data-gjs-drag-grid-style",e=document,r="var(--gs-theme-cl-cmp-bg1, var(--gjs-color-highlight))",n="var(--gs-theme-cl-cmp-bg2, var(--gjs-color-blue))",o=e.querySelector(`style[${t}]`)||e.createElement("style");o.setAttribute(t,"true"),o.innerHTML=`
1
+ (function(x,P){typeof exports=="object"&&typeof module<"u"?module.exports=P():typeof define=="function"&&define.amd?define(P):(x=typeof globalThis<"u"?globalThis:x||self,x.StudioSdkPlugins_canvasGridMode=P())})(this,function(){"use strict";const x="app.grapesjs.com",P="app-stage.grapesjs.com",W=[x,"app2.grapesjs.com",P,"app-stage2.grapesjs.com","localhost","127.0.0.1",".local-credentialless.webcontainer.io",".local.webcontainer.io","-sandpack.codesandbox.io",".claudemcpcontent.com",".web-sandbox.oaiusercontent.com"],rt="license:check:end",st=()=>typeof window<"u",at=({isDev:t,isStage:e,isPlatform:r})=>`${t?"":`https://${e?P:x}`}/${r?"platform-api":"api"}`,it=()=>{if(!st())return"";const{hostname:t}=window.location;if(t)return t;try{return window.parent.location.hostname||""}catch{return""}},lt=()=>{const t=it();return!!t&&(W.includes(t)||W.some(e=>t.endsWith(e)))};function U(t){return typeof t=="function"}async function ct({path:t,baseApiUrl:e,method:r="GET",headers:n={},params:o,body:i}){const a=`${e||at({isDev:!1,isStage:!1})}${t}`,p={method:r,headers:{"Content-Type":"application/json",...n}};i&&(p.body=JSON.stringify(i));const d=o?new URLSearchParams(o).toString():"",c=d?`?${d}`:"",l=await fetch(`${a}${c}`,p);if(!l.ok)throw new Error(`HTTP error! status: ${l.status}`);return l.json()}var G=(t=>(t.free="free",t.startup="startup",t.business="business",t.enterprise="enterprise",t))(G||{}),L=(t=>(t.toastAdd="studio:toastAdd",t.toastRemove="studio:toastRemove",t.dialogOpen="studio:dialogOpen",t.dialogClose="studio:dialogClose",t.dialogExportCode="studio:dialogExportCode",t.dialogImportCode="studio:dialogImportCode",t.sidebarLeftSet="studio:sidebarLeft:set",t.sidebarLeftGet="studio:sidebarLeft:get",t.sidebarLeftToggle="studio:sidebarLeft:toggle",t.sidebarRightSet="studio:sidebarRight:set",t.sidebarRightGet="studio:sidebarRight:get",t.sidebarRightToggle="studio:sidebarRight:toggle",t.sidebarTopSet="studio:sidebarTop:set",t.sidebarTopGet="studio:sidebarTop:get",t.sidebarTopToggle="studio:sidebarTop:toggle",t.sidebarBottomSet="studio:sidebarBottom:set",t.sidebarBottomGet="studio:sidebarBottom:get",t.sidebarBottomToggle="studio:sidebarBottom:toggle",t.symbolAdd="studio:symbolAdd",t.symbolDetach="studio:symbolDetach",t.symbolOverride="studio:symbolOverride",t.symbolPropagateStyles="studio:propagateStyles",t.getPagesConfig="studio:getPagesConfig",t.setPagesConfig="studio:setPagesConfig",t.getPageSettings="studio:getPageSettings",t.setPageSettings="studio:setPageSettings",t.clearPage="studio:clearPage",t.projectFiles="studio:projectFiles",t.validateCode="studio:validateCode",t.canvasReload="studio:canvasReload",t.getBlocksPanel="studio:getBlocksPanel",t.setBlocksPanel="studio:setBlocksPanel",t.getStateContextMenu="studio:getStateContextMenu",t.setStateContextMenu="studio:setStateContextMenu",t.contextMenuComponent="studio:contextMenuComponent",t.layoutAdd="studio:layoutAdd",t.layoutRemove="studio:layoutRemove",t.layoutToggle="studio:layoutToggle",t.layoutUpdate="studio:layoutUpdate",t.layoutGet="studio:layoutGet",t.layoutConfigGet="studio:layoutConfigGet",t.layoutConfigSet="studio:layoutConfigSet",t.layoutComponentAdd="studio:layoutComponentAdd",t.layoutComponentGet="studio:layoutComponentGet",t.layoutComponentRemove="studio:layoutComponentRemove",t.layoutComponentRender="studio:layoutComponentRender",t.getStateTheme="studio:getStateTheme",t.setStateTheme="studio:setStateTheme",t.settings="studio:settings",t.assetProviderGet="studio:assetProviderGet",t.assetProviderAdd="studio:assetProviderAdd",t.assetProviderRemove="studio:assetProviderRemove",t.fontGet="studio:fontGet",t.fontAdd="studio:fontAdd",t.fontRemove="studio:fontRemove",t.fontManagerOpen="studio:fontManagerOpen",t.menuFontLoad="studio:menuFontLoad",t.toggleStateDataSource="studio:toggleStateDataSource",t.getStateDataSource="studio:getStateDataSource",t.dataSourceSetGlobalData="studio:dataSourceSetGlobalData",t.dataSourceSetImporter="studio:dataSourceSetImporter",t.dataSourceSetExporter="studio:dataSourceSetExporter",t.setDragAbsolute="studio:setDragAbsolute",t))(L||{});const k={[G.free]:0,[G.startup]:10,[G.business]:20,[G.enterprise]:30};function pt(t){const e=t;return e.init=r=>n=>t(n,r),e}const dt=t=>pt(t);async function gt({editor:t,plan:e,pluginName:r,licenseKey:n,onLicenseCheckResponse:o,cleanup:i}){let s="",a;const p=l=>{console.warn("Cleanup plugin:",r,"Reason:",l),i()},d=(l={})=>{var w;const{error:g,sdkLicense:u}=l,h=(w=l.plan)==null?void 0:w.category;if(!(u||l.license)||g)p(g||"Invalid license");else if(h){const v=k[e],R=k[h];v>R&&p({pluginRequiredPlan:e,licensePlan:h})}};t.Commands.has(L.settings)&&(a=t.runCommand(L.settings),s=(a==null?void 0:a.baseUrl)||"");const c=l=>{o==null||o(l),l&&d(l)};if(!a){t.onReady(async()=>{if(!lt())if(n){const l=await ft({licenseKey:n,pluginName:r,baseApiUrl:s});c(l)}else p("The `licenseKey` option not provided")});return}if(a.licensePlan||a.licenseError){const l=ut(a);c(l);return}t.on(rt,l=>c(l))}const ut=t=>({sdkLicense:t.license,license:t.license,error:t.licenseError,plan:t.licensePlan});async function ft(t){const{licenseKey:e,pluginName:r,baseApiUrl:n}=t;try{return(await ct({baseApiUrl:n,path:`/sdk/${e||"na"}`,method:"POST",params:{d:window.location.hostname,pn:r}})).result||{}}catch(o){return console.error("Error during SDK license check:",o),!1}}const N="canvasGridMode",mt=G.startup,O="component-grid-mode",D="grid-mode",M="gjs-drag-grid-spot",q=`${M}__grid-item`,H=`${M}__grid-target`,Y=`${M}__snapped`,yt=`${M}__container`,ht=()=>{const t="data-gjs-drag-grid-style",e=document,r="var(--gs-theme-cl-cmp-bg1, var(--gjs-color-highlight))",n="var(--gs-theme-cl-cmp-bg2, var(--gjs-color-blue))",o=e.querySelector(`style[${t}]`)||e.createElement("style");o.setAttribute(t,"true"),o.innerHTML=`
2
2
  .${q} {
3
3
  outline: 2px solid ${n};
4
4
  background: ${r};
@@ -8,14 +8,14 @@
8
8
  height: 100%;
9
9
  opacity: 0.1;
10
10
  }
11
- .${H} {
11
+ .${Y} {
12
12
  width: 100%;
13
13
  height: 100%;
14
14
  outline: 2px solid ${n};
15
15
  outline-offset: -2px;
16
16
  position: absolute;
17
17
  }
18
- .${Y} {
18
+ .${H} {
19
19
  position: absolute;
20
20
  z-index: -1;
21
21
  background: ${r};
@@ -23,4 +23,4 @@
23
23
  outline-offset: -1px;
24
24
  opacity: 0.35;
25
25
  }
26
- `,e.head.appendChild(o)};function X(t){const{editor:e,type:r}=t,n=St(e,t.component),o=F(e,n.component);if(!$t(e,n,o,r))return{target:n,container:o,startScroll:Z(e).scroll,shadowContainerEl:document.createElement("div"),shadowSnappedEl:document.createElement("div"),shadowTargetEl:document.createElement("div"),spot:e.Canvas.addSpot({type:D,component:o.component})}}function K(t){const{editor:e,shadowTargetEl:r,shadowSnappedEl:n,shadowContainerEl:o,spotEl:i,target:s,container:a}=t,{Canvas:p}=e,d=e.config.stylePrefix;i==null||i.appendChild(o),o==null||o.appendChild(r),o==null||o.appendChild(n),ht(o,a),wt(r,s,a),bt(n,s),vt(o,a.el),s.el.style.opacity="0";const c=p.getSpots().filter(l=>l.type!==D);e.em.stopDefault({preserveSelected:!0}),p.removeSpots(c),p.startAutoscroll(),p.getBody().classList.add(`${d}is__grabbing`)}function J(t){const{editor:e,shadowSnappedEl:r,shadowContainerEl:n,target:o,cancelled:i}=t,{Canvas:s}=e,a=e.config.stylePrefix,{component:p}=o;if(!i){const d=window.getComputedStyle(r);p.addStyle({"grid-area":d.gridArea,width:"",height:""})}o.el.style.opacity="",n.contains(r)&&(n==null||n.removeChild(r)),e.getModel().runDefault({preserveSelected:1}),s.stopAutoscroll(),s.getBody().classList.remove(`${a}is__grabbing`),s.removeSpots({type:D}),e.select(p)}function ht(t,{rows:e,columns:r}){const n=[];for(let o=0;o<r.length;o++){n[o]=[];for(let i=0;i<e.length;i++){const s=document.createElement("div");s.className=q,s.style.gridArea=`${i+1} / ${o+1}`,n[o][i]=s,t.appendChild(s)}}return n}function wt(t,e,r){return t.className=Y,t.style.top=`${e.offset.top-r.offset.top}px`,t.style.left=`${e.offset.left-r.offset.left}px`,t.style.width=`${e.offset.width+e.margin.left+e.margin.right}px`,t.style.height=`${e.offset.height+e.margin.top+e.margin.bottom}px`,t}function bt(t,e){const r=tt(e.el,e.computedStyles);return t.className=H,t.style.gridArea=`${r.row.start} / ${r.column.start} / ${r.row.end} / ${r.column.end}`,t}function vt(t,e){const r=window.getComputedStyle(e);t.className=mt,t.style.position="relative",t.style.display=r.display,t.style.gap=r.gap,t.style.padding=r.padding,t.style.border=r.border,t.style.gridTemplateColumns=r.gridTemplateColumns,t.style.gridTemplateRows=r.gridTemplateRows}function Q(t,e){if(e){if(Array.isArray(e))return[...e].pop()}else return[...t.getSelectedAll()].pop();return e}function St(t,e){const r=Q(t,e),n=r.getEl(),o=window.getComputedStyle(n);return{component:r,el:n,offset:t.Canvas.offset(n),margin:{top:parseFloat(o.marginTop),right:parseFloat(o.marginRight),bottom:parseFloat(o.marginBottom),left:parseFloat(o.marginLeft)},computedStyles:o}}function F(t,e){const r=e.parent(),n=r.getEl(),o=window.getComputedStyle(n);return{component:r,el:n,offset:t.Canvas.offset(n),computedStyles:o,padding:{top:parseFloat(o.paddingTop),right:parseFloat(o.paddingRight),bottom:parseFloat(o.paddingBottom),left:parseFloat(o.paddingLeft)},columns:o.gridTemplateColumns.split(" ").map(s=>parseFloat(s)),rows:o.gridTemplateRows.split(" ").map(s=>parseFloat(s)),gap:{column:parseInt(o.columnGap),row:parseInt(o.rowGap)}}}function T(t,e,r,n,o=1){let i=0;for(let s=e;s<=t.length;s++){if(i+(t[s-1]+n)*o>r)return s;i+=n+t[s-1]}return t.length+1}function Z(t){const{scrollY:e,scrollX:r}=t.Canvas.getWindow();return{scroll:{top:e,left:r}}}function $t(t,e,r,n){const o=i=>t.em.logWarning(i);return n==="draggable"&&e.component.get(n)===!1?(o(`[${N}] The element is not ${n}`),!0):r.computedStyles.display!=="grid"?(o(`[${N}] The container does not have style display:grid`),!0):!1}function B(t,e,r={}){const n=Q(t,e),o=n==null?void 0:n.parent(),i=o==null?void 0:o.getEl();if(!o||!i)return!1;const{enableGrid:s}=r,a=window.getComputedStyle(i).display==="grid";return U(s)?s({component:n,parent:o,isParentGrid:a}):a}const V=t=>t.split(" ").map(e=>parseFloat(e));function tt(t,e){const r=t.ownerDocument.defaultView,n=e||r.getComputedStyle(t),o=n.gridArea.split("/").some(b=>isNaN(parseInt(b.trim()))),i={isComputed:o,raw:n.gridArea};if(!o)return{...i,row:{start:parseInt(n.gridRowStart),end:parseInt(n.gridRowEnd)},column:{start:parseInt(n.gridColumnStart),end:parseInt(n.gridColumnEnd)}};const s=t.parentElement,a=r.getComputedStyle(s),p=parseFloat(a.columnGap)||0,d=parseFloat(a.rowGap)||0,c=V(a.gridTemplateColumns),l=V(a.gridTemplateRows),g=parseFloat(a.paddingLeft)||0,u=parseFloat(a.paddingTop)||0,h=s.getBoundingClientRect(),m=t.getBoundingClientRect(),w=(b,S,E,$,_)=>{let I=1,A=$+_;for(let C=0;C<S.length;C++){const j=S[C],nt=A+j;if(b>=A&&b<nt)return I;A=nt+E,I++}return-1},v=w(m.left,c,p,h.left,g),R=w(m.right-1,c,p,h.left,g)+1,y=w(m.top,l,d,h.top,u),f=w(m.bottom-1,l,d,h.top,u)+1;return{...i,row:{start:y,end:f},column:{start:v,end:R}}}function Rt(t){t.Commands.add(O,{stop(){},run(e,r,n={}){const o=X({editor:e,component:n.target,type:"draggable"});if(!o){this.stopCommand();return}const{spot:i,target:s,shadowContainerEl:a,shadowSnappedEl:p,shadowTargetEl:d,startScroll:c}=o;let{container:l}=o,g;new e.Utils.Dragger({doc:s.el.ownerDocument,onStart:()=>{g=setTimeout(()=>{K({editor:e,shadowTargetEl:d,shadowSnappedEl:p,shadowContainerEl:a,spotEl:i.attributes.spotEl,target:s,container:l}),l=F(e,s.component)},10)},onEnd:(h,m,{cancelled:w})=>{clearTimeout(g),J({editor:e,shadowSnappedEl:p,shadowContainerEl:a,target:s,cancelled:w}),this.stopCommand(),e.em.set("_cmpDrag",1)},setPosition:({x:h,y:m})=>{const{scroll:w}=Z(e),{columns:v,rows:R,gap:y,offset:f,padding:b}=l,{offset:S,margin:E}=s,$=S.top-f.top-b.top-E.top+m-c.top+w.top,_=S.left-f.left-b.left-E.left+h-c.left+w.left,I=Math.min(T(v,1,_,y.column,.5),v.length),A=Math.min(T(R,1,$,y.row,.5),R.length),C=Math.min(T(v,I,S.width,y.column)+1,v.length+1),j=Math.min(T(R,A,S.height,y.row)+1,R.length+1);p.style.gridArea=`${A} / ${I} / ${j} / ${C}`,d.style.top=`${$+b.top}px`,d.style.left=`${_+b.left}px`}}).start(n.event)}})}function Tt(t,e){const r=X({editor:t,component:e.component,type:"resizable"});if(!r)return;const{onMove:n,onEnd:o}=e.options||{},{spot:i,target:s,shadowContainerEl:a,shadowSnappedEl:p,shadowTargetEl:d}=r;let{container:c}=r,l="",g;return{onStart:u=>{l=u.target.dataset.gjsHandler||"",g=setTimeout(()=>{K({editor:t,shadowTargetEl:d,shadowSnappedEl:p,shadowContainerEl:a,spotEl:i.attributes.spotEl,target:s,container:c}),c=F(t,s.component)},10),t.trigger("component:resize",{...s,type:"start"})},onEnd:(u,h)=>{const{startDim:m,rectDim:w}=h.resizer,v=JSON.stringify(m)===JSON.stringify(w);clearTimeout(g),J({editor:t,shadowSnappedEl:p,shadowContainerEl:a,target:s,cancelled:v}),o==null||o(u,h)},onMove:(u,h)=>{const m=tt(p),w=s.margin.left,v=s.margin.top,R=s.margin.bottom,y=s.margin.right,{w:f,t:b,l:S,h:E}=h.resizer.rectDim,$={t:b-v,l:S-w,h:E+v+R,w:f+w+y};l.endsWith("l")&&(m.column.start=T(c.columns,1,$.l-c.offset.left-c.padding.left,c.gap.column,.5)),l.startsWith("t")&&(m.row.start=T(c.rows,1,$.t-c.offset.top-c.padding.top,c.gap.row,.5)),l.endsWith("r")&&(m.column.end=Math.max(T(c.columns,m.column.start,$.w,c.gap.column,.5),m.column.start+1)),l.startsWith("b")&&(m.row.end=Math.max(T(c.rows,m.row.start,$.h,c.gap.row,.5),m.row.start+1)),p.style.gridArea=`${m.row.start} / ${m.column.start} / ${m.row.end} / ${m.column.end}`,d.style.width=`${$.w}px`,d.style.height=`${$.h}px`,d.style.left=`${$.l-c.offset.left}px`,d.style.top=`${$.t-c.offset.top}px`,n==null||n(u,h)}}}const et=["px","%","em","rem","vw","vh"],xt=(t,e)=>{const r=t.Styles.getSectors().find(n=>!!n.getProperty(e));return{sector:r,property:r?r.getProperty(e):void 0}},Pt=(t,e)=>xt(t,e),Gt=(t,{x:e,y:r,mergable:n}={})=>{const o={property:`${t}-x`,type:"integer",units:et,...e},i={property:`${t}-y`,type:"integer",units:et,...r};return{property:t,type:"composite",properties:[o,i],...n&&{fromStyle(s,{name:a,separator:p,property:d}){const[c,l]=d.getProperties(),[g,u]=(s[a]||"").split(p);return{[c.getId()]:s[c.getName()]||g||"",[l.getId()]:s[l.getName()]||u||g||""}},toStyle(s,{name:a,property:p}){const[d,c]=p.getProperties(),l=s[d.getId()],g=s[c.getId()];return{[a]:l===g?l:`${l} ${g}`}}}}},z={display:["grid"]};function Et(t=""){const e=/^repeat\(\s*(\d+)\s*,\s*(.+)\s*\)$/i,r=/^minmax\(\s*(.+?)\s*,\s*(.+?)\s*\)$/i,n=t.match(e);if(!n)return null;const o=parseInt(n[1],10),i=n[2];let s=i,a=i;const p=i.match(r);return p&&(s=p[1],a=p[2]),{total:o,min:s===a?"":s,max:a}}function At(t={}){let e="",r="",n="",o="";const i=m=>m.split("/").map(w=>w.trim()).filter(Boolean),s=t["grid-area"]||"",a=t["grid-column"]||"",p=t["grid-row"]||"",d=i(s),c=i(a),l=i(p),g=d.length,u=c.length,h=l.length;return g===4?(n=d[0],e=d[1],o=d[2],r=d[3]):g===3?(n=d[0],e=d[1],o=d[2]):g===2?(n=d[0],e=d[1]):g===1&&(n=d[0]),u===2?(e=c[0],r=c[1]):u===1&&(e=c[0]),h===2?(n=l[0],o=l[1]):h===1&&(n=l[0]),{columnStart:e,columnEnd:r,rowStart:n,rowEnd:o}}function ot(t){const{property:e,label:r}=t,n="1",o="1fr";return{property:e,label:r,type:"composite",requires:z,generic:!0,properties:[{name:" ",property:`${e}-repeat`,type:"number",full:!0,min:1,default:"1"},{label:"Min size",property:`${e}-min`,type:"number",min:0,units:["px","%"],default:"0"},{label:"Max size",property:`${e}-max`,type:"number",min:1,units:["fr","px","%"],default:"1"}],fromStyle(i,s){const{name:a,property:p}=s,[d,c,l]=p.getProperties(),g=i[a],u=Et(g),h=(u==null?void 0:u.max)??o;return{[d.id]:(u==null?void 0:u.total)??n,[c.id]:(u==null?void 0:u.min)??"",[l.id]:h===o?"":h}},toStyle(i,{name:s,property:a}){const[p,d,c]=a.getProperties(),l=i[p.id],g=i[d.id],u=i[c.id]||o,h=g&&u?`minmax(${g}, ${u})`:u;return{[s]:`repeat(${l||n}, ${h})`}}}}function Dt(t,e){if(!e.styleableGrid)return;const{property:r,...n}=Pt(t,"display");if(!r)return;const o=r.getOption("grid"),i=n.sector;o||r.addOption({id:"grid",label:"Grid"}),i.addProperty(ot({label:"Columns",property:"grid-template-columns"}),{}),i.addProperty(ot({label:"Rows",property:"grid-template-rows"}),{}),i.addProperty({id:"grid-gap",requires:z,...Gt("gap",{x:{id:"grid-row-gap",label:"Row",property:"row-gap",min:0,default:"0"},y:{id:"grid-column-gap",label:"Column",property:"column-gap",min:0,default:"0"},mergable:!0})},{}),i.addProperty({type:"composite",property:"grid-area",label:"Grid area",requiresParent:z,generic:!0,properties:[{label:"Row start",property:"grid-row-start",type:"integer",default:"auto"},{label:"Row end",property:"grid-row-end",type:"integer",default:"auto"},{label:"Column start",property:"grid-column-start",type:"integer",default:"auto"},{label:"Column end",property:"grid-column-end",type:"integer",default:"auto"}],fromStyle(s){const a=At(s);return{"grid-column-start":s["grid-column-start"]||a.columnStart,"grid-column-end":s["grid-column-end"]||a.columnEnd,"grid-row-start":s["grid-row-start"]||a.rowStart,"grid-row-end":s["grid-row-end"]||a.rowEnd}},toStyle(s,{name:a}){const p=s["grid-row-start"]||"auto",d=s["grid-row-end"]||"auto",c=s["grid-column-start"]||"auto",l=s["grid-column-end"]||"auto";return{[a]:`${p} / ${c} / ${d} / ${l}`}}},{})}return pt(function(t,e={}){const r={itemResizable:!0,...e},{Canvas:n,Commands:o,Components:i}=t,{itemResizable:s}=r,a=n.events,p=o.events,d=i.events,c=`${p.runBeforeCommand}tlb-move`,l=`${p.runBeforeCommand}resize`;let g;Rt(t);const u=({options:y})=>{B(t,y.target,r)&&(t.runCommand(O,{...y}),y.abort=!0)},h=y=>{const{options:f}=y;B(t,f.component,r)&&(f.options=Object.assign(f.options||{},Tt(t,f)))},m=()=>{const y=n.getSpots({type:D}).pop();if(!y)return;let f=y.attributes.spotEl;f||(f=document.createElement("div"),f.className=M,y.set({spotEl:f})),Object.entries(y.getStyle()).forEach(([b,S])=>f.style.setProperty(b,S)),g==null||g.appendChild(f)},w=({spot:y})=>{const f=y.attributes.spotEl;y.type!==D||!f||g==null||g.removeChild(f)};if(s){const y=f=>{const b=U(s)?s({component:f}):s;return typeof b=="boolean"?b:{tl:!1,tc:!1,tr:!1,cl:!1,cr:!1,bl:!1,bc:!1,br:!1,...b}};t.on(d.resizeInit,f=>{const{component:b}=f;if(B(t,b,r)){const S=y(b);f.resizable=S}})}const v=[[c,u],[l,h],[a.spot,m],[a.spotRemove,w]];v.forEach(([y,f])=>{t.on(y,f)}),t.onReady(()=>{g=n.getSpotsEl(),yt(),Dt(t,r)});const R=()=>{delete t.Commands.commands[O],v.forEach(([y,f])=>{t.off(y,f)})};dt({editor:t,licenseKey:r.licenseKey,plan:ft,pluginName:N,cleanup:R})})});
26
+ `,e.head.appendChild(o)};function X(t){const{editor:e,type:r}=t,n=$t(e,t.component),o=F(e,n.component);if(!Rt(e,n,o,r))return{target:n,container:o,startScroll:Z(e).scroll,shadowContainerEl:document.createElement("div"),shadowSnappedEl:document.createElement("div"),shadowTargetEl:document.createElement("div"),spot:e.Canvas.addSpot({type:D,component:o.component})}}function K(t){const{editor:e,shadowTargetEl:r,shadowSnappedEl:n,shadowContainerEl:o,spotEl:i,target:s,container:a}=t,{Canvas:p}=e,d=e.config.stylePrefix;i==null||i.appendChild(o),o==null||o.appendChild(r),o==null||o.appendChild(n),wt(o,a),bt(r,s,a),vt(n,s),St(o,a.el),s.el.style.opacity="0";const c=p.getSpots().filter(l=>l.type!==D);e.em.stopDefault({preserveSelected:!0}),p.removeSpots(c),p.startAutoscroll(),p.getBody().classList.add(`${d}is__grabbing`)}function J(t){const{editor:e,shadowSnappedEl:r,shadowContainerEl:n,target:o,cancelled:i}=t,{Canvas:s}=e,a=e.config.stylePrefix,{component:p}=o;if(!i){const d=window.getComputedStyle(r);p.addStyle({"grid-area":d.gridArea,width:"",height:""})}o.el.style.opacity="",n.contains(r)&&(n==null||n.removeChild(r)),e.getModel().runDefault({preserveSelected:1}),s.stopAutoscroll(),s.getBody().classList.remove(`${a}is__grabbing`),s.removeSpots({type:D}),e.select(p)}function wt(t,{rows:e,columns:r}){const n=[];for(let o=0;o<r.length;o++){n[o]=[];for(let i=0;i<e.length;i++){const s=document.createElement("div");s.className=q,s.style.gridArea=`${i+1} / ${o+1}`,n[o][i]=s,t.appendChild(s)}}return n}function bt(t,e,r){return t.className=H,t.style.top=`${e.offset.top-r.offset.top}px`,t.style.left=`${e.offset.left-r.offset.left}px`,t.style.width=`${e.offset.width+e.margin.left+e.margin.right}px`,t.style.height=`${e.offset.height+e.margin.top+e.margin.bottom}px`,t}function vt(t,e){const r=tt(e.el,e.computedStyles);return t.className=Y,t.style.gridArea=`${r.row.start} / ${r.column.start} / ${r.row.end} / ${r.column.end}`,t}function St(t,e){const r=window.getComputedStyle(e);t.className=yt,t.style.position="relative",t.style.display=r.display,t.style.gap=r.gap,t.style.padding=r.padding,t.style.border=r.border,t.style.gridTemplateColumns=r.gridTemplateColumns,t.style.gridTemplateRows=r.gridTemplateRows}function Q(t,e){if(e){if(Array.isArray(e))return[...e].pop()}else return[...t.getSelectedAll()].pop();return e}function $t(t,e){const r=Q(t,e),n=r.getEl(),o=window.getComputedStyle(n);return{component:r,el:n,offset:t.Canvas.offset(n),margin:{top:parseFloat(o.marginTop),right:parseFloat(o.marginRight),bottom:parseFloat(o.marginBottom),left:parseFloat(o.marginLeft)},computedStyles:o}}function F(t,e){const r=e.parent(),n=r.getEl(),o=window.getComputedStyle(n);return{component:r,el:n,offset:t.Canvas.offset(n),computedStyles:o,padding:{top:parseFloat(o.paddingTop),right:parseFloat(o.paddingRight),bottom:parseFloat(o.paddingBottom),left:parseFloat(o.paddingLeft)},columns:o.gridTemplateColumns.split(" ").map(s=>parseFloat(s)),rows:o.gridTemplateRows.split(" ").map(s=>parseFloat(s)),gap:{column:parseInt(o.columnGap),row:parseInt(o.rowGap)}}}function T(t,e,r,n,o=1){let i=0;for(let s=e;s<=t.length;s++){if(i+(t[s-1]+n)*o>r)return s;i+=n+t[s-1]}return t.length+1}function Z(t){const{scrollY:e,scrollX:r}=t.Canvas.getWindow();return{scroll:{top:e,left:r}}}function Rt(t,e,r,n){const o=i=>t.em.logWarning(i);return n==="draggable"&&e.component.get(n)===!1?(o(`[${N}] The element is not ${n}`),!0):r.computedStyles.display!=="grid"?(o(`[${N}] The container does not have style display:grid`),!0):!1}function B(t,e,r={}){const n=Q(t,e),o=n==null?void 0:n.parent(),i=o==null?void 0:o.getEl();if(!o||!i)return!1;const{enableGrid:s}=r,a=window.getComputedStyle(i).display==="grid";return U(s)?s({component:n,parent:o,isParentGrid:a}):a}const V=t=>t.split(" ").map(e=>parseFloat(e));function tt(t,e){const r=t.ownerDocument.defaultView,n=e||r.getComputedStyle(t),o=n.gridArea.split("/").some(b=>isNaN(parseInt(b.trim()))),i={isComputed:o,raw:n.gridArea};if(!o)return{...i,row:{start:parseInt(n.gridRowStart),end:parseInt(n.gridRowEnd)},column:{start:parseInt(n.gridColumnStart),end:parseInt(n.gridColumnEnd)}};const s=t.parentElement,a=r.getComputedStyle(s),p=parseFloat(a.columnGap)||0,d=parseFloat(a.rowGap)||0,c=V(a.gridTemplateColumns),l=V(a.gridTemplateRows),g=parseFloat(a.paddingLeft)||0,u=parseFloat(a.paddingTop)||0,h=s.getBoundingClientRect(),m=t.getBoundingClientRect(),w=(b,S,E,$,_)=>{let I=1,A=$+_;for(let C=0;C<S.length;C++){const j=S[C],nt=A+j;if(b>=A&&b<nt)return I;A=nt+E,I++}return-1},v=w(m.left,c,p,h.left,g),R=w(m.right-1,c,p,h.left,g)+1,y=w(m.top,l,d,h.top,u),f=w(m.bottom-1,l,d,h.top,u)+1;return{...i,row:{start:y,end:f},column:{start:v,end:R}}}function Tt(t){t.Commands.add(O,{stop(){},run(e,r,n={}){const o=X({editor:e,component:n.target,type:"draggable"});if(!o){this.stopCommand();return}const{spot:i,target:s,shadowContainerEl:a,shadowSnappedEl:p,shadowTargetEl:d,startScroll:c}=o;let{container:l}=o,g;new e.Utils.Dragger({doc:s.el.ownerDocument,onStart:()=>{g=setTimeout(()=>{K({editor:e,shadowTargetEl:d,shadowSnappedEl:p,shadowContainerEl:a,spotEl:i.attributes.spotEl,target:s,container:l}),l=F(e,s.component)},10)},onEnd:(h,m,{cancelled:w})=>{clearTimeout(g),J({editor:e,shadowSnappedEl:p,shadowContainerEl:a,target:s,cancelled:w}),this.stopCommand(),e.em.set("_cmpDrag",1)},setPosition:({x:h,y:m})=>{const{scroll:w}=Z(e),{columns:v,rows:R,gap:y,offset:f,padding:b}=l,{offset:S,margin:E}=s,$=S.top-f.top-b.top-E.top+m-c.top+w.top,_=S.left-f.left-b.left-E.left+h-c.left+w.left,I=Math.min(T(v,1,_,y.column,.5),v.length),A=Math.min(T(R,1,$,y.row,.5),R.length),C=Math.min(T(v,I,S.width,y.column)+1,v.length+1),j=Math.min(T(R,A,S.height,y.row)+1,R.length+1);p.style.gridArea=`${A} / ${I} / ${j} / ${C}`,d.style.top=`${$+b.top}px`,d.style.left=`${_+b.left}px`}}).start(n.event)}})}function xt(t,e){const r=X({editor:t,component:e.component,type:"resizable"});if(!r)return;const{onMove:n,onEnd:o}=e.options||{},{spot:i,target:s,shadowContainerEl:a,shadowSnappedEl:p,shadowTargetEl:d}=r;let{container:c}=r,l="",g;return{onStart:u=>{l=u.target.dataset.gjsHandler||"",g=setTimeout(()=>{K({editor:t,shadowTargetEl:d,shadowSnappedEl:p,shadowContainerEl:a,spotEl:i.attributes.spotEl,target:s,container:c}),c=F(t,s.component)},10),t.trigger("component:resize",{...s||{},type:"start"})},onEnd:(u,h)=>{const{startDim:m,rectDim:w}=h.resizer,v=JSON.stringify(m)===JSON.stringify(w);clearTimeout(g),J({editor:t,shadowSnappedEl:p,shadowContainerEl:a,target:s,cancelled:v}),o==null||o(u,h)},onMove:(u,h)=>{const m=tt(p),w=s.margin.left,v=s.margin.top,R=s.margin.bottom,y=s.margin.right,{w:f,t:b,l:S,h:E}=h.resizer.rectDim,$={t:b-v,l:S-w,h:E+v+R,w:f+w+y};l.endsWith("l")&&(m.column.start=T(c.columns,1,$.l-c.offset.left-c.padding.left,c.gap.column,.5)),l.startsWith("t")&&(m.row.start=T(c.rows,1,$.t-c.offset.top-c.padding.top,c.gap.row,.5)),l.endsWith("r")&&(m.column.end=Math.max(T(c.columns,m.column.start,$.w,c.gap.column,.5),m.column.start+1)),l.startsWith("b")&&(m.row.end=Math.max(T(c.rows,m.row.start,$.h,c.gap.row,.5),m.row.start+1)),p.style.gridArea=`${m.row.start} / ${m.column.start} / ${m.row.end} / ${m.column.end}`,d.style.width=`${$.w}px`,d.style.height=`${$.h}px`,d.style.left=`${$.l-c.offset.left}px`,d.style.top=`${$.t-c.offset.top}px`,n==null||n(u,h)}}}const et=["px","%","em","rem","vw","vh"],Pt=(t,e)=>{const r=t.Styles.getSectors().find(n=>!!n.getProperty(e));return{sector:r,property:r?r.getProperty(e):void 0}},Gt=(t,e)=>Pt(t,e),Et=(t,{x:e,y:r,mergable:n}={})=>{const o={property:`${t}-x`,type:"integer",units:et,...e},i={property:`${t}-y`,type:"integer",units:et,...r};return{property:t,type:"composite",properties:[o,i],...n&&{fromStyle(s,{name:a,separator:p,property:d}){const[c,l]=d.getProperties(),[g,u]=(s[a]||"").split(p);return{[c.getId()]:s[c.getName()]||g||"",[l.getId()]:s[l.getName()]||u||g||""}},toStyle(s,{name:a,property:p}){const[d,c]=p.getProperties(),l=s[d.getId()],g=s[c.getId()];return{[a]:l===g?l:`${l} ${g}`}}}}},z={display:["grid"]};function At(t=""){const e=/^repeat\(\s*(\d+)\s*,\s*(.+)\s*\)$/i,r=/^minmax\(\s*(.+?)\s*,\s*(.+?)\s*\)$/i,n=t.match(e);if(!n)return null;const o=parseInt(n[1],10),i=n[2];let s=i,a=i;const p=i.match(r);return p&&(s=p[1],a=p[2]),{total:o,min:s===a?"":s,max:a}}function Dt(t={}){let e="",r="",n="",o="";const i=m=>m.split("/").map(w=>w.trim()).filter(Boolean),s=t["grid-area"]||"",a=t["grid-column"]||"",p=t["grid-row"]||"",d=i(s),c=i(a),l=i(p),g=d.length,u=c.length,h=l.length;return g===4?(n=d[0],e=d[1],o=d[2],r=d[3]):g===3?(n=d[0],e=d[1],o=d[2]):g===2?(n=d[0],e=d[1]):g===1&&(n=d[0]),u===2?(e=c[0],r=c[1]):u===1&&(e=c[0]),h===2?(n=l[0],o=l[1]):h===1&&(n=l[0]),{columnStart:e,columnEnd:r,rowStart:n,rowEnd:o}}function ot(t){const{property:e,label:r}=t,n="1",o="1fr";return{property:e,label:r,type:"composite",requires:z,generic:!0,properties:[{name:" ",property:`${e}-repeat`,type:"number",full:!0,min:1,default:"1"},{label:"Min size",property:`${e}-min`,type:"number",min:0,units:["px","%"],default:"0"},{label:"Max size",property:`${e}-max`,type:"number",min:1,units:["fr","px","%"],default:"1"}],fromStyle(i,s){const{name:a,property:p}=s,[d,c,l]=p.getProperties(),g=i[a],u=At(g),h=(u==null?void 0:u.max)??o;return{[d.id]:(u==null?void 0:u.total)??n,[c.id]:(u==null?void 0:u.min)??"",[l.id]:h===o?"":h}},toStyle(i,{name:s,property:a}){const[p,d,c]=a.getProperties(),l=i[p.id],g=i[d.id],u=i[c.id]||o,h=g&&u?`minmax(${g}, ${u})`:u;return{[s]:`repeat(${l||n}, ${h})`}}}}function Mt(t,e){if(!e.styleableGrid)return;const{property:r,...n}=Gt(t,"display");if(!r)return;const o=r.getOption("grid"),i=n.sector;o||r.addOption({id:"grid",label:"Grid"}),i.addProperty(ot({label:"Columns",property:"grid-template-columns"}),{}),i.addProperty(ot({label:"Rows",property:"grid-template-rows"}),{}),i.addProperty({id:"grid-gap",requires:z,...Et("gap",{x:{id:"grid-row-gap",label:"Row",property:"row-gap",min:0,default:"0"},y:{id:"grid-column-gap",label:"Column",property:"column-gap",min:0,default:"0"},mergable:!0})},{}),i.addProperty({type:"composite",property:"grid-area",label:"Grid area",requiresParent:z,generic:!0,properties:[{label:"Row start",property:"grid-row-start",type:"integer",default:"auto"},{label:"Row end",property:"grid-row-end",type:"integer",default:"auto"},{label:"Column start",property:"grid-column-start",type:"integer",default:"auto"},{label:"Column end",property:"grid-column-end",type:"integer",default:"auto"}],fromStyle(s){const a=Dt(s);return{"grid-column-start":s["grid-column-start"]||a.columnStart,"grid-column-end":s["grid-column-end"]||a.columnEnd,"grid-row-start":s["grid-row-start"]||a.rowStart,"grid-row-end":s["grid-row-end"]||a.rowEnd}},toStyle(s,{name:a}){const p=s["grid-row-start"]||"auto",d=s["grid-row-end"]||"auto",c=s["grid-column-start"]||"auto",l=s["grid-column-end"]||"auto";return{[a]:`${p} / ${c} / ${d} / ${l}`}}},{})}return dt(function(t,e={}){const r={itemResizable:!0,...e},{Canvas:n,Commands:o,Components:i}=t,{itemResizable:s}=r,a=n.events,p=o.events,d=i.events,c=`${p.runBeforeCommand}tlb-move`,l=`${p.runBeforeCommand}resize`;let g;Tt(t);const u=({options:y})=>{B(t,y.target,r)&&(t.runCommand(O,{...y}),y.abort=!0)},h=y=>{const{options:f}=y;B(t,f.component,r)&&(f.options=Object.assign(f.options||{},xt(t,f)))},m=()=>{const y=n.getSpots({type:D}).pop();if(!y)return;let f=y.attributes.spotEl;f||(f=document.createElement("div"),f.className=M,y.set({spotEl:f})),Object.entries(y.getStyle()).forEach(([b,S])=>f.style.setProperty(b,S)),g==null||g.appendChild(f)},w=({spot:y})=>{const f=y.attributes.spotEl;y.type!==D||!f||g==null||g.removeChild(f)};if(s){const y=f=>{const b=U(s)?s({component:f}):s;return typeof b=="boolean"?b:{tl:!1,tc:!1,tr:!1,cl:!1,cr:!1,bl:!1,bc:!1,br:!1,...b}};t.on(d.resizeInit,f=>{const{component:b}=f;if(B(t,b,r)){const S=y(b);f.resizable=S}})}const v=[[c,u],[l,h],[a.spot,m],[a.spotRemove,w]];v.forEach(([y,f])=>{t.on(y,f)}),t.onReady(()=>{g=n.getSpotsEl(),ht(),Mt(t,r)});const R=()=>{delete t.Commands.commands[O],v.forEach(([y,f])=>{t.off(y,f)})};gt({editor:t,licenseKey:r.licenseKey,plan:mt,pluginName:N,cleanup:R})})});
@@ -1 +1 @@
1
- "use strict";const D="app.grapesjs.com",L="app-stage.grapesjs.com",G="app2.grapesjs.com",I="app-stage2.grapesjs.com",A=[D,G,L,I,"localhost","127.0.0.1",".local-credentialless.webcontainer.io",".local.webcontainer.io","-sandpack.codesandbox.io"],x="license:check:end",O=()=>typeof window<"u",B=(e,o={})=>{const n=j(e)?{id:e,src:e}:e;return new Promise((r,a)=>{var p,d;const{loadedScripts:i}=o,{id:c,src:s}=n,l=document.querySelector(`script[src="${s}"]`);if(l){if((p=o.onScript)==null||p.call(o,l),i&&!i.get(s)){l.addEventListener("load",()=>r(c)),l.addEventListener("error",()=>a(c));return}return r(c)}const u=window.define;window.define=void 0;const g=()=>{i==null||i.set(s,!0),window.define=u},t=document.createElement("script");t.src=s,t.onload=()=>{r(c),g()},t.onerror=()=>{a(c),g()},document.head.appendChild(t),(d=o.onScript)==null||d.call(o,t)})},M=e=>{const o=e.map(n=>B(n));return Promise.allSettled(o)},N=async e=>{const o=window.define;window.define=void 0;const n=await M(e);return window.define=o,n},U=({isDev:e,isStage:o,isPlatform:n})=>`${e?"":`https://${o?L:D}`}/${n?"platform-api":"api"}`,$=()=>{const e=O()&&window.location.hostname;return!!e&&(A.includes(e)||A.some(o=>e.endsWith(o)))},j=e=>typeof e=="string";async function _({path:e,baseApiUrl:o,method:n="GET",headers:r={},params:a,body:i}){const s=`${o||U({isDev:!1,isStage:!1})}${e}`,l={method:n,headers:{"Content-Type":"application/json",...r}};i&&(l.body=JSON.stringify(i));const u=a?new URLSearchParams(a).toString():"",g=u?`?${u}`:"",t=await fetch(`${s}${g}`,l);if(!t.ok)throw new Error(`HTTP error! status: ${t.status}`);return t.json()}var h=(e=>(e.free="free",e.startup="startup",e.business="business",e.enterprise="enterprise",e))(h||{}),P=(e=>(e.toastAdd="studio:toastAdd",e.toastRemove="studio:toastRemove",e.dialogOpen="studio:dialogOpen",e.dialogClose="studio:dialogClose",e.dialogExportCode="studio:dialogExportCode",e.dialogImportCode="studio:dialogImportCode",e.sidebarLeftSet="studio:sidebarLeft:set",e.sidebarLeftGet="studio:sidebarLeft:get",e.sidebarLeftToggle="studio:sidebarLeft:toggle",e.sidebarRightSet="studio:sidebarRight:set",e.sidebarRightGet="studio:sidebarRight:get",e.sidebarRightToggle="studio:sidebarRight:toggle",e.sidebarTopSet="studio:sidebarTop:set",e.sidebarTopGet="studio:sidebarTop:get",e.sidebarTopToggle="studio:sidebarTop:toggle",e.sidebarBottomSet="studio:sidebarBottom:set",e.sidebarBottomGet="studio:sidebarBottom:get",e.sidebarBottomToggle="studio:sidebarBottom:toggle",e.symbolAdd="studio:symbolAdd",e.symbolDetach="studio:symbolDetach",e.symbolOverride="studio:symbolOverride",e.symbolPropagateStyles="studio:propagateStyles",e.getPagesConfig="studio:getPagesConfig",e.setPagesConfig="studio:setPagesConfig",e.getPageSettings="studio:getPageSettings",e.setPageSettings="studio:setPageSettings",e.clearPage="studio:clearPage",e.projectFiles="studio:projectFiles",e.validateCode="studio:validateCode",e.canvasReload="studio:canvasReload",e.getBlocksPanel="studio:getBlocksPanel",e.setBlocksPanel="studio:setBlocksPanel",e.getStateContextMenu="studio:getStateContextMenu",e.setStateContextMenu="studio:setStateContextMenu",e.contextMenuComponent="studio:contextMenuComponent",e.layoutAdd="studio:layoutAdd",e.layoutRemove="studio:layoutRemove",e.layoutToggle="studio:layoutToggle",e.layoutUpdate="studio:layoutUpdate",e.layoutGet="studio:layoutGet",e.layoutConfigGet="studio:layoutConfigGet",e.layoutConfigSet="studio:layoutConfigSet",e.layoutComponentAdd="studio:layoutComponentAdd",e.layoutComponentGet="studio:layoutComponentGet",e.layoutComponentRemove="studio:layoutComponentRemove",e.layoutComponentRender="studio:layoutComponentRender",e.getStateTheme="studio:getStateTheme",e.setStateTheme="studio:setStateTheme",e.settings="studio:settings",e.assetProviderGet="studio:assetProviderGet",e.assetProviderAdd="studio:assetProviderAdd",e.assetProviderRemove="studio:assetProviderRemove",e.fontGet="studio:fontGet",e.fontAdd="studio:fontAdd",e.fontRemove="studio:fontRemove",e.fontManagerOpen="studio:fontManagerOpen",e.menuFontLoad="studio:menuFontLoad",e.toggleStateDataSource="studio:toggleStateDataSource",e.getStateDataSource="studio:getStateDataSource",e.dataSourceSetGlobalData="studio:dataSourceSetGlobalData",e.dataSourceSetImporter="studio:dataSourceSetImporter",e.dataSourceSetExporter="studio:dataSourceSetExporter",e.setDragAbsolute="studio:setDragAbsolute",e))(P||{});const R={[h.free]:0,[h.startup]:10,[h.business]:20,[h.enterprise]:30};function W(e){const o=e;return o.init=n=>r=>e(r,n),o}const k=e=>W(e);async function F({editor:e,plan:o,pluginName:n,licenseKey:r,onLicenseCheckResponse:a,cleanup:i}){let c="",s;const l=t=>{console.warn("Cleanup plugin:",n,"Reason:",t),i()},u=(t={})=>{var v;const{error:p,sdkLicense:d}=t,f=(v=t.plan)==null?void 0:v.category;if(!(d||t.license)||p)l(p||"Invalid license");else if(f){const y=R[o],b=R[f];y>b&&l({pluginRequiredPlan:o,licensePlan:f})}};e.Commands.has(P.settings)&&(s=e.runCommand(P.settings),c=(s==null?void 0:s.baseUrl)||"");const g=t=>{a==null||a(t),t&&u(t)};if(!s){e.onReady(async()=>{if(!$())if(r){const t=await K({licenseKey:r,pluginName:n,baseApiUrl:c});g(t)}else l("The `licenseKey` option not provided")});return}if(s.licensePlan||s.licenseError){const t=H(s);g(t);return}e.on(x,t=>g(t))}const H=e=>({sdkLicense:e.license,license:e.license,error:e.licenseError,plan:e.licensePlan});async function K(e){const{licenseKey:o,pluginName:n,baseApiUrl:r}=e;try{return(await _({baseApiUrl:r,path:`/sdk/${o||"na"}`,method:"POST",params:{d:window.location.hostname,pn:n}})).result||{}}catch(a){return console.error("Error during SDK license check:",a),!1}}const S="canvasScreenshot",q=h.startup;var E=(e=>(e.screenshot="studioPlugin:screenshot",e))(E||{});const J=async e=>await N([{id:"html-to-image",src:e}]),z=async(e,o={},n={})=>{const{cdnScript:r}=n;if(!window.htmlToImage){if(!r)return;await J(r)}return new Promise((a,i)=>{(async()=>{try{const{canvasWidth:s,canvasHeight:l,width:u,height:g,type:t,quality:p,addOptions:d}=o,f={pixelRatio:1,width:u,height:g,canvasWidth:s,canvasHeight:l},T=(d==null?void 0:d(f))||f,y=await window.htmlToImage.toCanvas(e,T);y.toBlob(b=>{b?a({file:b,canvas:y}):i(new Error("Failed to create file from canvas"))},t,p)}catch(s){i(s)}})()})},w=E.screenshot,Q=function(e,o={}){const{Commands:n,Canvas:r,Storage:a}=e,i=a.events.afterStore,c={cdnScript:"https://cdnjs.cloudflare.com/ajax/libs/html-to-image/1.11.13/html-to-image.min.js",...o};n.add(w,async(u,g,t)=>{const{el:p,...d}=t;return await z(p,d,c)});const s=async()=>{var g;const u=r.getBody();if(!u)return e.log("Canvas element not found");try{const t=await e.runCommand(w,{el:u,canvasWidth:400,canvasHeight:225,width:1200,height:675,type:"image/jpeg"});(g=c.screenshotOnSave)==null||g.call(c,{...t,editor:e})}catch(t){console.error("Screenshot error",t)}};c.screenshotOnSave&&e.on(i,s);const l=()=>{delete n.commands[w],e.off(i,s)};F({editor:e,licenseKey:o.licenseKey,plan:q,pluginName:S,cleanup:l})},V=k(Q);module.exports=V;
1
+ "use strict";const D="app.grapesjs.com",L="app-stage.grapesjs.com",G="app2.grapesjs.com",I="app-stage2.grapesjs.com",A=[D,G,L,I,"localhost","127.0.0.1",".local-credentialless.webcontainer.io",".local.webcontainer.io","-sandpack.codesandbox.io",".claudemcpcontent.com",".web-sandbox.oaiusercontent.com"],x="license:check:end",O=()=>typeof window<"u",B=(e,o={})=>{const n=_(e)?{id:e,src:e}:e;return new Promise((r,a)=>{var p,d;const{loadedScripts:i}=o,{id:c,src:s}=n,l=document.querySelector(`script[src="${s}"]`);if(l){if((p=o.onScript)==null||p.call(o,l),i&&!i.get(s)){l.addEventListener("load",()=>r(c)),l.addEventListener("error",()=>a(c));return}return r(c)}const u=window.define;window.define=void 0;const g=()=>{i==null||i.set(s,!0),window.define=u},t=document.createElement("script");t.src=s,t.onload=()=>{r(c),g()},t.onerror=()=>{a(c),g()},document.head.appendChild(t),(d=o.onScript)==null||d.call(o,t)})},M=e=>{const o=e.map(n=>B(n));return Promise.allSettled(o)},N=async e=>{const o=window.define;window.define=void 0;const n=await M(e);return window.define=o,n},U=({isDev:e,isStage:o,isPlatform:n})=>`${e?"":`https://${o?L:D}`}/${n?"platform-api":"api"}`,$=()=>{if(!O())return"";const{hostname:e}=window.location;if(e)return e;try{return window.parent.location.hostname||""}catch{return""}},j=()=>{const e=$();return!!e&&(A.includes(e)||A.some(o=>e.endsWith(o)))},_=e=>typeof e=="string";async function W({path:e,baseApiUrl:o,method:n="GET",headers:r={},params:a,body:i}){const s=`${o||U({isDev:!1,isStage:!1})}${e}`,l={method:n,headers:{"Content-Type":"application/json",...r}};i&&(l.body=JSON.stringify(i));const u=a?new URLSearchParams(a).toString():"",g=u?`?${u}`:"",t=await fetch(`${s}${g}`,l);if(!t.ok)throw new Error(`HTTP error! status: ${t.status}`);return t.json()}var h=(e=>(e.free="free",e.startup="startup",e.business="business",e.enterprise="enterprise",e))(h||{}),P=(e=>(e.toastAdd="studio:toastAdd",e.toastRemove="studio:toastRemove",e.dialogOpen="studio:dialogOpen",e.dialogClose="studio:dialogClose",e.dialogExportCode="studio:dialogExportCode",e.dialogImportCode="studio:dialogImportCode",e.sidebarLeftSet="studio:sidebarLeft:set",e.sidebarLeftGet="studio:sidebarLeft:get",e.sidebarLeftToggle="studio:sidebarLeft:toggle",e.sidebarRightSet="studio:sidebarRight:set",e.sidebarRightGet="studio:sidebarRight:get",e.sidebarRightToggle="studio:sidebarRight:toggle",e.sidebarTopSet="studio:sidebarTop:set",e.sidebarTopGet="studio:sidebarTop:get",e.sidebarTopToggle="studio:sidebarTop:toggle",e.sidebarBottomSet="studio:sidebarBottom:set",e.sidebarBottomGet="studio:sidebarBottom:get",e.sidebarBottomToggle="studio:sidebarBottom:toggle",e.symbolAdd="studio:symbolAdd",e.symbolDetach="studio:symbolDetach",e.symbolOverride="studio:symbolOverride",e.symbolPropagateStyles="studio:propagateStyles",e.getPagesConfig="studio:getPagesConfig",e.setPagesConfig="studio:setPagesConfig",e.getPageSettings="studio:getPageSettings",e.setPageSettings="studio:setPageSettings",e.clearPage="studio:clearPage",e.projectFiles="studio:projectFiles",e.validateCode="studio:validateCode",e.canvasReload="studio:canvasReload",e.getBlocksPanel="studio:getBlocksPanel",e.setBlocksPanel="studio:setBlocksPanel",e.getStateContextMenu="studio:getStateContextMenu",e.setStateContextMenu="studio:setStateContextMenu",e.contextMenuComponent="studio:contextMenuComponent",e.layoutAdd="studio:layoutAdd",e.layoutRemove="studio:layoutRemove",e.layoutToggle="studio:layoutToggle",e.layoutUpdate="studio:layoutUpdate",e.layoutGet="studio:layoutGet",e.layoutConfigGet="studio:layoutConfigGet",e.layoutConfigSet="studio:layoutConfigSet",e.layoutComponentAdd="studio:layoutComponentAdd",e.layoutComponentGet="studio:layoutComponentGet",e.layoutComponentRemove="studio:layoutComponentRemove",e.layoutComponentRender="studio:layoutComponentRender",e.getStateTheme="studio:getStateTheme",e.setStateTheme="studio:setStateTheme",e.settings="studio:settings",e.assetProviderGet="studio:assetProviderGet",e.assetProviderAdd="studio:assetProviderAdd",e.assetProviderRemove="studio:assetProviderRemove",e.fontGet="studio:fontGet",e.fontAdd="studio:fontAdd",e.fontRemove="studio:fontRemove",e.fontManagerOpen="studio:fontManagerOpen",e.menuFontLoad="studio:menuFontLoad",e.toggleStateDataSource="studio:toggleStateDataSource",e.getStateDataSource="studio:getStateDataSource",e.dataSourceSetGlobalData="studio:dataSourceSetGlobalData",e.dataSourceSetImporter="studio:dataSourceSetImporter",e.dataSourceSetExporter="studio:dataSourceSetExporter",e.setDragAbsolute="studio:setDragAbsolute",e))(P||{});const R={[h.free]:0,[h.startup]:10,[h.business]:20,[h.enterprise]:30};function k(e){const o=e;return o.init=n=>r=>e(r,n),o}const F=e=>k(e);async function H({editor:e,plan:o,pluginName:n,licenseKey:r,onLicenseCheckResponse:a,cleanup:i}){let c="",s;const l=t=>{console.warn("Cleanup plugin:",n,"Reason:",t),i()},u=(t={})=>{var v;const{error:p,sdkLicense:d}=t,f=(v=t.plan)==null?void 0:v.category;if(!(d||t.license)||p)l(p||"Invalid license");else if(f){const y=R[o],b=R[f];y>b&&l({pluginRequiredPlan:o,licensePlan:f})}};e.Commands.has(P.settings)&&(s=e.runCommand(P.settings),c=(s==null?void 0:s.baseUrl)||"");const g=t=>{a==null||a(t),t&&u(t)};if(!s){e.onReady(async()=>{if(!j())if(r){const t=await S({licenseKey:r,pluginName:n,baseApiUrl:c});g(t)}else l("The `licenseKey` option not provided")});return}if(s.licensePlan||s.licenseError){const t=K(s);g(t);return}e.on(x,t=>g(t))}const K=e=>({sdkLicense:e.license,license:e.license,error:e.licenseError,plan:e.licensePlan});async function S(e){const{licenseKey:o,pluginName:n,baseApiUrl:r}=e;try{return(await W({baseApiUrl:r,path:`/sdk/${o||"na"}`,method:"POST",params:{d:window.location.hostname,pn:n}})).result||{}}catch(a){return console.error("Error during SDK license check:",a),!1}}const q="canvasScreenshot",J=h.startup;var E=(e=>(e.screenshot="studioPlugin:screenshot",e))(E||{});const z=async e=>await N([{id:"html-to-image",src:e}]),Q=async(e,o={},n={})=>{const{cdnScript:r}=n;if(!window.htmlToImage){if(!r)return;await z(r)}return new Promise((a,i)=>{(async()=>{try{const{canvasWidth:s,canvasHeight:l,width:u,height:g,type:t,quality:p,addOptions:d}=o,f={pixelRatio:1,width:u,height:g,canvasWidth:s,canvasHeight:l},T=(d==null?void 0:d(f))||f,y=await window.htmlToImage.toCanvas(e,T);y.toBlob(b=>{b?a({file:b,canvas:y}):i(new Error("Failed to create file from canvas"))},t,p)}catch(s){i(s)}})()})},w=E.screenshot,V=function(e,o={}){const{Commands:n,Canvas:r,Storage:a}=e,i=a.events.afterStore,c={cdnScript:"https://cdnjs.cloudflare.com/ajax/libs/html-to-image/1.11.13/html-to-image.min.js",...o};n.add(w,async(u,g,t)=>{const{el:p,...d}=t;return await Q(p,d,c)});const s=async()=>{var g;const u=r.getBody();if(!u)return e.log("Canvas element not found");try{const t=await e.runCommand(w,{el:u,canvasWidth:400,canvasHeight:225,width:1200,height:675,type:"image/jpeg"});(g=c.screenshotOnSave)==null||g.call(c,{...t,editor:e})}catch(t){console.error("Screenshot error",t)}};c.screenshotOnSave&&e.on(i,s);const l=()=>{delete n.commands[w],e.off(i,s)};H({editor:e,licenseKey:o.licenseKey,plan:J,pluginName:q,cleanup:l})},X=F(V);module.exports=X;