@builder.io/sdk-vue 4.2.4 → 5.0.0-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 (68) hide show
  1. package/lib/browser/{awaiter-9j04A_GV.cjs → awaiter-8y0HlZSj.cjs} +1 -1
  2. package/lib/browser/{awaiter-k56NYxtZ.js → awaiter-meBPeE4o.js} +1 -1
  3. package/lib/browser/{block-wrapper-fa_I-FFZ.cjs → block-wrapper-JKEVgKKk.cjs} +1 -1
  4. package/lib/browser/{block-wrapper-nWZ8mnzV.js → block-wrapper-ps9jdsZS.js} +3 -3
  5. package/lib/browser/{component-ref-BiCTuNrm.cjs → component-ref-X5E6T9Bq.cjs} +1 -1
  6. package/lib/browser/{component-ref-809aE3jw.js → component-ref-lBj74aY-.js} +4 -4
  7. package/lib/browser/components/content/content.vue.d.ts +7 -1
  8. package/lib/browser/constants/sdk-version.d.ts +1 -1
  9. package/lib/browser/{get-block-properties-hv2UC_Ak.js → get-block-properties-Otw7bMxK.js} +1 -1
  10. package/lib/browser/{get-block-properties-Wj-bZmuN.cjs → get-block-properties-w1guGf0o.cjs} +1 -1
  11. package/lib/browser/{index-DRqRWus9.cjs → index-59ip1jzi.cjs} +3 -3
  12. package/lib/browser/{index-up0O4QOR.js → index-ea9XhI64.js} +24 -8
  13. package/lib/browser/index.cjs +1 -1
  14. package/lib/browser/index.mjs +1 -1
  15. package/lib/browser/{live-edit-u4CLwhz2.js → live-edit-GYMaRVHJ.js} +1 -1
  16. package/lib/browser/{live-edit-yg5JQxHm.cjs → live-edit-OZAH__UX.cjs} +1 -1
  17. package/lib/browser/{repeated-block-pz96mjT3.js → repeated-block-DJUHF1X4.js} +2 -2
  18. package/lib/browser/{repeated-block-0QfzfDq4.cjs → repeated-block-QYDS0GHI.cjs} +1 -1
  19. package/lib/browser/{style-wrapper-lru4KPfF.cjs → style-wrapper-cZTiuVb8.cjs} +1 -1
  20. package/lib/browser/{style-wrapper-XpqFC6zr.js → style-wrapper-ys7_5x8c.js} +1 -1
  21. package/lib/browser/types/input.d.ts +1 -1
  22. package/lib/edge/{awaiter-yiZL6S2H.cjs → awaiter-1jaz3zHu.cjs} +1 -1
  23. package/lib/edge/{awaiter-6dzFFSC3.js → awaiter-pkwpYXrM.js} +1 -1
  24. package/lib/edge/{block-wrapper-x_q82_kn.js → block-wrapper-bgtF5JF0.js} +3 -3
  25. package/lib/edge/{block-wrapper-f_-dny3h.cjs → block-wrapper-pgahpO1m.cjs} +1 -1
  26. package/lib/edge/{component-ref-6pdeZX03.cjs → component-ref-4GFv86n6.cjs} +1 -1
  27. package/lib/edge/{component-ref-o49BQXb9.js → component-ref-BlqZ00vs.js} +4 -4
  28. package/lib/edge/components/content/content.vue.d.ts +7 -1
  29. package/lib/edge/constants/sdk-version.d.ts +1 -1
  30. package/lib/edge/{get-block-properties-rN_Wdewg.js → get-block-properties-0KyZG-RB.js} +1 -1
  31. package/lib/edge/{get-block-properties-BZeTejYz.cjs → get-block-properties-n9pt41wi.cjs} +1 -1
  32. package/lib/edge/{index-YikH7lP_.js → index-0q4SHFCt.js} +227 -211
  33. package/lib/edge/{index-j3k1FtDv.cjs → index-xXY_-KsW.cjs} +3 -3
  34. package/lib/edge/index.cjs +1 -1
  35. package/lib/edge/index.mjs +1 -1
  36. package/lib/{node/live-edit-d95nI1uy.js → edge/live-edit-Hdgm5ryZ.js} +1 -1
  37. package/lib/{node/live-edit-4dgiiT0i.cjs → edge/live-edit-t1IgtdC8.cjs} +1 -1
  38. package/lib/{node/repeated-block-0GJiZm2S.js → edge/repeated-block--nKPD2Kz.js} +2 -2
  39. package/lib/edge/{repeated-block-BcDLD-Ro.cjs → repeated-block-5riXWQ_j.cjs} +1 -1
  40. package/lib/edge/{style-wrapper-gIxKA8yk.cjs → style-wrapper-Q5TP1oCh.cjs} +1 -1
  41. package/lib/edge/{style-wrapper-3dTutPaZ.js → style-wrapper-s0uDqtsM.js} +1 -1
  42. package/lib/edge/types/input.d.ts +1 -1
  43. package/lib/node/{awaiter-iefQuuK5.js → awaiter-5yM3PjX1.js} +1 -1
  44. package/lib/node/{awaiter-6p8mxokx.cjs → awaiter-BAj1n2qC.cjs} +1 -1
  45. package/lib/node/{block-wrapper-JOi6L86W.cjs → block-wrapper-MSW2K06W.cjs} +1 -1
  46. package/lib/node/{block-wrapper-e7v8Xkfa.js → block-wrapper-TWVPnhN0.js} +3 -3
  47. package/lib/node/{component-ref-cGDAecrm.cjs → component-ref--YcUaDSR.cjs} +1 -1
  48. package/lib/node/{component-ref--dFHHl9O.js → component-ref-D4bSV2sz.js} +5 -5
  49. package/lib/node/components/content/content.vue.d.ts +7 -1
  50. package/lib/node/constants/sdk-version.d.ts +1 -1
  51. package/lib/node/{get-block-properties-FaxCrM1a.js → get-block-properties-DzpFEmHW.js} +2 -2
  52. package/lib/node/{get-block-properties-jmSoWfe4.cjs → get-block-properties-M9_K0y5D.cjs} +1 -1
  53. package/lib/node/{index-XZ9fje0u.cjs → index-8IqpYXbZ.cjs} +3 -3
  54. package/lib/node/{index-cA6aiTF9.js → index-EXr8pPnh.js} +25 -9
  55. package/lib/node/index.cjs +1 -1
  56. package/lib/node/index.mjs +2 -2
  57. package/lib/node/init.cjs +1 -1
  58. package/lib/node/init.mjs +1 -1
  59. package/lib/{edge/live-edit--OTgD3lj.js → node/live-edit-93u_ahS3.js} +1 -1
  60. package/lib/{edge/live-edit-5TXPHULA.cjs → node/live-edit-hQmwWxEv.cjs} +1 -1
  61. package/lib/node/{repeated-block-dl3zJ7hh.cjs → repeated-block-cwHefMyv.cjs} +1 -1
  62. package/lib/{edge/repeated-block-cY7tvCZ6.js → node/repeated-block-lqNiXtAD.js} +2 -2
  63. package/lib/node/{should-force-browser-runtime-in-node-ikxWrCvn.js → should-force-browser-runtime-in-node-A2KBg23G.js} +37 -21
  64. package/lib/node/{should-force-browser-runtime-in-node-1vTKsoso.cjs → should-force-browser-runtime-in-node-pX8aK2P6.cjs} +2 -2
  65. package/lib/node/{style-wrapper-rg8DEjG3.js → style-wrapper-XD5sZ_I5.js} +2 -2
  66. package/lib/node/{style-wrapper-aM0mtDgE.cjs → style-wrapper-nXWXnrnh.cjs} +1 -1
  67. package/lib/node/types/input.d.ts +1 -1
  68. package/package.json +2 -2
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("vue"),o=require("./get-block-properties-BZeTejYz.cjs"),n=require("./index-j3k1FtDv.cjs"),c=()=>Promise.resolve().then(()=>require("./index-j3k1FtDv.cjs")).then(e=>e.dynamicRenderer).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component DynamicRenderer at ../../dynamic-renderer/dynamic-renderer.vue",e),e}),a=t.defineComponent({name:"block-wrapper",components:{DynamicRenderer:t.defineAsyncComponent(c)},props:["Wrapper","block","context"],data(){return{getBlockActions:o.getBlockActions,getBlockProperties:o.getBlockProperties}}});function i(e,l,p,d,m,u){const r=t.resolveComponent("DynamicRenderer");return t.openBlock(),t.createBlock(r,{TagName:e.Wrapper,attributes:e.getBlockProperties({block:e.block,context:e.context}),actionAttributes:e.getBlockActions({block:e.block,rootState:e.context.rootState,rootSetState:e.context.rootSetState,localState:e.context.localState,context:e.context.context,stripPrefix:!0})},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["TagName","attributes","actionAttributes"])}const s=n._export_sfc(a,[["render",i]]);exports.default=s;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("vue"),o=require("./get-block-properties-n9pt41wi.cjs"),n=require("./index-xXY_-KsW.cjs"),c=()=>Promise.resolve().then(()=>require("./index-xXY_-KsW.cjs")).then(e=>e.dynamicRenderer).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component DynamicRenderer at ../../dynamic-renderer/dynamic-renderer.vue",e),e}),a=t.defineComponent({name:"block-wrapper",components:{DynamicRenderer:t.defineAsyncComponent(c)},props:["Wrapper","block","context"],data(){return{getBlockActions:o.getBlockActions,getBlockProperties:o.getBlockProperties}}});function i(e,l,p,d,m,u){const r=t.resolveComponent("DynamicRenderer");return t.openBlock(),t.createBlock(r,{TagName:e.Wrapper,attributes:e.getBlockProperties({block:e.block,context:e.context}),actionAttributes:e.getBlockActions({block:e.block,rootState:e.context.rootState,rootSetState:e.context.rootSetState,localState:e.context.localState,context:e.context.context,stripPrefix:!0})},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["TagName","attributes","actionAttributes"])}const s=n._export_sfc(a,[["render",i]]);exports.default=s;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("vue"),n=require("./index-j3k1FtDv.cjs"),l=require("./get-block-properties-BZeTejYz.cjs"),u=()=>Promise.resolve().then(()=>require("./awaiter-yiZL6S2H.cjs")).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component Awaiter at ../../awaiter.vue",e),e}),k=()=>Promise.resolve().then(()=>require("./live-edit-5TXPHULA.cjs")).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component LiveEdit at ../../live-edit.vue",e),e}),f=t.defineComponent({name:"interactive-element",components:{LiveEdit:t.defineAsyncComponent(k),Awaiter:t.defineAsyncComponent(u)},props:["wrapperProps","block","includeBlockProps","context","Wrapper"],data(){return{forceRenderCount:0,TARGET:n.TARGET,isEditing:n.isEditing}},watch:{onUpdateHook0:{handler(){},immediate:!0}},computed:{attributes(){return this.includeBlockProps?{...l.getBlockProperties({block:this.block,context:this.context}),...l.getBlockActions({block:this.block,rootState:this.context.rootState,rootSetState:this.context.rootSetState,localState:this.context.localState,context:this.context.context})}:{}},targetWrapperProps(){return{...this.wrapperProps,...Object.keys(this.attributes).length>0?{attributes:this.attributes}:{}}},onUpdateHook0(){var e,o;return{0:this.wrapperProps,1:(o=(e=this.block)==null?void 0:e.component)==null?void 0:o.options}}}});function h(e,o,s,a,p,c){const i=t.resolveComponent("Awaiter"),r=t.resolveComponent("LiveEdit");return e.Wrapper.load?(t.openBlock(),t.createBlock(i,{key:0,load:e.Wrapper.load,fallback:e.Wrapper.fallback,props:e.wrapperProps,attributes:e.attributes},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["load","fallback","props","attributes"])):(t.openBlock(),t.createElementBlock(t.Fragment,{key:1},[e.TARGET==="rsc"&&e.isEditing()?(t.openBlock(),t.createBlock(r,{key:0,Wrapper:e.Wrapper,id:e.block.id||"",attributes:e.attributes},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["Wrapper","id","attributes"])):(t.openBlock(),t.createBlock(t.resolveDynamicComponent(e.Wrapper),t.mergeProps({key:1,attributes:e.attributes},e.targetWrapperProps),{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},16,["attributes"]))],64))}const m=n._export_sfc(f,[["render",h]]),b=({componentOptions:e,builderBlock:o,context:s,componentRef:a,includeBlockProps:p,isInteractive:c,contextValue:i})=>{const r={...e,...p?{attributes:l.getBlockProperties({block:o,context:i})}:{}};return c?{Wrapper:a,block:o,context:s,wrapperProps:e,includeBlockProps:p}:r},C=t.defineComponent({name:"component-ref",components:{Block:n.Block,InteractiveElement:m},props:["isInteractive","componentRef","componentOptions","builderBlock","context","linkComponent","includeBlockProps","blockChildren","registeredComponents"],data(){return{shouldUpdate:!1,Wrapper:this.isInteractive?n.wrapComponentRef(m):this.componentRef,getWrapperProps:b}}});function B(e,o,s,a,p,c){const i=t.resolveComponent("Block");return e.componentRef?(t.openBlock(),t.createBlock(t.resolveDynamicComponent(e.Wrapper),t.normalizeProps(t.mergeProps({key:0},e.getWrapperProps({componentOptions:e.componentOptions,builderBlock:e.builderBlock,context:e.context,componentRef:e.componentRef,linkComponent:e.linkComponent,includeBlockProps:e.includeBlockProps,isInteractive:e.isInteractive,contextValue:e.context}))),{default:t.withCtx(()=>[e.componentRef?(t.openBlock(!0),t.createElementBlock(t.Fragment,{key:0},t.renderList(e.blockChildren,(r,d)=>(t.openBlock(),t.createBlock(i,{key:r.id,block:r,context:e.context,registeredComponents:e.registeredComponents,linkComponent:e.linkComponent},null,8,["block","context","registeredComponents","linkComponent"]))),128)):t.createCommentVNode("",!0)]),_:1},16)):t.createCommentVNode("",!0)}const v=n._export_sfc(C,[["render",B]]);exports.default=v;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("vue"),n=require("./index-xXY_-KsW.cjs"),l=require("./get-block-properties-n9pt41wi.cjs"),u=()=>Promise.resolve().then(()=>require("./awaiter-1jaz3zHu.cjs")).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component Awaiter at ../../awaiter.vue",e),e}),k=()=>Promise.resolve().then(()=>require("./live-edit-t1IgtdC8.cjs")).then(e=>e.default).catch(e=>{throw console.error("Error while attempting to dynamically import component LiveEdit at ../../live-edit.vue",e),e}),f=t.defineComponent({name:"interactive-element",components:{LiveEdit:t.defineAsyncComponent(k),Awaiter:t.defineAsyncComponent(u)},props:["wrapperProps","block","includeBlockProps","context","Wrapper"],data(){return{forceRenderCount:0,TARGET:n.TARGET,isEditing:n.isEditing}},watch:{onUpdateHook0:{handler(){},immediate:!0}},computed:{attributes(){return this.includeBlockProps?{...l.getBlockProperties({block:this.block,context:this.context}),...l.getBlockActions({block:this.block,rootState:this.context.rootState,rootSetState:this.context.rootSetState,localState:this.context.localState,context:this.context.context})}:{}},targetWrapperProps(){return{...this.wrapperProps,...Object.keys(this.attributes).length>0?{attributes:this.attributes}:{}}},onUpdateHook0(){var e,o;return{0:this.wrapperProps,1:(o=(e=this.block)==null?void 0:e.component)==null?void 0:o.options}}}});function h(e,o,s,a,p,c){const i=t.resolveComponent("Awaiter"),r=t.resolveComponent("LiveEdit");return e.Wrapper.load?(t.openBlock(),t.createBlock(i,{key:0,load:e.Wrapper.load,fallback:e.Wrapper.fallback,props:e.wrapperProps,attributes:e.attributes},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["load","fallback","props","attributes"])):(t.openBlock(),t.createElementBlock(t.Fragment,{key:1},[e.TARGET==="rsc"&&e.isEditing()?(t.openBlock(),t.createBlock(r,{key:0,Wrapper:e.Wrapper,id:e.block.id||"",attributes:e.attributes},{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},8,["Wrapper","id","attributes"])):(t.openBlock(),t.createBlock(t.resolveDynamicComponent(e.Wrapper),t.mergeProps({key:1,attributes:e.attributes},e.targetWrapperProps),{default:t.withCtx(()=>[t.renderSlot(e.$slots,"default")]),_:3},16,["attributes"]))],64))}const m=n._export_sfc(f,[["render",h]]),b=({componentOptions:e,builderBlock:o,context:s,componentRef:a,includeBlockProps:p,isInteractive:c,contextValue:i})=>{const r={...e,...p?{attributes:l.getBlockProperties({block:o,context:i})}:{}};return c?{Wrapper:a,block:o,context:s,wrapperProps:e,includeBlockProps:p}:r},C=t.defineComponent({name:"component-ref",components:{Block:n.Block,InteractiveElement:m},props:["isInteractive","componentRef","componentOptions","builderBlock","context","linkComponent","includeBlockProps","blockChildren","registeredComponents"],data(){return{shouldUpdate:!1,Wrapper:this.isInteractive?n.wrapComponentRef(m):this.componentRef,getWrapperProps:b}}});function B(e,o,s,a,p,c){const i=t.resolveComponent("Block");return e.componentRef?(t.openBlock(),t.createBlock(t.resolveDynamicComponent(e.Wrapper),t.normalizeProps(t.mergeProps({key:0},e.getWrapperProps({componentOptions:e.componentOptions,builderBlock:e.builderBlock,context:e.context,componentRef:e.componentRef,linkComponent:e.linkComponent,includeBlockProps:e.includeBlockProps,isInteractive:e.isInteractive,contextValue:e.context}))),{default:t.withCtx(()=>[e.componentRef?(t.openBlock(!0),t.createElementBlock(t.Fragment,{key:0},t.renderList(e.blockChildren,(r,d)=>(t.openBlock(),t.createBlock(i,{key:r.id,block:r,context:e.context,registeredComponents:e.registeredComponents,linkComponent:e.linkComponent},null,8,["block","context","registeredComponents","linkComponent"]))),128)):t.createCommentVNode("",!0)]),_:1},16)):t.createCommentVNode("",!0)}const v=n._export_sfc(C,[["render",B]]);exports.default=v;
@@ -1,12 +1,12 @@
1
1
  import { defineComponent as b, defineAsyncComponent as u, resolveComponent as d, openBlock as o, createBlock as p, withCtx as i, renderSlot as m, createElementBlock as h, Fragment as w, resolveDynamicComponent as C, mergeProps as P, normalizeProps as B, renderList as E, createCommentVNode as k } from "vue";
2
- import { T as y, i as $, _ as g, B as R, w as A } from "./index-YikH7lP_.js";
3
- import { a as v, g as S } from "./get-block-properties-rN_Wdewg.js";
4
- const L = () => import("./awaiter-6dzFFSC3.js").then((e) => e.default).catch((e) => {
2
+ import { T as y, i as $, _ as g, B as R, w as A } from "./index-0q4SHFCt.js";
3
+ import { a as v, g as S } from "./get-block-properties-0KyZG-RB.js";
4
+ const L = () => import("./awaiter-pkwpYXrM.js").then((e) => e.default).catch((e) => {
5
5
  throw console.error(
6
6
  "Error while attempting to dynamically import component Awaiter at ../../awaiter.vue",
7
7
  e
8
8
  ), e;
9
- }), I = () => import("./live-edit--OTgD3lj.js").then((e) => e.default).catch((e) => {
9
+ }), I = () => import("./live-edit-Hdgm5ryZ.js").then((e) => e.default).catch((e) => {
10
10
  throw console.error(
11
11
  "Error while attempting to dynamically import component LiveEdit at ../../live-edit.vue",
12
12
  e
@@ -45,7 +45,13 @@ declare const _default: import("vue").DefineComponent<Readonly<{
45
45
  model: any;
46
46
  };
47
47
  TARGET: import("../../types/targets").Target;
48
- }, {}, {
48
+ }, {
49
+ onUpdateHook0(): {
50
+ 0: any;
51
+ 1: any;
52
+ 2: any;
53
+ };
54
+ }, {
49
55
  contentSetState(newRootState: BuilderRenderState): void;
50
56
  }, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<Readonly<{
51
57
  data?: any;
@@ -1 +1 @@
1
- export declare const SDK_VERSION = "4.2.4";
1
+ export declare const SDK_VERSION = "5.0.0-1";
@@ -1,4 +1,4 @@
1
- import { e as n, T as c, g as i, a as l } from "./index-YikH7lP_.js";
1
+ import { e as n, T as c, g as i, a as l } from "./index-0q4SHFCt.js";
2
2
  const f = (e) => `v-on:${e.toLowerCase()}`, p = (e, t) => (r) => n({
3
3
  code: e,
4
4
  context: t.context,
@@ -1 +1 @@
1
- "use strict";const s=require("./index-j3k1FtDv.cjs"),c=e=>`v-on:${e.toLowerCase()}`,i=(e,t)=>r=>s.evaluate({code:e,context:t.context,localState:t.localState,rootState:t.rootState,rootSetState:t.rootSetState,event:r,isExpression:!1});function l(e){const t={},r=e.block.actions??{};for(const o in r){if(!r.hasOwnProperty(o))continue;const a=r[o];let n=c(o);if(e.stripPrefix)switch(s.TARGET){case"vue":n=n.replace("v-on:","");break;case"svelte":n=n.replace("on:","");break}t[n]=i(a,e)}return t}function u({properties:e}){return e}const f=e=>({href:e.href});function p({block:e,context:t}){var o;const r={...f(e),...e.properties,"builder-id":e.id,style:s.getStyle({block:e,context:t}),[s.getClassPropName()]:[e.id,"builder-block",e.class,(o=e.properties)==null?void 0:o.class].filter(Boolean).join(" ")};return u({properties:r,context:t,block:e})}exports.getBlockActions=l;exports.getBlockProperties=p;
1
+ "use strict";const s=require("./index-xXY_-KsW.cjs"),c=e=>`v-on:${e.toLowerCase()}`,i=(e,t)=>r=>s.evaluate({code:e,context:t.context,localState:t.localState,rootState:t.rootState,rootSetState:t.rootSetState,event:r,isExpression:!1});function l(e){const t={},r=e.block.actions??{};for(const o in r){if(!r.hasOwnProperty(o))continue;const a=r[o];let n=c(o);if(e.stripPrefix)switch(s.TARGET){case"vue":n=n.replace("v-on:","");break;case"svelte":n=n.replace("on:","");break}t[n]=i(a,e)}return t}function u({properties:e}){return e}const f=e=>({href:e.href});function p({block:e,context:t}){var o;const r={...f(e),...e.properties,"builder-id":e.id,style:s.getStyle({block:e,context:t}),[s.getClassPropName()]:[e.id,"builder-block",e.class,(o=e.properties)==null?void 0:o.class].filter(Boolean).join(" ")};return u({properties:r,context:t,block:e})}exports.getBlockActions=l;exports.getBlockProperties=p;