@builder.io/sdk-react-native 0.4.4 → 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/dist/blocks/button/button.js +6 -2
- package/dist/blocks/button/component-info.js +4 -8
- package/dist/blocks/columns/columns.js +19 -23
- package/dist/blocks/columns/component-info.js +27 -48
- package/dist/blocks/custom-code/component-info.js +4 -8
- package/dist/blocks/custom-code/custom-code.js +1 -1
- package/dist/blocks/embed/component-info.js +7 -11
- package/dist/blocks/embed/embed.js +1 -1
- package/dist/blocks/embed/helpers.js +2 -6
- package/dist/blocks/form/component-info.js +33 -69
- package/dist/blocks/form/form.js +2 -203
- package/dist/blocks/fragment/fragment.js +1 -1
- package/dist/blocks/helpers.js +33 -0
- package/dist/blocks/image/component-info.js +21 -47
- package/dist/blocks/image/image.helpers.js +2 -2
- package/dist/blocks/img/component-info.js +2 -4
- package/dist/blocks/img/img.js +2 -1
- package/dist/blocks/input/component-info.js +8 -34
- package/dist/blocks/input/input.js +2 -1
- package/dist/blocks/raw-text/component-info.js +2 -4
- package/dist/blocks/raw-text/raw-text.js +3 -2
- package/dist/blocks/section/component-info.js +5 -10
- package/dist/blocks/section/section.js +2 -1
- package/dist/blocks/select/component-info.js +12 -24
- package/dist/blocks/select/select.js +2 -1
- package/dist/blocks/submit-button/component-info.js +2 -4
- package/dist/blocks/submit-button/submit-button.js +2 -1
- package/dist/blocks/symbol/component-info.js +7 -12
- package/dist/blocks/symbol/symbol.helpers.js +66 -0
- package/dist/blocks/symbol/symbol.js +23 -50
- package/dist/blocks/text/component-info.js +3 -4
- package/dist/blocks/textarea/component-info.js +6 -12
- package/dist/blocks/textarea/textarea.js +2 -1
- package/dist/blocks/video/component-info.js +21 -41
- package/dist/components/block/block.helpers.js +102 -0
- package/dist/components/block/block.js +141 -0
- package/dist/components/block/components/block-styles.js +95 -0
- package/dist/components/block/components/block-wrapper/block-wrapper.js +41 -0
- package/dist/components/block/components/block-wrapper.js +56 -0
- package/dist/components/block/components/component-ref/component-ref.helpers.js +40 -0
- package/dist/components/block/components/component-ref/component-ref.js +63 -0
- package/dist/components/block/components/component-ref.js +81 -0
- package/dist/components/block/components/component.js +41 -0
- package/dist/components/block/components/interactive-element/interactive-element.helpers.js +35 -0
- package/dist/components/block/components/interactive-element/interactive-element.js +36 -0
- package/dist/components/block/components/interactive-element.js +46 -0
- package/dist/components/block/components/repeated-block.js +40 -0
- package/dist/components/block/types.js +1 -0
- package/dist/components/blocks/blocks-wrapper.js +69 -0
- package/dist/components/blocks/blocks.js +41 -0
- package/dist/components/content/builder-editing.js +32 -0
- package/dist/components/content/components/content-styles.helpers.js +55 -0
- package/dist/components/content/components/content-styles.js +61 -0
- package/dist/components/content/components/enable-editor.js +310 -0
- package/dist/components/content/components/styles.helpers.js +55 -0
- package/dist/components/content/components/styles.js +61 -0
- package/dist/components/content/content.helpers.js +49 -0
- package/dist/components/content/content.js +110 -0
- package/dist/components/content/content.types.js +1 -0
- package/dist/components/content/index.js +8 -0
- package/dist/components/content/wrap-component-ref.js +5 -0
- package/dist/components/content-variants/content-variants.js +77 -0
- package/dist/components/content-variants/content-variants.types.js +1 -0
- package/dist/components/content-variants/helpers.js +175 -0
- package/dist/components/inlined-script.js +32 -0
- package/dist/components/{render-inlined-styles.js → inlined-styles.js} +3 -3
- package/dist/components/render-block/block-styles.js +2 -2
- package/dist/components/render-content/components/render-styles.js +2 -2
- package/dist/components/render-content/render-content.js +10 -8
- package/dist/components/render-content-variants/helpers.js +49 -20
- package/dist/components/render-content-variants/render-content-variants.js +29 -24
- package/dist/components/render-content-variants/render-content-variants.types.js +1 -0
- package/dist/constants/device-sizes.js +2 -2
- package/dist/constants/sdk-version.js +1 -1
- package/dist/context/builder.context.js +1 -1
- package/dist/functions/apply-patch-with-mutation.js +75 -0
- package/dist/functions/apply-patch-with-mutation.test.js +55 -0
- package/dist/functions/camel-to-kebab-case.js +1 -1
- package/dist/functions/evaluate/acorn.js +1691 -0
- package/dist/functions/evaluate/evaluate.js +72 -0
- package/dist/functions/evaluate/index.js +5 -0
- package/dist/functions/evaluate/interpreter.js +2903 -0
- package/dist/functions/evaluate/non-node-runtime.js +97 -0
- package/dist/functions/evaluate/types.js +1 -0
- package/dist/functions/evaluate.test.js +12 -6
- package/dist/functions/event-handler-name.js +1 -1
- package/dist/functions/extract-text-styles.js +3 -9
- package/dist/functions/fast-clone.js +1 -1
- package/dist/functions/get-block-actions-handler.js +2 -2
- package/dist/functions/get-block-actions.js +14 -1
- package/dist/functions/get-block-component-options.js +6 -1
- package/dist/functions/get-block-properties.js +21 -8
- package/dist/functions/get-builder-search-params/fn.test.js +3 -3
- package/dist/functions/get-builder-search-params/index.js +4 -4
- package/dist/functions/get-content/generate-content-url.js +12 -5
- package/dist/functions/get-content/generate-content-url.test.js +31 -17
- package/dist/functions/get-content/index.js +36 -12
- package/dist/functions/get-content/processCookies.js +7 -0
- package/dist/functions/get-processed-block.js +8 -3
- package/dist/functions/get-processed-block.test.js +3 -1
- package/dist/functions/get-react-native-block-styles.js +6 -1
- package/dist/functions/is-non-node-server.js +12 -0
- package/dist/functions/on-change.test.js +13 -3
- package/dist/functions/register-component.js +24 -19
- package/dist/functions/sanitize-react-native-block-styles.js +17 -6
- package/dist/functions/set.test.js +9 -3
- package/dist/functions/track/helpers.js +5 -5
- package/dist/functions/track/index.js +29 -18
- package/dist/functions/track/interaction.js +10 -4
- package/dist/functions/transform-block-properties.js +2 -0
- package/dist/helpers/ab-tests.js +38 -14
- package/dist/helpers/canTrack.js +2 -2
- package/dist/helpers/css.js +2 -2
- package/dist/helpers/flatten.js +10 -7
- package/dist/helpers/nullable.js +1 -1
- package/dist/helpers/preview-lru-cache/get.js +11 -0
- package/dist/helpers/preview-lru-cache/helpers.js +13 -0
- package/dist/helpers/preview-lru-cache/init.js +13 -0
- package/dist/helpers/preview-lru-cache/set.js +37 -0
- package/dist/helpers/preview-lru-cache/types.js +1 -0
- package/dist/helpers/sessionId.js +13 -6
- package/dist/helpers/url.js +1 -1
- package/dist/helpers/visitorId.js +4 -1
- package/dist/index-helpers/blocks-exports.js +2 -2
- package/dist/scripts/init-editing.js +61 -46
- package/dist/types/builder-props.js +1 -0
- package/dist/types/enforced-partials.js +1 -0
- package/package.json +2 -2
- package/src/blocks/button/button.jsx +11 -2
- package/src/blocks/button/component-info.js +16 -22
- package/src/blocks/columns/columns.jsx +29 -28
- package/src/blocks/columns/component-info.js +203 -226
- package/src/blocks/custom-code/component-info.js +19 -25
- package/src/blocks/custom-code/custom-code.jsx +1 -1
- package/src/blocks/embed/component-info.js +31 -37
- package/src/blocks/embed/embed.jsx +1 -1
- package/src/blocks/embed/helpers.js +3 -9
- package/src/blocks/form/component-info.js +174 -212
- package/src/blocks/form/form.jsx +3 -247
- package/src/blocks/fragment/component-info.js +1 -3
- package/src/blocks/fragment/fragment.jsx +1 -1
- 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 +3 -1
- package/src/blocks/input/component-info.js +29 -57
- package/src/blocks/input/input.jsx +3 -1
- package/src/blocks/raw-text/component-info.js +7 -11
- package/src/blocks/raw-text/raw-text.jsx +4 -2
- package/src/blocks/section/component-info.js +24 -31
- package/src/blocks/section/section.jsx +3 -1
- package/src/blocks/select/component-info.js +34 -48
- package/src/blocks/select/select.jsx +3 -1
- package/src/blocks/submit-button/component-info.js +6 -10
- package/src/blocks/submit-button/submit-button.jsx +3 -2
- package/src/blocks/symbol/component-info.js +30 -37
- package/src/blocks/symbol/symbol.helpers.js +60 -0
- package/src/blocks/symbol/symbol.jsx +34 -59
- package/src/blocks/text/component-info.js +10 -13
- package/src/blocks/textarea/component-info.js +22 -30
- package/src/blocks/textarea/textarea.jsx +3 -1
- package/src/blocks/video/component-info.js +74 -96
- 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} +68 -81
- package/src/components/{render-block → block/components}/block-styles.jsx +19 -18
- package/src/components/block/components/block-wrapper.jsx +58 -0
- package/src/components/block/components/component-ref/component-ref.helpers.js +41 -0
- package/src/components/block/components/component-ref/component-ref.jsx +72 -0
- package/src/components/block/components/interactive-element.jsx +37 -0
- package/src/components/{render-block/render-repeated-block.jsx → block/components/repeated-block.jsx} +10 -6
- package/src/components/blocks/blocks-wrapper.jsx +74 -0
- package/src/components/blocks/blocks.jsx +51 -0
- package/src/components/{render-content/render-content.jsx → content/components/enable-editor.jsx} +81 -165
- 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} +7 -7
- package/src/components/{render-content/render-content.helpers.js → content/content.helpers.js} +15 -15
- package/src/components/content/content.jsx +141 -0
- package/src/components/content/content.types.js +0 -0
- package/src/components/content/index.js +2 -0
- package/src/components/content/wrap-component-ref.js +2 -0
- package/src/components/content-variants/content-variants.jsx +120 -0
- package/src/components/{render-content-variants → content-variants}/helpers.js +58 -41
- package/src/components/inlined-script.jsx +18 -0
- package/src/components/{render-inlined-styles.jsx → inlined-styles.jsx} +3 -3
- 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 +2 -0
- package/src/helpers/ab-tests.js +46 -26
- package/src/helpers/canTrack.js +3 -5
- 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 +1 -1
- 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/types/enforced-partials.js +0 -0
- package/dist/blocks/BaseText.d.ts +0 -6
- package/dist/blocks/button/button.d.ts +0 -9
- package/dist/blocks/button/component-info.d.ts +0 -2
- package/dist/blocks/columns/columns.d.ts +0 -16
- package/dist/blocks/columns/component-info.d.ts +0 -2
- package/dist/blocks/custom-code/component-info.d.ts +0 -2
- package/dist/blocks/custom-code/custom-code.d.ts +0 -5
- package/dist/blocks/embed/component-info.d.ts +0 -2
- package/dist/blocks/embed/embed.d.ts +0 -5
- package/dist/blocks/embed/helpers.d.ts +0 -1
- package/dist/blocks/form/component-info.d.ts +0 -2
- package/dist/blocks/form/form.d.ts +0 -28
- package/dist/blocks/fragment/component-info.d.ts +0 -2
- package/dist/blocks/fragment/fragment.d.ts +0 -8
- package/dist/blocks/image/component-info.d.ts +0 -2
- package/dist/blocks/image/image.d.ts +0 -17
- package/dist/blocks/image/image.helpers.d.ts +0 -1
- package/dist/blocks/img/component-info.d.ts +0 -2
- package/dist/blocks/img/img.d.ts +0 -11
- package/dist/blocks/input/component-info.d.ts +0 -2
- package/dist/blocks/input/input.d.ts +0 -12
- package/dist/blocks/raw-text/component-info.d.ts +0 -2
- package/dist/blocks/raw-text/raw-text.d.ts +0 -5
- package/dist/blocks/section/component-info.d.ts +0 -2
- package/dist/blocks/section/section.d.ts +0 -9
- package/dist/blocks/select/component-info.d.ts +0 -2
- package/dist/blocks/select/select.d.ts +0 -13
- package/dist/blocks/submit-button/component-info.d.ts +0 -2
- package/dist/blocks/submit-button/submit-button.d.ts +0 -7
- package/dist/blocks/symbol/component-info.d.ts +0 -2
- package/dist/blocks/symbol/symbol.d.ts +0 -21
- package/dist/blocks/text/component-info.d.ts +0 -2
- package/dist/blocks/text/text.d.ts +0 -7
- package/dist/blocks/textarea/component-info.d.ts +0 -2
- package/dist/blocks/textarea/textarea.d.ts +0 -10
- package/dist/blocks/util.d.ts +0 -4
- package/dist/blocks/video/component-info.d.ts +0 -2
- package/dist/blocks/video/video.d.ts +0 -31
- package/dist/components/render-block/block-styles.d.ts +0 -9
- package/dist/components/render-block/render-block.d.ts +0 -9
- package/dist/components/render-block/render-block.helpers.d.ts +0 -12
- package/dist/components/render-block/render-component.d.ts +0 -17
- package/dist/components/render-block/render-repeated-block.d.ts +0 -9
- package/dist/components/render-block/types.d.ts +0 -6
- package/dist/components/render-blocks.d.ts +0 -10
- package/dist/components/render-content/builder-editing.d.ts +0 -3
- package/dist/components/render-content/components/render-styles.d.ts +0 -9
- package/dist/components/render-content/components/render-styles.helpers.d.ts +0 -15
- package/dist/components/render-content/index.d.ts +0 -1
- package/dist/components/render-content/render-content.d.ts +0 -4
- package/dist/components/render-content/render-content.helpers.d.ts +0 -7
- package/dist/components/render-content/render-content.types.d.ts +0 -38
- package/dist/components/render-content/wrap-component-ref.d.ts +0 -6
- package/dist/components/render-content-variants/helpers.d.ts +0 -17
- package/dist/components/render-content-variants/render-content-variants.d.ts +0 -5
- package/dist/components/render-inlined-styles.d.ts +0 -7
- package/dist/constants/builder-registered-components.d.ts +0 -6
- package/dist/constants/device-sizes.d.ts +0 -13
- package/dist/constants/sdk-version.d.ts +0 -1
- package/dist/constants/target.d.ts +0 -3
- package/dist/context/builder.context.d.ts +0 -3
- package/dist/context/types.d.ts +0 -35
- package/dist/functions/camel-to-kebab-case.d.ts +0 -1
- package/dist/functions/evaluate.d.ts +0 -7
- package/dist/functions/evaluate.test.d.ts +0 -1
- package/dist/functions/event-handler-name.d.ts +0 -1
- package/dist/functions/extract-text-styles.d.ts +0 -4
- package/dist/functions/fast-clone.d.ts +0 -4
- package/dist/functions/get-block-actions-handler.d.ts +0 -8
- package/dist/functions/get-block-actions.d.ts +0 -9
- package/dist/functions/get-block-component-options.d.ts +0 -2
- package/dist/functions/get-block-properties.d.ts +0 -2
- package/dist/functions/get-builder-search-params/fn.test.d.ts +0 -1
- package/dist/functions/get-builder-search-params/index.d.ts +0 -12
- package/dist/functions/get-content/generate-content-url.d.ts +0 -2
- package/dist/functions/get-content/generate-content-url.test.d.ts +0 -1
- package/dist/functions/get-content/index.d.ts +0 -16
- package/dist/functions/get-content/types.d.ts +0 -51
- package/dist/functions/get-fetch.d.ts +0 -1
- package/dist/functions/get-processed-block.d.ts +0 -10
- package/dist/functions/get-processed-block.test.d.ts +0 -1
- package/dist/functions/get-react-native-block-styles.d.ts +0 -7
- package/dist/functions/if-target.d.ts +0 -7
- package/dist/functions/is-browser.d.ts +0 -1
- package/dist/functions/is-editing.d.ts +0 -1
- package/dist/functions/is-iframe.d.ts +0 -1
- package/dist/functions/is-previewing.d.ts +0 -1
- package/dist/functions/on-change.d.ts +0 -7
- package/dist/functions/on-change.test.d.ts +0 -1
- package/dist/functions/register-component.d.ts +0 -14
- package/dist/functions/register.d.ts +0 -16
- package/dist/functions/sanitize-react-native-block-styles.d.ts +0 -3
- package/dist/functions/set-editor-settings.d.ts +0 -4
- package/dist/functions/set.d.ts +0 -7
- package/dist/functions/set.test.d.ts +0 -1
- package/dist/functions/track/helpers.d.ts +0 -5
- package/dist/functions/track/index.d.ts +0 -51
- package/dist/functions/track/interaction.d.ts +0 -13
- package/dist/functions/transform-block-properties.d.ts +0 -3
- package/dist/functions/transform-block.d.ts +0 -2
- package/dist/helpers/ab-tests.d.ts +0 -9
- package/dist/helpers/canTrack.d.ts +0 -1
- package/dist/helpers/cookie.d.ts +0 -9
- package/dist/helpers/css.d.ts +0 -7
- package/dist/helpers/flatten.d.ts +0 -6
- package/dist/helpers/localStorage.d.ts +0 -9
- package/dist/helpers/logger.d.ts +0 -6
- package/dist/helpers/nullable.d.ts +0 -2
- package/dist/helpers/sessionId.d.ts +0 -6
- package/dist/helpers/time.d.ts +0 -1
- package/dist/helpers/url.d.ts +0 -6
- package/dist/helpers/url.test.d.ts +0 -1
- package/dist/helpers/uuid.d.ts +0 -8
- package/dist/helpers/visitorId.d.ts +0 -6
- package/dist/index-helpers/blocks-exports.d.ts +0 -8
- package/dist/index-helpers/top-of-file.d.ts +0 -1
- package/dist/index.d.ts +0 -15
- package/dist/scripts/init-editing.d.ts +0 -6
- package/dist/types/api-version.d.ts +0 -2
- package/dist/types/builder-block.d.ts +0 -66
- package/dist/types/builder-content.d.ts +0 -44
- package/dist/types/can-track.d.ts +0 -3
- package/dist/types/components.d.ts +0 -105
- package/dist/types/deep-partial.d.ts +0 -3
- package/dist/types/element.d.ts +0 -59
- package/dist/types/input.d.ts +0 -121
- package/dist/types/targets.d.ts +0 -3
- package/dist/types/typescript.d.ts +0 -5
- package/src/blocks/util.js +0 -8
- package/src/components/render-block/render-component.jsx +0 -55
- package/src/components/render-blocks.jsx +0 -101
- package/src/components/render-content/builder-editing.jsx +0 -16
- package/src/components/render-content/index.js +0 -4
- package/src/components/render-content/wrap-component-ref.js +0 -4
- package/src/components/render-content-variants/render-content-variants.jsx +0 -101
- 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-variants/content-variants.types.js} +0 -0
|
@@ -22,7 +22,9 @@ test("Can process bindings", () => {
|
|
|
22
22
|
const processed = (0, get_processed_block_js_1.getProcessedBlock)({
|
|
23
23
|
block,
|
|
24
24
|
context: {},
|
|
25
|
-
rootState: {
|
|
25
|
+
rootState: {
|
|
26
|
+
test: "hello"
|
|
27
|
+
},
|
|
26
28
|
rootSetState: void 0,
|
|
27
29
|
localState: void 0,
|
|
28
30
|
shouldEvaluateBindings: true
|
|
@@ -5,7 +5,12 @@ var __defProp = Object.defineProperty;
|
|
|
5
5
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
7
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
8
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
configurable: true,
|
|
11
|
+
writable: true,
|
|
12
|
+
value
|
|
13
|
+
}) : obj[key] = value;
|
|
9
14
|
var __spreadValues = (a, b) => {
|
|
10
15
|
for (var prop in b || (b = {}))
|
|
11
16
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isNonNodeServer = void 0;
|
|
4
|
+
const is_browser_1 = require("./is-browser");
|
|
5
|
+
function isNonNodeServer() {
|
|
6
|
+
const hasNode = () => {
|
|
7
|
+
var _a;
|
|
8
|
+
return typeof process !== "undefined" && ((_a = process == null ? void 0 : process.versions) == null ? void 0 : _a.node);
|
|
9
|
+
};
|
|
10
|
+
return !(0, is_browser_1.isBrowser)() && !hasNode();
|
|
11
|
+
}
|
|
12
|
+
exports.isNonNodeServer = isNonNodeServer;
|
|
@@ -3,19 +3,29 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const on_change_js_1 = require("./on-change.js");
|
|
4
4
|
test("onChange can observe a shallow change", () => {
|
|
5
5
|
let changeHappend = false;
|
|
6
|
-
const obj = (0, on_change_js_1.onChange)({
|
|
6
|
+
const obj = (0, on_change_js_1.onChange)({
|
|
7
|
+
foo: "hi"
|
|
8
|
+
}, () => changeHappend = true);
|
|
7
9
|
obj.foo = "yo";
|
|
8
10
|
expect(changeHappend).toBe(true);
|
|
9
11
|
});
|
|
10
12
|
test("onChange can observe a deep change", () => {
|
|
11
13
|
let changeHappend = false;
|
|
12
|
-
const obj = (0, on_change_js_1.onChange)({
|
|
14
|
+
const obj = (0, on_change_js_1.onChange)({
|
|
15
|
+
foo: {
|
|
16
|
+
bar: "hi"
|
|
17
|
+
}
|
|
18
|
+
}, () => changeHappend = true);
|
|
13
19
|
obj.foo.bar = "yo";
|
|
14
20
|
expect(changeHappend).toBe(true);
|
|
15
21
|
});
|
|
16
22
|
test("Smoke test: callback is not fired if no properties updated", () => {
|
|
17
23
|
let changeHappend = false;
|
|
18
|
-
const obj = (0, on_change_js_1.onChange)({
|
|
24
|
+
const obj = (0, on_change_js_1.onChange)({
|
|
25
|
+
foo: {
|
|
26
|
+
bar: "hi"
|
|
27
|
+
}
|
|
28
|
+
}, () => changeHappend = true);
|
|
19
29
|
obj.foo.bar;
|
|
20
30
|
expect(changeHappend).toBe(false);
|
|
21
31
|
});
|
|
@@ -1,13 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.registerComponent = exports.createRegisterComponentMessage = exports.components = void 0;
|
|
3
|
+
exports.serializeComponentInfo = exports.registerComponent = exports.createRegisterComponentMessage = exports.components = void 0;
|
|
4
4
|
var __defProp = Object.defineProperty;
|
|
5
5
|
var __defProps = Object.defineProperties;
|
|
6
6
|
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
7
7
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
8
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
9
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
10
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
10
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
configurable: true,
|
|
13
|
+
writable: true,
|
|
14
|
+
value
|
|
15
|
+
}) : obj[key] = value;
|
|
11
16
|
var __spreadValues = (a, b) => {
|
|
12
17
|
for (var prop in b || (b = {}))
|
|
13
18
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -32,34 +37,34 @@ var __objRest = (source, exclude) => {
|
|
|
32
37
|
}
|
|
33
38
|
return target;
|
|
34
39
|
};
|
|
35
|
-
const util_js_1 = require("../blocks/util.js");
|
|
36
40
|
const fast_clone_js_1 = require("./fast-clone.js");
|
|
37
41
|
const components = [];
|
|
38
42
|
exports.components = components;
|
|
39
43
|
function registerComponent(component, info) {
|
|
40
|
-
components.push(__spreadValues({
|
|
44
|
+
components.push(__spreadValues({
|
|
45
|
+
component
|
|
46
|
+
}, info));
|
|
41
47
|
console.warn("registerComponent is deprecated. Use the `customComponents` prop in RenderContent instead to provide your custom components to the builder SDK.");
|
|
42
48
|
return component;
|
|
43
49
|
}
|
|
44
50
|
exports.registerComponent = registerComponent;
|
|
45
|
-
const createRegisterComponentMessage =
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
return {
|
|
50
|
-
type: "builder.registerComponent",
|
|
51
|
-
data: prepareComponentInfoToSend(info)
|
|
52
|
-
};
|
|
53
|
-
};
|
|
51
|
+
const createRegisterComponentMessage = info => ({
|
|
52
|
+
type: "builder.registerComponent",
|
|
53
|
+
data: info
|
|
54
|
+
});
|
|
54
55
|
exports.createRegisterComponentMessage = createRegisterComponentMessage;
|
|
55
|
-
const
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
56
|
+
const serializeFn = fnValue => {
|
|
57
|
+
const fnStr = fnValue.toString().trim();
|
|
58
|
+
const appendFunction = !fnStr.startsWith("function") && !fnStr.startsWith("(");
|
|
59
|
+
return `return (${appendFunction ? "function " : ""}${fnStr}).apply(this, arguments)`;
|
|
60
|
+
};
|
|
61
|
+
const serializeValue = value => typeof value === "function" ? serializeFn(value) : (0, fast_clone_js_1.fastClone)(value);
|
|
62
|
+
const serializeComponentInfo = _a => {
|
|
63
|
+
var _b = _a, { inputs } = _b, info = __objRest(_b, ["inputs"]);
|
|
60
64
|
return __spreadProps(__spreadValues({}, (0, fast_clone_js_1.fastClone)(info)), {
|
|
61
|
-
inputs: inputs == null ? void 0 : inputs.map(
|
|
65
|
+
inputs: inputs == null ? void 0 : inputs.map(input => Object.entries(input).reduce((acc, [key, value]) => __spreadProps(__spreadValues({}, acc), {
|
|
62
66
|
[key]: serializeValue(value)
|
|
63
67
|
}), {}))
|
|
64
68
|
});
|
|
65
69
|
};
|
|
70
|
+
exports.serializeComponentInfo = serializeComponentInfo;
|
|
@@ -7,7 +7,12 @@ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
|
7
7
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
8
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
9
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
10
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
10
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
configurable: true,
|
|
13
|
+
writable: true,
|
|
14
|
+
value
|
|
15
|
+
}) : obj[key] = value;
|
|
11
16
|
var __spreadValues = (a, b) => {
|
|
12
17
|
for (var prop in b || (b = {}))
|
|
13
18
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -23,7 +28,7 @@ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
|
23
28
|
const propertiesThatMustBeNumber = new Set(["lineHeight"]);
|
|
24
29
|
const displayValues = new Set(["flex", "none"]);
|
|
25
30
|
const SHOW_WARNINGS = false;
|
|
26
|
-
const normalizeNumber =
|
|
31
|
+
const normalizeNumber = value => {
|
|
27
32
|
if (Number.isNaN(value)) {
|
|
28
33
|
return void 0;
|
|
29
34
|
}
|
|
@@ -34,7 +39,7 @@ const normalizeNumber = (value) => {
|
|
|
34
39
|
return value;
|
|
35
40
|
}
|
|
36
41
|
};
|
|
37
|
-
const sanitizeReactNativeBlockStyles =
|
|
42
|
+
const sanitizeReactNativeBlockStyles = styles => {
|
|
38
43
|
return Object.keys(styles).reduce((acc, key) => {
|
|
39
44
|
const propertyValue = styles[key];
|
|
40
45
|
if (key === "display" && !displayValues.has(propertyValue)) {
|
|
@@ -55,17 +60,23 @@ const sanitizeReactNativeBlockStyles = (styles) => {
|
|
|
55
60
|
const newValue = parseFloat(propertyValue);
|
|
56
61
|
const normalizedValue = normalizeNumber(newValue);
|
|
57
62
|
if (normalizedValue) {
|
|
58
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
63
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
64
|
+
[key]: normalizedValue
|
|
65
|
+
});
|
|
59
66
|
}
|
|
60
67
|
else {
|
|
61
68
|
return acc;
|
|
62
69
|
}
|
|
63
70
|
}
|
|
64
71
|
else if (propertyValue === "0") {
|
|
65
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
72
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
73
|
+
[key]: 0
|
|
74
|
+
});
|
|
66
75
|
}
|
|
67
76
|
}
|
|
68
|
-
return __spreadProps(__spreadValues({}, acc), {
|
|
77
|
+
return __spreadProps(__spreadValues({}, acc), {
|
|
78
|
+
[key]: propertyValue
|
|
79
|
+
});
|
|
69
80
|
}, {});
|
|
70
81
|
};
|
|
71
82
|
exports.sanitizeReactNativeBlockStyles = sanitizeReactNativeBlockStyles;
|
|
@@ -2,17 +2,23 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const set_js_1 = require("./set.js");
|
|
4
4
|
test("can shallow set a property", () => {
|
|
5
|
-
const obj = {
|
|
5
|
+
const obj = {
|
|
6
|
+
foo: "bar"
|
|
7
|
+
};
|
|
6
8
|
(0, set_js_1.set)(obj, "foo", "baz");
|
|
7
9
|
expect(obj.foo).toBe("baz");
|
|
8
10
|
});
|
|
9
11
|
test("can deeply set a property", () => {
|
|
10
|
-
const obj = {
|
|
12
|
+
const obj = {
|
|
13
|
+
foo: "bar"
|
|
14
|
+
};
|
|
11
15
|
(0, set_js_1.set)(obj, "foo.bar", "baz");
|
|
12
16
|
expect(obj.foo.bar).toBe("baz");
|
|
13
17
|
});
|
|
14
18
|
test("can deeply create arrays", () => {
|
|
15
|
-
const obj = {
|
|
19
|
+
const obj = {
|
|
20
|
+
foo: "bar"
|
|
21
|
+
};
|
|
16
22
|
(0, set_js_1.set)(obj, "foo.bar.0", "hi");
|
|
17
23
|
expect(obj.foo.bar).toEqual(["hi"]);
|
|
18
24
|
});
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getUserAttributes = void 0;
|
|
4
|
-
const
|
|
5
|
-
const
|
|
4
|
+
const target_js_1 = require("../../constants/target.js");
|
|
5
|
+
const is_browser_js_1 = require("../is-browser.js");
|
|
6
6
|
const getLocation = () => {
|
|
7
|
-
if (
|
|
7
|
+
if (target_js_1.TARGET === "reactNative") {
|
|
8
8
|
return null;
|
|
9
9
|
}
|
|
10
|
-
else if ((0,
|
|
10
|
+
else if ((0, is_browser_js_1.isBrowser)()) {
|
|
11
11
|
const parsedLocation = new URL(location.href);
|
|
12
12
|
if (parsedLocation.pathname === "") {
|
|
13
13
|
parsedLocation.pathname = "/";
|
|
@@ -39,7 +39,7 @@ const getUserAttributes = () => {
|
|
|
39
39
|
return userAgent.match(/IEMobile/i) || userAgent.match(/WPDesktop/i);
|
|
40
40
|
},
|
|
41
41
|
any() {
|
|
42
|
-
return isMobile.Android() || isMobile.BlackBerry() || isMobile.iOS() || isMobile.Opera() || isMobile.Windows() ||
|
|
42
|
+
return isMobile.Android() || isMobile.BlackBerry() || isMobile.iOS() || isMobile.Opera() || isMobile.Windows() || target_js_1.TARGET === "reactNative";
|
|
43
43
|
}
|
|
44
44
|
};
|
|
45
45
|
const isTablet = userAgent.match(/Tablet|iPad/i);
|
|
@@ -7,7 +7,12 @@ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
|
7
7
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
8
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
9
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
10
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
10
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
configurable: true,
|
|
13
|
+
writable: true,
|
|
14
|
+
value
|
|
15
|
+
}) : obj[key] = value;
|
|
11
16
|
var __spreadValues = (a, b) => {
|
|
12
17
|
for (var prop in b || (b = {}))
|
|
13
18
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -34,7 +39,7 @@ var __objRest = (source, exclude) => {
|
|
|
34
39
|
};
|
|
35
40
|
var __async = (__this, __arguments, generator) => {
|
|
36
41
|
return new Promise((resolve, reject) => {
|
|
37
|
-
var fulfilled =
|
|
42
|
+
var fulfilled = value => {
|
|
38
43
|
try {
|
|
39
44
|
step(generator.next(value));
|
|
40
45
|
}
|
|
@@ -42,7 +47,7 @@ var __async = (__this, __arguments, generator) => {
|
|
|
42
47
|
reject(e);
|
|
43
48
|
}
|
|
44
49
|
};
|
|
45
|
-
var rejected =
|
|
50
|
+
var rejected = value => {
|
|
46
51
|
try {
|
|
47
52
|
step(generator.throw(value));
|
|
48
53
|
}
|
|
@@ -50,7 +55,7 @@ var __async = (__this, __arguments, generator) => {
|
|
|
50
55
|
reject(e);
|
|
51
56
|
}
|
|
52
57
|
};
|
|
53
|
-
var step =
|
|
58
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
54
59
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
55
60
|
});
|
|
56
61
|
};
|
|
@@ -61,31 +66,35 @@ const visitorId_js_1 = require("../../helpers/visitorId.js");
|
|
|
61
66
|
const is_browser_js_1 = require("../is-browser.js");
|
|
62
67
|
const is_editing_js_1 = require("../is-editing.js");
|
|
63
68
|
const helpers_js_1 = require("./helpers.js");
|
|
64
|
-
const getTrackingEventData =
|
|
69
|
+
const getTrackingEventData = _0 => __async(void 0, [_0], function* ({ canTrack }) {
|
|
65
70
|
if (!canTrack) {
|
|
66
|
-
return {
|
|
71
|
+
return {
|
|
72
|
+
visitorId: void 0,
|
|
73
|
+
sessionId: void 0
|
|
74
|
+
};
|
|
67
75
|
}
|
|
68
|
-
const sessionId = yield (0, sessionId_js_1.getSessionId)({
|
|
69
|
-
|
|
76
|
+
const sessionId = yield (0, sessionId_js_1.getSessionId)({
|
|
77
|
+
canTrack
|
|
78
|
+
});
|
|
79
|
+
const visitorId = (0, visitorId_js_1.getVisitorId)({
|
|
80
|
+
canTrack
|
|
81
|
+
});
|
|
70
82
|
return {
|
|
71
83
|
sessionId,
|
|
72
84
|
visitorId
|
|
73
85
|
};
|
|
74
86
|
});
|
|
75
|
-
const createEvent =
|
|
76
|
-
var _b = _a, { type: eventType, canTrack, apiKey, metadata } = _b, properties = __objRest(_b, [
|
|
77
|
-
"type",
|
|
78
|
-
"canTrack",
|
|
79
|
-
"apiKey",
|
|
80
|
-
"metadata"
|
|
81
|
-
]);
|
|
87
|
+
const createEvent = _a => __async(void 0, null, function* () {
|
|
88
|
+
var _b = _a, { type: eventType, canTrack, apiKey, metadata } = _b, properties = __objRest(_b, ["type", "canTrack", "apiKey", "metadata"]);
|
|
82
89
|
return {
|
|
83
90
|
type: eventType,
|
|
84
91
|
data: __spreadProps(__spreadValues(__spreadProps(__spreadValues({}, properties), {
|
|
85
92
|
metadata: __spreadValues({
|
|
86
93
|
url: location.href
|
|
87
94
|
}, metadata)
|
|
88
|
-
}), yield getTrackingEventData({
|
|
95
|
+
}), yield getTrackingEventData({
|
|
96
|
+
canTrack
|
|
97
|
+
})), {
|
|
89
98
|
userAttributes: (0, helpers_js_1.getUserAttributes)(),
|
|
90
99
|
ownerId: apiKey
|
|
91
100
|
})
|
|
@@ -115,11 +124,13 @@ function _track(eventProps) {
|
|
|
115
124
|
"content-type": "application/json"
|
|
116
125
|
},
|
|
117
126
|
mode: "cors"
|
|
118
|
-
}).catch(
|
|
127
|
+
}).catch(err => {
|
|
119
128
|
console.error("Failed to track: ", err);
|
|
120
129
|
});
|
|
121
130
|
});
|
|
122
131
|
}
|
|
123
132
|
exports._track = _track;
|
|
124
|
-
const track =
|
|
133
|
+
const track = args => _track(__spreadProps(__spreadValues({}, args), {
|
|
134
|
+
canTrack: true
|
|
135
|
+
}));
|
|
125
136
|
exports.track = track;
|
|
@@ -20,7 +20,7 @@ const findParentElement = (target, callback, checkElement = true) => {
|
|
|
20
20
|
} while (parent = parent.parentElement);
|
|
21
21
|
return null;
|
|
22
22
|
};
|
|
23
|
-
const findBuilderParent =
|
|
23
|
+
const findBuilderParent = target => findParentElement(target, el => {
|
|
24
24
|
const id = el.getAttribute("builder-id") || el.id;
|
|
25
25
|
return Boolean((id == null ? void 0 : id.indexOf("builder-")) === 0);
|
|
26
26
|
});
|
|
@@ -35,15 +35,21 @@ const computeOffset = ({ event, target }) => {
|
|
|
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
|
};
|
|
@@ -4,6 +4,8 @@ exports.transformBlockProperties = void 0;
|
|
|
4
4
|
const is_editing_js_1 = require("./is-editing.js");
|
|
5
5
|
const react_dom_1 = require("react-dom");
|
|
6
6
|
function transformBlockProperties(block) {
|
|
7
|
+
block.className = block.class;
|
|
8
|
+
delete block.class;
|
|
7
9
|
block.ref = (ref) => {
|
|
8
10
|
if ((0, is_editing_js_1.isEditing)()) {
|
|
9
11
|
const el = (0, react_dom_1.findDOMNode)(ref);
|
package/dist/helpers/ab-tests.js
CHANGED
|
@@ -5,7 +5,12 @@ var __defProp = Object.defineProperty;
|
|
|
5
5
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
7
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
8
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
configurable: true,
|
|
11
|
+
writable: true,
|
|
12
|
+
value
|
|
13
|
+
}) : obj[key] = value;
|
|
9
14
|
var __spreadValues = (a, b) => {
|
|
10
15
|
for (var prop in b || (b = {}))
|
|
11
16
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -19,7 +24,7 @@ var __spreadValues = (a, b) => {
|
|
|
19
24
|
};
|
|
20
25
|
var __async = (__this, __arguments, generator) => {
|
|
21
26
|
return new Promise((resolve, reject) => {
|
|
22
|
-
var fulfilled =
|
|
27
|
+
var fulfilled = value => {
|
|
23
28
|
try {
|
|
24
29
|
step(generator.next(value));
|
|
25
30
|
}
|
|
@@ -27,7 +32,7 @@ var __async = (__this, __arguments, generator) => {
|
|
|
27
32
|
reject(e);
|
|
28
33
|
}
|
|
29
34
|
};
|
|
30
|
-
var rejected =
|
|
35
|
+
var rejected = value => {
|
|
31
36
|
try {
|
|
32
37
|
step(generator.throw(value));
|
|
33
38
|
}
|
|
@@ -35,19 +40,30 @@ var __async = (__this, __arguments, generator) => {
|
|
|
35
40
|
reject(e);
|
|
36
41
|
}
|
|
37
42
|
};
|
|
38
|
-
var step =
|
|
43
|
+
var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
39
44
|
step((generator = generator.apply(__this, __arguments)).next());
|
|
40
45
|
});
|
|
41
46
|
};
|
|
42
47
|
const cookie_js_1 = require("./cookie.js");
|
|
43
48
|
const nullable_js_1 = require("../helpers/nullable.js");
|
|
44
49
|
const logger_js_1 = require("./logger.js");
|
|
50
|
+
const target_js_1 = require("../constants/target.js");
|
|
45
51
|
const BUILDER_STORE_PREFIX = "builder.tests";
|
|
46
|
-
const getContentTestKey =
|
|
47
|
-
const getContentVariationCookie = ({ contentId }) => (0, cookie_js_1.getCookie)({
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
52
|
+
const getContentTestKey = id => `${BUILDER_STORE_PREFIX}.${id}`;
|
|
53
|
+
const getContentVariationCookie = ({ contentId }) => (0, cookie_js_1.getCookie)({
|
|
54
|
+
name: getContentTestKey(contentId),
|
|
55
|
+
canTrack: true
|
|
56
|
+
});
|
|
57
|
+
const getContentVariationCookieSync = ({ contentId }) => (0, cookie_js_1.getCookieSync)({
|
|
58
|
+
name: getContentTestKey(contentId),
|
|
59
|
+
canTrack: true
|
|
60
|
+
});
|
|
61
|
+
const setContentVariationCookie = ({ contentId, value }) => (0, cookie_js_1.setCookie)({
|
|
62
|
+
name: getContentTestKey(contentId),
|
|
63
|
+
value,
|
|
64
|
+
canTrack: true
|
|
65
|
+
});
|
|
66
|
+
const checkIsBuilderContentWithVariations = item => (0, nullable_js_1.checkIsDefined)(item.id) && (0, nullable_js_1.checkIsDefined)(item.variations) && Object.keys(item.variations).length > 0;
|
|
51
67
|
const getRandomVariationId = ({ id, variations }) => {
|
|
52
68
|
var _a;
|
|
53
69
|
let n = 0;
|
|
@@ -61,12 +77,12 @@ const getRandomVariationId = ({ id, variations }) => {
|
|
|
61
77
|
}
|
|
62
78
|
return id;
|
|
63
79
|
};
|
|
64
|
-
const getAndSetVariantId =
|
|
80
|
+
const getAndSetVariantId = args => {
|
|
65
81
|
const randomVariationId = getRandomVariationId(args);
|
|
66
82
|
setContentVariationCookie({
|
|
67
83
|
contentId: args.id,
|
|
68
84
|
value: randomVariationId
|
|
69
|
-
}).catch(
|
|
85
|
+
}).catch(err => {
|
|
70
86
|
logger_js_1.logger.error("could not store A/B test variation: ", err);
|
|
71
87
|
});
|
|
72
88
|
return randomVariationId;
|
|
@@ -88,6 +104,8 @@ const getTestFields = ({ item, testGroupId }) => {
|
|
|
88
104
|
}
|
|
89
105
|
};
|
|
90
106
|
const handleABTestingSync = ({ item, canTrack }) => {
|
|
107
|
+
if (target_js_1.TARGET === "reactNative")
|
|
108
|
+
return item;
|
|
91
109
|
if (!canTrack) {
|
|
92
110
|
return item;
|
|
93
111
|
}
|
|
@@ -103,11 +121,14 @@ const handleABTestingSync = ({ item, canTrack }) => {
|
|
|
103
121
|
variations: item.variations,
|
|
104
122
|
id: item.id
|
|
105
123
|
});
|
|
106
|
-
const variationValue = getTestFields({
|
|
124
|
+
const variationValue = getTestFields({
|
|
125
|
+
item,
|
|
126
|
+
testGroupId
|
|
127
|
+
});
|
|
107
128
|
return __spreadValues(__spreadValues({}, item), variationValue);
|
|
108
129
|
};
|
|
109
130
|
exports.handleABTestingSync = handleABTestingSync;
|
|
110
|
-
const handleABTesting =
|
|
131
|
+
const handleABTesting = _0 => __async(void 0, [_0], function* ({ item, canTrack }) {
|
|
111
132
|
if (!canTrack) {
|
|
112
133
|
return item;
|
|
113
134
|
}
|
|
@@ -121,7 +142,10 @@ const handleABTesting = (_0) => __async(void 0, [_0], function* ({ item, canTrac
|
|
|
121
142
|
variations: item.variations,
|
|
122
143
|
id: item.id
|
|
123
144
|
});
|
|
124
|
-
const variationValue = getTestFields({
|
|
145
|
+
const variationValue = getTestFields({
|
|
146
|
+
item,
|
|
147
|
+
testGroupId
|
|
148
|
+
});
|
|
125
149
|
return __spreadValues(__spreadValues({}, item), variationValue);
|
|
126
150
|
});
|
|
127
151
|
exports.handleABTesting = handleABTesting;
|
package/dist/helpers/canTrack.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getDefaultCanTrack = void 0;
|
|
4
|
-
const
|
|
5
|
-
const getDefaultCanTrack =
|
|
4
|
+
const nullable_js_1 = require("./nullable.js");
|
|
5
|
+
const getDefaultCanTrack = canTrack => (0, nullable_js_1.checkIsDefined)(canTrack) ? canTrack : true;
|
|
6
6
|
exports.getDefaultCanTrack = getDefaultCanTrack;
|
package/dist/helpers/css.js
CHANGED
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createCssClass = exports.convertStyleMapToCSSArray = exports.convertStyleMapToCSS = void 0;
|
|
4
4
|
const camel_to_kebab_case_js_1 = require("../functions/camel-to-kebab-case.js");
|
|
5
5
|
const nullable_js_1 = require("./nullable.js");
|
|
6
|
-
const convertStyleMapToCSSArray =
|
|
6
|
+
const convertStyleMapToCSSArray = style => {
|
|
7
7
|
const cssProps = Object.entries(style).map(([key, value]) => {
|
|
8
8
|
if (typeof value === "string") {
|
|
9
9
|
return `${(0, camel_to_kebab_case_js_1.camelToKebabCase)(key)}: ${value};`;
|
|
@@ -15,7 +15,7 @@ const convertStyleMapToCSSArray = (style) => {
|
|
|
15
15
|
return cssProps.filter(nullable_js_1.checkIsDefined);
|
|
16
16
|
};
|
|
17
17
|
exports.convertStyleMapToCSSArray = convertStyleMapToCSSArray;
|
|
18
|
-
const convertStyleMapToCSS =
|
|
18
|
+
const convertStyleMapToCSS = style => convertStyleMapToCSSArray(style).join("\n");
|
|
19
19
|
exports.convertStyleMapToCSS = convertStyleMapToCSS;
|
|
20
20
|
const createCssClass = ({ mediaQuery, className, styles }) => {
|
|
21
21
|
const cssClass = `.${className} {
|
package/dist/helpers/flatten.js
CHANGED
|
@@ -7,7 +7,12 @@ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
|
7
7
|
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
8
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
9
|
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
10
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
10
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
configurable: true,
|
|
13
|
+
writable: true,
|
|
14
|
+
value
|
|
15
|
+
}) : obj[key] = value;
|
|
11
16
|
var __spreadValues = (a, b) => {
|
|
12
17
|
for (var prop in b || (b = {}))
|
|
13
18
|
if (__hasOwnProp.call(b, prop))
|
|
@@ -24,12 +29,10 @@ function flatten(object, path = null, separator = ".") {
|
|
|
24
29
|
return Object.keys(object).reduce((acc, key) => {
|
|
25
30
|
const value = object[key];
|
|
26
31
|
const newPath = [path, key].filter(Boolean).join(separator);
|
|
27
|
-
const isObject = [
|
|
28
|
-
|
|
29
|
-
value
|
|
30
|
-
|
|
31
|
-
].every(Boolean);
|
|
32
|
-
return isObject ? __spreadValues(__spreadValues({}, acc), flatten(value, newPath, separator)) : __spreadProps(__spreadValues({}, acc), { [newPath]: value });
|
|
32
|
+
const isObject = [typeof value === "object", value !== null, !(Array.isArray(value) && value.length === 0)].every(Boolean);
|
|
33
|
+
return isObject ? __spreadValues(__spreadValues({}, acc), flatten(value, newPath, separator)) : __spreadProps(__spreadValues({}, acc), {
|
|
34
|
+
[newPath]: value
|
|
35
|
+
});
|
|
33
36
|
}, {});
|
|
34
37
|
}
|
|
35
38
|
exports.flatten = flatten;
|
package/dist/helpers/nullable.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.checkIsDefined = void 0;
|
|
4
|
-
const checkIsDefined =
|
|
4
|
+
const checkIsDefined = maybeT => maybeT !== null && maybeT !== void 0;
|
|
5
5
|
exports.checkIsDefined = checkIsDefined;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getPreviewContent = void 0;
|
|
4
|
+
const helpers_1 = require("./helpers");
|
|
5
|
+
const init_1 = require("./init");
|
|
6
|
+
function getPreviewContent(searchParams) {
|
|
7
|
+
(0, init_1.init)();
|
|
8
|
+
const id = (0, helpers_1.getIdFromSearchParams)(searchParams);
|
|
9
|
+
return typeof id === "string" ? globalThis._BUILDER_PREVIEW_LRU_CACHE.get(id) : void 0;
|
|
10
|
+
}
|
|
11
|
+
exports.getPreviewContent = getPreviewContent;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getIdFromSearchParams = void 0;
|
|
4
|
+
const logger_1 = require("../logger");
|
|
5
|
+
const getIdFromSearchParams = searchParams => {
|
|
6
|
+
const previewedModel = searchParams.get("preview");
|
|
7
|
+
const previewedId = searchParams.get("overrides." + previewedModel);
|
|
8
|
+
if (!previewedId) {
|
|
9
|
+
logger_1.logger.warn("No previewed ID found in search params.");
|
|
10
|
+
}
|
|
11
|
+
return previewedId;
|
|
12
|
+
};
|
|
13
|
+
exports.getIdFromSearchParams = getIdFromSearchParams;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.init = void 0;
|
|
4
|
+
const lru_cache_1 = require("lru-cache");
|
|
5
|
+
function init() {
|
|
6
|
+
if (!globalThis._BUILDER_PREVIEW_LRU_CACHE) {
|
|
7
|
+
globalThis._BUILDER_PREVIEW_LRU_CACHE = new lru_cache_1.LRUCache({
|
|
8
|
+
max: 500,
|
|
9
|
+
ttl: 1e3 * 60 * 5
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.init = init;
|