@builder.io/sdk-react-nextjs 0.5.8 → 0.6.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/lib/browser/USE_CLIENT_BUNDLE-29f9ac5c.js +23 -0
- package/lib/browser/USE_CLIENT_BUNDLE-dfa97c43.mjs +664 -0
- package/lib/browser/USE_SERVER_BUNDLE-25e181fa.js +1 -0
- package/lib/browser/USE_SERVER_BUNDLE-fcd44ecb.mjs +11 -0
- package/lib/browser/bundle-5cab6113.js +76 -0
- package/lib/browser/bundle-babbd573.mjs +2419 -0
- package/lib/browser/index.cjs +1 -0
- package/lib/browser/index.mjs +34 -0
- package/lib/edge/USE_CLIENT_BUNDLE-3cbb02d5.mjs +664 -0
- package/lib/edge/USE_CLIENT_BUNDLE-d0b99f60.js +23 -0
- package/lib/edge/USE_SERVER_BUNDLE-4eeb4634.mjs +11 -0
- package/lib/edge/USE_SERVER_BUNDLE-bbd89085.js +1 -0
- package/lib/edge/bundle-9ed99f98.mjs +4863 -0
- package/lib/edge/bundle-e4764e2a.js +96 -0
- package/lib/edge/index.cjs +1 -0
- package/lib/edge/index.mjs +34 -0
- package/lib/node/USE_CLIENT_BUNDLE-29f9ac5c.js +23 -0
- package/lib/node/USE_CLIENT_BUNDLE-dfa97c43.mjs +664 -0
- package/lib/node/USE_SERVER_BUNDLE-25e181fa.js +1 -0
- package/lib/node/USE_SERVER_BUNDLE-fcd44ecb.mjs +11 -0
- package/lib/node/bundle-5cab6113.js +76 -0
- package/lib/node/bundle-babbd573.mjs +2419 -0
- package/lib/node/index.cjs +1 -0
- package/lib/node/index.mjs +34 -0
- package/package.json +96 -13
- package/{dist → types}/components/content/content.types.d.ts +2 -2
- package/{dist → types}/components/content-variants/content-variants.d.ts +2 -2
- package/{dist → types}/components/content-variants/content-variants.types.d.ts +1 -1
- package/types/constants/sdk-version.d.ts +1 -0
- package/types/functions/deopt.d.ts +4 -0
- package/types/functions/evaluate/browser-runtime/browser.d.ts +4 -0
- package/types/functions/evaluate/browser-runtime/index.d.ts +1 -0
- package/types/functions/evaluate/evaluate.d.ts +6 -0
- package/types/functions/evaluate/helpers.d.ts +18 -0
- package/types/functions/evaluate/index.d.ts +1 -0
- package/{dist → types}/functions/fetch-builder-props.d.ts +4 -3
- package/{dist → types}/functions/get-content/index.d.ts +4 -5
- package/{dist → types}/index-helpers/blocks-exports.d.ts +2 -2
- package/types/index.d.ts +7 -0
- package/{dist/index.d.ts → types/server-index.d.ts} +0 -1
- package/dist/blocks/button/button.js +0 -12
- package/dist/blocks/button/component-info.js +0 -34
- package/dist/blocks/columns/columns.js +0 -119
- package/dist/blocks/columns/component-info.js +0 -219
- package/dist/blocks/custom-code/component-info.js +0 -23
- package/dist/blocks/custom-code/custom-code.js +0 -51
- package/dist/blocks/embed/component-info.js +0 -39
- package/dist/blocks/embed/embed.js +0 -42
- package/dist/blocks/embed/helpers.js +0 -2
- package/dist/blocks/fragment/component-info.js +0 -7
- package/dist/blocks/fragment/fragment.js +0 -6
- package/dist/blocks/helpers.js +0 -40
- package/dist/blocks/image/component-info.js +0 -122
- package/dist/blocks/image/image.helpers.js +0 -47
- package/dist/blocks/image/image.js +0 -82
- package/dist/blocks/img/component-info.js +0 -15
- package/dist/blocks/img/img.js +0 -10
- package/dist/blocks/section/component-info.js +0 -40
- package/dist/blocks/section/section.js +0 -17
- package/dist/blocks/symbol/component-info.js +0 -34
- package/dist/blocks/symbol/symbol.helpers.js +0 -31
- package/dist/blocks/symbol/symbol.js +0 -29
- package/dist/blocks/text/component-info.js +0 -19
- package/dist/blocks/text/text.js +0 -7
- package/dist/blocks/video/component-info.js +0 -82
- package/dist/blocks/video/video.js +0 -50
- package/dist/components/block/block.helpers.js +0 -69
- package/dist/components/block/block.js +0 -92
- package/dist/components/block/components/block-styles.js +0 -65
- package/dist/components/block/components/block-wrapper.js +0 -36
- package/dist/components/block/components/component-ref/component-ref.helpers.js +0 -22
- package/dist/components/block/components/component-ref/component-ref.js +0 -21
- package/dist/components/block/components/interactive-element.js +0 -20
- package/dist/components/block/components/repeated-block.js +0 -7
- package/dist/components/block/types.js +0 -1
- package/dist/components/blocks/blocks-wrapper.js +0 -38
- package/dist/components/blocks/blocks.js +0 -10
- package/dist/components/content/components/enable-editor.js +0 -250
- package/dist/components/content/components/styles.helpers.js +0 -58
- package/dist/components/content/components/styles.js +0 -30
- package/dist/components/content/content.helpers.js +0 -30
- package/dist/components/content/content.js +0 -74
- package/dist/components/content/content.types.js +0 -1
- package/dist/components/content/wrap-component-ref.js +0 -6
- package/dist/components/content-variants/content-variants.js +0 -45
- package/dist/components/content-variants/content-variants.types.js +0 -1
- package/dist/components/content-variants/helpers.js +0 -189
- package/dist/components/inlined-script.js +0 -5
- package/dist/components/inlined-styles.js +0 -5
- package/dist/constants/builder-registered-components.js +0 -60
- package/dist/constants/device-sizes.js +0 -45
- package/dist/constants/sdk-version.d.ts +0 -1
- package/dist/constants/sdk-version.js +0 -1
- package/dist/constants/target.js +0 -2
- package/dist/context/builder.context.js +0 -12
- package/dist/context/components.context.js +0 -2
- package/dist/context/types.js +0 -1
- package/dist/functions/camel-to-kebab-case.js +0 -1
- package/dist/functions/evaluate/acorn-interpreter.d.ts +0 -2
- package/dist/functions/evaluate/acorn-interpreter.js +0 -3111
- package/dist/functions/evaluate/evaluate.d.ts +0 -10
- package/dist/functions/evaluate/evaluate.js +0 -70
- package/dist/functions/evaluate/index.d.ts +0 -1
- package/dist/functions/evaluate/index.js +0 -1
- package/dist/functions/evaluate/non-node-runtime/index.d.ts +0 -1
- package/dist/functions/evaluate/non-node-runtime/index.js +0 -2
- package/dist/functions/evaluate/non-node-runtime/non-node-runtime.d.ts +0 -2
- package/dist/functions/evaluate/non-node-runtime/non-node-runtime.js +0 -84
- package/dist/functions/evaluate/types.d.ts +0 -11
- package/dist/functions/evaluate/types.js +0 -1
- package/dist/functions/event-handler-name.js +0 -4
- package/dist/functions/extract-text-styles.js +0 -22
- package/dist/functions/fast-clone.js +0 -4
- package/dist/functions/fetch-builder-props.js +0 -25
- package/dist/functions/get-block-actions-handler.js +0 -10
- package/dist/functions/get-block-actions.js +0 -28
- package/dist/functions/get-block-component-options.js +0 -10
- package/dist/functions/get-block-properties.js +0 -72
- package/dist/functions/get-builder-search-params/index.js +0 -38
- package/dist/functions/get-content/generate-content-url.js +0 -33
- package/dist/functions/get-content/index.js +0 -100
- package/dist/functions/get-content/types.js +0 -1
- package/dist/functions/get-fetch.js +0 -11
- package/dist/functions/get-global-this.js +0 -15
- package/dist/functions/get-processed-block.js +0 -46
- package/dist/functions/get-react-native-block-styles.js +0 -17
- package/dist/functions/is-browser.js +0 -3
- package/dist/functions/is-editing.js +0 -5
- package/dist/functions/is-iframe.js +0 -4
- package/dist/functions/is-non-node-server.d.ts +0 -4
- package/dist/functions/is-non-node-server.js +0 -8
- package/dist/functions/is-previewing.js +0 -11
- package/dist/functions/register-component.js +0 -38
- package/dist/functions/register.js +0 -27
- package/dist/functions/sanitize-react-native-block-styles.js +0 -61
- package/dist/functions/set-editor-settings.js +0 -12
- package/dist/functions/set.js +0 -14
- package/dist/functions/track/helpers.js +0 -51
- package/dist/functions/track/index.js +0 -71
- package/dist/functions/track/interaction.js +0 -53
- package/dist/functions/transform-block-properties.js +0 -5
- package/dist/functions/transform-block.js +0 -4
- package/dist/helpers/ab-tests.js +0 -122
- package/dist/helpers/canTrack.js +0 -2
- package/dist/helpers/cookie.js +0 -55
- package/dist/helpers/css.js +0 -27
- package/dist/helpers/flatten.js +0 -19
- package/dist/helpers/localStorage.js +0 -24
- package/dist/helpers/logger.js +0 -7
- package/dist/helpers/nullable.js +0 -1
- package/dist/helpers/preview-lru-cache/get.js +0 -9
- package/dist/helpers/preview-lru-cache/helpers.js +0 -9
- package/dist/helpers/preview-lru-cache/init.js +0 -15
- package/dist/helpers/preview-lru-cache/set.js +0 -7
- package/dist/helpers/preview-lru-cache/types.js +0 -6
- package/dist/helpers/sessionId.js +0 -30
- package/dist/helpers/url.js +0 -15
- package/dist/helpers/uuid.js +0 -15
- package/dist/helpers/visitorId.js +0 -30
- package/dist/index-helpers/blocks-exports.js +0 -19
- package/dist/index-helpers/top-of-file.js +0 -4
- package/dist/index.js +0 -11
- package/dist/scripts/init-editing.js +0 -110
- package/dist/types/api-version.js +0 -1
- package/dist/types/builder-block.js +0 -1
- package/dist/types/builder-content.js +0 -1
- package/dist/types/builder-props.js +0 -1
- package/dist/types/can-track.js +0 -1
- package/dist/types/components.js +0 -1
- package/dist/types/deep-partial.js +0 -1
- package/dist/types/element.js +0 -1
- package/dist/types/enforced-partials.js +0 -1
- package/dist/types/input.js +0 -1
- package/dist/types/targets.js +0 -1
- package/dist/types/typescript.js +0 -1
- /package/{dist → types}/blocks/button/button.d.ts +0 -0
- /package/{dist → types}/blocks/button/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/columns/columns.d.ts +0 -0
- /package/{dist → types}/blocks/columns/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/custom-code/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/custom-code/custom-code.d.ts +0 -0
- /package/{dist → types}/blocks/embed/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/embed/embed.d.ts +0 -0
- /package/{dist → types}/blocks/embed/helpers.d.ts +0 -0
- /package/{dist → types}/blocks/fragment/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/fragment/fragment.d.ts +0 -0
- /package/{dist → types}/blocks/helpers.d.ts +0 -0
- /package/{dist → types}/blocks/image/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/image/image.d.ts +0 -0
- /package/{dist → types}/blocks/image/image.helpers.d.ts +0 -0
- /package/{dist → types}/blocks/img/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/img/img.d.ts +0 -0
- /package/{dist → types}/blocks/section/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/section/section.d.ts +0 -0
- /package/{dist → types}/blocks/symbol/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/symbol/symbol.d.ts +0 -0
- /package/{dist → types}/blocks/symbol/symbol.helpers.d.ts +0 -0
- /package/{dist → types}/blocks/text/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/text/text.d.ts +0 -0
- /package/{dist → types}/blocks/video/component-info.d.ts +0 -0
- /package/{dist → types}/blocks/video/video.d.ts +0 -0
- /package/{dist → types}/components/block/block.d.ts +0 -0
- /package/{dist → types}/components/block/block.helpers.d.ts +0 -0
- /package/{dist → types}/components/block/components/block-styles.d.ts +0 -0
- /package/{dist → types}/components/block/components/block-wrapper.d.ts +0 -0
- /package/{dist → types}/components/block/components/component-ref/component-ref.d.ts +0 -0
- /package/{dist → types}/components/block/components/component-ref/component-ref.helpers.d.ts +0 -0
- /package/{dist → types}/components/block/components/interactive-element.d.ts +0 -0
- /package/{dist → types}/components/block/components/repeated-block.d.ts +0 -0
- /package/{dist → types}/components/block/types.d.ts +0 -0
- /package/{dist → types}/components/blocks/blocks-wrapper.d.ts +0 -0
- /package/{dist → types}/components/blocks/blocks.d.ts +0 -0
- /package/{dist → types}/components/content/components/enable-editor.d.ts +0 -0
- /package/{dist → types}/components/content/components/styles.d.ts +0 -0
- /package/{dist → types}/components/content/components/styles.helpers.d.ts +0 -0
- /package/{dist → types}/components/content/content.d.ts +0 -0
- /package/{dist → types}/components/content/content.helpers.d.ts +0 -0
- /package/{dist → types}/components/content/wrap-component-ref.d.ts +0 -0
- /package/{dist → types}/components/content-variants/helpers.d.ts +0 -0
- /package/{dist → types}/components/inlined-script.d.ts +0 -0
- /package/{dist → types}/components/inlined-styles.d.ts +0 -0
- /package/{dist → types}/constants/builder-registered-components.d.ts +0 -0
- /package/{dist → types}/constants/device-sizes.d.ts +0 -0
- /package/{dist → types}/constants/target.d.ts +0 -0
- /package/{dist → types}/context/builder.context.d.ts +0 -0
- /package/{dist → types}/context/components.context.d.ts +0 -0
- /package/{dist → types}/context/types.d.ts +0 -0
- /package/{dist → types}/functions/camel-to-kebab-case.d.ts +0 -0
- /package/{dist → types}/functions/event-handler-name.d.ts +0 -0
- /package/{dist → types}/functions/extract-text-styles.d.ts +0 -0
- /package/{dist → types}/functions/fast-clone.d.ts +0 -0
- /package/{dist → types}/functions/get-block-actions-handler.d.ts +0 -0
- /package/{dist → types}/functions/get-block-actions.d.ts +0 -0
- /package/{dist → types}/functions/get-block-component-options.d.ts +0 -0
- /package/{dist → types}/functions/get-block-properties.d.ts +0 -0
- /package/{dist → types}/functions/get-builder-search-params/index.d.ts +0 -0
- /package/{dist → types}/functions/get-content/generate-content-url.d.ts +0 -0
- /package/{dist → types}/functions/get-content/types.d.ts +0 -0
- /package/{dist → types}/functions/get-fetch.d.ts +0 -0
- /package/{dist → types}/functions/get-global-this.d.ts +0 -0
- /package/{dist → types}/functions/get-processed-block.d.ts +0 -0
- /package/{dist → types}/functions/get-react-native-block-styles.d.ts +0 -0
- /package/{dist → types}/functions/is-browser.d.ts +0 -0
- /package/{dist → types}/functions/is-editing.d.ts +0 -0
- /package/{dist → types}/functions/is-iframe.d.ts +0 -0
- /package/{dist → types}/functions/is-previewing.d.ts +0 -0
- /package/{dist → types}/functions/register-component.d.ts +0 -0
- /package/{dist → types}/functions/register.d.ts +0 -0
- /package/{dist → types}/functions/sanitize-react-native-block-styles.d.ts +0 -0
- /package/{dist → types}/functions/set-editor-settings.d.ts +0 -0
- /package/{dist → types}/functions/set.d.ts +0 -0
- /package/{dist → types}/functions/track/helpers.d.ts +0 -0
- /package/{dist → types}/functions/track/index.d.ts +0 -0
- /package/{dist → types}/functions/track/interaction.d.ts +0 -0
- /package/{dist → types}/functions/transform-block-properties.d.ts +0 -0
- /package/{dist → types}/functions/transform-block.d.ts +0 -0
- /package/{dist → types}/helpers/ab-tests.d.ts +0 -0
- /package/{dist → types}/helpers/canTrack.d.ts +0 -0
- /package/{dist → types}/helpers/cookie.d.ts +0 -0
- /package/{dist → types}/helpers/css.d.ts +0 -0
- /package/{dist → types}/helpers/flatten.d.ts +0 -0
- /package/{dist → types}/helpers/localStorage.d.ts +0 -0
- /package/{dist → types}/helpers/logger.d.ts +0 -0
- /package/{dist → types}/helpers/nullable.d.ts +0 -0
- /package/{dist → types}/helpers/preview-lru-cache/get.d.ts +0 -0
- /package/{dist → types}/helpers/preview-lru-cache/helpers.d.ts +0 -0
- /package/{dist → types}/helpers/preview-lru-cache/init.d.ts +0 -0
- /package/{dist → types}/helpers/preview-lru-cache/set.d.ts +0 -0
- /package/{dist → types}/helpers/preview-lru-cache/types.d.ts +0 -0
- /package/{dist → types}/helpers/sessionId.d.ts +0 -0
- /package/{dist → types}/helpers/url.d.ts +0 -0
- /package/{dist → types}/helpers/uuid.d.ts +0 -0
- /package/{dist → types}/helpers/visitorId.d.ts +0 -0
- /package/{dist → types}/index-helpers/top-of-file.d.ts +0 -0
- /package/{dist → types}/scripts/init-editing.d.ts +0 -0
- /package/{dist → types}/types/api-version.d.ts +0 -0
- /package/{dist → types}/types/builder-block.d.ts +0 -0
- /package/{dist → types}/types/builder-content.d.ts +0 -0
- /package/{dist → types}/types/builder-props.d.ts +0 -0
- /package/{dist → types}/types/can-track.d.ts +0 -0
- /package/{dist → types}/types/components.d.ts +0 -0
- /package/{dist → types}/types/deep-partial.d.ts +0 -0
- /package/{dist → types}/types/element.d.ts +0 -0
- /package/{dist → types}/types/enforced-partials.d.ts +0 -0
- /package/{dist → types}/types/input.d.ts +0 -0
- /package/{dist → types}/types/targets.d.ts +0 -0
- /package/{dist → types}/types/typescript.d.ts +0 -0
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
import { getSrcSet } from "./image.helpers.js";
|
|
4
|
-
function Image(props) {
|
|
5
|
-
function srcSetToUse() {
|
|
6
|
-
const imageToUse = props.image || props.src;
|
|
7
|
-
const url = imageToUse;
|
|
8
|
-
if (!url ||
|
|
9
|
-
// We can auto add srcset for cdn.builder.io and shopify
|
|
10
|
-
// images, otherwise you can supply this prop manually
|
|
11
|
-
!(url.match(/builder\.io/) || url.match(/cdn\.shopify\.com/))) {
|
|
12
|
-
return props.srcset;
|
|
13
|
-
}
|
|
14
|
-
if (props.srcset && props.image?.includes("builder.io/api/v1/image")) {
|
|
15
|
-
if (!props.srcset.includes(props.image.split("?")[0])) {
|
|
16
|
-
console.debug("Removed given srcset");
|
|
17
|
-
return getSrcSet(url);
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
else if (props.image && !props.srcset) {
|
|
21
|
-
return getSrcSet(url);
|
|
22
|
-
}
|
|
23
|
-
return getSrcSet(url);
|
|
24
|
-
}
|
|
25
|
-
function webpSrcSet() {
|
|
26
|
-
if (srcSetToUse?.()?.match(/builder\.io/) && !props.noWebp) {
|
|
27
|
-
return srcSetToUse().replace(/\?/g, "?format=webp&");
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
return "";
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
function aspectRatioCss() {
|
|
34
|
-
const aspectRatioStyles = {
|
|
35
|
-
position: "absolute",
|
|
36
|
-
height: "100%",
|
|
37
|
-
width: "100%",
|
|
38
|
-
left: "0px",
|
|
39
|
-
top: "0px",
|
|
40
|
-
};
|
|
41
|
-
const out = props.aspectRatio ? aspectRatioStyles : undefined;
|
|
42
|
-
return out;
|
|
43
|
-
}
|
|
44
|
-
return (React.createElement(React.Fragment, null,
|
|
45
|
-
React.createElement(React.Fragment, null,
|
|
46
|
-
React.createElement("picture", null,
|
|
47
|
-
webpSrcSet() ? (React.createElement(React.Fragment, null,
|
|
48
|
-
React.createElement("source", { type: "image/webp", srcSet: webpSrcSet() }))) : null,
|
|
49
|
-
React.createElement("img", { loading: "lazy", alt: props.altText, role: props.altText ? "presentation" : undefined, style: {
|
|
50
|
-
objectPosition: props.backgroundPosition || "center",
|
|
51
|
-
objectFit: props.backgroundSize || "cover",
|
|
52
|
-
...aspectRatioCss(),
|
|
53
|
-
}, className: "builder-image" +
|
|
54
|
-
(props.className ? " " + props.className : "") +
|
|
55
|
-
" img-7c5f6b46", src: props.image, srcSet: srcSetToUse(), sizes: props.sizes })),
|
|
56
|
-
props.aspectRatio &&
|
|
57
|
-
!(props.builderBlock?.children?.length && props.fitContent) ? (React.createElement(React.Fragment, null,
|
|
58
|
-
React.createElement("div", { className: "builder-image-sizer div-7c5f6b46", style: {
|
|
59
|
-
paddingTop: props.aspectRatio * 100 + "%",
|
|
60
|
-
} }))) : null,
|
|
61
|
-
props.builderBlock?.children?.length && props.fitContent ? (React.createElement(React.Fragment, null, props.children)) : null,
|
|
62
|
-
!props.fitContent && props.children ? (React.createElement(React.Fragment, null,
|
|
63
|
-
React.createElement("div", { className: "div-7c5f6b46-2" }, props.children))) : null),
|
|
64
|
-
React.createElement("style", null, `.img-7c5f6b46 {
|
|
65
|
-
opacity: 1;
|
|
66
|
-
transition: opacity 0.2s ease-in-out;
|
|
67
|
-
}.div-7c5f6b46 {
|
|
68
|
-
width: 100%;
|
|
69
|
-
pointer-events: none;
|
|
70
|
-
font-size: 0;
|
|
71
|
-
}.div-7c5f6b46-2 {
|
|
72
|
-
display: flex;
|
|
73
|
-
flex-direction: column;
|
|
74
|
-
align-items: stretch;
|
|
75
|
-
position: absolute;
|
|
76
|
-
top: 0;
|
|
77
|
-
left: 0;
|
|
78
|
-
width: 100%;
|
|
79
|
-
height: 100%;
|
|
80
|
-
}`)));
|
|
81
|
-
}
|
|
82
|
-
export default Image;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
export const componentInfo = {
|
|
2
|
-
// friendlyName?
|
|
3
|
-
name: 'Raw:Img',
|
|
4
|
-
hideFromInsertMenu: true,
|
|
5
|
-
image: 'https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-insert_photo-24px.svg?alt=media&token=4e5d0ef4-f5e8-4e57-b3a9-38d63a9b9dc4',
|
|
6
|
-
inputs: [{
|
|
7
|
-
name: 'image',
|
|
8
|
-
bubble: true,
|
|
9
|
-
type: 'file',
|
|
10
|
-
allowedFileTypes: ['jpeg', 'jpg', 'png', 'svg', 'gif', 'webp'],
|
|
11
|
-
required: true
|
|
12
|
-
}],
|
|
13
|
-
noWrap: true,
|
|
14
|
-
static: true
|
|
15
|
-
};
|
package/dist/blocks/img/img.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
import { isEditing } from "../../functions/is-editing.js";
|
|
4
|
-
function ImgComponent(props) {
|
|
5
|
-
return (React.createElement("img", { style: {
|
|
6
|
-
objectFit: props.backgroundSize || "cover",
|
|
7
|
-
objectPosition: props.backgroundPosition || "center",
|
|
8
|
-
}, key: (isEditing() && props.imgSrc) || "default-key", alt: props.altText, src: props.imgSrc || props.image, ...props.attributes }));
|
|
9
|
-
}
|
|
10
|
-
export default ImgComponent;
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
export const componentInfo = {
|
|
2
|
-
name: 'Core:Section',
|
|
3
|
-
static: true,
|
|
4
|
-
image: 'https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2F682efef23ace49afac61748dd305c70a',
|
|
5
|
-
inputs: [{
|
|
6
|
-
name: 'maxWidth',
|
|
7
|
-
type: 'number',
|
|
8
|
-
defaultValue: 1200
|
|
9
|
-
}, {
|
|
10
|
-
name: 'lazyLoad',
|
|
11
|
-
type: 'boolean',
|
|
12
|
-
defaultValue: false,
|
|
13
|
-
advanced: true,
|
|
14
|
-
description: 'Only render this section when in view'
|
|
15
|
-
}],
|
|
16
|
-
defaultStyles: {
|
|
17
|
-
paddingLeft: '20px',
|
|
18
|
-
paddingRight: '20px',
|
|
19
|
-
paddingTop: '50px',
|
|
20
|
-
paddingBottom: '50px',
|
|
21
|
-
marginTop: '0px',
|
|
22
|
-
width: '100vw',
|
|
23
|
-
marginLeft: 'calc(50% - 50vw)'
|
|
24
|
-
},
|
|
25
|
-
canHaveChildren: true,
|
|
26
|
-
defaultChildren: [{
|
|
27
|
-
'@type': '@builder.io/sdk:Element',
|
|
28
|
-
responsiveStyles: {
|
|
29
|
-
large: {
|
|
30
|
-
textAlign: 'center'
|
|
31
|
-
}
|
|
32
|
-
},
|
|
33
|
-
component: {
|
|
34
|
-
name: 'Text',
|
|
35
|
-
options: {
|
|
36
|
-
text: "<p><b>I am a section! My content keeps from getting too wide, so that it's easy to read even on big screens.</b></p><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur</p>"
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
}]
|
|
40
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
function SectionComponent(props) {
|
|
4
|
-
return (React.createElement("section", { ...props.attributes, style: {
|
|
5
|
-
width: "100%",
|
|
6
|
-
alignSelf: "stretch",
|
|
7
|
-
flexGrow: 1,
|
|
8
|
-
boxSizing: "border-box",
|
|
9
|
-
maxWidth: props.maxWidth || 1200,
|
|
10
|
-
display: "flex",
|
|
11
|
-
flexDirection: "column",
|
|
12
|
-
alignItems: "stretch",
|
|
13
|
-
marginLeft: "auto",
|
|
14
|
-
marginRight: "auto",
|
|
15
|
-
} }, props.children));
|
|
16
|
-
}
|
|
17
|
-
export default SectionComponent;
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
export const componentInfo = {
|
|
2
|
-
name: 'Symbol',
|
|
3
|
-
noWrap: true,
|
|
4
|
-
static: true,
|
|
5
|
-
isRSC: true,
|
|
6
|
-
inputs: [{
|
|
7
|
-
name: 'symbol',
|
|
8
|
-
type: 'uiSymbol'
|
|
9
|
-
}, {
|
|
10
|
-
name: 'dataOnly',
|
|
11
|
-
helperText: "Make this a data symbol that doesn't display any UI",
|
|
12
|
-
type: 'boolean',
|
|
13
|
-
defaultValue: false,
|
|
14
|
-
advanced: true,
|
|
15
|
-
hideFromUI: true
|
|
16
|
-
}, {
|
|
17
|
-
name: 'inheritState',
|
|
18
|
-
helperText: 'Inherit the parent component state and data',
|
|
19
|
-
type: 'boolean',
|
|
20
|
-
defaultValue: false,
|
|
21
|
-
advanced: true
|
|
22
|
-
}, {
|
|
23
|
-
name: 'renderToLiquid',
|
|
24
|
-
helperText: 'Render this symbols contents to liquid. Turn off to fetch with javascript and use custom targeting',
|
|
25
|
-
type: 'boolean',
|
|
26
|
-
defaultValue: false,
|
|
27
|
-
advanced: true,
|
|
28
|
-
hideFromUI: true
|
|
29
|
-
}, {
|
|
30
|
-
name: 'useChildren',
|
|
31
|
-
hideFromUI: true,
|
|
32
|
-
type: 'boolean'
|
|
33
|
-
}]
|
|
34
|
-
};
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { logger } from '../../helpers/logger.js';
|
|
2
|
-
import { fetchOneEntry } from '../../index.js';
|
|
3
|
-
export const fetchSymbolContent = async ({ builderContextValue, symbol }) => {
|
|
4
|
-
/**
|
|
5
|
-
* If:
|
|
6
|
-
* - we have a symbol prop
|
|
7
|
-
* - yet it does not have any content
|
|
8
|
-
* - and we have not already stored content from before
|
|
9
|
-
* - and it has a model name
|
|
10
|
-
*
|
|
11
|
-
* then we want to re-fetch the symbol content.
|
|
12
|
-
*/
|
|
13
|
-
if (symbol?.model &&
|
|
14
|
-
// This is a hack, we should not need to check for this, but it is needed for Svelte.
|
|
15
|
-
builderContextValue?.apiKey) {
|
|
16
|
-
return fetchOneEntry({
|
|
17
|
-
model: symbol.model,
|
|
18
|
-
apiKey: builderContextValue.apiKey,
|
|
19
|
-
apiVersion: builderContextValue.apiVersion,
|
|
20
|
-
...(symbol?.entry && {
|
|
21
|
-
query: {
|
|
22
|
-
id: symbol.entry
|
|
23
|
-
}
|
|
24
|
-
})
|
|
25
|
-
}).catch(err => {
|
|
26
|
-
logger.error('Could not fetch symbol content: ', err);
|
|
27
|
-
return undefined;
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
return undefined;
|
|
31
|
-
};
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import ContentVariants from "../../components/content-variants/content-variants";
|
|
3
|
-
import { fetchSymbolContent } from "./symbol.helpers.js";
|
|
4
|
-
async function Symbol(props) {
|
|
5
|
-
const className = function className() {
|
|
6
|
-
return [
|
|
7
|
-
...[props.attributes.className],
|
|
8
|
-
"builder-symbol",
|
|
9
|
-
props.symbol?.inline ? "builder-inline-symbol" : undefined,
|
|
10
|
-
props.symbol?.dynamic || props.dynamic
|
|
11
|
-
? "builder-dynamic-symbol"
|
|
12
|
-
: undefined,
|
|
13
|
-
]
|
|
14
|
-
.filter(Boolean)
|
|
15
|
-
.join(" ");
|
|
16
|
-
};
|
|
17
|
-
const contentToUse = (props.symbol?.content ||
|
|
18
|
-
(await fetchSymbolContent({
|
|
19
|
-
symbol: props.symbol,
|
|
20
|
-
builderContextValue: props.builderContext,
|
|
21
|
-
})));
|
|
22
|
-
return (React.createElement("div", { ...props.attributes, className: className() },
|
|
23
|
-
React.createElement(ContentVariants, { __isNestedRender: true, apiVersion: props.builderContext.apiVersion, apiKey: props.builderContext.apiKey, context: props.builderContext.context, customComponents: Object.values(props.builderComponents), data: {
|
|
24
|
-
...props.symbol?.data,
|
|
25
|
-
...props.builderContext.localState,
|
|
26
|
-
...contentToUse?.data?.state,
|
|
27
|
-
}, model: props.symbol?.model, content: contentToUse })));
|
|
28
|
-
}
|
|
29
|
-
export default Symbol;
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export const componentInfo = {
|
|
2
|
-
name: 'Text',
|
|
3
|
-
static: true,
|
|
4
|
-
isRSC: true,
|
|
5
|
-
image: 'https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-text_fields-24px%20(1).svg?alt=media&token=12177b73-0ee3-42ca-98c6-0dd003de1929',
|
|
6
|
-
inputs: [{
|
|
7
|
-
name: 'text',
|
|
8
|
-
type: 'html',
|
|
9
|
-
required: true,
|
|
10
|
-
autoFocus: true,
|
|
11
|
-
bubble: true,
|
|
12
|
-
defaultValue: 'Enter some text...'
|
|
13
|
-
}],
|
|
14
|
-
defaultStyles: {
|
|
15
|
-
lineHeight: 'normal',
|
|
16
|
-
height: 'auto',
|
|
17
|
-
textAlign: 'center'
|
|
18
|
-
}
|
|
19
|
-
};
|
package/dist/blocks/text/text.js
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
export const componentInfo = {
|
|
2
|
-
name: 'Video',
|
|
3
|
-
canHaveChildren: true,
|
|
4
|
-
defaultStyles: {
|
|
5
|
-
minHeight: '20px',
|
|
6
|
-
minWidth: '20px'
|
|
7
|
-
},
|
|
8
|
-
image: 'https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-videocam-24px%20(1).svg?alt=media&token=49a84e4a-b20e-4977-a650-047f986874bb',
|
|
9
|
-
inputs: [{
|
|
10
|
-
name: 'video',
|
|
11
|
-
type: 'file',
|
|
12
|
-
allowedFileTypes: ['mp4'],
|
|
13
|
-
bubble: true,
|
|
14
|
-
defaultValue: 'https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/assets%2FKQlEmWDxA0coC3PK6UvkrjwkIGI2%2F28cb070609f546cdbe5efa20e931aa4b?alt=media&token=912e9551-7a7c-4dfb-86b6-3da1537d1a7f',
|
|
15
|
-
required: true
|
|
16
|
-
}, {
|
|
17
|
-
name: 'posterImage',
|
|
18
|
-
type: 'file',
|
|
19
|
-
allowedFileTypes: ['jpeg', 'png'],
|
|
20
|
-
helperText: 'Image to show before the video plays'
|
|
21
|
-
}, {
|
|
22
|
-
name: 'autoPlay',
|
|
23
|
-
type: 'boolean',
|
|
24
|
-
defaultValue: true
|
|
25
|
-
}, {
|
|
26
|
-
name: 'controls',
|
|
27
|
-
type: 'boolean',
|
|
28
|
-
defaultValue: false
|
|
29
|
-
}, {
|
|
30
|
-
name: 'muted',
|
|
31
|
-
type: 'boolean',
|
|
32
|
-
defaultValue: true
|
|
33
|
-
}, {
|
|
34
|
-
name: 'loop',
|
|
35
|
-
type: 'boolean',
|
|
36
|
-
defaultValue: true
|
|
37
|
-
}, {
|
|
38
|
-
name: 'playsInline',
|
|
39
|
-
type: 'boolean',
|
|
40
|
-
defaultValue: true
|
|
41
|
-
}, {
|
|
42
|
-
name: 'fit',
|
|
43
|
-
type: 'text',
|
|
44
|
-
defaultValue: 'cover',
|
|
45
|
-
enum: ['contain', 'cover', 'fill', 'auto']
|
|
46
|
-
}, {
|
|
47
|
-
name: 'preload',
|
|
48
|
-
type: 'text',
|
|
49
|
-
defaultValue: 'metadata',
|
|
50
|
-
enum: ['auto', 'metadata', 'none']
|
|
51
|
-
}, {
|
|
52
|
-
name: 'fitContent',
|
|
53
|
-
type: 'boolean',
|
|
54
|
-
helperText: 'When child blocks are provided, fit to them instead of using the aspect ratio',
|
|
55
|
-
defaultValue: true,
|
|
56
|
-
advanced: true
|
|
57
|
-
}, {
|
|
58
|
-
name: 'position',
|
|
59
|
-
type: 'text',
|
|
60
|
-
defaultValue: 'center',
|
|
61
|
-
enum: ['center', 'top', 'left', 'right', 'bottom', 'top left', 'top right', 'bottom left', 'bottom right']
|
|
62
|
-
}, {
|
|
63
|
-
name: 'height',
|
|
64
|
-
type: 'number',
|
|
65
|
-
advanced: true
|
|
66
|
-
}, {
|
|
67
|
-
name: 'width',
|
|
68
|
-
type: 'number',
|
|
69
|
-
advanced: true
|
|
70
|
-
}, {
|
|
71
|
-
name: 'aspectRatio',
|
|
72
|
-
type: 'number',
|
|
73
|
-
advanced: true,
|
|
74
|
-
defaultValue: 0.7004048582995948
|
|
75
|
-
}, {
|
|
76
|
-
name: 'lazyLoad',
|
|
77
|
-
type: 'boolean',
|
|
78
|
-
helperText: 'Load this video "lazily" - as in only when a user scrolls near the video. Recommended for optmized performance and bandwidth consumption',
|
|
79
|
-
defaultValue: true,
|
|
80
|
-
advanced: true
|
|
81
|
-
}]
|
|
82
|
-
};
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
function Video(props) {
|
|
4
|
-
function videoProps() {
|
|
5
|
-
return {
|
|
6
|
-
...(props.autoPlay === true
|
|
7
|
-
? {
|
|
8
|
-
autoPlay: true,
|
|
9
|
-
}
|
|
10
|
-
: {}),
|
|
11
|
-
...(props.muted === true
|
|
12
|
-
? {
|
|
13
|
-
muted: true,
|
|
14
|
-
}
|
|
15
|
-
: {}),
|
|
16
|
-
...(props.controls === true
|
|
17
|
-
? {
|
|
18
|
-
controls: true,
|
|
19
|
-
}
|
|
20
|
-
: {}),
|
|
21
|
-
...(props.loop === true
|
|
22
|
-
? {
|
|
23
|
-
loop: true,
|
|
24
|
-
}
|
|
25
|
-
: {}),
|
|
26
|
-
...(props.playsInline === true
|
|
27
|
-
? {
|
|
28
|
-
playsInline: true,
|
|
29
|
-
}
|
|
30
|
-
: {}),
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
function spreadProps() {
|
|
34
|
-
return {
|
|
35
|
-
...props.attributes,
|
|
36
|
-
...videoProps(),
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
return (React.createElement("video", { ...spreadProps(), preload: props.preload || "metadata", style: {
|
|
40
|
-
width: "100%",
|
|
41
|
-
height: "100%",
|
|
42
|
-
...props.attributes?.style,
|
|
43
|
-
objectFit: props.fit,
|
|
44
|
-
objectPosition: props.position,
|
|
45
|
-
// Hack to get object fit to work as expected and
|
|
46
|
-
// not have the video overflow
|
|
47
|
-
borderRadius: 1,
|
|
48
|
-
}, src: props.video || "no-src", poster: props.posterImage }));
|
|
49
|
-
}
|
|
50
|
-
export default Video;
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { evaluate } from '../../functions/evaluate/index.js';
|
|
2
|
-
import { getProcessedBlock } from '../../functions/get-processed-block.js';
|
|
3
|
-
/**
|
|
4
|
-
* https://developer.mozilla.org/en-US/docs/Glossary/Empty_element
|
|
5
|
-
*/
|
|
6
|
-
const EMPTY_HTML_ELEMENTS = ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'meta', 'param', 'source', 'track', 'wbr'];
|
|
7
|
-
export const isEmptyHtmlElement = (tagName) => {
|
|
8
|
-
return typeof tagName === 'string' && EMPTY_HTML_ELEMENTS.includes(tagName.toLowerCase());
|
|
9
|
-
};
|
|
10
|
-
export const getComponent = ({ block, context, registeredComponents }) => {
|
|
11
|
-
const componentName = getProcessedBlock({
|
|
12
|
-
block,
|
|
13
|
-
localState: context.localState,
|
|
14
|
-
rootState: context.rootState,
|
|
15
|
-
rootSetState: context.rootSetState,
|
|
16
|
-
context: context.context,
|
|
17
|
-
shouldEvaluateBindings: false
|
|
18
|
-
}).component?.name;
|
|
19
|
-
if (!componentName) {
|
|
20
|
-
return null;
|
|
21
|
-
}
|
|
22
|
-
const ref = registeredComponents[componentName];
|
|
23
|
-
if (!ref) {
|
|
24
|
-
// TODO: Public doc page with more info about this message
|
|
25
|
-
console.warn(`
|
|
26
|
-
Could not find a registered component named "${componentName}".
|
|
27
|
-
If you registered it, is the file that registered it imported by the file that needs to render it?`);
|
|
28
|
-
return undefined;
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
return ref;
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
export const getRepeatItemData = ({ block, context }) => {
|
|
35
|
-
/**
|
|
36
|
-
* we don't use `state.processedBlock` here because the processing done within its logic includes evaluating the block's bindings,
|
|
37
|
-
* which will not work if there is a repeat.
|
|
38
|
-
*/
|
|
39
|
-
const { repeat, ...blockWithoutRepeat } = block;
|
|
40
|
-
if (!repeat?.collection) {
|
|
41
|
-
return undefined;
|
|
42
|
-
}
|
|
43
|
-
const itemsArray = evaluate({
|
|
44
|
-
code: repeat.collection,
|
|
45
|
-
localState: context.localState,
|
|
46
|
-
rootState: context.rootState,
|
|
47
|
-
rootSetState: context.rootSetState,
|
|
48
|
-
context: context.context
|
|
49
|
-
});
|
|
50
|
-
if (!Array.isArray(itemsArray)) {
|
|
51
|
-
return undefined;
|
|
52
|
-
}
|
|
53
|
-
const collectionName = repeat.collection.split('.').pop();
|
|
54
|
-
const itemNameToUse = repeat.itemName || (collectionName ? collectionName + 'Item' : 'item');
|
|
55
|
-
const repeatArray = itemsArray.map((item, index) => ({
|
|
56
|
-
context: {
|
|
57
|
-
...context,
|
|
58
|
-
localState: {
|
|
59
|
-
...context.localState,
|
|
60
|
-
$index: index,
|
|
61
|
-
$item: item,
|
|
62
|
-
[itemNameToUse]: item,
|
|
63
|
-
[`$${itemNameToUse}Index`]: index
|
|
64
|
-
}
|
|
65
|
-
},
|
|
66
|
-
block: blockWithoutRepeat
|
|
67
|
-
}));
|
|
68
|
-
return repeatArray;
|
|
69
|
-
};
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { getBlockComponentOptions } from "../../functions/get-block-component-options.js";
|
|
3
|
-
import { getProcessedBlock } from "../../functions/get-processed-block.js";
|
|
4
|
-
import BlockStyles from "./components/block-styles";
|
|
5
|
-
import { getComponent, getRepeatItemData, isEmptyHtmlElement, } from "./block.helpers.js";
|
|
6
|
-
import RepeatedBlock from "./components/repeated-block";
|
|
7
|
-
import ComponentRef from "./components/component-ref/component-ref";
|
|
8
|
-
import BlockWrapper from "./components/block-wrapper";
|
|
9
|
-
function Block(props) {
|
|
10
|
-
const blockComponent = function blockComponent() {
|
|
11
|
-
return getComponent({
|
|
12
|
-
block: props.block,
|
|
13
|
-
context: props.context,
|
|
14
|
-
registeredComponents: props.registeredComponents,
|
|
15
|
-
});
|
|
16
|
-
};
|
|
17
|
-
const repeatItem = function repeatItem() {
|
|
18
|
-
return getRepeatItemData({
|
|
19
|
-
block: props.block,
|
|
20
|
-
context: props.context,
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
|
-
const processedBlock = function processedBlock() {
|
|
24
|
-
return repeatItem()
|
|
25
|
-
? props.block
|
|
26
|
-
: getProcessedBlock({
|
|
27
|
-
block: props.block,
|
|
28
|
-
localState: props.context.localState,
|
|
29
|
-
rootState: props.context.rootState,
|
|
30
|
-
rootSetState: props.context.rootSetState,
|
|
31
|
-
context: props.context.context,
|
|
32
|
-
shouldEvaluateBindings: true,
|
|
33
|
-
});
|
|
34
|
-
};
|
|
35
|
-
const Tag = function Tag() {
|
|
36
|
-
return props.block.tagName || "div";
|
|
37
|
-
};
|
|
38
|
-
const canShowBlock = function canShowBlock() {
|
|
39
|
-
if ("hide" in processedBlock()) {
|
|
40
|
-
return !processedBlock().hide;
|
|
41
|
-
}
|
|
42
|
-
if ("show" in processedBlock()) {
|
|
43
|
-
return processedBlock().show;
|
|
44
|
-
}
|
|
45
|
-
return true;
|
|
46
|
-
};
|
|
47
|
-
const childrenWithoutParentComponent = function childrenWithoutParentComponent() {
|
|
48
|
-
/**
|
|
49
|
-
* When there is no `componentRef`, there might still be children that need to be rendered. In this case,
|
|
50
|
-
* we render them outside of `componentRef`.
|
|
51
|
-
* NOTE: We make sure not to render this if `repeatItemData` is non-null, because that means we are rendering an array of
|
|
52
|
-
* blocks, and the children will be repeated within those blocks.
|
|
53
|
-
*/
|
|
54
|
-
const shouldRenderChildrenOutsideRef = !blockComponent()?.component && !repeatItem();
|
|
55
|
-
return shouldRenderChildrenOutsideRef
|
|
56
|
-
? processedBlock().children ?? []
|
|
57
|
-
: [];
|
|
58
|
-
};
|
|
59
|
-
const componentRefProps = function componentRefProps() {
|
|
60
|
-
return {
|
|
61
|
-
blockChildren: processedBlock().children ?? [],
|
|
62
|
-
componentRef: blockComponent()?.component,
|
|
63
|
-
componentOptions: {
|
|
64
|
-
...getBlockComponentOptions(processedBlock()),
|
|
65
|
-
builderContext: props.context,
|
|
66
|
-
...(blockComponent()?.name === "Symbol" ||
|
|
67
|
-
blockComponent()?.name === "Columns"
|
|
68
|
-
? {
|
|
69
|
-
builderComponents: props.registeredComponents,
|
|
70
|
-
}
|
|
71
|
-
: {}),
|
|
72
|
-
},
|
|
73
|
-
context: childrenContext,
|
|
74
|
-
registeredComponents: props.registeredComponents,
|
|
75
|
-
builderBlock: processedBlock(),
|
|
76
|
-
includeBlockProps: blockComponent()?.noWrap === true,
|
|
77
|
-
isInteractive: !blockComponent()?.isRSC,
|
|
78
|
-
};
|
|
79
|
-
};
|
|
80
|
-
const childrenContext = props.context;
|
|
81
|
-
return (React.createElement(React.Fragment, null, canShowBlock() ? (React.createElement(React.Fragment, null, !blockComponent()?.noWrap ? (React.createElement(React.Fragment, null,
|
|
82
|
-
isEmptyHtmlElement(Tag()) ? (React.createElement(React.Fragment, null,
|
|
83
|
-
React.createElement(BlockWrapper, { Wrapper: Tag(), block: processedBlock(), context: props.context, hasChildren: false }))) : null,
|
|
84
|
-
!isEmptyHtmlElement(Tag()) && repeatItem() ? (React.createElement(React.Fragment, null, repeatItem()?.map((data, index) => (React.createElement(RepeatedBlock, { key: index, repeatContext: data.context, block: data.block, registeredComponents: props.registeredComponents }))))) : null,
|
|
85
|
-
!isEmptyHtmlElement(Tag()) && !repeatItem() ? (React.createElement(React.Fragment, null,
|
|
86
|
-
React.createElement(BlockWrapper, { Wrapper: Tag(), block: processedBlock(), context: props.context, hasChildren: true },
|
|
87
|
-
React.createElement(ComponentRef, { ...componentRefProps() }),
|
|
88
|
-
childrenWithoutParentComponent()?.map((child) => (React.createElement(Block, { key: "block-" + child.id, block: child, context: childrenContext, registeredComponents: props.registeredComponents }))),
|
|
89
|
-
childrenWithoutParentComponent()?.map((child) => (React.createElement(BlockStyles, { key: "block-style-" + child.id, block: child, context: childrenContext })))))) : null)) : (React.createElement(React.Fragment, null,
|
|
90
|
-
React.createElement(ComponentRef, { ...componentRefProps() }))))) : null));
|
|
91
|
-
}
|
|
92
|
-
export default Block;
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
import { useState } from "react";
|
|
4
|
-
import { getMaxWidthQueryForSize, getSizesForBreakpoints, } from "../../../constants/device-sizes.js";
|
|
5
|
-
import { TARGET } from "../../../constants/target.js";
|
|
6
|
-
import { getProcessedBlock } from "../../../functions/get-processed-block.js";
|
|
7
|
-
import { createCssClass } from "../../../helpers/css.js";
|
|
8
|
-
import { checkIsDefined } from "../../../helpers/nullable.js";
|
|
9
|
-
import InlinedStyles from "../../inlined-styles";
|
|
10
|
-
function BlockStyles(props) {
|
|
11
|
-
const [processedBlock, setProcessedBlock] = useState(() => getProcessedBlock({
|
|
12
|
-
block: props.block,
|
|
13
|
-
localState: props.context.localState,
|
|
14
|
-
rootState: props.context.rootState,
|
|
15
|
-
rootSetState: props.context.rootSetState,
|
|
16
|
-
context: props.context.context,
|
|
17
|
-
shouldEvaluateBindings: true,
|
|
18
|
-
}));
|
|
19
|
-
function canShowBlock() {
|
|
20
|
-
// only render styles for blocks that are visible
|
|
21
|
-
if (checkIsDefined(processedBlock.hide)) {
|
|
22
|
-
return !processedBlock.hide;
|
|
23
|
-
}
|
|
24
|
-
if (checkIsDefined(processedBlock.show)) {
|
|
25
|
-
return processedBlock.show;
|
|
26
|
-
}
|
|
27
|
-
return true;
|
|
28
|
-
}
|
|
29
|
-
function css() {
|
|
30
|
-
const styles = processedBlock.responsiveStyles;
|
|
31
|
-
const content = props.context.content;
|
|
32
|
-
const sizesWithUpdatedBreakpoints = getSizesForBreakpoints(content?.meta?.breakpoints || {});
|
|
33
|
-
const largeStyles = styles?.large;
|
|
34
|
-
const mediumStyles = styles?.medium;
|
|
35
|
-
const smallStyles = styles?.small;
|
|
36
|
-
const className = processedBlock.id;
|
|
37
|
-
if (!className) {
|
|
38
|
-
return "";
|
|
39
|
-
}
|
|
40
|
-
const largeStylesClass = largeStyles
|
|
41
|
-
? createCssClass({
|
|
42
|
-
className,
|
|
43
|
-
styles: largeStyles,
|
|
44
|
-
})
|
|
45
|
-
: "";
|
|
46
|
-
const mediumStylesClass = mediumStyles
|
|
47
|
-
? createCssClass({
|
|
48
|
-
className,
|
|
49
|
-
styles: mediumStyles,
|
|
50
|
-
mediaQuery: getMaxWidthQueryForSize("medium", sizesWithUpdatedBreakpoints),
|
|
51
|
-
})
|
|
52
|
-
: "";
|
|
53
|
-
const smallStylesClass = smallStyles
|
|
54
|
-
? createCssClass({
|
|
55
|
-
className,
|
|
56
|
-
styles: smallStyles,
|
|
57
|
-
mediaQuery: getMaxWidthQueryForSize("small", sizesWithUpdatedBreakpoints),
|
|
58
|
-
})
|
|
59
|
-
: "";
|
|
60
|
-
return [largeStylesClass, mediumStylesClass, smallStylesClass].join(" ");
|
|
61
|
-
}
|
|
62
|
-
return (React.createElement(React.Fragment, null, TARGET !== "reactNative" && css() && canShowBlock() ? (React.createElement(React.Fragment, null,
|
|
63
|
-
React.createElement(InlinedStyles, { styles: css() }))) : null));
|
|
64
|
-
}
|
|
65
|
-
export default BlockStyles;
|