@builder.io/sdk-react-nextjs 0.17.0 → 0.17.1

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 (113) hide show
  1. package/lib/browser/blocks/image/component-info.cjs +1 -1
  2. package/lib/browser/blocks/image/component-info.mjs +4 -3
  3. package/lib/browser/blocks/image/image.cjs +4 -4
  4. package/lib/browser/blocks/image/image.mjs +20 -20
  5. package/lib/browser/blocks/img/component-info.cjs +1 -1
  6. package/lib/browser/blocks/img/component-info.mjs +4 -3
  7. package/lib/browser/blocks/video/component-info.cjs +1 -1
  8. package/lib/browser/blocks/video/component-info.mjs +5 -4
  9. package/lib/browser/components/block/block.cjs +1 -1
  10. package/lib/browser/components/block/block.helpers.cjs +3 -3
  11. package/lib/browser/components/block/block.helpers.mjs +57 -54
  12. package/lib/browser/components/block/block.mjs +28 -26
  13. package/lib/browser/components/content/components/enable-editor.cjs +1 -1
  14. package/lib/browser/components/content/components/enable-editor.helpers.cjs +1 -0
  15. package/lib/browser/components/content/components/enable-editor.helpers.mjs +8 -0
  16. package/lib/browser/components/content/components/enable-editor.mjs +139 -133
  17. package/lib/browser/components/content/content.cjs +1 -1
  18. package/lib/browser/components/content/content.mjs +57 -56
  19. package/lib/browser/constants/file-types.cjs +1 -0
  20. package/lib/browser/constants/file-types.mjs +5 -0
  21. package/lib/browser/constants/sdk-version.cjs +1 -1
  22. package/lib/browser/constants/sdk-version.mjs +1 -1
  23. package/lib/browser/context/builder.context.cjs +1 -1
  24. package/lib/browser/context/builder.context.mjs +2 -1
  25. package/lib/browser/functions/extract-localized-values.cjs +1 -0
  26. package/lib/browser/functions/extract-localized-values.mjs +28 -0
  27. package/lib/browser/functions/get-processed-block.cjs +1 -1
  28. package/lib/browser/functions/get-processed-block.mjs +46 -45
  29. package/lib/browser/functions/register-component.cjs +1 -1
  30. package/lib/browser/functions/register-component.mjs +7 -7
  31. package/lib/browser/functions/traverse.cjs +1 -0
  32. package/lib/browser/functions/traverse.mjs +20 -0
  33. package/lib/edge/blocks/image/component-info.cjs +1 -1
  34. package/lib/edge/blocks/image/component-info.mjs +4 -3
  35. package/lib/edge/blocks/image/image.cjs +4 -4
  36. package/lib/edge/blocks/image/image.mjs +20 -20
  37. package/lib/edge/blocks/img/component-info.cjs +1 -1
  38. package/lib/edge/blocks/img/component-info.mjs +4 -3
  39. package/lib/edge/blocks/video/component-info.cjs +1 -1
  40. package/lib/edge/blocks/video/component-info.mjs +5 -4
  41. package/lib/edge/components/block/block.cjs +1 -1
  42. package/lib/edge/components/block/block.helpers.cjs +3 -3
  43. package/lib/edge/components/block/block.helpers.mjs +57 -54
  44. package/lib/edge/components/block/block.mjs +28 -26
  45. package/lib/edge/components/content/components/enable-editor.cjs +1 -1
  46. package/lib/edge/components/content/components/enable-editor.helpers.cjs +1 -0
  47. package/lib/edge/components/content/components/enable-editor.helpers.mjs +8 -0
  48. package/lib/edge/components/content/components/enable-editor.mjs +139 -133
  49. package/lib/edge/components/content/content.cjs +1 -1
  50. package/lib/edge/components/content/content.mjs +57 -56
  51. package/lib/edge/constants/file-types.cjs +1 -0
  52. package/lib/edge/constants/file-types.mjs +5 -0
  53. package/lib/edge/constants/sdk-version.cjs +1 -1
  54. package/lib/edge/constants/sdk-version.mjs +1 -1
  55. package/lib/edge/context/builder.context.cjs +1 -1
  56. package/lib/edge/context/builder.context.mjs +2 -1
  57. package/lib/edge/functions/extract-localized-values.cjs +1 -0
  58. package/lib/edge/functions/extract-localized-values.mjs +28 -0
  59. package/lib/edge/functions/get-processed-block.cjs +1 -1
  60. package/lib/edge/functions/get-processed-block.mjs +46 -45
  61. package/lib/edge/functions/register-component.cjs +1 -1
  62. package/lib/edge/functions/register-component.mjs +7 -7
  63. package/lib/edge/functions/traverse.cjs +1 -0
  64. package/lib/edge/functions/traverse.mjs +20 -0
  65. package/lib/node/blocks/image/component-info.cjs +1 -1
  66. package/lib/node/blocks/image/component-info.mjs +4 -3
  67. package/lib/node/blocks/image/image.cjs +4 -4
  68. package/lib/node/blocks/image/image.mjs +20 -20
  69. package/lib/node/blocks/img/component-info.cjs +1 -1
  70. package/lib/node/blocks/img/component-info.mjs +4 -3
  71. package/lib/node/blocks/video/component-info.cjs +1 -1
  72. package/lib/node/blocks/video/component-info.mjs +5 -4
  73. package/lib/node/components/block/block.cjs +1 -1
  74. package/lib/node/components/block/block.helpers.cjs +3 -3
  75. package/lib/node/components/block/block.helpers.mjs +57 -54
  76. package/lib/node/components/block/block.mjs +28 -26
  77. package/lib/node/components/content/components/enable-editor.cjs +1 -1
  78. package/lib/node/components/content/components/enable-editor.helpers.cjs +1 -0
  79. package/lib/node/components/content/components/enable-editor.helpers.mjs +8 -0
  80. package/lib/node/components/content/components/enable-editor.mjs +139 -133
  81. package/lib/node/components/content/content.cjs +1 -1
  82. package/lib/node/components/content/content.mjs +57 -56
  83. package/lib/node/constants/file-types.cjs +1 -0
  84. package/lib/node/constants/file-types.mjs +5 -0
  85. package/lib/node/constants/sdk-version.cjs +1 -1
  86. package/lib/node/constants/sdk-version.mjs +1 -1
  87. package/lib/node/context/builder.context.cjs +1 -1
  88. package/lib/node/context/builder.context.mjs +2 -1
  89. package/lib/node/functions/extract-localized-values.cjs +1 -0
  90. package/lib/node/functions/extract-localized-values.mjs +28 -0
  91. package/lib/node/functions/get-processed-block.cjs +1 -1
  92. package/lib/node/functions/get-processed-block.mjs +46 -45
  93. package/lib/node/functions/register-component.cjs +1 -1
  94. package/lib/node/functions/register-component.mjs +7 -7
  95. package/lib/node/functions/traverse.cjs +1 -0
  96. package/lib/node/functions/traverse.mjs +20 -0
  97. package/package.json +1 -1
  98. package/types/cjs/components/block/block.helpers.d.ts +6 -3
  99. package/types/cjs/components/content/components/enable-editor.helpers.d.ts +11 -0
  100. package/types/cjs/constants/file-types.d.ts +2 -0
  101. package/types/cjs/constants/sdk-version.d.ts +1 -1
  102. package/types/cjs/context/types.d.ts +1 -0
  103. package/types/cjs/functions/extract-localized-values.d.ts +2 -0
  104. package/types/cjs/functions/traverse.d.ts +34 -0
  105. package/types/cjs/types/components.d.ts +3 -0
  106. package/types/esm/components/block/block.helpers.d.ts +6 -3
  107. package/types/esm/components/content/components/enable-editor.helpers.d.ts +11 -0
  108. package/types/esm/constants/file-types.d.ts +2 -0
  109. package/types/esm/constants/sdk-version.d.ts +1 -1
  110. package/types/esm/context/types.d.ts +1 -0
  111. package/types/esm/functions/extract-localized-values.d.ts +2 -0
  112. package/types/esm/functions/traverse.d.ts +34 -0
  113. package/types/esm/types/components.d.ts +3 -0
@@ -0,0 +1,28 @@
1
+ import { traverse as r } from "./traverse.mjs";
2
+ function s(e) {
3
+ return e && typeof e == "object" && e["@type"] === "@builder.io/core:LocalizedValue";
4
+ }
5
+ function l(e) {
6
+ if (!e || !Object.getOwnPropertyNames(e).length)
7
+ return !1;
8
+ let o = !1;
9
+ return r(e, (t) => {
10
+ if (s(t)) {
11
+ o = !0;
12
+ return;
13
+ }
14
+ }), o;
15
+ }
16
+ function u(e, o) {
17
+ return !e || !Object.getOwnPropertyNames(e).length ? {} : (r(e, (t, n) => {
18
+ var i;
19
+ s(t) && n((i = t[o]) != null ? i : void 0);
20
+ }), e);
21
+ }
22
+ function p(e, o) {
23
+ var t, n;
24
+ return (t = e.component) != null && t.options && l((n = e.component) == null ? void 0 : n.options) && (o || console.warn("[Builder.io] In order to use localized fields in Builder, you must pass a locale prop to the BuilderComponent or to options object while fetching the content to resolve localized fields. Learn more: https://www.builder.io/c/docs/localization-inline#targeting-and-inline-localization"), e.component.options = u(e.component.options, o != null ? o : "Default")), e;
25
+ }
26
+ export {
27
+ p as resolveLocalizedValues
28
+ };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("../constants/target.cjs"),l=require("../helpers/omit.cjs"),p=require("./evaluate/evaluate.cjs"),f=require("./fast-clone.cjs"),g=require("./set.cjs"),m=require("./transform-block.cjs");function o(e){if(e===null||typeof e!="object")return e;if(Array.isArray(e))return e.map(n=>o(n));if(e["@type"]==="@builder.io/sdk:Element")return e;const t={};for(const n in e)n!=="meta"&&Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=o(e[n]));return t}const y=["svelte","vue","angular","qwik","solid"].includes(d.TARGET),C=e=>{if(y){const t=f.fastClone(e);return{...t,properties:{...t.properties},actions:{...t.actions}}}else{const t=o(l.omit(e,"children","meta"));return{...t,properties:{...t.properties},actions:{...t.actions},children:e.children,meta:e.meta}}},q=({block:e,context:t,localState:n,rootState:s,rootSetState:c})=>{if(!e.bindings)return e;const i=C(e);for(const r in e.bindings){const a=e.bindings[r],u=p.evaluate({code:a,localState:n,rootState:s,rootSetState:c,context:t});g.set(i,r,u)}return i};function v({block:e,context:t,shouldEvaluateBindings:n,localState:s,rootState:c,rootSetState:i}){const r=m.transformBlock(e);return n?q({block:r,localState:s,rootState:c,rootSetState:i,context:t}):r}exports.deepCloneWithConditions=o;exports.getProcessedBlock=v;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("../constants/target.cjs"),d=require("../helpers/omit.cjs"),p=require("./evaluate/evaluate.cjs"),f=require("./extract-localized-values.cjs"),g=require("./fast-clone.cjs"),m=require("./set.cjs"),y=require("./transform-block.cjs");function o(e){if(e===null||typeof e!="object")return e;if(Array.isArray(e))return e.map(n=>o(n));if(e["@type"]==="@builder.io/sdk:Element")return e;const t={};for(const n in e)n!=="meta"&&Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=o(e[n]));return t}const C=["svelte","vue","angular","qwik","solid"].includes(u.TARGET),q=e=>{if(C){const t=g.fastClone(e);return{...t,properties:{...t.properties},actions:{...t.actions}}}else{const t=o(d.omit(e,"children","meta"));return{...t,properties:{...t.properties},actions:{...t.actions},children:e.children,meta:e.meta}}},v=({block:e,context:t,localState:n,rootState:c,rootSetState:i})=>{if(!e.bindings)return e;const s=q(e);for(const r in e.bindings){const a=e.bindings[r],l=p.evaluate({code:a,localState:n,rootState:c,rootSetState:i,context:t});m.set(s,r,l)}return s};function B({block:e,context:t,shouldEvaluateBindings:n,localState:c,rootState:i,rootSetState:s}){let r=f.resolveLocalizedValues(e,i.locale);return r=y.transformBlock(r),n?v({block:r,localState:c,rootState:i,rootSetState:s,context:t}):r}exports.deepCloneWithConditions=o;exports.getProcessedBlock=B;
@@ -1,42 +1,43 @@
1
- import { TARGET as d } from "../constants/target.mjs";
2
- import { omit as f } from "../helpers/omit.mjs";
3
- import { evaluate as m } from "./evaluate/evaluate.mjs";
1
+ import { TARGET as l } from "../constants/target.mjs";
2
+ import { omit as m } from "../helpers/omit.mjs";
3
+ import { evaluate as d } from "./evaluate/evaluate.mjs";
4
+ import { resolveLocalizedValues as f } from "./extract-localized-values.mjs";
4
5
  import { fastClone as u } from "./fast-clone.mjs";
5
- import { set as l } from "./set.mjs";
6
- import { transformBlock as y } from "./transform-block.mjs";
6
+ import { set as y } from "./set.mjs";
7
+ import { transformBlock as g } from "./transform-block.mjs";
7
8
  function c(e) {
8
9
  if (e === null || typeof e != "object")
9
10
  return e;
10
11
  if (Array.isArray(e))
11
- return e.map((r) => c(r));
12
+ return e.map((t) => c(t));
12
13
  if (e["@type"] === "@builder.io/sdk:Element")
13
14
  return e;
14
- const t = {};
15
- for (const r in e)
16
- r !== "meta" && Object.prototype.hasOwnProperty.call(e, r) && (t[r] = c(e[r]));
17
- return t;
15
+ const r = {};
16
+ for (const t in e)
17
+ t !== "meta" && Object.prototype.hasOwnProperty.call(e, t) && (r[t] = c(e[t]));
18
+ return r;
18
19
  }
19
- const g = ["svelte", "vue", "angular", "qwik", "solid"].includes(d), C = (e) => {
20
- if (g) {
21
- const t = u(e);
20
+ const C = ["svelte", "vue", "angular", "qwik", "solid"].includes(l), v = (e) => {
21
+ if (C) {
22
+ const r = u(e);
22
23
  return {
23
- ...t,
24
+ ...r,
24
25
  properties: {
25
- ...t.properties
26
+ ...r.properties
26
27
  },
27
28
  actions: {
28
- ...t.actions
29
+ ...r.actions
29
30
  }
30
31
  };
31
32
  } else {
32
- const t = c(f(e, "children", "meta"));
33
+ const r = c(m(e, "children", "meta"));
33
34
  return {
34
- ...t,
35
+ ...r,
35
36
  properties: {
36
- ...t.properties
37
+ ...r.properties
37
38
  },
38
39
  actions: {
39
- ...t.actions
40
+ ...r.actions
40
41
  },
41
42
  children: e.children,
42
43
  meta: e.meta
@@ -44,44 +45,44 @@ const g = ["svelte", "vue", "angular", "qwik", "solid"].includes(d), C = (e) =>
44
45
  }
45
46
  }, O = ({
46
47
  block: e,
47
- context: t,
48
- localState: r,
49
- rootState: o,
50
- rootSetState: s
48
+ context: r,
49
+ localState: t,
50
+ rootState: s,
51
+ rootSetState: i
51
52
  }) => {
52
53
  if (!e.bindings)
53
54
  return e;
54
- const i = C(e);
55
+ const o = v(e);
55
56
  for (const n in e.bindings) {
56
- const p = e.bindings[n], a = m({
57
+ const p = e.bindings[n], a = d({
57
58
  code: p,
58
- localState: r,
59
- rootState: o,
60
- rootSetState: s,
61
- context: t
59
+ localState: t,
60
+ rootState: s,
61
+ rootSetState: i,
62
+ context: r
62
63
  });
63
- l(i, n, a);
64
+ y(o, n, a);
64
65
  }
65
- return i;
66
+ return o;
66
67
  };
67
- function S({
68
+ function P({
68
69
  block: e,
69
- context: t,
70
- shouldEvaluateBindings: r,
71
- localState: o,
72
- rootState: s,
73
- rootSetState: i
70
+ context: r,
71
+ shouldEvaluateBindings: t,
72
+ localState: s,
73
+ rootState: i,
74
+ rootSetState: o
74
75
  }) {
75
- const n = y(e);
76
- return r ? O({
76
+ let n = f(e, i.locale);
77
+ return n = g(n), t ? O({
77
78
  block: n,
78
- localState: o,
79
- rootState: s,
80
- rootSetState: i,
81
- context: t
79
+ localState: s,
80
+ rootState: i,
81
+ rootSetState: o,
82
+ context: r
82
83
  }) : n;
83
84
  }
84
85
  export {
85
86
  c as deepCloneWithConditions,
86
- S as getProcessedBlock
87
+ P as getProcessedBlock
87
88
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=t=>({type:"builder.registerComponent",data:r(t)}),s=t=>{const n=t.toString().trim(),e=/^[a-zA-Z0-9_]+\s*=>/i.test(n);return`return (${!n.startsWith("function")&&!n.startsWith("(")&&!e?"function ":""}${n}).apply(this, arguments)`};function r(t){return JSON.parse(JSON.stringify(t,(n,e)=>typeof e=="function"?s(e):e))}exports.createRegisterComponentMessage=i;exports.serializeIncludingFunctions=r;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=n=>({type:"builder.registerComponent",data:r(n)}),s=n=>{const t=n.toString().trim(),e=/^[a-zA-Z0-9_]+\s*=>/i.test(t);return`return (${!t.startsWith("function")&&!t.startsWith("async")&&!t.startsWith("(")&&!e?"function ":""}${t}).apply(this, arguments)`};function r(n){return JSON.parse(JSON.stringify(n,(t,e)=>typeof e=="function"?s(e):e))}exports.createRegisterComponentMessage=i;exports.serializeIncludingFunctions=r;
@@ -1,12 +1,12 @@
1
- const o = (t) => ({
1
+ const o = (n) => ({
2
2
  type: "builder.registerComponent",
3
- data: i(t)
4
- }), e = (t) => {
5
- const n = t.toString().trim(), r = /^[a-zA-Z0-9_]+\s*=>/i.test(n);
6
- return `return (${!n.startsWith("function") && !n.startsWith("(") && !r ? "function " : ""}${n}).apply(this, arguments)`;
3
+ data: i(n)
4
+ }), e = (n) => {
5
+ const t = n.toString().trim(), r = /^[a-zA-Z0-9_]+\s*=>/i.test(t);
6
+ return `return (${!t.startsWith("function") && !t.startsWith("async") && !t.startsWith("(") && !r ? "function " : ""}${t}).apply(this, arguments)`;
7
7
  };
8
- function i(t) {
9
- return JSON.parse(JSON.stringify(t, (n, r) => typeof r == "function" ? e(r) : r));
8
+ function i(n) {
9
+ return JSON.parse(JSON.stringify(n, (t, r) => typeof r == "function" ? e(r) : r));
10
10
  }
11
11
  export {
12
12
  o as createRegisterComponentMessage,
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function s(e,t,a=null,l=null,n=new WeakSet){if(e==null||typeof e!="object"){t(e,r=>{a!==null&&l!==null&&(a[l]=r)});return}n.has(e)||(n.add(e),Array.isArray(e)?e.forEach((r,u)=>{t(r,f=>{e[u]=f}),s(r,t,e,u,n)}):Object.entries(e).forEach(([r,u])=>{t(u,f=>{e[r]=f}),s(u,t,e,r,n)}))}exports.traverse=s;
@@ -0,0 +1,20 @@
1
+ function h(r, t, p = null, s = null, e = /* @__PURE__ */ new WeakSet()) {
2
+ if (r == null || typeof r != "object") {
3
+ t(r, (n) => {
4
+ p !== null && s !== null && (p[s] = n);
5
+ });
6
+ return;
7
+ }
8
+ e.has(r) || (e.add(r), Array.isArray(r) ? r.forEach((n, u) => {
9
+ t(n, (f) => {
10
+ r[u] = f;
11
+ }), h(n, t, r, u, e);
12
+ }) : Object.entries(r).forEach(([n, u]) => {
13
+ t(u, (f) => {
14
+ r[n] = f;
15
+ }), h(u, t, r, n, e);
16
+ }));
17
+ }
18
+ export {
19
+ h as traverse
20
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@builder.io/sdk-react-nextjs",
3
3
  "description": "Builder.io RSC SDK for NextJS App Directory",
4
- "version": "0.17.0",
4
+ "version": "0.17.1",
5
5
  "homepage": "https://github.com/BuilderIO/builder/tree/main/packages/sdks/output/nextjs",
6
6
  "repository": {
7
7
  "type": "git",
@@ -1,9 +1,10 @@
1
1
  import type { BuilderContextInterface, RegisteredComponent, RegisteredComponents } from '../../context/types.js';
2
2
  import type { BuilderBlock } from '../../types/builder-block.js';
3
3
  import type { RepeatData } from './types.js';
4
- export declare const getComponent: ({ block, registeredComponents }: {
4
+ export declare const getComponent: ({ block, registeredComponents, model }: {
5
5
  block: BuilderBlock;
6
6
  registeredComponents: RegisteredComponents;
7
+ model: string;
7
8
  }) => RegisteredComponent;
8
9
  export declare const getRepeatItemData: ({ block, context }: {
9
10
  block: BuilderBlock;
@@ -18,8 +19,10 @@ export declare const provideLinkComponent: (block: RegisteredComponent | null |
18
19
  } | {
19
20
  builderLinkComponent?: undefined;
20
21
  };
21
- export declare const provideRegisteredComponents: (block: RegisteredComponent | null | undefined, registeredComponents: RegisteredComponents) => {
22
- builderComponents: RegisteredComponents;
22
+ export declare const provideRegisteredComponents: (block: RegisteredComponent | null | undefined, registeredComponents: RegisteredComponents, model: string) => {
23
+ builderComponents: {
24
+ [k: string]: RegisteredComponent;
25
+ };
23
26
  } | {
24
27
  builderComponents?: undefined;
25
28
  };
@@ -0,0 +1,11 @@
1
+ import type { Target } from '../../../types/targets.js';
2
+ /**
3
+ * SDKS that use the elementRef approach to enable visual editing.
4
+ * We don't need to render the div for other SDKs as they attach event listeners to the window.
5
+ */
6
+ export declare const SDKS_USING_ELEMENT_REF_APPROACH: Target[];
7
+ /**
8
+ * We need to attach this div only when content exists or isPreviewing/isEditing even when content is null,
9
+ * as we need to set the elementRef and allow previewing and visual editing
10
+ */
11
+ export declare const needsElementRefDivForEditing: () => boolean;
@@ -0,0 +1,2 @@
1
+ export declare const IMAGE_FILE_TYPES: string[];
2
+ export declare const VIDEO_FILE_TYPES: string[];
@@ -1 +1 @@
1
- export declare const SDK_VERSION = "0.17.0";
1
+ export declare const SDK_VERSION = "0.17.1";
@@ -36,5 +36,6 @@ export interface BuilderContextInterface extends Pick<BlocksWrapperProps, 'Block
36
36
  componentInfos: Dictionary<ComponentInfo>;
37
37
  inheritedStyles: Record<string, unknown>;
38
38
  nonce: string;
39
+ model: string;
39
40
  canTrack?: boolean;
40
41
  }
@@ -0,0 +1,2 @@
1
+ import type { BuilderBlock } from '../types/builder-block.js';
2
+ export declare function resolveLocalizedValues(block: BuilderBlock, locale: string | undefined): BuilderBlock;
@@ -0,0 +1,34 @@
1
+ type TraverseCallback = (value: any, update: (newValue: any) => void) => void;
2
+ /**
3
+ * Recursively traverses an object or array, invoking a callback on each value.
4
+ *
5
+ * @param {any} obj - The object or array to traverse. Can also handle primitives, null, or undefined.
6
+ * @param {TraverseCallback} callback - The function to invoke on each value. Receives the current value
7
+ * and an `update` function to modify the value in its parent container.
8
+ * @param {any} [parent=null] - The parent object or array of the current value. Used internally.
9
+ * @param {any} [key=null] - The key or index of the current value in its parent. Used internally.
10
+ * @param {WeakSet} [visited=new WeakSet()] - Tracks visited objects to handle circular references. Used internally.
11
+ *
12
+ * @example
13
+ * // Example: Doubling all numbers in an object
14
+ * const obj = { a: 1, b: [2, 3, { c: 4 }] };
15
+ * traverse(obj, (value, update) => {
16
+ * if (typeof value === 'number') {
17
+ * update(value * 2);
18
+ * }
19
+ * });
20
+ * console.log(obj); // { a: 2, b: [4, 6, { c: 8 }] }
21
+ *
22
+ * @example
23
+ * // Example: Handling circular references
24
+ * const obj = { a: 1 };
25
+ * obj.self = obj;
26
+ * traverse(obj, (value, update) => {
27
+ * if (typeof value === 'number') {
28
+ * update(value * 2);
29
+ * }
30
+ * });
31
+ * console.log(obj.a); // 2
32
+ */
33
+ export declare function traverse(obj: any, callback: TraverseCallback, parent?: any, key?: any, visited?: WeakSet<WeakKey>): void;
34
+ export {};
@@ -146,6 +146,9 @@ export interface ComponentInfo {
146
146
  */
147
147
  builderLinkComponent?: boolean;
148
148
  };
149
+ meta?: {
150
+ [key: string]: any;
151
+ };
149
152
  }
150
153
  type Permission = 'read' | 'publish' | 'editCode' | 'editDesigns' | 'admin' | 'create';
151
154
  export {};
@@ -1,9 +1,10 @@
1
1
  import type { BuilderContextInterface, RegisteredComponent, RegisteredComponents } from '../../context/types.js';
2
2
  import type { BuilderBlock } from '../../types/builder-block.js';
3
3
  import type { RepeatData } from './types.js';
4
- export declare const getComponent: ({ block, registeredComponents }: {
4
+ export declare const getComponent: ({ block, registeredComponents, model }: {
5
5
  block: BuilderBlock;
6
6
  registeredComponents: RegisteredComponents;
7
+ model: string;
7
8
  }) => RegisteredComponent;
8
9
  export declare const getRepeatItemData: ({ block, context }: {
9
10
  block: BuilderBlock;
@@ -18,8 +19,10 @@ export declare const provideLinkComponent: (block: RegisteredComponent | null |
18
19
  } | {
19
20
  builderLinkComponent?: undefined;
20
21
  };
21
- export declare const provideRegisteredComponents: (block: RegisteredComponent | null | undefined, registeredComponents: RegisteredComponents) => {
22
- builderComponents: RegisteredComponents;
22
+ export declare const provideRegisteredComponents: (block: RegisteredComponent | null | undefined, registeredComponents: RegisteredComponents, model: string) => {
23
+ builderComponents: {
24
+ [k: string]: RegisteredComponent;
25
+ };
23
26
  } | {
24
27
  builderComponents?: undefined;
25
28
  };
@@ -0,0 +1,11 @@
1
+ import type { Target } from '../../../types/targets.js';
2
+ /**
3
+ * SDKS that use the elementRef approach to enable visual editing.
4
+ * We don't need to render the div for other SDKs as they attach event listeners to the window.
5
+ */
6
+ export declare const SDKS_USING_ELEMENT_REF_APPROACH: Target[];
7
+ /**
8
+ * We need to attach this div only when content exists or isPreviewing/isEditing even when content is null,
9
+ * as we need to set the elementRef and allow previewing and visual editing
10
+ */
11
+ export declare const needsElementRefDivForEditing: () => boolean;
@@ -0,0 +1,2 @@
1
+ export declare const IMAGE_FILE_TYPES: string[];
2
+ export declare const VIDEO_FILE_TYPES: string[];
@@ -1 +1 @@
1
- export declare const SDK_VERSION = "0.17.0";
1
+ export declare const SDK_VERSION = "0.17.1";
@@ -36,5 +36,6 @@ export interface BuilderContextInterface extends Pick<BlocksWrapperProps, 'Block
36
36
  componentInfos: Dictionary<ComponentInfo>;
37
37
  inheritedStyles: Record<string, unknown>;
38
38
  nonce: string;
39
+ model: string;
39
40
  canTrack?: boolean;
40
41
  }
@@ -0,0 +1,2 @@
1
+ import type { BuilderBlock } from '../types/builder-block.js';
2
+ export declare function resolveLocalizedValues(block: BuilderBlock, locale: string | undefined): BuilderBlock;
@@ -0,0 +1,34 @@
1
+ type TraverseCallback = (value: any, update: (newValue: any) => void) => void;
2
+ /**
3
+ * Recursively traverses an object or array, invoking a callback on each value.
4
+ *
5
+ * @param {any} obj - The object or array to traverse. Can also handle primitives, null, or undefined.
6
+ * @param {TraverseCallback} callback - The function to invoke on each value. Receives the current value
7
+ * and an `update` function to modify the value in its parent container.
8
+ * @param {any} [parent=null] - The parent object or array of the current value. Used internally.
9
+ * @param {any} [key=null] - The key or index of the current value in its parent. Used internally.
10
+ * @param {WeakSet} [visited=new WeakSet()] - Tracks visited objects to handle circular references. Used internally.
11
+ *
12
+ * @example
13
+ * // Example: Doubling all numbers in an object
14
+ * const obj = { a: 1, b: [2, 3, { c: 4 }] };
15
+ * traverse(obj, (value, update) => {
16
+ * if (typeof value === 'number') {
17
+ * update(value * 2);
18
+ * }
19
+ * });
20
+ * console.log(obj); // { a: 2, b: [4, 6, { c: 8 }] }
21
+ *
22
+ * @example
23
+ * // Example: Handling circular references
24
+ * const obj = { a: 1 };
25
+ * obj.self = obj;
26
+ * traverse(obj, (value, update) => {
27
+ * if (typeof value === 'number') {
28
+ * update(value * 2);
29
+ * }
30
+ * });
31
+ * console.log(obj.a); // 2
32
+ */
33
+ export declare function traverse(obj: any, callback: TraverseCallback, parent?: any, key?: any, visited?: WeakSet<WeakKey>): void;
34
+ export {};
@@ -146,6 +146,9 @@ export interface ComponentInfo {
146
146
  */
147
147
  builderLinkComponent?: boolean;
148
148
  };
149
+ meta?: {
150
+ [key: string]: any;
151
+ };
149
152
  }
150
153
  type Permission = 'read' | 'publish' | 'editCode' | 'editDesigns' | 'admin' | 'create';
151
154
  export {};