@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.
Files changed (287) hide show
  1. package/lib/browser/USE_CLIENT_BUNDLE-29f9ac5c.js +23 -0
  2. package/lib/browser/USE_CLIENT_BUNDLE-dfa97c43.mjs +664 -0
  3. package/lib/browser/USE_SERVER_BUNDLE-25e181fa.js +1 -0
  4. package/lib/browser/USE_SERVER_BUNDLE-fcd44ecb.mjs +11 -0
  5. package/lib/browser/bundle-5cab6113.js +76 -0
  6. package/lib/browser/bundle-babbd573.mjs +2419 -0
  7. package/lib/browser/index.cjs +1 -0
  8. package/lib/browser/index.mjs +34 -0
  9. package/lib/edge/USE_CLIENT_BUNDLE-3cbb02d5.mjs +664 -0
  10. package/lib/edge/USE_CLIENT_BUNDLE-d0b99f60.js +23 -0
  11. package/lib/edge/USE_SERVER_BUNDLE-4eeb4634.mjs +11 -0
  12. package/lib/edge/USE_SERVER_BUNDLE-bbd89085.js +1 -0
  13. package/lib/edge/bundle-9ed99f98.mjs +4863 -0
  14. package/lib/edge/bundle-e4764e2a.js +96 -0
  15. package/lib/edge/index.cjs +1 -0
  16. package/lib/edge/index.mjs +34 -0
  17. package/lib/node/USE_CLIENT_BUNDLE-29f9ac5c.js +23 -0
  18. package/lib/node/USE_CLIENT_BUNDLE-dfa97c43.mjs +664 -0
  19. package/lib/node/USE_SERVER_BUNDLE-25e181fa.js +1 -0
  20. package/lib/node/USE_SERVER_BUNDLE-fcd44ecb.mjs +11 -0
  21. package/lib/node/bundle-5cab6113.js +76 -0
  22. package/lib/node/bundle-babbd573.mjs +2419 -0
  23. package/lib/node/index.cjs +1 -0
  24. package/lib/node/index.mjs +34 -0
  25. package/package.json +96 -13
  26. package/{dist → types}/components/content/content.types.d.ts +2 -2
  27. package/{dist → types}/components/content-variants/content-variants.d.ts +2 -2
  28. package/{dist → types}/components/content-variants/content-variants.types.d.ts +1 -1
  29. package/types/constants/sdk-version.d.ts +1 -0
  30. package/types/functions/deopt.d.ts +4 -0
  31. package/types/functions/evaluate/browser-runtime/browser.d.ts +4 -0
  32. package/types/functions/evaluate/browser-runtime/index.d.ts +1 -0
  33. package/types/functions/evaluate/evaluate.d.ts +6 -0
  34. package/types/functions/evaluate/helpers.d.ts +18 -0
  35. package/types/functions/evaluate/index.d.ts +1 -0
  36. package/{dist → types}/functions/fetch-builder-props.d.ts +4 -3
  37. package/{dist → types}/functions/get-content/index.d.ts +4 -5
  38. package/{dist → types}/index-helpers/blocks-exports.d.ts +2 -2
  39. package/types/index.d.ts +7 -0
  40. package/{dist/index.d.ts → types/server-index.d.ts} +0 -1
  41. package/dist/blocks/button/button.js +0 -12
  42. package/dist/blocks/button/component-info.js +0 -34
  43. package/dist/blocks/columns/columns.js +0 -119
  44. package/dist/blocks/columns/component-info.js +0 -219
  45. package/dist/blocks/custom-code/component-info.js +0 -23
  46. package/dist/blocks/custom-code/custom-code.js +0 -51
  47. package/dist/blocks/embed/component-info.js +0 -39
  48. package/dist/blocks/embed/embed.js +0 -42
  49. package/dist/blocks/embed/helpers.js +0 -2
  50. package/dist/blocks/fragment/component-info.js +0 -7
  51. package/dist/blocks/fragment/fragment.js +0 -6
  52. package/dist/blocks/helpers.js +0 -40
  53. package/dist/blocks/image/component-info.js +0 -122
  54. package/dist/blocks/image/image.helpers.js +0 -47
  55. package/dist/blocks/image/image.js +0 -82
  56. package/dist/blocks/img/component-info.js +0 -15
  57. package/dist/blocks/img/img.js +0 -10
  58. package/dist/blocks/section/component-info.js +0 -40
  59. package/dist/blocks/section/section.js +0 -17
  60. package/dist/blocks/symbol/component-info.js +0 -34
  61. package/dist/blocks/symbol/symbol.helpers.js +0 -31
  62. package/dist/blocks/symbol/symbol.js +0 -29
  63. package/dist/blocks/text/component-info.js +0 -19
  64. package/dist/blocks/text/text.js +0 -7
  65. package/dist/blocks/video/component-info.js +0 -82
  66. package/dist/blocks/video/video.js +0 -50
  67. package/dist/components/block/block.helpers.js +0 -69
  68. package/dist/components/block/block.js +0 -92
  69. package/dist/components/block/components/block-styles.js +0 -65
  70. package/dist/components/block/components/block-wrapper.js +0 -36
  71. package/dist/components/block/components/component-ref/component-ref.helpers.js +0 -22
  72. package/dist/components/block/components/component-ref/component-ref.js +0 -21
  73. package/dist/components/block/components/interactive-element.js +0 -20
  74. package/dist/components/block/components/repeated-block.js +0 -7
  75. package/dist/components/block/types.js +0 -1
  76. package/dist/components/blocks/blocks-wrapper.js +0 -38
  77. package/dist/components/blocks/blocks.js +0 -10
  78. package/dist/components/content/components/enable-editor.js +0 -250
  79. package/dist/components/content/components/styles.helpers.js +0 -58
  80. package/dist/components/content/components/styles.js +0 -30
  81. package/dist/components/content/content.helpers.js +0 -30
  82. package/dist/components/content/content.js +0 -74
  83. package/dist/components/content/content.types.js +0 -1
  84. package/dist/components/content/wrap-component-ref.js +0 -6
  85. package/dist/components/content-variants/content-variants.js +0 -45
  86. package/dist/components/content-variants/content-variants.types.js +0 -1
  87. package/dist/components/content-variants/helpers.js +0 -189
  88. package/dist/components/inlined-script.js +0 -5
  89. package/dist/components/inlined-styles.js +0 -5
  90. package/dist/constants/builder-registered-components.js +0 -60
  91. package/dist/constants/device-sizes.js +0 -45
  92. package/dist/constants/sdk-version.d.ts +0 -1
  93. package/dist/constants/sdk-version.js +0 -1
  94. package/dist/constants/target.js +0 -2
  95. package/dist/context/builder.context.js +0 -12
  96. package/dist/context/components.context.js +0 -2
  97. package/dist/context/types.js +0 -1
  98. package/dist/functions/camel-to-kebab-case.js +0 -1
  99. package/dist/functions/evaluate/acorn-interpreter.d.ts +0 -2
  100. package/dist/functions/evaluate/acorn-interpreter.js +0 -3111
  101. package/dist/functions/evaluate/evaluate.d.ts +0 -10
  102. package/dist/functions/evaluate/evaluate.js +0 -70
  103. package/dist/functions/evaluate/index.d.ts +0 -1
  104. package/dist/functions/evaluate/index.js +0 -1
  105. package/dist/functions/evaluate/non-node-runtime/index.d.ts +0 -1
  106. package/dist/functions/evaluate/non-node-runtime/index.js +0 -2
  107. package/dist/functions/evaluate/non-node-runtime/non-node-runtime.d.ts +0 -2
  108. package/dist/functions/evaluate/non-node-runtime/non-node-runtime.js +0 -84
  109. package/dist/functions/evaluate/types.d.ts +0 -11
  110. package/dist/functions/evaluate/types.js +0 -1
  111. package/dist/functions/event-handler-name.js +0 -4
  112. package/dist/functions/extract-text-styles.js +0 -22
  113. package/dist/functions/fast-clone.js +0 -4
  114. package/dist/functions/fetch-builder-props.js +0 -25
  115. package/dist/functions/get-block-actions-handler.js +0 -10
  116. package/dist/functions/get-block-actions.js +0 -28
  117. package/dist/functions/get-block-component-options.js +0 -10
  118. package/dist/functions/get-block-properties.js +0 -72
  119. package/dist/functions/get-builder-search-params/index.js +0 -38
  120. package/dist/functions/get-content/generate-content-url.js +0 -33
  121. package/dist/functions/get-content/index.js +0 -100
  122. package/dist/functions/get-content/types.js +0 -1
  123. package/dist/functions/get-fetch.js +0 -11
  124. package/dist/functions/get-global-this.js +0 -15
  125. package/dist/functions/get-processed-block.js +0 -46
  126. package/dist/functions/get-react-native-block-styles.js +0 -17
  127. package/dist/functions/is-browser.js +0 -3
  128. package/dist/functions/is-editing.js +0 -5
  129. package/dist/functions/is-iframe.js +0 -4
  130. package/dist/functions/is-non-node-server.d.ts +0 -4
  131. package/dist/functions/is-non-node-server.js +0 -8
  132. package/dist/functions/is-previewing.js +0 -11
  133. package/dist/functions/register-component.js +0 -38
  134. package/dist/functions/register.js +0 -27
  135. package/dist/functions/sanitize-react-native-block-styles.js +0 -61
  136. package/dist/functions/set-editor-settings.js +0 -12
  137. package/dist/functions/set.js +0 -14
  138. package/dist/functions/track/helpers.js +0 -51
  139. package/dist/functions/track/index.js +0 -71
  140. package/dist/functions/track/interaction.js +0 -53
  141. package/dist/functions/transform-block-properties.js +0 -5
  142. package/dist/functions/transform-block.js +0 -4
  143. package/dist/helpers/ab-tests.js +0 -122
  144. package/dist/helpers/canTrack.js +0 -2
  145. package/dist/helpers/cookie.js +0 -55
  146. package/dist/helpers/css.js +0 -27
  147. package/dist/helpers/flatten.js +0 -19
  148. package/dist/helpers/localStorage.js +0 -24
  149. package/dist/helpers/logger.js +0 -7
  150. package/dist/helpers/nullable.js +0 -1
  151. package/dist/helpers/preview-lru-cache/get.js +0 -9
  152. package/dist/helpers/preview-lru-cache/helpers.js +0 -9
  153. package/dist/helpers/preview-lru-cache/init.js +0 -15
  154. package/dist/helpers/preview-lru-cache/set.js +0 -7
  155. package/dist/helpers/preview-lru-cache/types.js +0 -6
  156. package/dist/helpers/sessionId.js +0 -30
  157. package/dist/helpers/url.js +0 -15
  158. package/dist/helpers/uuid.js +0 -15
  159. package/dist/helpers/visitorId.js +0 -30
  160. package/dist/index-helpers/blocks-exports.js +0 -19
  161. package/dist/index-helpers/top-of-file.js +0 -4
  162. package/dist/index.js +0 -11
  163. package/dist/scripts/init-editing.js +0 -110
  164. package/dist/types/api-version.js +0 -1
  165. package/dist/types/builder-block.js +0 -1
  166. package/dist/types/builder-content.js +0 -1
  167. package/dist/types/builder-props.js +0 -1
  168. package/dist/types/can-track.js +0 -1
  169. package/dist/types/components.js +0 -1
  170. package/dist/types/deep-partial.js +0 -1
  171. package/dist/types/element.js +0 -1
  172. package/dist/types/enforced-partials.js +0 -1
  173. package/dist/types/input.js +0 -1
  174. package/dist/types/targets.js +0 -1
  175. package/dist/types/typescript.js +0 -1
  176. /package/{dist → types}/blocks/button/button.d.ts +0 -0
  177. /package/{dist → types}/blocks/button/component-info.d.ts +0 -0
  178. /package/{dist → types}/blocks/columns/columns.d.ts +0 -0
  179. /package/{dist → types}/blocks/columns/component-info.d.ts +0 -0
  180. /package/{dist → types}/blocks/custom-code/component-info.d.ts +0 -0
  181. /package/{dist → types}/blocks/custom-code/custom-code.d.ts +0 -0
  182. /package/{dist → types}/blocks/embed/component-info.d.ts +0 -0
  183. /package/{dist → types}/blocks/embed/embed.d.ts +0 -0
  184. /package/{dist → types}/blocks/embed/helpers.d.ts +0 -0
  185. /package/{dist → types}/blocks/fragment/component-info.d.ts +0 -0
  186. /package/{dist → types}/blocks/fragment/fragment.d.ts +0 -0
  187. /package/{dist → types}/blocks/helpers.d.ts +0 -0
  188. /package/{dist → types}/blocks/image/component-info.d.ts +0 -0
  189. /package/{dist → types}/blocks/image/image.d.ts +0 -0
  190. /package/{dist → types}/blocks/image/image.helpers.d.ts +0 -0
  191. /package/{dist → types}/blocks/img/component-info.d.ts +0 -0
  192. /package/{dist → types}/blocks/img/img.d.ts +0 -0
  193. /package/{dist → types}/blocks/section/component-info.d.ts +0 -0
  194. /package/{dist → types}/blocks/section/section.d.ts +0 -0
  195. /package/{dist → types}/blocks/symbol/component-info.d.ts +0 -0
  196. /package/{dist → types}/blocks/symbol/symbol.d.ts +0 -0
  197. /package/{dist → types}/blocks/symbol/symbol.helpers.d.ts +0 -0
  198. /package/{dist → types}/blocks/text/component-info.d.ts +0 -0
  199. /package/{dist → types}/blocks/text/text.d.ts +0 -0
  200. /package/{dist → types}/blocks/video/component-info.d.ts +0 -0
  201. /package/{dist → types}/blocks/video/video.d.ts +0 -0
  202. /package/{dist → types}/components/block/block.d.ts +0 -0
  203. /package/{dist → types}/components/block/block.helpers.d.ts +0 -0
  204. /package/{dist → types}/components/block/components/block-styles.d.ts +0 -0
  205. /package/{dist → types}/components/block/components/block-wrapper.d.ts +0 -0
  206. /package/{dist → types}/components/block/components/component-ref/component-ref.d.ts +0 -0
  207. /package/{dist → types}/components/block/components/component-ref/component-ref.helpers.d.ts +0 -0
  208. /package/{dist → types}/components/block/components/interactive-element.d.ts +0 -0
  209. /package/{dist → types}/components/block/components/repeated-block.d.ts +0 -0
  210. /package/{dist → types}/components/block/types.d.ts +0 -0
  211. /package/{dist → types}/components/blocks/blocks-wrapper.d.ts +0 -0
  212. /package/{dist → types}/components/blocks/blocks.d.ts +0 -0
  213. /package/{dist → types}/components/content/components/enable-editor.d.ts +0 -0
  214. /package/{dist → types}/components/content/components/styles.d.ts +0 -0
  215. /package/{dist → types}/components/content/components/styles.helpers.d.ts +0 -0
  216. /package/{dist → types}/components/content/content.d.ts +0 -0
  217. /package/{dist → types}/components/content/content.helpers.d.ts +0 -0
  218. /package/{dist → types}/components/content/wrap-component-ref.d.ts +0 -0
  219. /package/{dist → types}/components/content-variants/helpers.d.ts +0 -0
  220. /package/{dist → types}/components/inlined-script.d.ts +0 -0
  221. /package/{dist → types}/components/inlined-styles.d.ts +0 -0
  222. /package/{dist → types}/constants/builder-registered-components.d.ts +0 -0
  223. /package/{dist → types}/constants/device-sizes.d.ts +0 -0
  224. /package/{dist → types}/constants/target.d.ts +0 -0
  225. /package/{dist → types}/context/builder.context.d.ts +0 -0
  226. /package/{dist → types}/context/components.context.d.ts +0 -0
  227. /package/{dist → types}/context/types.d.ts +0 -0
  228. /package/{dist → types}/functions/camel-to-kebab-case.d.ts +0 -0
  229. /package/{dist → types}/functions/event-handler-name.d.ts +0 -0
  230. /package/{dist → types}/functions/extract-text-styles.d.ts +0 -0
  231. /package/{dist → types}/functions/fast-clone.d.ts +0 -0
  232. /package/{dist → types}/functions/get-block-actions-handler.d.ts +0 -0
  233. /package/{dist → types}/functions/get-block-actions.d.ts +0 -0
  234. /package/{dist → types}/functions/get-block-component-options.d.ts +0 -0
  235. /package/{dist → types}/functions/get-block-properties.d.ts +0 -0
  236. /package/{dist → types}/functions/get-builder-search-params/index.d.ts +0 -0
  237. /package/{dist → types}/functions/get-content/generate-content-url.d.ts +0 -0
  238. /package/{dist → types}/functions/get-content/types.d.ts +0 -0
  239. /package/{dist → types}/functions/get-fetch.d.ts +0 -0
  240. /package/{dist → types}/functions/get-global-this.d.ts +0 -0
  241. /package/{dist → types}/functions/get-processed-block.d.ts +0 -0
  242. /package/{dist → types}/functions/get-react-native-block-styles.d.ts +0 -0
  243. /package/{dist → types}/functions/is-browser.d.ts +0 -0
  244. /package/{dist → types}/functions/is-editing.d.ts +0 -0
  245. /package/{dist → types}/functions/is-iframe.d.ts +0 -0
  246. /package/{dist → types}/functions/is-previewing.d.ts +0 -0
  247. /package/{dist → types}/functions/register-component.d.ts +0 -0
  248. /package/{dist → types}/functions/register.d.ts +0 -0
  249. /package/{dist → types}/functions/sanitize-react-native-block-styles.d.ts +0 -0
  250. /package/{dist → types}/functions/set-editor-settings.d.ts +0 -0
  251. /package/{dist → types}/functions/set.d.ts +0 -0
  252. /package/{dist → types}/functions/track/helpers.d.ts +0 -0
  253. /package/{dist → types}/functions/track/index.d.ts +0 -0
  254. /package/{dist → types}/functions/track/interaction.d.ts +0 -0
  255. /package/{dist → types}/functions/transform-block-properties.d.ts +0 -0
  256. /package/{dist → types}/functions/transform-block.d.ts +0 -0
  257. /package/{dist → types}/helpers/ab-tests.d.ts +0 -0
  258. /package/{dist → types}/helpers/canTrack.d.ts +0 -0
  259. /package/{dist → types}/helpers/cookie.d.ts +0 -0
  260. /package/{dist → types}/helpers/css.d.ts +0 -0
  261. /package/{dist → types}/helpers/flatten.d.ts +0 -0
  262. /package/{dist → types}/helpers/localStorage.d.ts +0 -0
  263. /package/{dist → types}/helpers/logger.d.ts +0 -0
  264. /package/{dist → types}/helpers/nullable.d.ts +0 -0
  265. /package/{dist → types}/helpers/preview-lru-cache/get.d.ts +0 -0
  266. /package/{dist → types}/helpers/preview-lru-cache/helpers.d.ts +0 -0
  267. /package/{dist → types}/helpers/preview-lru-cache/init.d.ts +0 -0
  268. /package/{dist → types}/helpers/preview-lru-cache/set.d.ts +0 -0
  269. /package/{dist → types}/helpers/preview-lru-cache/types.d.ts +0 -0
  270. /package/{dist → types}/helpers/sessionId.d.ts +0 -0
  271. /package/{dist → types}/helpers/url.d.ts +0 -0
  272. /package/{dist → types}/helpers/uuid.d.ts +0 -0
  273. /package/{dist → types}/helpers/visitorId.d.ts +0 -0
  274. /package/{dist → types}/index-helpers/top-of-file.d.ts +0 -0
  275. /package/{dist → types}/scripts/init-editing.d.ts +0 -0
  276. /package/{dist → types}/types/api-version.d.ts +0 -0
  277. /package/{dist → types}/types/builder-block.d.ts +0 -0
  278. /package/{dist → types}/types/builder-content.d.ts +0 -0
  279. /package/{dist → types}/types/builder-props.d.ts +0 -0
  280. /package/{dist → types}/types/can-track.d.ts +0 -0
  281. /package/{dist → types}/types/components.d.ts +0 -0
  282. /package/{dist → types}/types/deep-partial.d.ts +0 -0
  283. /package/{dist → types}/types/element.d.ts +0 -0
  284. /package/{dist → types}/types/enforced-partials.d.ts +0 -0
  285. /package/{dist → types}/types/input.d.ts +0 -0
  286. /package/{dist → types}/types/targets.d.ts +0 -0
  287. /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
- };
@@ -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
- };
@@ -1,7 +0,0 @@
1
- import * as React from "react";
2
- function Text(props) {
3
- return (React.createElement("span", { className: "builder-text", dangerouslySetInnerHTML: { __html: props.text?.toString() || "" }, style: {
4
- outline: "none",
5
- } }));
6
- }
7
- export default Text;
@@ -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;