@builder.io/sdk-solid 0.4.5 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4 -0
- package/package.json +1 -1
- package/src/blocks/BaseText.jsx +1 -1
- package/src/blocks/button/button.jsx +5 -3
- package/src/blocks/button/component-info.js +16 -22
- package/src/blocks/columns/columns.jsx +12 -21
- package/src/blocks/columns/component-info.js +203 -226
- package/src/blocks/custom-code/component-info.js +19 -25
- package/src/blocks/embed/component-info.js +31 -37
- package/src/blocks/embed/helpers.js +3 -9
- package/src/blocks/form/component-info.js +174 -212
- package/src/blocks/form/form.jsx +1 -268
- package/src/blocks/fragment/component-info.js +1 -3
- package/src/blocks/helpers.js +27 -0
- package/src/blocks/image/component-info.js +105 -133
- package/src/blocks/image/image.helpers.js +3 -5
- package/src/blocks/img/component-info.js +8 -12
- package/src/blocks/img/img.jsx +2 -0
- package/src/blocks/input/component-info.js +29 -57
- package/src/blocks/input/input.jsx +2 -0
- package/src/blocks/raw-text/component-info.js +7 -11
- package/src/blocks/raw-text/raw-text.jsx +2 -2
- package/src/blocks/section/component-info.js +24 -31
- package/src/blocks/section/section.jsx +3 -0
- package/src/blocks/select/component-info.js +34 -48
- package/src/blocks/select/select.jsx +2 -0
- package/src/blocks/submit-button/component-info.js +6 -10
- package/src/blocks/submit-button/submit-button.jsx +3 -1
- package/src/blocks/symbol/component-info.js +30 -37
- package/src/blocks/symbol/symbol.helpers.js +60 -0
- package/src/blocks/symbol/symbol.jsx +31 -68
- package/src/blocks/text/component-info.js +10 -13
- package/src/blocks/text/text.jsx +1 -1
- package/src/blocks/textarea/component-info.js +22 -30
- package/src/blocks/textarea/textarea.jsx +3 -0
- package/src/blocks/video/component-info.js +74 -96
- package/src/blocks/video/video.jsx +1 -0
- package/src/components/{render-block/render-block.helpers.js → block/block.helpers.js} +26 -44
- package/src/components/{render-block/render-block.jsx → block/block.jsx} +65 -80
- package/src/components/{render-block → block/components}/block-styles.jsx +16 -16
- package/src/components/block/components/block-wrapper.jsx +50 -0
- package/src/components/block/components/component-ref/component-ref.helpers.js +41 -0
- package/src/components/block/components/component-ref/component-ref.jsx +58 -0
- package/src/components/block/components/interactive-element.jsx +30 -0
- package/src/components/block/components/repeated-block.jsx +20 -0
- package/src/components/blocks/blocks-wrapper.jsx +66 -0
- package/src/components/blocks/blocks.jsx +48 -0
- package/src/components/{render-content/render-content.jsx → content/components/enable-editor.jsx} +86 -175
- package/src/components/{render-content/components/render-styles.helpers.js → content/components/styles.helpers.js} +6 -7
- package/src/components/{render-content/components/render-styles.jsx → content/components/styles.jsx} +4 -4
- package/src/components/{render-content/render-content.helpers.js → content/content.helpers.js} +15 -15
- package/src/components/content/content.jsx +129 -0
- package/src/components/content/index.js +2 -0
- package/src/components/content/wrap-component-ref.js +2 -0
- package/src/components/{render-content-variants/render-content-variants.jsx → content-variants/content-variants.jsx} +19 -22
- package/src/components/{render-content-variants → content-variants}/helpers.js +28 -40
- package/src/constants/builder-registered-components.js +34 -25
- package/src/constants/device-sizes.js +6 -6
- package/src/constants/sdk-version.js +1 -1
- package/src/context/builder.context.js +1 -1
- package/src/functions/apply-patch-with-mutation.js +66 -0
- package/src/functions/camel-to-kebab-case.js +2 -4
- package/src/functions/evaluate/acorn.js +1595 -0
- package/src/functions/{evaluate.js → evaluate/evaluate.js} +36 -10
- package/src/functions/evaluate/index.js +2 -0
- package/src/functions/evaluate/interpreter.js +2801 -0
- package/src/functions/evaluate/non-node-runtime.js +92 -0
- package/src/functions/evaluate/types.js +0 -0
- package/src/functions/event-handler-name.js +2 -4
- package/src/functions/extract-text-styles.js +4 -12
- package/src/functions/fast-clone.js +2 -4
- package/src/functions/get-block-actions-handler.js +3 -5
- package/src/functions/get-block-actions.js +15 -4
- package/src/functions/get-block-component-options.js +11 -12
- package/src/functions/get-block-properties.js +29 -19
- package/src/functions/get-builder-search-params/index.js +5 -10
- package/src/functions/get-content/generate-content-url.js +17 -19
- package/src/functions/get-content/index.js +43 -29
- package/src/functions/get-fetch.js +1 -3
- package/src/functions/get-global-this.js +1 -3
- package/src/functions/get-processed-block.js +12 -13
- package/src/functions/get-react-native-block-styles.js +11 -12
- package/src/functions/if-target.js +1 -3
- package/src/functions/is-browser.js +1 -3
- package/src/functions/is-editing.js +1 -3
- package/src/functions/is-iframe.js +1 -3
- package/src/functions/is-non-node-server.js +9 -0
- package/src/functions/is-previewing.js +1 -3
- package/src/functions/on-change.js +1 -4
- package/src/functions/register-component.js +34 -42
- package/src/functions/register.js +1 -3
- package/src/functions/sanitize-react-native-block-styles.js +22 -17
- package/src/functions/set-editor-settings.js +1 -3
- package/src/functions/set.js +1 -3
- package/src/functions/track/helpers.js +3 -5
- package/src/functions/track/index.js +45 -43
- package/src/functions/track/interaction.js +11 -7
- package/src/functions/transform-block-properties.js +1 -3
- package/src/functions/transform-block.js +1 -3
- package/src/helpers/ab-tests.js +45 -28
- package/src/helpers/canTrack.js +3 -5
- package/src/helpers/cookie.js +15 -24
- package/src/helpers/css.js +3 -7
- package/src/helpers/flatten.js +15 -18
- package/src/helpers/localStorage.js +1 -4
- package/src/helpers/logger.js +1 -3
- package/src/helpers/nullable.js +2 -4
- package/src/helpers/preview-lru-cache/get.js +8 -0
- package/src/helpers/preview-lru-cache/helpers.js +10 -0
- package/src/helpers/preview-lru-cache/init.js +10 -0
- package/src/helpers/preview-lru-cache/set.js +35 -0
- package/src/helpers/preview-lru-cache/types.js +0 -0
- package/src/helpers/sessionId.js +14 -11
- package/src/helpers/time.js +1 -3
- package/src/helpers/url.js +2 -4
- package/src/helpers/uuid.js +4 -6
- package/src/helpers/visitorId.js +8 -7
- package/src/index-helpers/blocks-exports.js +3 -14
- package/src/index-helpers/top-of-file.js +1 -3
- package/src/index.js +2 -17
- package/src/scripts/init-editing.js +62 -48
- package/src/types/api-version.js +1 -3
- package/src/types/builder-props.js +0 -0
- package/src/blocks/util.js +0 -8
- package/src/components/render-block/render-component.jsx +0 -40
- package/src/components/render-block/render-repeated-block.jsx +0 -16
- package/src/components/render-blocks.jsx +0 -100
- package/src/components/render-content/builder-editing.jsx +0 -5
- package/src/components/render-content/index.js +0 -4
- package/src/components/render-content/wrap-component-ref.js +0 -4
- package/src/functions/evaluate.test.js +0 -17
- package/src/functions/get-builder-search-params/fn.test.js +0 -13
- package/src/functions/get-content/generate-content-url.test.js +0 -97
- package/src/functions/get-processed-block.test.js +0 -34
- package/src/functions/on-change.test.js +0 -19
- package/src/functions/set.test.js +0 -16
- package/src/helpers/url.test.js +0 -21
- /package/src/components/{render-block → block}/types.js +0 -0
- /package/src/components/{render-content/render-content.types.js → content/content.types.js} +0 -0
- /package/src/components/{render-content-variants/render-content-variants.types.js → content-variants/content-variants.types.js} +0 -0
package/src/helpers/cookie.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
var __async = (__this, __arguments, generator) => {
|
|
2
2
|
return new Promise((resolve, reject) => {
|
|
3
|
-
var fulfilled =
|
|
3
|
+
var fulfilled = value => {
|
|
4
4
|
try {
|
|
5
5
|
step(generator.next(value));
|
|
6
6
|
} catch (e) {
|
|
7
7
|
reject(e);
|
|
8
8
|
}
|
|
9
9
|
};
|
|
10
|
-
var rejected =
|
|
10
|
+
var rejected = value => {
|
|
11
11
|
try {
|
|
12
12
|
step(generator.throw(value));
|
|
13
13
|
} catch (e) {
|
|
14
14
|
reject(e);
|
|
15
15
|
}
|
|
16
16
|
};
|
|
17
|
-
var step =
|
|
17
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
18
18
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
19
19
|
});
|
|
20
20
|
};
|
|
@@ -31,20 +31,17 @@ const getCookieSync = ({
|
|
|
31
31
|
if (!canTrack) {
|
|
32
32
|
return void 0;
|
|
33
33
|
}
|
|
34
|
-
return (_a = document.cookie.split("; ").find(
|
|
34
|
+
return (_a = document.cookie.split("; ").find(row => row.startsWith(`${name}=`))) == null ? void 0 : _a.split("=")[1];
|
|
35
35
|
} catch (err) {
|
|
36
36
|
logger.warn("[COOKIE] GET error: ", (err == null ? void 0 : err.message) || err);
|
|
37
37
|
return void 0;
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
|
-
const getCookie =
|
|
40
|
+
const getCookie = args => __async(void 0, null, function* () {
|
|
41
41
|
return getCookieSync(args);
|
|
42
42
|
});
|
|
43
|
-
const stringifyCookie =
|
|
44
|
-
const SECURE_CONFIG = [
|
|
45
|
-
["secure", ""],
|
|
46
|
-
["SameSite", "None"]
|
|
47
|
-
];
|
|
43
|
+
const stringifyCookie = cookie => cookie.map(([key, value]) => value ? `${key}=${value}` : key).filter(checkIsDefined).join("; ");
|
|
44
|
+
const SECURE_CONFIG = [["secure", ""], ["SameSite", "None"]];
|
|
48
45
|
const createCookieString = ({
|
|
49
46
|
name,
|
|
50
47
|
value,
|
|
@@ -53,17 +50,11 @@ const createCookieString = ({
|
|
|
53
50
|
const secure = isBrowser() ? location.protocol === "https:" : true;
|
|
54
51
|
const secureObj = secure ? SECURE_CONFIG : [[]];
|
|
55
52
|
const expiresObj = expires ? [["expires", expires.toUTCString()]] : [[]];
|
|
56
|
-
const cookieValue = [
|
|
57
|
-
[name, value],
|
|
58
|
-
...expiresObj,
|
|
59
|
-
["path", "/"],
|
|
60
|
-
["domain", getTopLevelDomain(window.location.hostname)],
|
|
61
|
-
...secureObj
|
|
62
|
-
];
|
|
53
|
+
const cookieValue = [[name, value], ...expiresObj, ["path", "/"], ["domain", getTopLevelDomain(window.location.hostname)], ...secureObj];
|
|
63
54
|
const cookie = stringifyCookie(cookieValue);
|
|
64
55
|
return cookie;
|
|
65
56
|
};
|
|
66
|
-
const setCookie =
|
|
57
|
+
const setCookie = _0 => __async(void 0, [_0], function* ({
|
|
67
58
|
name,
|
|
68
59
|
value,
|
|
69
60
|
expires,
|
|
@@ -73,14 +64,14 @@ const setCookie = (_0) => __async(void 0, [_0], function* ({
|
|
|
73
64
|
if (!canTrack) {
|
|
74
65
|
return;
|
|
75
66
|
}
|
|
76
|
-
const cookie = createCookieString({
|
|
67
|
+
const cookie = createCookieString({
|
|
68
|
+
name,
|
|
69
|
+
value,
|
|
70
|
+
expires
|
|
71
|
+
});
|
|
77
72
|
document.cookie = cookie;
|
|
78
73
|
} catch (err) {
|
|
79
74
|
logger.warn("[COOKIE] SET error: ", (err == null ? void 0 : err.message) || err);
|
|
80
75
|
}
|
|
81
76
|
});
|
|
82
|
-
export {
|
|
83
|
-
getCookie,
|
|
84
|
-
getCookieSync,
|
|
85
|
-
setCookie
|
|
86
|
-
};
|
|
77
|
+
export { getCookie, getCookieSync, setCookie }
|
package/src/helpers/css.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { camelToKebabCase } from "../functions/camel-to-kebab-case.js";
|
|
2
2
|
import { checkIsDefined } from "./nullable.js";
|
|
3
|
-
const convertStyleMapToCSSArray =
|
|
3
|
+
const convertStyleMapToCSSArray = style => {
|
|
4
4
|
const cssProps = Object.entries(style).map(([key, value]) => {
|
|
5
5
|
if (typeof value === "string") {
|
|
6
6
|
return `${camelToKebabCase(key)}: ${value};`;
|
|
@@ -10,7 +10,7 @@ const convertStyleMapToCSSArray = (style) => {
|
|
|
10
10
|
});
|
|
11
11
|
return cssProps.filter(checkIsDefined);
|
|
12
12
|
};
|
|
13
|
-
const convertStyleMapToCSS =
|
|
13
|
+
const convertStyleMapToCSS = style => convertStyleMapToCSSArray(style).join("\n");
|
|
14
14
|
const createCssClass = ({
|
|
15
15
|
mediaQuery,
|
|
16
16
|
className,
|
|
@@ -27,8 +27,4 @@ const createCssClass = ({
|
|
|
27
27
|
return cssClass;
|
|
28
28
|
}
|
|
29
29
|
};
|
|
30
|
-
export {
|
|
31
|
-
convertStyleMapToCSS,
|
|
32
|
-
convertStyleMapToCSSArray,
|
|
33
|
-
createCssClass
|
|
34
|
-
};
|
|
30
|
+
export { convertStyleMapToCSS, convertStyleMapToCSSArray, createCssClass }
|
package/src/helpers/flatten.js
CHANGED
|
@@ -4,16 +4,17 @@ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
|
4
4
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
6
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
configurable: true,
|
|
10
|
+
writable: true,
|
|
11
|
+
value
|
|
12
|
+
}) : obj[key] = value;
|
|
8
13
|
var __spreadValues = (a, b) => {
|
|
9
|
-
for (var prop in b || (b = {}))
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
-
if (__propIsEnum.call(b, prop))
|
|
15
|
-
__defNormalProp(a, prop, b[prop]);
|
|
16
|
-
}
|
|
14
|
+
for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]);
|
|
15
|
+
if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) {
|
|
16
|
+
if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]);
|
|
17
|
+
}
|
|
17
18
|
return a;
|
|
18
19
|
};
|
|
19
20
|
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
@@ -21,14 +22,10 @@ function flatten(object, path = null, separator = ".") {
|
|
|
21
22
|
return Object.keys(object).reduce((acc, key) => {
|
|
22
23
|
const value = object[key];
|
|
23
24
|
const newPath = [path, key].filter(Boolean).join(separator);
|
|
24
|
-
const isObject = [
|
|
25
|
-
|
|
26
|
-
value
|
|
27
|
-
|
|
28
|
-
].every(Boolean);
|
|
29
|
-
return isObject ? __spreadValues(__spreadValues({}, acc), flatten(value, newPath, separator)) : __spreadProps(__spreadValues({}, acc), { [newPath]: value });
|
|
25
|
+
const isObject = [typeof value === "object", value !== null, !(Array.isArray(value) && value.length === 0)].every(Boolean);
|
|
26
|
+
return isObject ? __spreadValues(__spreadValues({}, acc), flatten(value, newPath, separator)) : __spreadProps(__spreadValues({}, acc), {
|
|
27
|
+
[newPath]: value
|
|
28
|
+
});
|
|
30
29
|
}, {});
|
|
31
30
|
}
|
|
32
|
-
export {
|
|
33
|
-
flatten
|
|
34
|
-
};
|
|
31
|
+
export { flatten }
|
package/src/helpers/logger.js
CHANGED
package/src/helpers/nullable.js
CHANGED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { getIdFromSearchParams } from "./helpers";
|
|
2
|
+
import { init } from "./init";
|
|
3
|
+
function getPreviewContent(searchParams) {
|
|
4
|
+
init();
|
|
5
|
+
const id = getIdFromSearchParams(searchParams);
|
|
6
|
+
return typeof id === "string" ? globalThis._BUILDER_PREVIEW_LRU_CACHE.get(id) : void 0;
|
|
7
|
+
}
|
|
8
|
+
export { getPreviewContent }
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { logger } from "../logger";
|
|
2
|
+
const getIdFromSearchParams = searchParams => {
|
|
3
|
+
const previewedModel = searchParams.get("preview");
|
|
4
|
+
const previewedId = searchParams.get("overrides." + previewedModel);
|
|
5
|
+
if (!previewedId) {
|
|
6
|
+
logger.warn("No previewed ID found in search params.");
|
|
7
|
+
}
|
|
8
|
+
return previewedId;
|
|
9
|
+
};
|
|
10
|
+
export { getIdFromSearchParams }
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
var __async = (__this, __arguments, generator) => {
|
|
2
|
+
return new Promise((resolve, reject) => {
|
|
3
|
+
var fulfilled = value => {
|
|
4
|
+
try {
|
|
5
|
+
step(generator.next(value));
|
|
6
|
+
} catch (e) {
|
|
7
|
+
reject(e);
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
var rejected = value => {
|
|
11
|
+
try {
|
|
12
|
+
step(generator.throw(value));
|
|
13
|
+
} catch (e) {
|
|
14
|
+
reject(e);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
18
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
"use server";
|
|
22
|
+
import { init } from "./init";
|
|
23
|
+
function postPreviewContent(_0) {
|
|
24
|
+
return __async(this, arguments, function* ({
|
|
25
|
+
key,
|
|
26
|
+
value
|
|
27
|
+
}) {
|
|
28
|
+
init();
|
|
29
|
+
globalThis._BUILDER_PREVIEW_LRU_CACHE.set(key, value);
|
|
30
|
+
return {
|
|
31
|
+
[key]: value
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
export { postPreviewContent }
|
|
File without changes
|
package/src/helpers/sessionId.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
var __async = (__this, __arguments, generator) => {
|
|
2
2
|
return new Promise((resolve, reject) => {
|
|
3
|
-
var fulfilled =
|
|
3
|
+
var fulfilled = value => {
|
|
4
4
|
try {
|
|
5
5
|
step(generator.next(value));
|
|
6
6
|
} catch (e) {
|
|
7
7
|
reject(e);
|
|
8
8
|
}
|
|
9
9
|
};
|
|
10
|
-
var rejected =
|
|
10
|
+
var rejected = value => {
|
|
11
11
|
try {
|
|
12
12
|
step(generator.throw(value));
|
|
13
13
|
} catch (e) {
|
|
14
14
|
reject(e);
|
|
15
15
|
}
|
|
16
16
|
};
|
|
17
|
-
var step =
|
|
17
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
18
18
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
19
19
|
});
|
|
20
20
|
};
|
|
@@ -22,7 +22,7 @@ import { getCookie, setCookie } from "./cookie.js";
|
|
|
22
22
|
import { checkIsDefined } from "./nullable.js";
|
|
23
23
|
import { uuid } from "./uuid.js";
|
|
24
24
|
const SESSION_LOCAL_STORAGE_KEY = "builderSessionId";
|
|
25
|
-
const getSessionId =
|
|
25
|
+
const getSessionId = _0 => __async(void 0, [_0], function* ({
|
|
26
26
|
canTrack
|
|
27
27
|
}) {
|
|
28
28
|
if (!canTrack) {
|
|
@@ -36,7 +36,10 @@ const getSessionId = (_0) => __async(void 0, [_0], function* ({
|
|
|
36
36
|
return sessionId;
|
|
37
37
|
} else {
|
|
38
38
|
const newSessionId = createSessionId();
|
|
39
|
-
setSessionId({
|
|
39
|
+
setSessionId({
|
|
40
|
+
id: newSessionId,
|
|
41
|
+
canTrack
|
|
42
|
+
});
|
|
40
43
|
return newSessionId;
|
|
41
44
|
}
|
|
42
45
|
});
|
|
@@ -44,9 +47,9 @@ const createSessionId = () => uuid();
|
|
|
44
47
|
const setSessionId = ({
|
|
45
48
|
id,
|
|
46
49
|
canTrack
|
|
47
|
-
}) => setCookie({
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
50
|
+
}) => setCookie({
|
|
51
|
+
name: SESSION_LOCAL_STORAGE_KEY,
|
|
52
|
+
value: id,
|
|
53
|
+
canTrack
|
|
54
|
+
});
|
|
55
|
+
export { createSessionId, getSessionId, setSessionId }
|
package/src/helpers/time.js
CHANGED
package/src/helpers/url.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const getTopLevelDomain =
|
|
1
|
+
const getTopLevelDomain = host => {
|
|
2
2
|
if (host === "localhost" || host === "127.0.0.1") {
|
|
3
3
|
return host;
|
|
4
4
|
}
|
|
@@ -8,6 +8,4 @@ const getTopLevelDomain = (host) => {
|
|
|
8
8
|
}
|
|
9
9
|
return host;
|
|
10
10
|
};
|
|
11
|
-
export {
|
|
12
|
-
getTopLevelDomain
|
|
13
|
-
};
|
|
11
|
+
export { getTopLevelDomain }
|
package/src/helpers/uuid.js
CHANGED
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
function uuidv4() {
|
|
2
|
-
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
|
|
3
|
-
const r = Math.random() * 16 | 0,
|
|
2
|
+
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) {
|
|
3
|
+
const r = Math.random() * 16 | 0,
|
|
4
|
+
v = c == "x" ? r : r & 3 | 8;
|
|
4
5
|
return v.toString(16);
|
|
5
6
|
});
|
|
6
7
|
}
|
|
7
8
|
function uuid() {
|
|
8
9
|
return uuidv4().replace(/-/g, "");
|
|
9
10
|
}
|
|
10
|
-
export {
|
|
11
|
-
uuid,
|
|
12
|
-
uuidv4
|
|
13
|
-
};
|
|
11
|
+
export { uuid, uuidv4 }
|
package/src/helpers/visitorId.js
CHANGED
|
@@ -2,7 +2,9 @@ import { getLocalStorageItem, setLocalStorageItem } from "./localStorage.js";
|
|
|
2
2
|
import { checkIsDefined } from "./nullable.js";
|
|
3
3
|
import { uuid } from "./uuid.js";
|
|
4
4
|
const VISITOR_LOCAL_STORAGE_KEY = "builderVisitorId";
|
|
5
|
-
const getVisitorId = ({
|
|
5
|
+
const getVisitorId = ({
|
|
6
|
+
canTrack
|
|
7
|
+
}) => {
|
|
6
8
|
if (!canTrack) {
|
|
7
9
|
return void 0;
|
|
8
10
|
}
|
|
@@ -14,7 +16,10 @@ const getVisitorId = ({ canTrack }) => {
|
|
|
14
16
|
return visitorId;
|
|
15
17
|
} else {
|
|
16
18
|
const newVisitorId = createVisitorId();
|
|
17
|
-
setVisitorId({
|
|
19
|
+
setVisitorId({
|
|
20
|
+
id: newVisitorId,
|
|
21
|
+
canTrack
|
|
22
|
+
});
|
|
18
23
|
return newVisitorId;
|
|
19
24
|
}
|
|
20
25
|
};
|
|
@@ -27,8 +32,4 @@ const setVisitorId = ({
|
|
|
27
32
|
value: id,
|
|
28
33
|
canTrack
|
|
29
34
|
});
|
|
30
|
-
export {
|
|
31
|
-
createVisitorId,
|
|
32
|
-
getVisitorId,
|
|
33
|
-
setVisitorId
|
|
34
|
-
};
|
|
35
|
+
export { createVisitorId, getVisitorId, setVisitorId }
|
|
@@ -2,21 +2,10 @@ import { default as default2 } from "../blocks/button/button";
|
|
|
2
2
|
import { default as default3 } from "../blocks/columns/columns";
|
|
3
3
|
import { default as default4 } from "../blocks/fragment/fragment";
|
|
4
4
|
import { default as default5 } from "../blocks/image/image";
|
|
5
|
-
import { default as default6 } from "../components/
|
|
5
|
+
import { default as default6 } from "../components/blocks/blocks";
|
|
6
6
|
import { default as default7 } from "../blocks/section/section";
|
|
7
7
|
import { default as default8 } from "../blocks/symbol/symbol";
|
|
8
8
|
import { default as default9 } from "../blocks/text/text";
|
|
9
9
|
import { default as default10 } from "../blocks/video/video";
|
|
10
|
-
import { default as default11 } from "../components/
|
|
11
|
-
export {
|
|
12
|
-
default2 as Button,
|
|
13
|
-
default3 as Columns,
|
|
14
|
-
default4 as Fragment,
|
|
15
|
-
default5 as Image,
|
|
16
|
-
default6 as RenderBlocks,
|
|
17
|
-
default11 as RenderContent,
|
|
18
|
-
default7 as Section,
|
|
19
|
-
default8 as Symbol,
|
|
20
|
-
default9 as Text,
|
|
21
|
-
default10 as Video
|
|
22
|
-
};
|
|
10
|
+
import { default as default11 } from "../components/content-variants/content-variants";
|
|
11
|
+
export { default2 as Button, default3 as Columns, default4 as Fragment, default5 as Image, default6 as RenderBlocks, default11 as RenderContent, default7 as Section, default8 as Symbol, default9 as Text, default10 as Video }
|
package/src/index.js
CHANGED
|
@@ -5,22 +5,7 @@ import { isPreviewing } from "./functions/is-previewing.js";
|
|
|
5
5
|
import { createRegisterComponentMessage } from "./functions/register-component.js";
|
|
6
6
|
import { register } from "./functions/register.js";
|
|
7
7
|
import { setEditorSettings } from "./functions/set-editor-settings.js";
|
|
8
|
-
import {
|
|
9
|
-
getAllContent,
|
|
10
|
-
getContent,
|
|
11
|
-
processContentResult
|
|
12
|
-
} from "./functions/get-content/index.js";
|
|
8
|
+
import { getAllContent, getContent, processContentResult } from "./functions/get-content/index.js";
|
|
13
9
|
import { getBuilderSearchParams } from "./functions/get-builder-search-params/index.js";
|
|
14
10
|
import { track } from "./functions/track/index.js";
|
|
15
|
-
export {
|
|
16
|
-
createRegisterComponentMessage,
|
|
17
|
-
getAllContent,
|
|
18
|
-
getBuilderSearchParams,
|
|
19
|
-
getContent,
|
|
20
|
-
isEditing,
|
|
21
|
-
isPreviewing,
|
|
22
|
-
processContentResult,
|
|
23
|
-
register,
|
|
24
|
-
setEditorSettings,
|
|
25
|
-
track
|
|
26
|
-
};
|
|
11
|
+
export { createRegisterComponentMessage, getAllContent, getBuilderSearchParams, getContent, isEditing, isPreviewing, processContentResult, register, setEditorSettings, track }
|
|
@@ -6,18 +6,23 @@ const registerInsertMenu = () => {
|
|
|
6
6
|
register("insertMenu", {
|
|
7
7
|
name: "_default",
|
|
8
8
|
default: true,
|
|
9
|
-
items: [
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
9
|
+
items: [{
|
|
10
|
+
name: "Box"
|
|
11
|
+
}, {
|
|
12
|
+
name: "Text"
|
|
13
|
+
}, {
|
|
14
|
+
name: "Image"
|
|
15
|
+
}, {
|
|
16
|
+
name: "Columns"
|
|
17
|
+
}, ...(TARGET === "reactNative" ? [] : [{
|
|
18
|
+
name: "Core:Section"
|
|
19
|
+
}, {
|
|
20
|
+
name: "Core:Button"
|
|
21
|
+
}, {
|
|
22
|
+
name: "Embed"
|
|
23
|
+
}, {
|
|
24
|
+
name: "Custom Code"
|
|
25
|
+
}])]
|
|
21
26
|
});
|
|
22
27
|
};
|
|
23
28
|
let isSetupForEditing = false;
|
|
@@ -44,52 +49,61 @@ const setupBrowserForEditing = (options = {}) => {
|
|
|
44
49
|
options
|
|
45
50
|
}
|
|
46
51
|
}, "*");
|
|
47
|
-
window.addEventListener("message", ({
|
|
52
|
+
window.addEventListener("message", ({
|
|
53
|
+
data
|
|
54
|
+
}) => {
|
|
48
55
|
var _a2, _b2;
|
|
49
56
|
if (!(data == null ? void 0 : data.type)) {
|
|
50
57
|
return;
|
|
51
58
|
}
|
|
52
59
|
switch (data.type) {
|
|
53
|
-
case "builder.evaluate":
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
(
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
60
|
+
case "builder.evaluate":
|
|
61
|
+
{
|
|
62
|
+
const text = data.data.text;
|
|
63
|
+
const args = data.data.arguments || [];
|
|
64
|
+
const id = data.data.id;
|
|
65
|
+
const fn = new Function(text);
|
|
66
|
+
let result;
|
|
67
|
+
let error = null;
|
|
68
|
+
try {
|
|
69
|
+
result = fn.apply(null, args);
|
|
70
|
+
} catch (err) {
|
|
71
|
+
error = err;
|
|
72
|
+
}
|
|
73
|
+
if (error) {
|
|
74
|
+
(_a2 = window.parent) == null ? void 0 : _a2.postMessage({
|
|
75
|
+
type: "builder.evaluateError",
|
|
76
|
+
data: {
|
|
77
|
+
id,
|
|
78
|
+
error: error.message
|
|
79
|
+
}
|
|
80
|
+
}, "*");
|
|
81
|
+
} else {
|
|
82
|
+
if (result && typeof result.then === "function") {
|
|
83
|
+
result.then(finalResult => {
|
|
84
|
+
var _a3;
|
|
85
|
+
(_a3 = window.parent) == null ? void 0 : _a3.postMessage({
|
|
86
|
+
type: "builder.evaluateResult",
|
|
87
|
+
data: {
|
|
88
|
+
id,
|
|
89
|
+
result: finalResult
|
|
90
|
+
}
|
|
91
|
+
}, "*");
|
|
92
|
+
}).catch(console.error);
|
|
93
|
+
} else {
|
|
94
|
+
(_b2 = window.parent) == null ? void 0 : _b2.postMessage({
|
|
75
95
|
type: "builder.evaluateResult",
|
|
76
|
-
data: {
|
|
96
|
+
data: {
|
|
97
|
+
result,
|
|
98
|
+
id
|
|
99
|
+
}
|
|
77
100
|
}, "*");
|
|
78
|
-
}
|
|
79
|
-
} else {
|
|
80
|
-
(_b2 = window.parent) == null ? void 0 : _b2.postMessage({
|
|
81
|
-
type: "builder.evaluateResult",
|
|
82
|
-
data: { result, id }
|
|
83
|
-
}, "*");
|
|
101
|
+
}
|
|
84
102
|
}
|
|
103
|
+
break;
|
|
85
104
|
}
|
|
86
|
-
break;
|
|
87
|
-
}
|
|
88
105
|
}
|
|
89
106
|
});
|
|
90
107
|
}
|
|
91
108
|
};
|
|
92
|
-
export {
|
|
93
|
-
registerInsertMenu,
|
|
94
|
-
setupBrowserForEditing
|
|
95
|
-
};
|
|
109
|
+
export { registerInsertMenu, setupBrowserForEditing }
|
package/src/types/api-version.js
CHANGED
|
File without changes
|
package/src/blocks/util.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
const serializeFn = (fnValue) => {
|
|
2
|
-
const fnStr = fnValue.toString().trim();
|
|
3
|
-
const appendFunction = !fnStr.startsWith("function") && !fnStr.startsWith("(");
|
|
4
|
-
return `return (${appendFunction ? "function " : ""}${fnStr}).apply(this, arguments)`;
|
|
5
|
-
};
|
|
6
|
-
export {
|
|
7
|
-
serializeFn
|
|
8
|
-
};
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { Show, For } from "solid-js";
|
|
2
|
-
import { Dynamic } from "solid-js/web";
|
|
3
|
-
|
|
4
|
-
import BlockStyles from "./block-styles.jsx";
|
|
5
|
-
import RenderBlock from "./render-block.jsx";
|
|
6
|
-
|
|
7
|
-
function RenderComponent(props) {
|
|
8
|
-
return (
|
|
9
|
-
<Show when={props.componentRef}>
|
|
10
|
-
<Dynamic {...props.componentOptions} component={props.componentRef}>
|
|
11
|
-
<For each={props.blockChildren}>
|
|
12
|
-
{(child, _index) => {
|
|
13
|
-
const index = _index();
|
|
14
|
-
return (
|
|
15
|
-
<RenderBlock
|
|
16
|
-
key={"render-block-" + child.id}
|
|
17
|
-
block={child}
|
|
18
|
-
context={props.context}
|
|
19
|
-
></RenderBlock>
|
|
20
|
-
);
|
|
21
|
-
}}
|
|
22
|
-
</For>
|
|
23
|
-
<For each={props.blockChildren}>
|
|
24
|
-
{(child, _index) => {
|
|
25
|
-
const index = _index();
|
|
26
|
-
return (
|
|
27
|
-
<BlockStyles
|
|
28
|
-
key={"block-style-" + child.id}
|
|
29
|
-
block={child}
|
|
30
|
-
context={props.context}
|
|
31
|
-
></BlockStyles>
|
|
32
|
-
);
|
|
33
|
-
}}
|
|
34
|
-
</For>
|
|
35
|
-
</Dynamic>
|
|
36
|
-
</Show>
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
export default RenderComponent;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { createSignal } from "solid-js";
|
|
2
|
-
|
|
3
|
-
import BuilderContext from "../../context/builder.context.js";
|
|
4
|
-
import RenderBlock from "./render-block.jsx";
|
|
5
|
-
|
|
6
|
-
function RenderRepeatedBlock(props) {
|
|
7
|
-
const [store, setStore] = createSignal(props.repeatContext);
|
|
8
|
-
|
|
9
|
-
return (
|
|
10
|
-
<BuilderContext.Provider value={store()}>
|
|
11
|
-
<RenderBlock block={props.block} context={store()}></RenderBlock>
|
|
12
|
-
</BuilderContext.Provider>
|
|
13
|
-
);
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export default RenderRepeatedBlock;
|