@builder.io/sdk-solid 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 (89) hide show
  1. package/README.md +3 -0
  2. package/package.json +9 -0
  3. package/src/blocks/button.js +41 -0
  4. package/src/blocks/button.lite.tsx +18 -0
  5. package/src/blocks/columns.js +133 -0
  6. package/src/blocks/columns.lite.tsx +96 -0
  7. package/src/blocks/custom-code.js +72 -0
  8. package/src/blocks/custom-code.lite.tsx +65 -0
  9. package/src/blocks/embed.js +62 -0
  10. package/src/blocks/embed.lite.tsx +57 -0
  11. package/src/blocks/form.js +355 -0
  12. package/src/blocks/form.lite.tsx +291 -0
  13. package/src/blocks/fragment.js +15 -0
  14. package/src/blocks/fragment.lite.tsx +3 -0
  15. package/src/blocks/image.js +136 -0
  16. package/src/blocks/image.lite.tsx +81 -0
  17. package/src/blocks/img.js +39 -0
  18. package/src/blocks/img.lite.tsx +16 -0
  19. package/src/blocks/input.js +45 -0
  20. package/src/blocks/input.lite.tsx +18 -0
  21. package/src/blocks/raw-text.js +25 -0
  22. package/src/blocks/raw-text.lite.tsx +8 -0
  23. package/src/blocks/section.js +24 -0
  24. package/src/blocks/section.lite.tsx +16 -0
  25. package/src/blocks/select.js +57 -0
  26. package/src/blocks/select.lite.tsx +23 -0
  27. package/src/blocks/submit-button.js +18 -0
  28. package/src/blocks/submit-button.lite.tsx +7 -0
  29. package/src/blocks/symbol.js +69 -0
  30. package/src/blocks/symbol.lite.tsx +37 -0
  31. package/src/blocks/text.js +15 -0
  32. package/src/blocks/text.lite.tsx +3 -0
  33. package/src/blocks/textarea.js +34 -0
  34. package/src/blocks/textarea.lite.tsx +11 -0
  35. package/src/blocks/video.js +54 -0
  36. package/src/blocks/video.lite.tsx +24 -0
  37. package/src/components/block-styles.js +3 -0
  38. package/src/components/block-styles.lite.tsx +3 -0
  39. package/src/components/error-boundary.js +3 -0
  40. package/src/components/error-boundary.lite.tsx +3 -0
  41. package/src/components/render-block.js +154 -0
  42. package/src/components/render-block.lite.tsx +108 -0
  43. package/src/components/render-blocks.js +104 -0
  44. package/src/components/render-blocks.lite.tsx +72 -0
  45. package/src/components/render-content.js +314 -0
  46. package/src/components/render-content.lite.tsx +289 -0
  47. package/src/constants/device-sizes.js +39 -0
  48. package/src/context/builder.context.js +10 -0
  49. package/src/functions/evaluate.js +28 -0
  50. package/src/functions/event-handler-name.js +7 -0
  51. package/src/functions/get-block-actions.js +23 -0
  52. package/src/functions/get-block-component-options.js +23 -0
  53. package/src/functions/get-block-properties.js +29 -0
  54. package/src/functions/get-block-styles.js +42 -0
  55. package/src/functions/get-block-tag.js +6 -0
  56. package/src/functions/get-builder-search-params/fn.test.js +13 -0
  57. package/src/functions/get-builder-search-params/index.js +22 -0
  58. package/src/functions/get-content/fn.test.js +31 -0
  59. package/src/functions/get-content/index.js +137 -0
  60. package/src/functions/get-fetch.js +12 -0
  61. package/src/functions/get-global-this.js +18 -0
  62. package/src/functions/get-processed-block.js +46 -0
  63. package/src/functions/get-processed-block.test.js +31 -0
  64. package/src/functions/get-target.js +6 -0
  65. package/src/functions/if-target.js +6 -0
  66. package/src/functions/is-browser.js +6 -0
  67. package/src/functions/is-editing.js +7 -0
  68. package/src/functions/is-iframe.js +7 -0
  69. package/src/functions/is-previewing.js +14 -0
  70. package/src/functions/is-react-native.js +6 -0
  71. package/src/functions/macro-eval.js +5 -0
  72. package/src/functions/on-change.js +27 -0
  73. package/src/functions/on-change.test.js +19 -0
  74. package/src/functions/previewing-model-name.js +11 -0
  75. package/src/functions/register-component.js +53 -0
  76. package/src/functions/register.js +29 -0
  77. package/src/functions/set-editor-settings.js +15 -0
  78. package/src/functions/set.js +11 -0
  79. package/src/functions/set.test.js +16 -0
  80. package/src/functions/track.js +22 -0
  81. package/src/functions/transform-block.js +6 -0
  82. package/src/index-helpers/blocks-exports.js +20 -0
  83. package/src/index-helpers/top-of-file.js +4 -0
  84. package/src/index.js +13 -0
  85. package/src/scripts/init-editing.js +70 -0
  86. package/src/types/builder-block.js +0 -0
  87. package/src/types/builder-content.js +0 -0
  88. package/src/types/deep-partial.js +0 -0
  89. package/src/types/typescript.js +0 -0
@@ -0,0 +1,23 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
4
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
+ var __spreadValues = (a, b) => {
7
+ for (var prop in b || (b = {}))
8
+ if (__hasOwnProp.call(b, prop))
9
+ __defNormalProp(a, prop, b[prop]);
10
+ if (__getOwnPropSymbols)
11
+ for (var prop of __getOwnPropSymbols(b)) {
12
+ if (__propIsEnum.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ }
15
+ return a;
16
+ };
17
+ function getBlockComponentOptions(block) {
18
+ var _a;
19
+ return __spreadValues(__spreadValues({}, (_a = block.component) == null ? void 0 : _a.options), block.options);
20
+ }
21
+ export {
22
+ getBlockComponentOptions
23
+ };
@@ -0,0 +1,29 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ function getBlockProperties(block) {
21
+ var _a;
22
+ return __spreadProps(__spreadValues({}, block.properties), {
23
+ "builder-id": block.id,
24
+ class: [block.id, "builder-block", block.class, (_a = block.properties) == null ? void 0 : _a.class].filter(Boolean).join(" ")
25
+ });
26
+ }
27
+ export {
28
+ getBlockProperties
29
+ };
@@ -0,0 +1,42 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
4
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
+ var __spreadValues = (a, b) => {
7
+ for (var prop in b || (b = {}))
8
+ if (__hasOwnProp.call(b, prop))
9
+ __defNormalProp(a, prop, b[prop]);
10
+ if (__getOwnPropSymbols)
11
+ for (var prop of __getOwnPropSymbols(b)) {
12
+ if (__propIsEnum.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ }
15
+ return a;
16
+ };
17
+ import { sizes } from "../constants/device-sizes";
18
+ const camelCaseToDashCase = (str = "") => str.replace(/[A-Z]/g, (match) => "-" + match.toLowerCase());
19
+ const convertStyleObject = (obj) => {
20
+ if (!obj) {
21
+ return obj;
22
+ }
23
+ const newObj = {};
24
+ for (const key in obj) {
25
+ newObj[camelCaseToDashCase(key)] = obj[key];
26
+ }
27
+ return newObj;
28
+ };
29
+ function getBlockStyles(block) {
30
+ var _a, _b, _c, _d, _e;
31
+ const styles = __spreadValues({}, convertStyleObject((_a = block.responsiveStyles) == null ? void 0 : _a.large));
32
+ if ((_b = block.responsiveStyles) == null ? void 0 : _b.medium) {
33
+ styles[`@media (max-width: ${sizes.medium})`] = convertStyleObject((_c = block.responsiveStyles) == null ? void 0 : _c.medium);
34
+ }
35
+ if ((_d = block.responsiveStyles) == null ? void 0 : _d.small) {
36
+ styles[`@media (max-width: ${sizes.small})`] = convertStyleObject((_e = block.responsiveStyles) == null ? void 0 : _e.small);
37
+ }
38
+ return styles;
39
+ }
40
+ export {
41
+ getBlockStyles
42
+ };
@@ -0,0 +1,6 @@
1
+ function getBlockTag(block) {
2
+ return block.tagName || "div";
3
+ }
4
+ export {
5
+ getBlockTag
6
+ };
@@ -0,0 +1,13 @@
1
+ import { getBuilderSearchParams, convertSearchParamsToQueryObject } from ".";
2
+ const querystring = "someotherValue=jklsjfdal&abc=klfdjklgfds&builder.cachebust=true&builder.preview=page&builder.noCache=true&__builder_editing__=true&builder.overrides.page=037948e52eaf4743afed464f02c70da4&builder.overrides.037948e52eaf4743afed464f02c70da4=037948e52eaf4743afed464f02c70da4&builder.overrides.page%3A%2F=037948e52eaf4743afed464f02c70da4&preview_theme_id=128854393017";
3
+ const url = new URL(`localhost:3000/about-us?${querystring}`);
4
+ describe("Get Builder SearchParams", () => {
5
+ test("correctly converts URLSearchParams to object", () => {
6
+ const output = convertSearchParamsToQueryObject(url.searchParams);
7
+ expect(output).toMatchSnapshot();
8
+ });
9
+ test("correctly extracts all builder params from a query object", () => {
10
+ const output = getBuilderSearchParams(convertSearchParamsToQueryObject(url.searchParams));
11
+ expect(output).toMatchSnapshot();
12
+ });
13
+ });
@@ -0,0 +1,22 @@
1
+ const BUILDER_SEARCHPARAMS_PREFIX = "builder.";
2
+ const convertSearchParamsToQueryObject = (searchParams) => {
3
+ const options = {};
4
+ searchParams.forEach((value, key) => {
5
+ options[key] = value;
6
+ });
7
+ return options;
8
+ };
9
+ const getBuilderSearchParams = (options) => {
10
+ const newOptions = {};
11
+ Object.keys(options).forEach((key) => {
12
+ if (key.startsWith(BUILDER_SEARCHPARAMS_PREFIX)) {
13
+ const trimmedKey = key.replace(BUILDER_SEARCHPARAMS_PREFIX, "");
14
+ newOptions[trimmedKey] = options[key];
15
+ }
16
+ });
17
+ return newOptions;
18
+ };
19
+ export {
20
+ convertSearchParamsToQueryObject,
21
+ getBuilderSearchParams
22
+ };
@@ -0,0 +1,31 @@
1
+ import { generateContentUrl } from ".";
2
+ const testKey = "YJIGb4i01jvw0SRdL5Bt";
3
+ const testModel = "page";
4
+ const testId = "c1b81bab59704599b997574eb0736def";
5
+ const options = {
6
+ cachebust: "true",
7
+ noCache: "true",
8
+ "overrides.037948e52eaf4743afed464f02c70da4": "037948e52eaf4743afed464f02c70da4",
9
+ "overrides.page": "037948e52eaf4743afed464f02c70da4",
10
+ "overrides.page:/": "037948e52eaf4743afed464f02c70da4",
11
+ preview: "page"
12
+ };
13
+ describe("Generate Content URL", () => {
14
+ test("generates the proper value for a simple query", () => {
15
+ const output = generateContentUrl({
16
+ apiKey: testKey,
17
+ model: testModel,
18
+ query: { id: testId }
19
+ });
20
+ expect(output).toMatchSnapshot();
21
+ });
22
+ test("Handles overrides correctly", () => {
23
+ const output = generateContentUrl({
24
+ apiKey: testKey,
25
+ model: testModel,
26
+ query: { id: testId },
27
+ options
28
+ });
29
+ expect(output).toMatchSnapshot();
30
+ });
31
+ });
@@ -0,0 +1,137 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __async = (__this, __arguments, generator) => {
21
+ return new Promise((resolve, reject) => {
22
+ var fulfilled = (value) => {
23
+ try {
24
+ step(generator.next(value));
25
+ } catch (e) {
26
+ reject(e);
27
+ }
28
+ };
29
+ var rejected = (value) => {
30
+ try {
31
+ step(generator.throw(value));
32
+ } catch (e) {
33
+ reject(e);
34
+ }
35
+ };
36
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
37
+ step((generator = generator.apply(__this, __arguments)).next());
38
+ });
39
+ };
40
+ import { getFetch } from "../get-fetch";
41
+ const fetch = getFetch();
42
+ function flatten(object, path = null, separator = ".") {
43
+ return Object.keys(object).reduce((acc, key) => {
44
+ const value = object[key];
45
+ const newPath = [path, key].filter(Boolean).join(separator);
46
+ const isObject = [
47
+ typeof value === "object",
48
+ value !== null,
49
+ !(Array.isArray(value) && value.length === 0)
50
+ ].every(Boolean);
51
+ return isObject ? __spreadValues(__spreadValues({}, acc), flatten(value, newPath, separator)) : __spreadProps(__spreadValues({}, acc), { [newPath]: value });
52
+ }, {});
53
+ }
54
+ function getContent(options) {
55
+ return __async(this, null, function* () {
56
+ return (yield getAllContent(__spreadProps(__spreadValues({}, options), { limit: 1 }))).results[0] || null;
57
+ });
58
+ }
59
+ const generateContentUrl = (options) => {
60
+ const {
61
+ limit = 1,
62
+ userAttributes,
63
+ query,
64
+ noTraverse = false,
65
+ model,
66
+ apiKey
67
+ } = options;
68
+ const url = new URL(`https://cdn.builder.io/api/v2/content/${model}?apiKey=${apiKey}&limit=${limit}&noTraverse=${noTraverse}`);
69
+ if (options.options) {
70
+ const flattened = flatten(options.options);
71
+ for (const key in flattened) {
72
+ url.searchParams.set(key, String(flattened[key]));
73
+ }
74
+ }
75
+ if (userAttributes) {
76
+ url.searchParams.set("userAttributes", JSON.stringify(userAttributes));
77
+ }
78
+ if (query) {
79
+ const flattened = flatten({ query });
80
+ for (const key in flattened) {
81
+ url.searchParams.set(key, JSON.stringify(flattened[key]));
82
+ }
83
+ }
84
+ return url;
85
+ };
86
+ const handleABTesting = (content, testGroups) => {
87
+ for (const item of content.results) {
88
+ if (item.variations && Object.keys(item.variations).length) {
89
+ const testGroup = testGroups[item.id];
90
+ const variationValue = item.variations[testGroup];
91
+ if (testGroup && variationValue) {
92
+ item.data = variationValue.data;
93
+ item.testVariationId = variationValue.id;
94
+ item.testVariationName = variationValue.name;
95
+ } else {
96
+ let n = 0;
97
+ const random = Math.random();
98
+ let set = false;
99
+ for (const id in item.variations) {
100
+ const variation = item.variations[id];
101
+ const testRatio = variation.testRatio;
102
+ n += testRatio;
103
+ if (random < n) {
104
+ const variationName = variation.name || (variation.id === item.id ? "Default variation" : "");
105
+ set = true;
106
+ Object.assign(item, {
107
+ data: variation.data,
108
+ testVariationId: variation.id,
109
+ testVariationName: variationName
110
+ });
111
+ }
112
+ }
113
+ if (!set) {
114
+ Object.assign(item, {
115
+ testVariationId: item.id,
116
+ testVariationName: "Default"
117
+ });
118
+ }
119
+ }
120
+ }
121
+ }
122
+ };
123
+ function getAllContent(options) {
124
+ return __async(this, null, function* () {
125
+ const url = generateContentUrl(options);
126
+ const content = yield fetch(url.href).then((res) => res.json());
127
+ if (options.testGroups) {
128
+ handleABTesting(content, options.testGroups);
129
+ }
130
+ return content;
131
+ });
132
+ }
133
+ export {
134
+ generateContentUrl,
135
+ getAllContent,
136
+ getContent
137
+ };
@@ -0,0 +1,12 @@
1
+ import { getGlobalThis } from "./get-global-this";
2
+ function getFetch() {
3
+ let fetch = getGlobalThis().fetch;
4
+ if (typeof fetch === "undefined" && typeof global !== "undefined") {
5
+ const _require = eval("require");
6
+ fetch = _require("node-fetch");
7
+ }
8
+ return fetch;
9
+ }
10
+ export {
11
+ getFetch
12
+ };
@@ -0,0 +1,18 @@
1
+ function getGlobalThis() {
2
+ if (typeof globalThis !== "undefined") {
3
+ return globalThis;
4
+ }
5
+ if (typeof window !== "undefined") {
6
+ return window;
7
+ }
8
+ if (typeof global !== "undefined") {
9
+ return global;
10
+ }
11
+ if (typeof self !== "undefined") {
12
+ return self;
13
+ }
14
+ return null;
15
+ }
16
+ export {
17
+ getGlobalThis
18
+ };
@@ -0,0 +1,46 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { evaluate } from "./evaluate";
21
+ import { set } from "./set";
22
+ import { transformBlock } from "./transform-block";
23
+ function getProcessedBlock(options) {
24
+ const { state, context } = options;
25
+ const block = transformBlock(options.block);
26
+ if (!block.bindings) {
27
+ return block;
28
+ }
29
+ const copied = __spreadProps(__spreadValues({}, block), {
30
+ properties: __spreadValues({}, block.properties),
31
+ actions: __spreadValues({}, block.actions)
32
+ });
33
+ for (const binding in block.bindings) {
34
+ const expression = block.bindings[binding];
35
+ const value = evaluate({
36
+ code: expression,
37
+ state,
38
+ context
39
+ });
40
+ set(copied, binding, value);
41
+ }
42
+ return copied;
43
+ }
44
+ export {
45
+ getProcessedBlock
46
+ };
@@ -0,0 +1,31 @@
1
+ import { getProcessedBlock } from "./get-processed-block";
2
+ test("Can process bindings", () => {
3
+ var _a, _b, _c, _d, _e, _f;
4
+ const block = {
5
+ "@type": "@builder.io/sdk:Element",
6
+ properties: {
7
+ foo: "bar"
8
+ },
9
+ bindings: {
10
+ "properties.foo": '"baz"',
11
+ "responsiveStyles.large.zIndex": "1 + 1",
12
+ "properties.test": "state.test",
13
+ "properties.block": `
14
+ const foo = 'bar';
15
+ return foo;
16
+ `,
17
+ "properties.isEditing": "builder.isEditing"
18
+ }
19
+ };
20
+ const processed = getProcessedBlock({
21
+ block,
22
+ context: {},
23
+ state: { test: "hello" }
24
+ });
25
+ expect(processed).not.toEqual(block);
26
+ expect((_a = processed.properties) == null ? void 0 : _a.foo).toEqual("baz");
27
+ expect((_b = processed.properties) == null ? void 0 : _b.test).toEqual("hello");
28
+ expect((_c = processed.properties) == null ? void 0 : _c.block).toEqual("bar");
29
+ expect((_d = processed.properties) == null ? void 0 : _d.isEditing).toEqual(false);
30
+ expect((_f = (_e = processed.responsiveStyles) == null ? void 0 : _e.large) == null ? void 0 : _f.zIndex).toEqual(2);
31
+ });
@@ -0,0 +1,6 @@
1
+ function getTarget(_) {
2
+ return "reactNative";
3
+ }
4
+ export {
5
+ getTarget
6
+ };
@@ -0,0 +1,6 @@
1
+ function ifTarget(target, doThing, elseThing) {
2
+ return doThing();
3
+ }
4
+ export {
5
+ ifTarget
6
+ };
@@ -0,0 +1,6 @@
1
+ function isBrowser() {
2
+ return typeof window !== "undefined" && typeof document !== "undefined";
3
+ }
4
+ export {
5
+ isBrowser
6
+ };
@@ -0,0 +1,7 @@
1
+ import { isIframe } from "./is-iframe";
2
+ function isEditing() {
3
+ return isIframe() && window.location.search.indexOf("builder.frameEditing=") !== -1;
4
+ }
5
+ export {
6
+ isEditing
7
+ };
@@ -0,0 +1,7 @@
1
+ import { isBrowser } from "./is-browser";
2
+ function isIframe() {
3
+ return isBrowser() && window.self !== window.top;
4
+ }
5
+ export {
6
+ isIframe
7
+ };
@@ -0,0 +1,14 @@
1
+ import { isBrowser } from "./is-browser";
2
+ import { isEditing } from "./is-editing";
3
+ function isPreviewing() {
4
+ if (!isBrowser()) {
5
+ return false;
6
+ }
7
+ if (isEditing()) {
8
+ return false;
9
+ }
10
+ return Boolean(location.search.indexOf("builder.preview=") !== -1);
11
+ }
12
+ export {
13
+ isPreviewing
14
+ };
@@ -0,0 +1,6 @@
1
+ function isReactNative() {
2
+ return false;
3
+ }
4
+ export {
5
+ isReactNative
6
+ };
@@ -0,0 +1,5 @@
1
+ function macroEval(items, string) {
2
+ }
3
+ export {
4
+ macroEval
5
+ };
@@ -0,0 +1,27 @@
1
+ const onChangeProxySymbol = Symbol("onChangeProxySymbol");
2
+ function onChange(obj, cb) {
3
+ return new Proxy(obj, {
4
+ get(target, key) {
5
+ if (key === onChangeProxySymbol) {
6
+ return true;
7
+ }
8
+ const value = Reflect.get(target, key);
9
+ if (value && typeof value === "object") {
10
+ if (value[onChangeProxySymbol]) {
11
+ return value;
12
+ }
13
+ return onChange(value, cb);
14
+ }
15
+ return value;
16
+ },
17
+ set(target, key, value) {
18
+ const returnValue = Reflect.set(target, key, value);
19
+ cb();
20
+ return returnValue;
21
+ }
22
+ });
23
+ }
24
+ export {
25
+ onChange,
26
+ onChangeProxySymbol
27
+ };
@@ -0,0 +1,19 @@
1
+ import { onChange } from "./on-change";
2
+ test("onChange can observe a shallow change", () => {
3
+ let changeHappend = false;
4
+ const obj = onChange({ foo: "hi" }, () => changeHappend = true);
5
+ obj.foo = "yo";
6
+ expect(changeHappend).toBe(true);
7
+ });
8
+ test("onChange can observe a deep change", () => {
9
+ let changeHappend = false;
10
+ const obj = onChange({ foo: { bar: "hi" } }, () => changeHappend = true);
11
+ obj.foo.bar = "yo";
12
+ expect(changeHappend).toBe(true);
13
+ });
14
+ test("Smoke test: callback is not fired if no properties updated", () => {
15
+ let changeHappend = false;
16
+ const obj = onChange({ foo: { bar: "hi" } }, () => changeHappend = true);
17
+ obj.foo.bar;
18
+ expect(changeHappend).toBe(false);
19
+ });
@@ -0,0 +1,11 @@
1
+ import { isPreviewing } from "./is-previewing";
2
+ function previewingModelName() {
3
+ if (!isPreviewing()) {
4
+ return null;
5
+ }
6
+ const url = new URL(location.href);
7
+ return url.searchParams.get("builder.preview");
8
+ }
9
+ export {
10
+ previewingModelName
11
+ };
@@ -0,0 +1,53 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { isBrowser } from "./is-browser";
21
+ const components = {};
22
+ function registerComponent(component, info) {
23
+ var _a;
24
+ components[info.name] = { component, info };
25
+ if (isBrowser()) {
26
+ const sendInfo = prepareComponentInfoToSend(info);
27
+ (_a = window.parent) == null ? void 0 : _a.postMessage({
28
+ type: "builder.registerComponent",
29
+ data: sendInfo
30
+ }, "*");
31
+ }
32
+ return component;
33
+ }
34
+ function prepareComponentInfoToSend(info) {
35
+ return __spreadValues(__spreadValues({}, info), info.inputs && {
36
+ inputs: info.inputs.map((input) => {
37
+ const keysToConvertFnToString = ["onChange", "showIf"];
38
+ for (const key of keysToConvertFnToString) {
39
+ if (input[key] && typeof input[key] === "function") {
40
+ const fn = input[key];
41
+ input = __spreadProps(__spreadValues({}, input), {
42
+ [key]: `return (${fn.toString()}).apply(this, arguments)`
43
+ });
44
+ }
45
+ }
46
+ return input;
47
+ })
48
+ });
49
+ }
50
+ export {
51
+ components,
52
+ registerComponent
53
+ };
@@ -0,0 +1,29 @@
1
+ import { isBrowser } from "./is-browser";
2
+ const registry = {};
3
+ function register(type, info) {
4
+ let typeList = registry[type];
5
+ if (!typeList) {
6
+ typeList = registry[type] = [];
7
+ }
8
+ typeList.push(info);
9
+ if (isBrowser()) {
10
+ const message = {
11
+ type: "builder.register",
12
+ data: {
13
+ type,
14
+ info
15
+ }
16
+ };
17
+ try {
18
+ parent.postMessage(message, "*");
19
+ if (parent !== window) {
20
+ window.postMessage(message, "*");
21
+ }
22
+ } catch (err) {
23
+ console.debug("Could not postmessage", err);
24
+ }
25
+ }
26
+ }
27
+ export {
28
+ register
29
+ };
@@ -0,0 +1,15 @@
1
+ import { isBrowser } from "./is-browser";
2
+ const settings = {};
3
+ function setEditorSettings(newSettings) {
4
+ if (isBrowser()) {
5
+ Object.assign(settings, newSettings);
6
+ const message = {
7
+ type: "builder.settingsChange",
8
+ data: settings
9
+ };
10
+ parent.postMessage(message, "*");
11
+ }
12
+ }
13
+ export {
14
+ setEditorSettings
15
+ };
@@ -0,0 +1,11 @@
1
+ const set = (obj, _path, value) => {
2
+ if (Object(obj) !== obj) {
3
+ return obj;
4
+ }
5
+ const path = Array.isArray(_path) ? _path : _path.toString().match(/[^.[\]]+/g);
6
+ path.slice(0, -1).reduce((a, c, i) => Object(a[c]) === a[c] ? a[c] : a[c] = Math.abs(Number(path[i + 1])) >> 0 === +path[i + 1] ? [] : {}, obj)[path[path.length - 1]] = value;
7
+ return obj;
8
+ };
9
+ export {
10
+ set
11
+ };