@builder.io/sdk-solid 0.4.5 → 0.5.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.
- package/CHANGELOG.md +8 -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 +57 -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 +136 -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/context/components.context.js +5 -0
- 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
|
@@ -4,65 +4,57 @@ 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));
|
|
20
21
|
var __objRest = (source, exclude) => {
|
|
21
22
|
var target = {};
|
|
22
|
-
for (var prop in source)
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
-
target[prop] = source[prop];
|
|
29
|
-
}
|
|
23
|
+
for (var prop in source) if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0) target[prop] = source[prop];
|
|
24
|
+
if (source != null && __getOwnPropSymbols) for (var prop of __getOwnPropSymbols(source)) {
|
|
25
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) target[prop] = source[prop];
|
|
26
|
+
}
|
|
30
27
|
return target;
|
|
31
28
|
};
|
|
32
|
-
import { serializeFn } from "../blocks/util.js";
|
|
33
29
|
import { fastClone } from "./fast-clone.js";
|
|
34
30
|
const components = [];
|
|
35
31
|
function registerComponent(component, info) {
|
|
36
|
-
components.push(__spreadValues({
|
|
32
|
+
components.push(__spreadValues({
|
|
33
|
+
component
|
|
34
|
+
}, info));
|
|
37
35
|
console.warn("registerComponent is deprecated. Use the `customComponents` prop in RenderContent instead to provide your custom components to the builder SDK.");
|
|
38
36
|
return component;
|
|
39
37
|
}
|
|
40
|
-
const createRegisterComponentMessage =
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
data: prepareComponentInfoToSend(info)
|
|
49
|
-
};
|
|
38
|
+
const createRegisterComponentMessage = info => ({
|
|
39
|
+
type: "builder.registerComponent",
|
|
40
|
+
data: info
|
|
41
|
+
});
|
|
42
|
+
const serializeFn = fnValue => {
|
|
43
|
+
const fnStr = fnValue.toString().trim();
|
|
44
|
+
const appendFunction = !fnStr.startsWith("function") && !fnStr.startsWith("(");
|
|
45
|
+
return `return (${appendFunction ? "function " : ""}${fnStr}).apply(this, arguments)`;
|
|
50
46
|
};
|
|
51
|
-
const serializeValue =
|
|
52
|
-
const
|
|
53
|
-
var
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
47
|
+
const serializeValue = value => typeof value === "function" ? serializeFn(value) : fastClone(value);
|
|
48
|
+
const serializeComponentInfo = _a => {
|
|
49
|
+
var _b = _a,
|
|
50
|
+
{
|
|
51
|
+
inputs
|
|
52
|
+
} = _b,
|
|
53
|
+
info = __objRest(_b, ["inputs"]);
|
|
58
54
|
return __spreadProps(__spreadValues({}, fastClone(info)), {
|
|
59
|
-
inputs: inputs == null ? void 0 : inputs.map(
|
|
55
|
+
inputs: inputs == null ? void 0 : inputs.map(input => Object.entries(input).reduce((acc, [key, value]) => __spreadProps(__spreadValues({}, acc), {
|
|
60
56
|
[key]: serializeValue(value)
|
|
61
57
|
}), {}))
|
|
62
58
|
});
|
|
63
59
|
};
|
|
64
|
-
export {
|
|
65
|
-
components,
|
|
66
|
-
createRegisterComponentMessage,
|
|
67
|
-
registerComponent
|
|
68
|
-
};
|
|
60
|
+
export { components, createRegisterComponentMessage, registerComponent, serializeComponentInfo }
|
|
@@ -4,23 +4,24 @@ 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));
|
|
20
21
|
const propertiesThatMustBeNumber = new Set(["lineHeight"]);
|
|
21
22
|
const displayValues = new Set(["flex", "none"]);
|
|
22
23
|
const SHOW_WARNINGS = false;
|
|
23
|
-
const normalizeNumber =
|
|
24
|
+
const normalizeNumber = value => {
|
|
24
25
|
if (Number.isNaN(value)) {
|
|
25
26
|
return void 0;
|
|
26
27
|
} else if (value < 0) {
|
|
@@ -29,7 +30,7 @@ const normalizeNumber = (value) => {
|
|
|
29
30
|
return value;
|
|
30
31
|
}
|
|
31
32
|
};
|
|
32
|
-
const sanitizeReactNativeBlockStyles =
|
|
33
|
+
const sanitizeReactNativeBlockStyles = styles => {
|
|
33
34
|
return Object.keys(styles).reduce((acc, key) => {
|
|
34
35
|
const propertyValue = styles[key];
|
|
35
36
|
if (key === "display" && !displayValues.has(propertyValue)) {
|
|
@@ -50,17 +51,21 @@ const sanitizeReactNativeBlockStyles = (styles) => {
|
|
|
50
51
|
const newValue = parseFloat(propertyValue);
|
|
51
52
|
const normalizedValue = normalizeNumber(newValue);
|
|
52
53
|
if (normalizedValue) {
|
|
53
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
54
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
55
|
+
[key]: normalizedValue
|
|
56
|
+
});
|
|
54
57
|
} else {
|
|
55
58
|
return acc;
|
|
56
59
|
}
|
|
57
60
|
} else if (propertyValue === "0") {
|
|
58
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
61
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
62
|
+
[key]: 0
|
|
63
|
+
});
|
|
59
64
|
}
|
|
60
65
|
}
|
|
61
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
66
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
67
|
+
[key]: propertyValue
|
|
68
|
+
});
|
|
62
69
|
}, {});
|
|
63
70
|
};
|
|
64
|
-
export {
|
|
65
|
-
sanitizeReactNativeBlockStyles
|
|
66
|
-
};
|
|
71
|
+
export { sanitizeReactNativeBlockStyles }
|
package/src/functions/set.js
CHANGED
|
@@ -6,6 +6,4 @@ const set = (obj, _path, value) => {
|
|
|
6
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
7
|
return obj;
|
|
8
8
|
};
|
|
9
|
-
export {
|
|
10
|
-
set
|
|
11
|
-
};
|
|
9
|
+
export { set }
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { TARGET } from "../../constants/target";
|
|
2
|
-
import { isBrowser } from "../is-browser";
|
|
1
|
+
import { TARGET } from "../../constants/target.js";
|
|
2
|
+
import { isBrowser } from "../is-browser.js";
|
|
3
3
|
const getLocation = () => {
|
|
4
4
|
if (TARGET === "reactNative") {
|
|
5
5
|
return null;
|
|
@@ -45,6 +45,4 @@ const getUserAttributes = () => {
|
|
|
45
45
|
device: isTablet ? "tablet" : isMobile.any() ? "mobile" : "desktop"
|
|
46
46
|
};
|
|
47
47
|
};
|
|
48
|
-
export {
|
|
49
|
-
getUserAttributes
|
|
50
|
-
};
|
|
48
|
+
export { getUserAttributes }
|
|
@@ -4,48 +4,45 @@ 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));
|
|
20
21
|
var __objRest = (source, exclude) => {
|
|
21
22
|
var target = {};
|
|
22
|
-
for (var prop in source)
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
-
target[prop] = source[prop];
|
|
29
|
-
}
|
|
23
|
+
for (var prop in source) if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0) target[prop] = source[prop];
|
|
24
|
+
if (source != null && __getOwnPropSymbols) for (var prop of __getOwnPropSymbols(source)) {
|
|
25
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) target[prop] = source[prop];
|
|
26
|
+
}
|
|
30
27
|
return target;
|
|
31
28
|
};
|
|
32
29
|
var __async = (__this, __arguments, generator) => {
|
|
33
30
|
return new Promise((resolve, reject) => {
|
|
34
|
-
var fulfilled =
|
|
31
|
+
var fulfilled = value => {
|
|
35
32
|
try {
|
|
36
33
|
step(generator.next(value));
|
|
37
34
|
} catch (e) {
|
|
38
35
|
reject(e);
|
|
39
36
|
}
|
|
40
37
|
};
|
|
41
|
-
var rejected =
|
|
38
|
+
var rejected = value => {
|
|
42
39
|
try {
|
|
43
40
|
step(generator.throw(value));
|
|
44
41
|
} catch (e) {
|
|
45
42
|
reject(e);
|
|
46
43
|
}
|
|
47
44
|
};
|
|
48
|
-
var step =
|
|
45
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
49
46
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
50
47
|
});
|
|
51
48
|
};
|
|
@@ -56,38 +53,44 @@ import { getVisitorId } from "../../helpers/visitorId.js";
|
|
|
56
53
|
import { isBrowser } from "../is-browser.js";
|
|
57
54
|
import { isEditing } from "../is-editing.js";
|
|
58
55
|
import { getUserAttributes } from "./helpers.js";
|
|
59
|
-
const getTrackingEventData =
|
|
56
|
+
const getTrackingEventData = _0 => __async(void 0, [_0], function* ({
|
|
60
57
|
canTrack
|
|
61
58
|
}) {
|
|
62
59
|
if (!canTrack) {
|
|
63
|
-
return {
|
|
60
|
+
return {
|
|
61
|
+
visitorId: void 0,
|
|
62
|
+
sessionId: void 0
|
|
63
|
+
};
|
|
64
64
|
}
|
|
65
|
-
const sessionId = yield getSessionId({
|
|
66
|
-
|
|
65
|
+
const sessionId = yield getSessionId({
|
|
66
|
+
canTrack
|
|
67
|
+
});
|
|
68
|
+
const visitorId = getVisitorId({
|
|
69
|
+
canTrack
|
|
70
|
+
});
|
|
67
71
|
return {
|
|
68
72
|
sessionId,
|
|
69
73
|
visitorId
|
|
70
74
|
};
|
|
71
75
|
});
|
|
72
|
-
const createEvent =
|
|
73
|
-
var _b = _a,
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
"canTrack",
|
|
81
|
-
"apiKey",
|
|
82
|
-
"metadata"
|
|
83
|
-
]);
|
|
76
|
+
const createEvent = _a => __async(void 0, null, function* () {
|
|
77
|
+
var _b = _a,
|
|
78
|
+
{
|
|
79
|
+
type: eventType,
|
|
80
|
+
canTrack,
|
|
81
|
+
apiKey,
|
|
82
|
+
metadata
|
|
83
|
+
} = _b,
|
|
84
|
+
properties = __objRest(_b, ["type", "canTrack", "apiKey", "metadata"]);
|
|
84
85
|
return {
|
|
85
86
|
type: eventType,
|
|
86
87
|
data: __spreadProps(__spreadValues(__spreadProps(__spreadValues({}, properties), {
|
|
87
88
|
metadata: __spreadValues({
|
|
88
89
|
url: location.href
|
|
89
90
|
}, metadata)
|
|
90
|
-
}), yield getTrackingEventData({
|
|
91
|
+
}), yield getTrackingEventData({
|
|
92
|
+
canTrack
|
|
93
|
+
})), {
|
|
91
94
|
userAttributes: getUserAttributes(),
|
|
92
95
|
ownerId: apiKey
|
|
93
96
|
})
|
|
@@ -117,13 +120,12 @@ function _track(eventProps) {
|
|
|
117
120
|
"content-type": "application/json"
|
|
118
121
|
},
|
|
119
122
|
mode: "cors"
|
|
120
|
-
}).catch(
|
|
123
|
+
}).catch(err => {
|
|
121
124
|
console.error("Failed to track: ", err);
|
|
122
125
|
});
|
|
123
126
|
});
|
|
124
127
|
}
|
|
125
|
-
const track =
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
};
|
|
128
|
+
const track = args => _track(__spreadProps(__spreadValues({}, args), {
|
|
129
|
+
canTrack: true
|
|
130
|
+
}));
|
|
131
|
+
export { _track, track }
|
|
@@ -17,7 +17,7 @@ const findParentElement = (target, callback, checkElement = true) => {
|
|
|
17
17
|
} while (parent = parent.parentElement);
|
|
18
18
|
return null;
|
|
19
19
|
};
|
|
20
|
-
const findBuilderParent =
|
|
20
|
+
const findBuilderParent = target => findParentElement(target, el => {
|
|
21
21
|
const id = el.getAttribute("builder-id") || el.id;
|
|
22
22
|
return Boolean((id == null ? void 0 : id.indexOf("builder-")) === 0);
|
|
23
23
|
});
|
|
@@ -35,19 +35,23 @@ const computeOffset = ({
|
|
|
35
35
|
y: yRatio
|
|
36
36
|
};
|
|
37
37
|
};
|
|
38
|
-
const getInteractionPropertiesForEvent =
|
|
38
|
+
const getInteractionPropertiesForEvent = event => {
|
|
39
39
|
const target = event.target;
|
|
40
40
|
const targetBuilderElement = target && findBuilderParent(target);
|
|
41
41
|
const builderId = (targetBuilderElement == null ? void 0 : targetBuilderElement.getAttribute("builder-id")) || (targetBuilderElement == null ? void 0 : targetBuilderElement.id);
|
|
42
42
|
return {
|
|
43
43
|
targetBuilderElement: builderId || void 0,
|
|
44
44
|
metadata: {
|
|
45
|
-
targetOffset: target ? computeOffset({
|
|
46
|
-
|
|
45
|
+
targetOffset: target ? computeOffset({
|
|
46
|
+
event,
|
|
47
|
+
target
|
|
48
|
+
}) : void 0,
|
|
49
|
+
builderTargetOffset: targetBuilderElement ? computeOffset({
|
|
50
|
+
event,
|
|
51
|
+
target: targetBuilderElement
|
|
52
|
+
}) : void 0,
|
|
47
53
|
builderElementIndex: targetBuilderElement && builderId ? [].slice.call(document.getElementsByClassName(builderId)).indexOf(targetBuilderElement) : void 0
|
|
48
54
|
}
|
|
49
55
|
};
|
|
50
56
|
};
|
|
51
|
-
export {
|
|
52
|
-
getInteractionPropertiesForEvent
|
|
53
|
-
};
|
|
57
|
+
export { getInteractionPropertiesForEvent }
|
package/src/helpers/ab-tests.js
CHANGED
|
@@ -2,35 +2,36 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
3
3
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
4
4
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
5
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
5
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true,
|
|
9
|
+
value
|
|
10
|
+
}) : obj[key] = value;
|
|
6
11
|
var __spreadValues = (a, b) => {
|
|
7
|
-
for (var prop in b || (b = {}))
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
12
|
-
if (__propIsEnum.call(b, prop))
|
|
13
|
-
__defNormalProp(a, prop, b[prop]);
|
|
14
|
-
}
|
|
12
|
+
for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]);
|
|
13
|
+
if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]);
|
|
15
|
+
}
|
|
15
16
|
return a;
|
|
16
17
|
};
|
|
17
18
|
var __async = (__this, __arguments, generator) => {
|
|
18
19
|
return new Promise((resolve, reject) => {
|
|
19
|
-
var fulfilled =
|
|
20
|
+
var fulfilled = value => {
|
|
20
21
|
try {
|
|
21
22
|
step(generator.next(value));
|
|
22
23
|
} catch (e) {
|
|
23
24
|
reject(e);
|
|
24
25
|
}
|
|
25
26
|
};
|
|
26
|
-
var rejected =
|
|
27
|
+
var rejected = value => {
|
|
27
28
|
try {
|
|
28
29
|
step(generator.throw(value));
|
|
29
30
|
} catch (e) {
|
|
30
31
|
reject(e);
|
|
31
32
|
}
|
|
32
33
|
};
|
|
33
|
-
var step =
|
|
34
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
34
35
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
35
36
|
});
|
|
36
37
|
};
|
|
@@ -39,14 +40,28 @@ import { checkIsDefined } from "../helpers/nullable.js";
|
|
|
39
40
|
import { logger } from "./logger.js";
|
|
40
41
|
import { TARGET } from "../constants/target.js";
|
|
41
42
|
const BUILDER_STORE_PREFIX = "builder.tests";
|
|
42
|
-
const getContentTestKey =
|
|
43
|
-
const getContentVariationCookie = ({
|
|
44
|
-
|
|
43
|
+
const getContentTestKey = id => `${BUILDER_STORE_PREFIX}.${id}`;
|
|
44
|
+
const getContentVariationCookie = ({
|
|
45
|
+
contentId
|
|
46
|
+
}) => getCookie({
|
|
47
|
+
name: getContentTestKey(contentId),
|
|
48
|
+
canTrack: true
|
|
49
|
+
});
|
|
50
|
+
const getContentVariationCookieSync = ({
|
|
51
|
+
contentId
|
|
52
|
+
}) => getCookieSync({
|
|
53
|
+
name: getContentTestKey(contentId),
|
|
54
|
+
canTrack: true
|
|
55
|
+
});
|
|
45
56
|
const setContentVariationCookie = ({
|
|
46
57
|
contentId,
|
|
47
58
|
value
|
|
48
|
-
}) => setCookie({
|
|
49
|
-
|
|
59
|
+
}) => setCookie({
|
|
60
|
+
name: getContentTestKey(contentId),
|
|
61
|
+
value,
|
|
62
|
+
canTrack: true
|
|
63
|
+
});
|
|
64
|
+
const checkIsBuilderContentWithVariations = item => checkIsDefined(item.id) && checkIsDefined(item.variations) && Object.keys(item.variations).length > 0;
|
|
50
65
|
const getRandomVariationId = ({
|
|
51
66
|
id,
|
|
52
67
|
variations
|
|
@@ -63,12 +78,12 @@ const getRandomVariationId = ({
|
|
|
63
78
|
}
|
|
64
79
|
return id;
|
|
65
80
|
};
|
|
66
|
-
const getAndSetVariantId =
|
|
81
|
+
const getAndSetVariantId = args => {
|
|
67
82
|
const randomVariationId = getRandomVariationId(args);
|
|
68
83
|
setContentVariationCookie({
|
|
69
84
|
contentId: args.id,
|
|
70
85
|
value: randomVariationId
|
|
71
|
-
}).catch(
|
|
86
|
+
}).catch(err => {
|
|
72
87
|
logger.error("could not store A/B test variation: ", err);
|
|
73
88
|
});
|
|
74
89
|
return randomVariationId;
|
|
@@ -95,8 +110,7 @@ const handleABTestingSync = ({
|
|
|
95
110
|
item,
|
|
96
111
|
canTrack
|
|
97
112
|
}) => {
|
|
98
|
-
if (TARGET === "reactNative")
|
|
99
|
-
return item;
|
|
113
|
+
if (TARGET === "reactNative") return item;
|
|
100
114
|
if (!canTrack) {
|
|
101
115
|
return item;
|
|
102
116
|
}
|
|
@@ -112,10 +126,13 @@ const handleABTestingSync = ({
|
|
|
112
126
|
variations: item.variations,
|
|
113
127
|
id: item.id
|
|
114
128
|
});
|
|
115
|
-
const variationValue = getTestFields({
|
|
129
|
+
const variationValue = getTestFields({
|
|
130
|
+
item,
|
|
131
|
+
testGroupId
|
|
132
|
+
});
|
|
116
133
|
return __spreadValues(__spreadValues({}, item), variationValue);
|
|
117
134
|
};
|
|
118
|
-
const handleABTesting =
|
|
135
|
+
const handleABTesting = _0 => __async(void 0, [_0], function* ({
|
|
119
136
|
item,
|
|
120
137
|
canTrack
|
|
121
138
|
}) {
|
|
@@ -132,10 +149,10 @@ const handleABTesting = (_0) => __async(void 0, [_0], function* ({
|
|
|
132
149
|
variations: item.variations,
|
|
133
150
|
id: item.id
|
|
134
151
|
});
|
|
135
|
-
const variationValue = getTestFields({
|
|
152
|
+
const variationValue = getTestFields({
|
|
153
|
+
item,
|
|
154
|
+
testGroupId
|
|
155
|
+
});
|
|
136
156
|
return __spreadValues(__spreadValues({}, item), variationValue);
|
|
137
157
|
});
|
|
138
|
-
export {
|
|
139
|
-
handleABTesting,
|
|
140
|
-
handleABTestingSync
|
|
141
|
-
};
|
|
158
|
+
export { handleABTesting, handleABTestingSync }
|
package/src/helpers/canTrack.js
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
import { checkIsDefined } from "./nullable";
|
|
2
|
-
const getDefaultCanTrack =
|
|
3
|
-
export {
|
|
4
|
-
getDefaultCanTrack
|
|
5
|
-
};
|
|
1
|
+
import { checkIsDefined } from "./nullable.js";
|
|
2
|
+
const getDefaultCanTrack = canTrack => checkIsDefined(canTrack) ? canTrack : true;
|
|
3
|
+
export { getDefaultCanTrack }
|