@builder.io/sdk-react 0.2.3-4 → 0.3.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/README.md +72 -3
- package/dist/sdk/blocks/columns/columns.js +5 -5
- package/dist/sdk/blocks/image/image.js +8 -7
- package/dist/sdk/blocks/symbol/symbol.js +3 -2
- package/dist/sdk/blocks/video/video.js +4 -1
- package/dist/sdk/components/render-block/block-styles.js +3 -1
- package/dist/sdk/components/render-block/render-block.helpers.d.ts +0 -1
- package/dist/sdk/components/render-block/render-block.helpers.js +8 -20
- package/dist/sdk/components/render-block/render-block.js +24 -15
- package/dist/sdk/components/render-block/render-repeated-block.js +3 -2
- package/dist/sdk/components/render-content/render-content.js +31 -12
- package/dist/sdk/components/render-content-variants/helpers.d.ts +12 -0
- package/dist/sdk/components/render-content-variants/helpers.js +154 -0
- package/dist/sdk/components/render-content-variants/render-content-variants.d.ts +5 -0
- package/dist/sdk/components/render-content-variants/render-content-variants.js +29 -0
- package/dist/sdk/components/render-inlined-styles.js +2 -2
- package/dist/sdk/constants/sdk-version.d.ts +1 -0
- package/dist/sdk/constants/sdk-version.js +1 -0
- package/dist/sdk/context/builder.context.js +3 -2
- package/dist/sdk/context/types.d.ts +17 -2
- package/dist/sdk/functions/evaluate.d.ts +4 -3
- package/dist/sdk/functions/evaluate.js +23 -2
- package/dist/sdk/functions/evaluate.test.d.ts +1 -0
- package/dist/sdk/functions/evaluate.test.js +17 -0
- package/dist/sdk/functions/get-block-actions-handler.d.ts +1 -1
- package/dist/sdk/functions/get-block-actions-handler.js +3 -1
- package/dist/sdk/functions/get-block-actions.d.ts +1 -1
- package/dist/sdk/functions/get-processed-block.d.ts +2 -2
- package/dist/sdk/functions/get-processed-block.js +16 -4
- package/dist/sdk/functions/get-processed-block.test.js +3 -1
- package/dist/sdk/helpers/canTrack.d.ts +1 -0
- package/dist/sdk/helpers/canTrack.js +2 -0
- package/dist/sdk/index.d.ts +1 -0
- package/dist/sdk/scripts/init-editing.js +2 -0
- package/package.json +5 -5
- package/CHANGELOG.md +0 -25
- package/packages/react/src/blocks/BaseText.tsx +0 -19
- package/packages/react/src/blocks/button/button.tsx +0 -45
- package/packages/react/src/blocks/button/component-info.ts +0 -42
- package/packages/react/src/blocks/columns/columns.tsx +0 -211
- package/packages/react/src/blocks/columns/component-info.ts +0 -254
- package/packages/react/src/blocks/custom-code/component-info.ts +0 -31
- package/packages/react/src/blocks/custom-code/custom-code.tsx +0 -76
- package/packages/react/src/blocks/embed/component-info.ts +0 -55
- package/packages/react/src/blocks/embed/embed.tsx +0 -59
- package/packages/react/src/blocks/embed/helpers.ts +0 -8
- package/packages/react/src/blocks/form/component-info.ts +0 -282
- package/packages/react/src/blocks/form/form.tsx +0 -320
- package/packages/react/src/blocks/fragment/component-info.ts +0 -10
- package/packages/react/src/blocks/fragment/fragment.tsx +0 -14
- package/packages/react/src/blocks/image/component-info.ts +0 -172
- package/packages/react/src/blocks/image/image.helpers.ts +0 -75
- package/packages/react/src/blocks/image/image.tsx +0 -144
- package/packages/react/src/blocks/img/component-info.ts +0 -21
- package/packages/react/src/blocks/img/img.tsx +0 -40
- package/packages/react/src/blocks/input/component-info.ts +0 -78
- package/packages/react/src/blocks/input/input.tsx +0 -33
- package/packages/react/src/blocks/raw-text/component-info.ts +0 -15
- package/packages/react/src/blocks/raw-text/raw-text.tsx +0 -18
- package/packages/react/src/blocks/section/component-info.ts +0 -50
- package/packages/react/src/blocks/section/section.tsx +0 -33
- package/packages/react/src/blocks/select/component-info.ts +0 -61
- package/packages/react/src/blocks/select/select.tsx +0 -35
- package/packages/react/src/blocks/submit-button/component-info.ts +0 -32
- package/packages/react/src/blocks/submit-button/submit-button.tsx +0 -17
- package/packages/react/src/blocks/symbol/component-info.ts +0 -43
- package/packages/react/src/blocks/symbol/symbol.tsx +0 -111
- package/packages/react/src/blocks/text/component-info.ts +0 -24
- package/packages/react/src/blocks/text/text.tsx +0 -20
- package/packages/react/src/blocks/textarea/component-info.ts +0 -48
- package/packages/react/src/blocks/textarea/textarea.tsx +0 -24
- package/packages/react/src/blocks/util.ts +0 -18
- package/packages/react/src/blocks/video/component-info.ts +0 -109
- package/packages/react/src/blocks/video/video.tsx +0 -84
- package/packages/react/src/components/render-block/block-styles.tsx +0 -98
- package/packages/react/src/components/render-block/render-block.helpers.ts +0 -138
- package/packages/react/src/components/render-block/render-block.tsx +0 -216
- package/packages/react/src/components/render-block/render-component.tsx +0 -52
- package/packages/react/src/components/render-block/render-repeated-block.tsx +0 -43
- package/packages/react/src/components/render-block/types.ts +0 -7
- package/packages/react/src/components/render-blocks.tsx +0 -97
- package/packages/react/src/components/render-content/builder-editing.tsx +0 -8
- package/packages/react/src/components/render-content/components/render-styles.helpers.ts +0 -79
- package/packages/react/src/components/render-content/components/render-styles.tsx +0 -45
- package/packages/react/src/components/render-content/index.ts +0 -1
- package/packages/react/src/components/render-content/render-content.helpers.ts +0 -48
- package/packages/react/src/components/render-content/render-content.tsx +0 -410
- package/packages/react/src/components/render-content/render-content.types.ts +0 -33
- package/packages/react/src/components/render-inlined-styles.tsx +0 -36
- package/packages/react/src/constants/builder-registered-components.ts +0 -42
- package/packages/react/src/constants/device-sizes.ts +0 -65
- package/packages/react/src/constants/target.ts +0 -2
- package/packages/react/src/context/builder.context.ts +0 -12
- package/packages/react/src/context/types.ts +0 -26
- package/packages/react/src/functions/camel-to-kebab-case.ts +0 -2
- package/packages/react/src/functions/evaluate.ts +0 -57
- package/packages/react/src/functions/event-handler-name.ts +0 -6
- package/packages/react/src/functions/extract-text-styles.ts +0 -39
- package/packages/react/src/functions/fast-clone.ts +0 -5
- package/packages/react/src/functions/get-block-actions-handler.ts +0 -20
- package/packages/react/src/functions/get-block-actions.ts +0 -25
- package/packages/react/src/functions/get-block-component-options.ts +0 -12
- package/packages/react/src/functions/get-block-properties.ts +0 -75
- package/packages/react/src/functions/get-builder-search-params/fn.test.ts +0 -19
- package/packages/react/src/functions/get-builder-search-params/index.ts +0 -50
- package/packages/react/src/functions/get-content/ab-testing.ts +0 -132
- package/packages/react/src/functions/get-content/generate-content-url.test.ts +0 -95
- package/packages/react/src/functions/get-content/generate-content-url.ts +0 -59
- package/packages/react/src/functions/get-content/index.ts +0 -62
- package/packages/react/src/functions/get-content/types.ts +0 -53
- package/packages/react/src/functions/get-fetch.ts +0 -18
- package/packages/react/src/functions/get-global-this.ts +0 -17
- package/packages/react/src/functions/get-processed-block.test.ts +0 -33
- package/packages/react/src/functions/get-processed-block.ts +0 -54
- package/packages/react/src/functions/get-react-native-block-styles.ts +0 -33
- package/packages/react/src/functions/if-target.ts +0 -20
- package/packages/react/src/functions/is-browser.ts +0 -3
- package/packages/react/src/functions/is-editing.ts +0 -10
- package/packages/react/src/functions/is-iframe.ts +0 -5
- package/packages/react/src/functions/is-previewing.ts +0 -14
- package/packages/react/src/functions/on-change.test.ts +0 -23
- package/packages/react/src/functions/on-change.ts +0 -29
- package/packages/react/src/functions/register-component.ts +0 -50
- package/packages/react/src/functions/register.ts +0 -46
- package/packages/react/src/functions/sanitize-react-native-block-styles.ts +0 -65
- package/packages/react/src/functions/set-editor-settings.ts +0 -16
- package/packages/react/src/functions/set.test.ts +0 -19
- package/packages/react/src/functions/set.ts +0 -26
- package/packages/react/src/functions/track/helpers.ts +0 -67
- package/packages/react/src/functions/track/index.ts +0 -136
- package/packages/react/src/functions/track/interaction.ts +0 -80
- package/packages/react/src/functions/transform-block-properties.ts +0 -3
- package/packages/react/src/functions/transform-block.ts +0 -6
- package/packages/react/src/helpers/ab-tests.ts +0 -22
- package/packages/react/src/helpers/cookie.ts +0 -107
- package/packages/react/src/helpers/css.ts +0 -42
- package/packages/react/src/helpers/flatten.ts +0 -24
- package/packages/react/src/helpers/localStorage.ts +0 -40
- package/packages/react/src/helpers/logger.ts +0 -6
- package/packages/react/src/helpers/nullable.ts +0 -4
- package/packages/react/src/helpers/sessionId.ts +0 -38
- package/packages/react/src/helpers/time.ts +0 -4
- package/packages/react/src/helpers/url.test.ts +0 -23
- package/packages/react/src/helpers/url.ts +0 -16
- package/packages/react/src/helpers/uuid.ts +0 -17
- package/packages/react/src/helpers/visitorId.ts +0 -40
- package/packages/react/src/index-helpers/blocks-exports.ts +0 -10
- package/packages/react/src/index-helpers/top-of-file.ts +0 -4
- package/packages/react/src/index.ts +0 -14
- package/packages/react/src/scripts/init-editing.ts +0 -123
- package/packages/react/src/types/api-version.ts +0 -2
- package/packages/react/src/types/builder-block.ts +0 -69
- package/packages/react/src/types/builder-content.ts +0 -46
- package/packages/react/src/types/can-track.ts +0 -3
- package/packages/react/src/types/components.ts +0 -117
- package/packages/react/src/types/deep-partial.ts +0 -7
- package/packages/react/src/types/element.ts +0 -60
- package/packages/react/src/types/input.ts +0 -125
- package/packages/react/src/types/targets.ts +0 -6
- package/packages/react/src/types/typescript.ts +0 -7
- package/packages/rsc/src/blocks/BaseText.jsx +0 -12
- package/packages/rsc/src/blocks/button/button.jsx +0 -37
- package/packages/rsc/src/blocks/button/component-info.js +0 -40
- package/packages/rsc/src/blocks/columns/columns.jsx +0 -172
- package/packages/rsc/src/blocks/columns/component-info.js +0 -241
- package/packages/rsc/src/blocks/custom-code/component-info.js +0 -30
- package/packages/rsc/src/blocks/custom-code/custom-code.jsx +0 -57
- package/packages/rsc/src/blocks/embed/component-info.js +0 -43
- package/packages/rsc/src/blocks/embed/embed.jsx +0 -45
- package/packages/rsc/src/blocks/embed/helpers.js +0 -9
- package/packages/rsc/src/blocks/form/component-info.js +0 -261
- package/packages/rsc/src/blocks/form/form.jsx +0 -260
- package/packages/rsc/src/blocks/fragment/component-info.js +0 -10
- package/packages/rsc/src/blocks/fragment/fragment.jsx +0 -9
- package/packages/rsc/src/blocks/image/component-info.js +0 -150
- package/packages/rsc/src/blocks/image/image.helpers.js +0 -48
- package/packages/rsc/src/blocks/image/image.jsx +0 -122
- package/packages/rsc/src/blocks/img/component-info.js +0 -19
- package/packages/rsc/src/blocks/img/img.jsx +0 -21
- package/packages/rsc/src/blocks/input/component-info.js +0 -73
- package/packages/rsc/src/blocks/input/input.jsx +0 -23
- package/packages/rsc/src/blocks/raw-text/component-info.js +0 -15
- package/packages/rsc/src/blocks/raw-text/raw-text.jsx +0 -14
- package/packages/rsc/src/blocks/section/component-info.js +0 -48
- package/packages/rsc/src/blocks/section/section.jsx +0 -27
- package/packages/rsc/src/blocks/select/component-info.js +0 -58
- package/packages/rsc/src/blocks/select/select.jsx +0 -24
- package/packages/rsc/src/blocks/submit-button/component-info.js +0 -27
- package/packages/rsc/src/blocks/submit-button/submit-button.jsx +0 -13
- package/packages/rsc/src/blocks/symbol/component-info.js +0 -42
- package/packages/rsc/src/blocks/symbol/symbol.jsx +0 -89
- package/packages/rsc/src/blocks/text/component-info.js +0 -23
- package/packages/rsc/src/blocks/text/text.jsx +0 -17
- package/packages/rsc/src/blocks/textarea/component-info.js +0 -46
- package/packages/rsc/src/blocks/textarea/textarea.jsx +0 -17
- package/packages/rsc/src/blocks/util.js +0 -8
- package/packages/rsc/src/blocks/video/component-info.js +0 -105
- package/packages/rsc/src/blocks/video/video.jsx +0 -63
- package/packages/rsc/src/components/render-block/block-styles.jsx +0 -88
- package/packages/rsc/src/components/render-block/render-block.helpers.js +0 -129
- package/packages/rsc/src/components/render-block/render-block.jsx +0 -201
- package/packages/rsc/src/components/render-block/render-component.jsx +0 -39
- package/packages/rsc/src/components/render-block/render-repeated-block.jsx +0 -27
- package/packages/rsc/src/components/render-block/types.js +0 -0
- package/packages/rsc/src/components/render-blocks.jsx +0 -92
- package/packages/rsc/src/components/render-content/builder-editing.jsx +0 -64
- package/packages/rsc/src/components/render-content/components/render-styles.helpers.js +0 -57
- package/packages/rsc/src/components/render-content/components/render-styles.jsx +0 -39
- package/packages/rsc/src/components/render-content/index.js +0 -4
- package/packages/rsc/src/components/render-content/render-content.helpers.js +0 -48
- package/packages/rsc/src/components/render-content/render-content.jsx +0 -253
- package/packages/rsc/src/components/render-content/render-content.types.js +0 -0
- package/packages/rsc/src/components/render-inlined-styles.jsx +0 -33
- package/packages/rsc/src/constants/builder-registered-components.js +0 -54
- package/packages/rsc/src/constants/device-sizes.js +0 -48
- package/packages/rsc/src/constants/target.js +0 -4
- package/packages/rsc/src/context/builder.context.js +0 -14
- package/packages/rsc/src/context/types.js +0 -0
- package/packages/rsc/src/functions/camel-to-kebab-case.js +0 -4
- package/packages/rsc/src/functions/evaluate.js +0 -6
- package/packages/rsc/src/functions/event-handler-name.js +0 -7
- package/packages/rsc/src/functions/extract-text-styles.js +0 -22
- package/packages/rsc/src/functions/fast-clone.js +0 -4
- package/packages/rsc/src/functions/get-block-actions-handler.js +0 -11
- package/packages/rsc/src/functions/get-block-actions.js +0 -18
- package/packages/rsc/src/functions/get-block-component-options.js +0 -28
- package/packages/rsc/src/functions/get-block-properties.js +0 -53
- package/packages/rsc/src/functions/get-builder-search-params/fn.test.js +0 -13
- package/packages/rsc/src/functions/get-builder-search-params/index.js +0 -38
- package/packages/rsc/src/functions/get-content/ab-testing.js +0 -99
- package/packages/rsc/src/functions/get-content/generate-content-url.js +0 -60
- package/packages/rsc/src/functions/get-content/generate-content-url.test.js +0 -82
- package/packages/rsc/src/functions/get-content/index.js +0 -83
- package/packages/rsc/src/functions/get-content/types.js +0 -0
- package/packages/rsc/src/functions/get-fetch.js +0 -14
- package/packages/rsc/src/functions/get-global-this.js +0 -18
- package/packages/rsc/src/functions/get-processed-block.js +0 -59
- package/packages/rsc/src/functions/get-processed-block.test.js +0 -32
- package/packages/rsc/src/functions/get-react-native-block-styles.js +0 -33
- package/packages/rsc/src/functions/if-target.js +0 -15
- package/packages/rsc/src/functions/is-browser.js +0 -6
- package/packages/rsc/src/functions/is-editing.js +0 -8
- package/packages/rsc/src/functions/is-iframe.js +0 -7
- package/packages/rsc/src/functions/is-previewing.js +0 -14
- package/packages/rsc/src/functions/on-change.js +0 -27
- package/packages/rsc/src/functions/on-change.test.js +0 -19
- package/packages/rsc/src/functions/register-component.js +0 -68
- package/packages/rsc/src/functions/register.js +0 -29
- package/packages/rsc/src/functions/sanitize-react-native-block-styles.js +0 -66
- package/packages/rsc/src/functions/set-editor-settings.js +0 -15
- package/packages/rsc/src/functions/set.js +0 -11
- package/packages/rsc/src/functions/set.test.js +0 -16
- package/packages/rsc/src/functions/track/helpers.js +0 -50
- package/packages/rsc/src/functions/track/index.js +0 -129
- package/packages/rsc/src/functions/track/interaction.js +0 -53
- package/packages/rsc/src/functions/transform-block-properties.js +0 -6
- package/packages/rsc/src/functions/transform-block.js +0 -6
- package/packages/rsc/src/helpers/ab-tests.js +0 -16
- package/packages/rsc/src/helpers/cookie.js +0 -81
- package/packages/rsc/src/helpers/css.js +0 -34
- package/packages/rsc/src/helpers/flatten.js +0 -34
- package/packages/rsc/src/helpers/localStorage.js +0 -35
- package/packages/rsc/src/helpers/logger.js +0 -9
- package/packages/rsc/src/helpers/nullable.js +0 -4
- package/packages/rsc/src/helpers/sessionId.js +0 -52
- package/packages/rsc/src/helpers/time.js +0 -5
- package/packages/rsc/src/helpers/url.js +0 -13
- package/packages/rsc/src/helpers/url.test.js +0 -21
- package/packages/rsc/src/helpers/uuid.js +0 -13
- package/packages/rsc/src/helpers/visitorId.js +0 -34
- package/packages/rsc/src/index-helpers/blocks-exports.js +0 -22
- package/packages/rsc/src/index-helpers/top-of-file.js +0 -2
- package/packages/rsc/src/index.js +0 -13
- package/packages/rsc/src/scripts/init-editing.js +0 -93
- package/packages/rsc/src/types/api-version.js +0 -4
- package/packages/rsc/src/types/builder-block.js +0 -0
- package/packages/rsc/src/types/builder-content.js +0 -0
- package/packages/rsc/src/types/can-track.js +0 -0
- package/packages/rsc/src/types/components.js +0 -0
- package/packages/rsc/src/types/deep-partial.js +0 -0
- package/packages/rsc/src/types/element.js +0 -0
- package/packages/rsc/src/types/input.js +0 -0
- package/packages/rsc/src/types/targets.js +0 -0
- package/packages/rsc/src/types/typescript.js +0 -0
- package/tsconfig.json +0 -28
- package/tsconfig.sdk.json +0 -10
- package/tsconfig.server.json +0 -10
- package/vite.config.ts +0 -91
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { getGlobalThis } from "./get-global-this.js";
|
|
2
|
-
function getFetch() {
|
|
3
|
-
const globalFetch = getGlobalThis().fetch;
|
|
4
|
-
if (typeof globalFetch === "undefined") {
|
|
5
|
-
console.warn(`Builder SDK could not find a global fetch function. Make sure you have a polyfill for fetch in your project.
|
|
6
|
-
For more information, read https://github.com/BuilderIO/this-package-uses-fetch`);
|
|
7
|
-
throw new Error("Builder SDK could not find a global `fetch` function");
|
|
8
|
-
}
|
|
9
|
-
return globalFetch;
|
|
10
|
-
}
|
|
11
|
-
const fetch = getFetch();
|
|
12
|
-
export {
|
|
13
|
-
fetch
|
|
14
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
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 globalThis;
|
|
15
|
-
}
|
|
16
|
-
export {
|
|
17
|
-
getGlobalThis
|
|
18
|
-
};
|
|
@@ -1,59 +0,0 @@
|
|
|
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.js";
|
|
21
|
-
import { fastClone } from "./fast-clone.js";
|
|
22
|
-
import { set } from "./set.js";
|
|
23
|
-
import { transformBlock } from "./transform-block.js";
|
|
24
|
-
const evaluateBindings = ({
|
|
25
|
-
block,
|
|
26
|
-
context,
|
|
27
|
-
state
|
|
28
|
-
}) => {
|
|
29
|
-
if (!block.bindings) {
|
|
30
|
-
return block;
|
|
31
|
-
}
|
|
32
|
-
const copy = fastClone(block);
|
|
33
|
-
const copied = __spreadProps(__spreadValues({}, copy), {
|
|
34
|
-
properties: __spreadValues({}, copy.properties),
|
|
35
|
-
actions: __spreadValues({}, copy.actions)
|
|
36
|
-
});
|
|
37
|
-
for (const binding in block.bindings) {
|
|
38
|
-
const expression = block.bindings[binding];
|
|
39
|
-
const value = evaluate({ code: expression, state, context });
|
|
40
|
-
set(copied, binding, value);
|
|
41
|
-
}
|
|
42
|
-
return copied;
|
|
43
|
-
};
|
|
44
|
-
function getProcessedBlock({
|
|
45
|
-
block,
|
|
46
|
-
context,
|
|
47
|
-
shouldEvaluateBindings,
|
|
48
|
-
state
|
|
49
|
-
}) {
|
|
50
|
-
const transformedBlock = transformBlock(block);
|
|
51
|
-
if (shouldEvaluateBindings) {
|
|
52
|
-
return evaluateBindings({ block: transformedBlock, state, context });
|
|
53
|
-
} else {
|
|
54
|
-
return transformedBlock;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
export {
|
|
58
|
-
getProcessedBlock
|
|
59
|
-
};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { getProcessedBlock } from "./get-processed-block.js";
|
|
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
|
-
shouldEvaluateBindings: true
|
|
25
|
-
});
|
|
26
|
-
expect(processed).not.toEqual(block);
|
|
27
|
-
expect((_a = processed.properties) == null ? void 0 : _a.foo).toEqual("baz");
|
|
28
|
-
expect((_b = processed.properties) == null ? void 0 : _b.test).toEqual("hello");
|
|
29
|
-
expect((_c = processed.properties) == null ? void 0 : _c.block).toEqual("bar");
|
|
30
|
-
expect((_d = processed.properties) == null ? void 0 : _d.isEditing).toEqual(false);
|
|
31
|
-
expect((_f = (_e = processed.responsiveStyles) == null ? void 0 : _e.large) == null ? void 0 : _f.zIndex).toEqual(2);
|
|
32
|
-
});
|
|
@@ -1,33 +0,0 @@
|
|
|
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 { sanitizeReactNativeBlockStyles } from "./sanitize-react-native-block-styles.js";
|
|
18
|
-
function getReactNativeBlockStyles({
|
|
19
|
-
block,
|
|
20
|
-
context,
|
|
21
|
-
blockStyles
|
|
22
|
-
}) {
|
|
23
|
-
const responsiveStyles = block.responsiveStyles;
|
|
24
|
-
if (!responsiveStyles) {
|
|
25
|
-
return {};
|
|
26
|
-
}
|
|
27
|
-
const styles = __spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues({}, context.inheritedStyles), responsiveStyles.large || {}), responsiveStyles.medium || {}), responsiveStyles.small || {}), blockStyles);
|
|
28
|
-
const newStyles = sanitizeReactNativeBlockStyles(styles);
|
|
29
|
-
return newStyles;
|
|
30
|
-
}
|
|
31
|
-
export {
|
|
32
|
-
getReactNativeBlockStyles
|
|
33
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { TARGET } from "../constants/target.js";
|
|
2
|
-
function ifTarget({
|
|
3
|
-
targets,
|
|
4
|
-
doThing,
|
|
5
|
-
elseThing
|
|
6
|
-
}) {
|
|
7
|
-
if (TARGET && targets.includes(TARGET)) {
|
|
8
|
-
return doThing();
|
|
9
|
-
} else {
|
|
10
|
-
return elseThing == null ? void 0 : elseThing();
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
export {
|
|
14
|
-
ifTarget
|
|
15
|
-
};
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { TARGET } from "../constants/target.js";
|
|
2
|
-
import { isIframe } from "./is-iframe.js";
|
|
3
|
-
function isEditing() {
|
|
4
|
-
return isIframe() && (TARGET === "reactNative" || window.location.search.indexOf("builder.frameEditing=") !== -1);
|
|
5
|
-
}
|
|
6
|
-
export {
|
|
7
|
-
isEditing
|
|
8
|
-
};
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { isBrowser } from "./is-browser.js";
|
|
2
|
-
import { isEditing } from "./is-editing.js";
|
|
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
|
-
};
|
|
@@ -1,27 +0,0 @@
|
|
|
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
|
-
};
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { onChange } from "./on-change.js";
|
|
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
|
-
});
|
|
@@ -1,68 +0,0 @@
|
|
|
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 __objRest = (source, exclude) => {
|
|
21
|
-
var target = {};
|
|
22
|
-
for (var prop in source)
|
|
23
|
-
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
-
target[prop] = source[prop];
|
|
25
|
-
if (source != null && __getOwnPropSymbols)
|
|
26
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
-
target[prop] = source[prop];
|
|
29
|
-
}
|
|
30
|
-
return target;
|
|
31
|
-
};
|
|
32
|
-
import { serializeFn } from "../blocks/util.js";
|
|
33
|
-
import { fastClone } from "./fast-clone.js";
|
|
34
|
-
const components = [];
|
|
35
|
-
function registerComponent(component, info) {
|
|
36
|
-
components.push(__spreadValues({ component }, info));
|
|
37
|
-
console.warn("registerComponent is deprecated. Use the `customComponents` prop in RenderContent instead to provide your custom components to the builder SDK.");
|
|
38
|
-
return component;
|
|
39
|
-
}
|
|
40
|
-
const createRegisterComponentMessage = (_a) => {
|
|
41
|
-
var _b = _a, {
|
|
42
|
-
component: _
|
|
43
|
-
} = _b, info = __objRest(_b, [
|
|
44
|
-
"component"
|
|
45
|
-
]);
|
|
46
|
-
return {
|
|
47
|
-
type: "builder.registerComponent",
|
|
48
|
-
data: prepareComponentInfoToSend(info)
|
|
49
|
-
};
|
|
50
|
-
};
|
|
51
|
-
const serializeValue = (value) => typeof value === "function" ? serializeFn(value) : fastClone(value);
|
|
52
|
-
const prepareComponentInfoToSend = (_c) => {
|
|
53
|
-
var _d = _c, {
|
|
54
|
-
inputs
|
|
55
|
-
} = _d, info = __objRest(_d, [
|
|
56
|
-
"inputs"
|
|
57
|
-
]);
|
|
58
|
-
return __spreadProps(__spreadValues({}, fastClone(info)), {
|
|
59
|
-
inputs: inputs == null ? void 0 : inputs.map((input) => Object.entries(input).reduce((acc, [key, value]) => __spreadProps(__spreadValues({}, acc), {
|
|
60
|
-
[key]: serializeValue(value)
|
|
61
|
-
}), {}))
|
|
62
|
-
});
|
|
63
|
-
};
|
|
64
|
-
export {
|
|
65
|
-
components,
|
|
66
|
-
createRegisterComponentMessage,
|
|
67
|
-
registerComponent
|
|
68
|
-
};
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { isBrowser } from "./is-browser.js";
|
|
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
|
-
};
|
|
@@ -1,66 +0,0 @@
|
|
|
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
|
-
const propertiesThatMustBeNumber = new Set(["lineHeight"]);
|
|
21
|
-
const displayValues = new Set(["flex", "none"]);
|
|
22
|
-
const SHOW_WARNINGS = false;
|
|
23
|
-
const normalizeNumber = (value) => {
|
|
24
|
-
if (Number.isNaN(value)) {
|
|
25
|
-
return void 0;
|
|
26
|
-
} else if (value < 0) {
|
|
27
|
-
return 0;
|
|
28
|
-
} else {
|
|
29
|
-
return value;
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
const sanitizeReactNativeBlockStyles = (styles) => {
|
|
33
|
-
return Object.keys(styles).reduce((acc, key) => {
|
|
34
|
-
const propertyValue = styles[key];
|
|
35
|
-
if (key === "display" && !displayValues.has(propertyValue)) {
|
|
36
|
-
if (SHOW_WARNINGS) {
|
|
37
|
-
console.warn(`Style value for key "display" must be "flex" or "none" but had ${propertyValue}`);
|
|
38
|
-
}
|
|
39
|
-
return acc;
|
|
40
|
-
}
|
|
41
|
-
if (propertiesThatMustBeNumber.has(key) && typeof propertyValue !== "number") {
|
|
42
|
-
if (SHOW_WARNINGS) {
|
|
43
|
-
console.warn(`Style key ${key} must be a number, but had value \`${styles[key]}\``);
|
|
44
|
-
}
|
|
45
|
-
return acc;
|
|
46
|
-
}
|
|
47
|
-
if (typeof propertyValue === "string") {
|
|
48
|
-
const isPixelUnit = propertyValue.match(/^-?(\d*)(\.?)(\d*)*px$/);
|
|
49
|
-
if (isPixelUnit) {
|
|
50
|
-
const newValue = parseFloat(propertyValue);
|
|
51
|
-
const normalizedValue = normalizeNumber(newValue);
|
|
52
|
-
if (normalizedValue) {
|
|
53
|
-
return __spreadProps(__spreadValues({}, acc), { [key]: normalizedValue });
|
|
54
|
-
} else {
|
|
55
|
-
return acc;
|
|
56
|
-
}
|
|
57
|
-
} else if (propertyValue === "0") {
|
|
58
|
-
return __spreadProps(__spreadValues({}, acc), { [key]: 0 });
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return __spreadProps(__spreadValues({}, acc), { [key]: propertyValue });
|
|
62
|
-
}, {});
|
|
63
|
-
};
|
|
64
|
-
export {
|
|
65
|
-
sanitizeReactNativeBlockStyles
|
|
66
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { isBrowser } from "./is-browser.js";
|
|
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
|
-
};
|
|
@@ -1,11 +0,0 @@
|
|
|
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
|
-
};
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { set } from "./set.js";
|
|
2
|
-
test("can shallow set a property", () => {
|
|
3
|
-
const obj = { foo: "bar" };
|
|
4
|
-
set(obj, "foo", "baz");
|
|
5
|
-
expect(obj.foo).toBe("baz");
|
|
6
|
-
});
|
|
7
|
-
test("can deeply set a property", () => {
|
|
8
|
-
const obj = { foo: "bar" };
|
|
9
|
-
set(obj, "foo.bar", "baz");
|
|
10
|
-
expect(obj.foo.bar).toBe("baz");
|
|
11
|
-
});
|
|
12
|
-
test("can deeply create arrays", () => {
|
|
13
|
-
const obj = { foo: "bar" };
|
|
14
|
-
set(obj, "foo.bar.0", "hi");
|
|
15
|
-
expect(obj.foo.bar).toEqual(["hi"]);
|
|
16
|
-
});
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { TARGET } from "../../constants/target";
|
|
2
|
-
import { isBrowser } from "../is-browser";
|
|
3
|
-
const getLocation = () => {
|
|
4
|
-
if (TARGET === "reactNative") {
|
|
5
|
-
return null;
|
|
6
|
-
} else if (isBrowser()) {
|
|
7
|
-
const parsedLocation = new URL(location.href);
|
|
8
|
-
if (parsedLocation.pathname === "") {
|
|
9
|
-
parsedLocation.pathname = "/";
|
|
10
|
-
}
|
|
11
|
-
return parsedLocation;
|
|
12
|
-
} else {
|
|
13
|
-
console.warn("Cannot get location for tracking in non-browser environment");
|
|
14
|
-
return null;
|
|
15
|
-
}
|
|
16
|
-
};
|
|
17
|
-
const getUserAgent = () => typeof navigator === "object" && navigator.userAgent || "";
|
|
18
|
-
const getUserAttributes = () => {
|
|
19
|
-
const userAgent = getUserAgent();
|
|
20
|
-
const isMobile = {
|
|
21
|
-
Android() {
|
|
22
|
-
return userAgent.match(/Android/i);
|
|
23
|
-
},
|
|
24
|
-
BlackBerry() {
|
|
25
|
-
return userAgent.match(/BlackBerry/i);
|
|
26
|
-
},
|
|
27
|
-
iOS() {
|
|
28
|
-
return userAgent.match(/iPhone|iPod/i);
|
|
29
|
-
},
|
|
30
|
-
Opera() {
|
|
31
|
-
return userAgent.match(/Opera Mini/i);
|
|
32
|
-
},
|
|
33
|
-
Windows() {
|
|
34
|
-
return userAgent.match(/IEMobile/i) || userAgent.match(/WPDesktop/i);
|
|
35
|
-
},
|
|
36
|
-
any() {
|
|
37
|
-
return isMobile.Android() || isMobile.BlackBerry() || isMobile.iOS() || isMobile.Opera() || isMobile.Windows() || TARGET === "reactNative";
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
const isTablet = userAgent.match(/Tablet|iPad/i);
|
|
41
|
-
const url = getLocation();
|
|
42
|
-
return {
|
|
43
|
-
urlPath: url == null ? void 0 : url.pathname,
|
|
44
|
-
host: (url == null ? void 0 : url.host) || (url == null ? void 0 : url.hostname),
|
|
45
|
-
device: isTablet ? "tablet" : isMobile.any() ? "mobile" : "desktop"
|
|
46
|
-
};
|
|
47
|
-
};
|
|
48
|
-
export {
|
|
49
|
-
getUserAttributes
|
|
50
|
-
};
|
|
@@ -1,129 +0,0 @@
|
|
|
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 __objRest = (source, exclude) => {
|
|
21
|
-
var target = {};
|
|
22
|
-
for (var prop in source)
|
|
23
|
-
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
-
target[prop] = source[prop];
|
|
25
|
-
if (source != null && __getOwnPropSymbols)
|
|
26
|
-
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
-
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
-
target[prop] = source[prop];
|
|
29
|
-
}
|
|
30
|
-
return target;
|
|
31
|
-
};
|
|
32
|
-
var __async = (__this, __arguments, generator) => {
|
|
33
|
-
return new Promise((resolve, reject) => {
|
|
34
|
-
var fulfilled = (value) => {
|
|
35
|
-
try {
|
|
36
|
-
step(generator.next(value));
|
|
37
|
-
} catch (e) {
|
|
38
|
-
reject(e);
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
var rejected = (value) => {
|
|
42
|
-
try {
|
|
43
|
-
step(generator.throw(value));
|
|
44
|
-
} catch (e) {
|
|
45
|
-
reject(e);
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
49
|
-
step((generator = generator.apply(__this, __arguments)).next());
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
import { TARGET } from "../../constants/target.js";
|
|
53
|
-
import { logger } from "../../helpers/logger.js";
|
|
54
|
-
import { getSessionId } from "../../helpers/sessionId.js";
|
|
55
|
-
import { getVisitorId } from "../../helpers/visitorId.js";
|
|
56
|
-
import { isBrowser } from "../is-browser.js";
|
|
57
|
-
import { isEditing } from "../is-editing.js";
|
|
58
|
-
import { getUserAttributes } from "./helpers.js";
|
|
59
|
-
const getTrackingEventData = (_0) => __async(void 0, [_0], function* ({
|
|
60
|
-
canTrack
|
|
61
|
-
}) {
|
|
62
|
-
if (!canTrack) {
|
|
63
|
-
return { visitorId: void 0, sessionId: void 0 };
|
|
64
|
-
}
|
|
65
|
-
const sessionId = yield getSessionId({ canTrack });
|
|
66
|
-
const visitorId = getVisitorId({ canTrack });
|
|
67
|
-
return {
|
|
68
|
-
sessionId,
|
|
69
|
-
visitorId
|
|
70
|
-
};
|
|
71
|
-
});
|
|
72
|
-
const createEvent = (_a) => __async(void 0, null, function* () {
|
|
73
|
-
var _b = _a, {
|
|
74
|
-
type: eventType,
|
|
75
|
-
canTrack,
|
|
76
|
-
apiKey,
|
|
77
|
-
metadata
|
|
78
|
-
} = _b, properties = __objRest(_b, [
|
|
79
|
-
"type",
|
|
80
|
-
"canTrack",
|
|
81
|
-
"apiKey",
|
|
82
|
-
"metadata"
|
|
83
|
-
]);
|
|
84
|
-
return {
|
|
85
|
-
type: eventType,
|
|
86
|
-
data: __spreadProps(__spreadValues(__spreadProps(__spreadValues({}, properties), {
|
|
87
|
-
metadata: __spreadValues({
|
|
88
|
-
url: location.href
|
|
89
|
-
}, metadata)
|
|
90
|
-
}), yield getTrackingEventData({ canTrack })), {
|
|
91
|
-
userAttributes: getUserAttributes(),
|
|
92
|
-
ownerId: apiKey
|
|
93
|
-
})
|
|
94
|
-
};
|
|
95
|
-
});
|
|
96
|
-
function _track(eventProps) {
|
|
97
|
-
return __async(this, null, function* () {
|
|
98
|
-
if (!eventProps.apiKey) {
|
|
99
|
-
logger.error("Missing API key for track call. Please provide your API key.");
|
|
100
|
-
return;
|
|
101
|
-
}
|
|
102
|
-
if (!eventProps.canTrack) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
if (isEditing()) {
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
if (!(isBrowser() || TARGET === "reactNative")) {
|
|
109
|
-
return;
|
|
110
|
-
}
|
|
111
|
-
return fetch(`https://builder.io/api/v1/track`, {
|
|
112
|
-
method: "POST",
|
|
113
|
-
body: JSON.stringify({
|
|
114
|
-
events: [yield createEvent(eventProps)]
|
|
115
|
-
}),
|
|
116
|
-
headers: {
|
|
117
|
-
"content-type": "application/json"
|
|
118
|
-
},
|
|
119
|
-
mode: "cors"
|
|
120
|
-
}).catch((err) => {
|
|
121
|
-
console.error("Failed to track: ", err);
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
const track = (args) => _track(__spreadProps(__spreadValues({}, args), { canTrack: true }));
|
|
126
|
-
export {
|
|
127
|
-
_track,
|
|
128
|
-
track
|
|
129
|
-
};
|