@builder.io/sdk-react 0.2.3-4 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (288) hide show
  1. package/README.md +72 -3
  2. package/dist/sdk/blocks/columns/columns.js +5 -5
  3. package/dist/sdk/blocks/image/image.js +8 -7
  4. package/dist/sdk/blocks/symbol/symbol.js +3 -2
  5. package/dist/sdk/blocks/video/video.js +4 -1
  6. package/dist/sdk/components/render-block/block-styles.js +3 -1
  7. package/dist/sdk/components/render-block/render-block.helpers.d.ts +0 -1
  8. package/dist/sdk/components/render-block/render-block.helpers.js +8 -20
  9. package/dist/sdk/components/render-block/render-block.js +24 -15
  10. package/dist/sdk/components/render-block/render-repeated-block.js +3 -2
  11. package/dist/sdk/components/render-content/render-content.js +31 -12
  12. package/dist/sdk/components/render-content-variants/helpers.d.ts +12 -0
  13. package/dist/sdk/components/render-content-variants/helpers.js +154 -0
  14. package/dist/sdk/components/render-content-variants/render-content-variants.d.ts +5 -0
  15. package/dist/sdk/components/render-content-variants/render-content-variants.js +29 -0
  16. package/dist/sdk/components/render-inlined-styles.js +2 -2
  17. package/dist/sdk/constants/sdk-version.d.ts +1 -0
  18. package/dist/sdk/constants/sdk-version.js +1 -0
  19. package/dist/sdk/context/builder.context.js +3 -2
  20. package/dist/sdk/context/types.d.ts +17 -2
  21. package/dist/sdk/functions/evaluate.d.ts +4 -3
  22. package/dist/sdk/functions/evaluate.js +23 -2
  23. package/dist/sdk/functions/evaluate.test.d.ts +1 -0
  24. package/dist/sdk/functions/evaluate.test.js +17 -0
  25. package/dist/sdk/functions/get-block-actions-handler.d.ts +1 -1
  26. package/dist/sdk/functions/get-block-actions-handler.js +3 -1
  27. package/dist/sdk/functions/get-block-actions.d.ts +1 -1
  28. package/dist/sdk/functions/get-processed-block.d.ts +2 -2
  29. package/dist/sdk/functions/get-processed-block.js +16 -4
  30. package/dist/sdk/functions/get-processed-block.test.js +3 -1
  31. package/dist/sdk/helpers/canTrack.d.ts +1 -0
  32. package/dist/sdk/helpers/canTrack.js +2 -0
  33. package/dist/sdk/index.d.ts +1 -0
  34. package/dist/sdk/scripts/init-editing.js +2 -0
  35. package/package.json +5 -5
  36. package/CHANGELOG.md +0 -25
  37. package/packages/react/src/blocks/BaseText.tsx +0 -19
  38. package/packages/react/src/blocks/button/button.tsx +0 -45
  39. package/packages/react/src/blocks/button/component-info.ts +0 -42
  40. package/packages/react/src/blocks/columns/columns.tsx +0 -211
  41. package/packages/react/src/blocks/columns/component-info.ts +0 -254
  42. package/packages/react/src/blocks/custom-code/component-info.ts +0 -31
  43. package/packages/react/src/blocks/custom-code/custom-code.tsx +0 -76
  44. package/packages/react/src/blocks/embed/component-info.ts +0 -55
  45. package/packages/react/src/blocks/embed/embed.tsx +0 -59
  46. package/packages/react/src/blocks/embed/helpers.ts +0 -8
  47. package/packages/react/src/blocks/form/component-info.ts +0 -282
  48. package/packages/react/src/blocks/form/form.tsx +0 -320
  49. package/packages/react/src/blocks/fragment/component-info.ts +0 -10
  50. package/packages/react/src/blocks/fragment/fragment.tsx +0 -14
  51. package/packages/react/src/blocks/image/component-info.ts +0 -172
  52. package/packages/react/src/blocks/image/image.helpers.ts +0 -75
  53. package/packages/react/src/blocks/image/image.tsx +0 -144
  54. package/packages/react/src/blocks/img/component-info.ts +0 -21
  55. package/packages/react/src/blocks/img/img.tsx +0 -40
  56. package/packages/react/src/blocks/input/component-info.ts +0 -78
  57. package/packages/react/src/blocks/input/input.tsx +0 -33
  58. package/packages/react/src/blocks/raw-text/component-info.ts +0 -15
  59. package/packages/react/src/blocks/raw-text/raw-text.tsx +0 -18
  60. package/packages/react/src/blocks/section/component-info.ts +0 -50
  61. package/packages/react/src/blocks/section/section.tsx +0 -33
  62. package/packages/react/src/blocks/select/component-info.ts +0 -61
  63. package/packages/react/src/blocks/select/select.tsx +0 -35
  64. package/packages/react/src/blocks/submit-button/component-info.ts +0 -32
  65. package/packages/react/src/blocks/submit-button/submit-button.tsx +0 -17
  66. package/packages/react/src/blocks/symbol/component-info.ts +0 -43
  67. package/packages/react/src/blocks/symbol/symbol.tsx +0 -111
  68. package/packages/react/src/blocks/text/component-info.ts +0 -24
  69. package/packages/react/src/blocks/text/text.tsx +0 -20
  70. package/packages/react/src/blocks/textarea/component-info.ts +0 -48
  71. package/packages/react/src/blocks/textarea/textarea.tsx +0 -24
  72. package/packages/react/src/blocks/util.ts +0 -18
  73. package/packages/react/src/blocks/video/component-info.ts +0 -109
  74. package/packages/react/src/blocks/video/video.tsx +0 -84
  75. package/packages/react/src/components/render-block/block-styles.tsx +0 -98
  76. package/packages/react/src/components/render-block/render-block.helpers.ts +0 -138
  77. package/packages/react/src/components/render-block/render-block.tsx +0 -216
  78. package/packages/react/src/components/render-block/render-component.tsx +0 -52
  79. package/packages/react/src/components/render-block/render-repeated-block.tsx +0 -43
  80. package/packages/react/src/components/render-block/types.ts +0 -7
  81. package/packages/react/src/components/render-blocks.tsx +0 -97
  82. package/packages/react/src/components/render-content/builder-editing.tsx +0 -8
  83. package/packages/react/src/components/render-content/components/render-styles.helpers.ts +0 -79
  84. package/packages/react/src/components/render-content/components/render-styles.tsx +0 -45
  85. package/packages/react/src/components/render-content/index.ts +0 -1
  86. package/packages/react/src/components/render-content/render-content.helpers.ts +0 -48
  87. package/packages/react/src/components/render-content/render-content.tsx +0 -410
  88. package/packages/react/src/components/render-content/render-content.types.ts +0 -33
  89. package/packages/react/src/components/render-inlined-styles.tsx +0 -36
  90. package/packages/react/src/constants/builder-registered-components.ts +0 -42
  91. package/packages/react/src/constants/device-sizes.ts +0 -65
  92. package/packages/react/src/constants/target.ts +0 -2
  93. package/packages/react/src/context/builder.context.ts +0 -12
  94. package/packages/react/src/context/types.ts +0 -26
  95. package/packages/react/src/functions/camel-to-kebab-case.ts +0 -2
  96. package/packages/react/src/functions/evaluate.ts +0 -57
  97. package/packages/react/src/functions/event-handler-name.ts +0 -6
  98. package/packages/react/src/functions/extract-text-styles.ts +0 -39
  99. package/packages/react/src/functions/fast-clone.ts +0 -5
  100. package/packages/react/src/functions/get-block-actions-handler.ts +0 -20
  101. package/packages/react/src/functions/get-block-actions.ts +0 -25
  102. package/packages/react/src/functions/get-block-component-options.ts +0 -12
  103. package/packages/react/src/functions/get-block-properties.ts +0 -75
  104. package/packages/react/src/functions/get-builder-search-params/fn.test.ts +0 -19
  105. package/packages/react/src/functions/get-builder-search-params/index.ts +0 -50
  106. package/packages/react/src/functions/get-content/ab-testing.ts +0 -132
  107. package/packages/react/src/functions/get-content/generate-content-url.test.ts +0 -95
  108. package/packages/react/src/functions/get-content/generate-content-url.ts +0 -59
  109. package/packages/react/src/functions/get-content/index.ts +0 -62
  110. package/packages/react/src/functions/get-content/types.ts +0 -53
  111. package/packages/react/src/functions/get-fetch.ts +0 -18
  112. package/packages/react/src/functions/get-global-this.ts +0 -17
  113. package/packages/react/src/functions/get-processed-block.test.ts +0 -33
  114. package/packages/react/src/functions/get-processed-block.ts +0 -54
  115. package/packages/react/src/functions/get-react-native-block-styles.ts +0 -33
  116. package/packages/react/src/functions/if-target.ts +0 -20
  117. package/packages/react/src/functions/is-browser.ts +0 -3
  118. package/packages/react/src/functions/is-editing.ts +0 -10
  119. package/packages/react/src/functions/is-iframe.ts +0 -5
  120. package/packages/react/src/functions/is-previewing.ts +0 -14
  121. package/packages/react/src/functions/on-change.test.ts +0 -23
  122. package/packages/react/src/functions/on-change.ts +0 -29
  123. package/packages/react/src/functions/register-component.ts +0 -50
  124. package/packages/react/src/functions/register.ts +0 -46
  125. package/packages/react/src/functions/sanitize-react-native-block-styles.ts +0 -65
  126. package/packages/react/src/functions/set-editor-settings.ts +0 -16
  127. package/packages/react/src/functions/set.test.ts +0 -19
  128. package/packages/react/src/functions/set.ts +0 -26
  129. package/packages/react/src/functions/track/helpers.ts +0 -67
  130. package/packages/react/src/functions/track/index.ts +0 -136
  131. package/packages/react/src/functions/track/interaction.ts +0 -80
  132. package/packages/react/src/functions/transform-block-properties.ts +0 -3
  133. package/packages/react/src/functions/transform-block.ts +0 -6
  134. package/packages/react/src/helpers/ab-tests.ts +0 -22
  135. package/packages/react/src/helpers/cookie.ts +0 -107
  136. package/packages/react/src/helpers/css.ts +0 -42
  137. package/packages/react/src/helpers/flatten.ts +0 -24
  138. package/packages/react/src/helpers/localStorage.ts +0 -40
  139. package/packages/react/src/helpers/logger.ts +0 -6
  140. package/packages/react/src/helpers/nullable.ts +0 -4
  141. package/packages/react/src/helpers/sessionId.ts +0 -38
  142. package/packages/react/src/helpers/time.ts +0 -4
  143. package/packages/react/src/helpers/url.test.ts +0 -23
  144. package/packages/react/src/helpers/url.ts +0 -16
  145. package/packages/react/src/helpers/uuid.ts +0 -17
  146. package/packages/react/src/helpers/visitorId.ts +0 -40
  147. package/packages/react/src/index-helpers/blocks-exports.ts +0 -10
  148. package/packages/react/src/index-helpers/top-of-file.ts +0 -4
  149. package/packages/react/src/index.ts +0 -14
  150. package/packages/react/src/scripts/init-editing.ts +0 -123
  151. package/packages/react/src/types/api-version.ts +0 -2
  152. package/packages/react/src/types/builder-block.ts +0 -69
  153. package/packages/react/src/types/builder-content.ts +0 -46
  154. package/packages/react/src/types/can-track.ts +0 -3
  155. package/packages/react/src/types/components.ts +0 -117
  156. package/packages/react/src/types/deep-partial.ts +0 -7
  157. package/packages/react/src/types/element.ts +0 -60
  158. package/packages/react/src/types/input.ts +0 -125
  159. package/packages/react/src/types/targets.ts +0 -6
  160. package/packages/react/src/types/typescript.ts +0 -7
  161. package/packages/rsc/src/blocks/BaseText.jsx +0 -12
  162. package/packages/rsc/src/blocks/button/button.jsx +0 -37
  163. package/packages/rsc/src/blocks/button/component-info.js +0 -40
  164. package/packages/rsc/src/blocks/columns/columns.jsx +0 -172
  165. package/packages/rsc/src/blocks/columns/component-info.js +0 -241
  166. package/packages/rsc/src/blocks/custom-code/component-info.js +0 -30
  167. package/packages/rsc/src/blocks/custom-code/custom-code.jsx +0 -57
  168. package/packages/rsc/src/blocks/embed/component-info.js +0 -43
  169. package/packages/rsc/src/blocks/embed/embed.jsx +0 -45
  170. package/packages/rsc/src/blocks/embed/helpers.js +0 -9
  171. package/packages/rsc/src/blocks/form/component-info.js +0 -261
  172. package/packages/rsc/src/blocks/form/form.jsx +0 -260
  173. package/packages/rsc/src/blocks/fragment/component-info.js +0 -10
  174. package/packages/rsc/src/blocks/fragment/fragment.jsx +0 -9
  175. package/packages/rsc/src/blocks/image/component-info.js +0 -150
  176. package/packages/rsc/src/blocks/image/image.helpers.js +0 -48
  177. package/packages/rsc/src/blocks/image/image.jsx +0 -122
  178. package/packages/rsc/src/blocks/img/component-info.js +0 -19
  179. package/packages/rsc/src/blocks/img/img.jsx +0 -21
  180. package/packages/rsc/src/blocks/input/component-info.js +0 -73
  181. package/packages/rsc/src/blocks/input/input.jsx +0 -23
  182. package/packages/rsc/src/blocks/raw-text/component-info.js +0 -15
  183. package/packages/rsc/src/blocks/raw-text/raw-text.jsx +0 -14
  184. package/packages/rsc/src/blocks/section/component-info.js +0 -48
  185. package/packages/rsc/src/blocks/section/section.jsx +0 -27
  186. package/packages/rsc/src/blocks/select/component-info.js +0 -58
  187. package/packages/rsc/src/blocks/select/select.jsx +0 -24
  188. package/packages/rsc/src/blocks/submit-button/component-info.js +0 -27
  189. package/packages/rsc/src/blocks/submit-button/submit-button.jsx +0 -13
  190. package/packages/rsc/src/blocks/symbol/component-info.js +0 -42
  191. package/packages/rsc/src/blocks/symbol/symbol.jsx +0 -89
  192. package/packages/rsc/src/blocks/text/component-info.js +0 -23
  193. package/packages/rsc/src/blocks/text/text.jsx +0 -17
  194. package/packages/rsc/src/blocks/textarea/component-info.js +0 -46
  195. package/packages/rsc/src/blocks/textarea/textarea.jsx +0 -17
  196. package/packages/rsc/src/blocks/util.js +0 -8
  197. package/packages/rsc/src/blocks/video/component-info.js +0 -105
  198. package/packages/rsc/src/blocks/video/video.jsx +0 -63
  199. package/packages/rsc/src/components/render-block/block-styles.jsx +0 -88
  200. package/packages/rsc/src/components/render-block/render-block.helpers.js +0 -129
  201. package/packages/rsc/src/components/render-block/render-block.jsx +0 -201
  202. package/packages/rsc/src/components/render-block/render-component.jsx +0 -39
  203. package/packages/rsc/src/components/render-block/render-repeated-block.jsx +0 -27
  204. package/packages/rsc/src/components/render-block/types.js +0 -0
  205. package/packages/rsc/src/components/render-blocks.jsx +0 -92
  206. package/packages/rsc/src/components/render-content/builder-editing.jsx +0 -64
  207. package/packages/rsc/src/components/render-content/components/render-styles.helpers.js +0 -57
  208. package/packages/rsc/src/components/render-content/components/render-styles.jsx +0 -39
  209. package/packages/rsc/src/components/render-content/index.js +0 -4
  210. package/packages/rsc/src/components/render-content/render-content.helpers.js +0 -48
  211. package/packages/rsc/src/components/render-content/render-content.jsx +0 -253
  212. package/packages/rsc/src/components/render-content/render-content.types.js +0 -0
  213. package/packages/rsc/src/components/render-inlined-styles.jsx +0 -33
  214. package/packages/rsc/src/constants/builder-registered-components.js +0 -54
  215. package/packages/rsc/src/constants/device-sizes.js +0 -48
  216. package/packages/rsc/src/constants/target.js +0 -4
  217. package/packages/rsc/src/context/builder.context.js +0 -14
  218. package/packages/rsc/src/context/types.js +0 -0
  219. package/packages/rsc/src/functions/camel-to-kebab-case.js +0 -4
  220. package/packages/rsc/src/functions/evaluate.js +0 -6
  221. package/packages/rsc/src/functions/event-handler-name.js +0 -7
  222. package/packages/rsc/src/functions/extract-text-styles.js +0 -22
  223. package/packages/rsc/src/functions/fast-clone.js +0 -4
  224. package/packages/rsc/src/functions/get-block-actions-handler.js +0 -11
  225. package/packages/rsc/src/functions/get-block-actions.js +0 -18
  226. package/packages/rsc/src/functions/get-block-component-options.js +0 -28
  227. package/packages/rsc/src/functions/get-block-properties.js +0 -53
  228. package/packages/rsc/src/functions/get-builder-search-params/fn.test.js +0 -13
  229. package/packages/rsc/src/functions/get-builder-search-params/index.js +0 -38
  230. package/packages/rsc/src/functions/get-content/ab-testing.js +0 -99
  231. package/packages/rsc/src/functions/get-content/generate-content-url.js +0 -60
  232. package/packages/rsc/src/functions/get-content/generate-content-url.test.js +0 -82
  233. package/packages/rsc/src/functions/get-content/index.js +0 -83
  234. package/packages/rsc/src/functions/get-content/types.js +0 -0
  235. package/packages/rsc/src/functions/get-fetch.js +0 -14
  236. package/packages/rsc/src/functions/get-global-this.js +0 -18
  237. package/packages/rsc/src/functions/get-processed-block.js +0 -59
  238. package/packages/rsc/src/functions/get-processed-block.test.js +0 -32
  239. package/packages/rsc/src/functions/get-react-native-block-styles.js +0 -33
  240. package/packages/rsc/src/functions/if-target.js +0 -15
  241. package/packages/rsc/src/functions/is-browser.js +0 -6
  242. package/packages/rsc/src/functions/is-editing.js +0 -8
  243. package/packages/rsc/src/functions/is-iframe.js +0 -7
  244. package/packages/rsc/src/functions/is-previewing.js +0 -14
  245. package/packages/rsc/src/functions/on-change.js +0 -27
  246. package/packages/rsc/src/functions/on-change.test.js +0 -19
  247. package/packages/rsc/src/functions/register-component.js +0 -68
  248. package/packages/rsc/src/functions/register.js +0 -29
  249. package/packages/rsc/src/functions/sanitize-react-native-block-styles.js +0 -66
  250. package/packages/rsc/src/functions/set-editor-settings.js +0 -15
  251. package/packages/rsc/src/functions/set.js +0 -11
  252. package/packages/rsc/src/functions/set.test.js +0 -16
  253. package/packages/rsc/src/functions/track/helpers.js +0 -50
  254. package/packages/rsc/src/functions/track/index.js +0 -129
  255. package/packages/rsc/src/functions/track/interaction.js +0 -53
  256. package/packages/rsc/src/functions/transform-block-properties.js +0 -6
  257. package/packages/rsc/src/functions/transform-block.js +0 -6
  258. package/packages/rsc/src/helpers/ab-tests.js +0 -16
  259. package/packages/rsc/src/helpers/cookie.js +0 -81
  260. package/packages/rsc/src/helpers/css.js +0 -34
  261. package/packages/rsc/src/helpers/flatten.js +0 -34
  262. package/packages/rsc/src/helpers/localStorage.js +0 -35
  263. package/packages/rsc/src/helpers/logger.js +0 -9
  264. package/packages/rsc/src/helpers/nullable.js +0 -4
  265. package/packages/rsc/src/helpers/sessionId.js +0 -52
  266. package/packages/rsc/src/helpers/time.js +0 -5
  267. package/packages/rsc/src/helpers/url.js +0 -13
  268. package/packages/rsc/src/helpers/url.test.js +0 -21
  269. package/packages/rsc/src/helpers/uuid.js +0 -13
  270. package/packages/rsc/src/helpers/visitorId.js +0 -34
  271. package/packages/rsc/src/index-helpers/blocks-exports.js +0 -22
  272. package/packages/rsc/src/index-helpers/top-of-file.js +0 -2
  273. package/packages/rsc/src/index.js +0 -13
  274. package/packages/rsc/src/scripts/init-editing.js +0 -93
  275. package/packages/rsc/src/types/api-version.js +0 -4
  276. package/packages/rsc/src/types/builder-block.js +0 -0
  277. package/packages/rsc/src/types/builder-content.js +0 -0
  278. package/packages/rsc/src/types/can-track.js +0 -0
  279. package/packages/rsc/src/types/components.js +0 -0
  280. package/packages/rsc/src/types/deep-partial.js +0 -0
  281. package/packages/rsc/src/types/element.js +0 -0
  282. package/packages/rsc/src/types/input.js +0 -0
  283. package/packages/rsc/src/types/targets.js +0 -0
  284. package/packages/rsc/src/types/typescript.js +0 -0
  285. package/tsconfig.json +0 -28
  286. package/tsconfig.sdk.json +0 -10
  287. package/tsconfig.server.json +0 -10
  288. package/vite.config.ts +0 -91
@@ -1,254 +0,0 @@
1
- import type { ComponentInfo } from '../../types/components';
2
- import { serializeFn } from '../util.js';
3
-
4
- export const componentInfo: ComponentInfo = {
5
- // TODO: ways to statically preprocess JSON for references, functions, etc
6
- name: 'Columns',
7
-
8
- inputs: [
9
- {
10
- name: 'columns',
11
- type: 'array',
12
- broadcast: true,
13
- subFields: [
14
- {
15
- name: 'blocks',
16
- type: 'array',
17
- hideFromUI: true,
18
- defaultValue: [
19
- {
20
- '@type': '@builder.io/sdk:Element',
21
- responsiveStyles: {
22
- large: {
23
- display: 'flex',
24
- flexDirection: 'column',
25
- alignItems: 'stretch',
26
- flexShrink: '0',
27
- position: 'relative',
28
- marginTop: '30px',
29
- textAlign: 'center',
30
- lineHeight: 'normal',
31
- height: 'auto',
32
- minHeight: '20px',
33
- minWidth: '20px',
34
- overflow: 'hidden',
35
- },
36
- },
37
- component: {
38
- name: 'Image',
39
- options: {
40
- image:
41
- 'https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d',
42
- backgroundPosition: 'center',
43
- backgroundSize: 'cover',
44
- aspectRatio: 0.7004048582995948,
45
- },
46
- },
47
- },
48
- {
49
- '@type': '@builder.io/sdk:Element',
50
- responsiveStyles: {
51
- large: {
52
- display: 'flex',
53
- flexDirection: 'column',
54
- alignItems: 'stretch',
55
- flexShrink: '0',
56
- position: 'relative',
57
- marginTop: '30px',
58
- textAlign: 'center',
59
- lineHeight: 'normal',
60
- height: 'auto',
61
- },
62
- },
63
- component: {
64
- name: 'Text',
65
- options: {
66
- text: '<p>Enter some text...</p>',
67
- },
68
- },
69
- },
70
- ],
71
- },
72
- {
73
- name: 'width',
74
- type: 'number',
75
- hideFromUI: true,
76
- helperText: 'Width %, e.g. set to 50 to fill half of the space',
77
- },
78
- {
79
- name: 'link',
80
- type: 'url',
81
- helperText:
82
- 'Optionally set a url that clicking this column will link to',
83
- },
84
- ],
85
- defaultValue: [
86
- {
87
- blocks: [
88
- {
89
- '@type': '@builder.io/sdk:Element',
90
- responsiveStyles: {
91
- large: {
92
- display: 'flex',
93
- flexDirection: 'column',
94
- alignItems: 'stretch',
95
- flexShrink: '0',
96
- position: 'relative',
97
- marginTop: '30px',
98
- textAlign: 'center',
99
- lineHeight: 'normal',
100
- height: 'auto',
101
- minHeight: '20px',
102
- minWidth: '20px',
103
- overflow: 'hidden',
104
- },
105
- },
106
- component: {
107
- name: 'Image',
108
- options: {
109
- image:
110
- 'https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d',
111
- backgroundPosition: 'center',
112
- backgroundSize: 'cover',
113
- aspectRatio: 0.7004048582995948,
114
- },
115
- },
116
- },
117
- {
118
- '@type': '@builder.io/sdk:Element',
119
- responsiveStyles: {
120
- large: {
121
- display: 'flex',
122
- flexDirection: 'column',
123
- alignItems: 'stretch',
124
- flexShrink: '0',
125
- position: 'relative',
126
- marginTop: '30px',
127
- textAlign: 'center',
128
- lineHeight: 'normal',
129
- height: 'auto',
130
- },
131
- },
132
- component: {
133
- name: 'Text',
134
- options: {
135
- text: '<p>Enter some text...</p>',
136
- },
137
- },
138
- },
139
- ],
140
- },
141
- {
142
- blocks: [
143
- {
144
- '@type': '@builder.io/sdk:Element',
145
- responsiveStyles: {
146
- large: {
147
- display: 'flex',
148
- flexDirection: 'column',
149
- alignItems: 'stretch',
150
- flexShrink: '0',
151
- position: 'relative',
152
- marginTop: '30px',
153
- textAlign: 'center',
154
- lineHeight: 'normal',
155
- height: 'auto',
156
- minHeight: '20px',
157
- minWidth: '20px',
158
- overflow: 'hidden',
159
- },
160
- },
161
- component: {
162
- name: 'Image',
163
- options: {
164
- image:
165
- 'https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d',
166
- backgroundPosition: 'center',
167
- backgroundSize: 'cover',
168
- aspectRatio: 0.7004048582995948,
169
- },
170
- },
171
- },
172
- {
173
- '@type': '@builder.io/sdk:Element',
174
- responsiveStyles: {
175
- large: {
176
- display: 'flex',
177
- flexDirection: 'column',
178
- alignItems: 'stretch',
179
- flexShrink: '0',
180
- position: 'relative',
181
- marginTop: '30px',
182
- textAlign: 'center',
183
- lineHeight: 'normal',
184
- height: 'auto',
185
- },
186
- },
187
- component: {
188
- name: 'Text',
189
- options: {
190
- text: '<p>Enter some text...</p>',
191
- },
192
- },
193
- },
194
- ],
195
- },
196
- ],
197
- onChange: serializeFn((options: Map<string, any>) => {
198
- function clearWidths() {
199
- columns.forEach((col) => {
200
- col.delete('width');
201
- });
202
- }
203
-
204
- const columns: Array<Map<string, any>> = options.get('columns');
205
-
206
- if (Array.isArray(columns)) {
207
- const containsColumnWithWidth = !!columns.find((col) =>
208
- col.get('width')
209
- );
210
-
211
- if (containsColumnWithWidth) {
212
- const containsColumnWithoutWidth = !!columns.find(
213
- (col) => !col.get('width')
214
- );
215
- if (containsColumnWithoutWidth) {
216
- clearWidths();
217
- } else {
218
- const sumWidths = columns.reduce((memo, col) => {
219
- return memo + col.get('width');
220
- }, 0);
221
- const widthsDontAddUp = sumWidths !== 100;
222
- if (widthsDontAddUp) {
223
- clearWidths();
224
- }
225
- }
226
- }
227
- }
228
- }),
229
- },
230
- {
231
- name: 'space',
232
- type: 'number',
233
- defaultValue: 20,
234
- helperText: 'Size of gap between columns',
235
- advanced: true,
236
- },
237
- {
238
- name: 'stackColumnsAt',
239
- type: 'string',
240
- defaultValue: 'tablet',
241
- helperText: 'Convert horizontal columns to vertical at what device size',
242
- enum: ['tablet', 'mobile', 'never'],
243
- advanced: true,
244
- },
245
- {
246
- name: 'reverseColumnsWhenStacked',
247
- type: 'boolean',
248
- defaultValue: false,
249
- helperText:
250
- 'When stacking columns for mobile devices, reverse the ordering',
251
- advanced: true,
252
- },
253
- ],
254
- };
@@ -1,31 +0,0 @@
1
- import type { ComponentInfo } from '../../types/components';
2
-
3
- export const componentInfo: ComponentInfo = {
4
- name: 'Custom Code',
5
- static: true,
6
-
7
- requiredPermissions: ['editCode'],
8
- inputs: [
9
- {
10
- name: 'code',
11
- type: 'html',
12
- required: true,
13
- defaultValue: '<p>Hello there, I am custom HTML code!</p>',
14
- code: true,
15
- },
16
- {
17
- name: 'replaceNodes',
18
- type: 'boolean',
19
- helperText: 'Preserve server rendered dom nodes',
20
- advanced: true,
21
- },
22
- {
23
- name: 'scriptsClientOnly',
24
- type: 'boolean',
25
- defaultValue: false,
26
- helperText:
27
- 'Only print and run scripts on the client. Important when scripts influence DOM that could be replaced when client loads',
28
- advanced: true,
29
- },
30
- ],
31
- };
@@ -1,76 +0,0 @@
1
- "use client";
2
- import * as React from "react";
3
- import { useState, useRef, useEffect } from "react";
4
-
5
- export interface CustomCodeProps {
6
- code: string;
7
- replaceNodes?: boolean;
8
- }
9
-
10
- function CustomCode(props: CustomCodeProps) {
11
- const elem = useRef<HTMLDivElement>(null);
12
- const [scriptsInserted, setScriptsInserted] = useState(() => []);
13
-
14
- const [scriptsRun, setScriptsRun] = useState(() => []);
15
-
16
- function findAndRunScripts() {
17
- // TODO: Move this function to standalone one in '@builder.io/utils'
18
- if (
19
- elem.current &&
20
- elem.current.getElementsByTagName &&
21
- typeof window !== "undefined"
22
- ) {
23
- const scripts = elem.current.getElementsByTagName("script");
24
-
25
- for (let i = 0; i < scripts.length; i++) {
26
- const script = scripts[i];
27
-
28
- if (script.src) {
29
- if (scriptsInserted.includes(script.src)) {
30
- continue;
31
- }
32
-
33
- scriptsInserted.push(script.src);
34
- const newScript = document.createElement("script");
35
- newScript.async = true;
36
- newScript.src = script.src;
37
- document.head.appendChild(newScript);
38
- } else if (
39
- !script.type ||
40
- [
41
- "text/javascript",
42
- "application/javascript",
43
- "application/ecmascript",
44
- ].includes(script.type)
45
- ) {
46
- if (scriptsRun.includes(script.innerText)) {
47
- continue;
48
- }
49
-
50
- try {
51
- scriptsRun.push(script.innerText);
52
- new Function(script.innerText)();
53
- } catch (error) {
54
- console.warn("`CustomCode`: Error running script:", error);
55
- }
56
- }
57
- }
58
- }
59
- }
60
-
61
- useEffect(() => {
62
- findAndRunScripts();
63
- }, []);
64
-
65
- return (
66
- <div
67
- ref={elem}
68
- className={
69
- "builder-custom-code" + (props.replaceNodes ? " replace-nodes" : "")
70
- }
71
- dangerouslySetInnerHTML={{ __html: props.code }}
72
- />
73
- );
74
- }
75
-
76
- export default CustomCode;
@@ -1,55 +0,0 @@
1
- import type { ComponentInfo } from '../../types/components';
2
- import { serializeFn } from '../util.js';
3
-
4
- export const componentInfo: ComponentInfo = {
5
- name: 'Embed',
6
- static: true,
7
-
8
- inputs: [
9
- {
10
- name: 'url',
11
- type: 'url',
12
- required: true,
13
- defaultValue: '',
14
- helperText: 'e.g. enter a youtube url, google map, etc',
15
- onChange: serializeFn(
16
- (options: Map<string, any>): void | Promise<void> => {
17
- const url = options.get('url');
18
- if (url) {
19
- options.set('content', 'Loading...');
20
- // TODO: get this out of here!
21
- const apiKey = 'ae0e60e78201a3f2b0de4b';
22
- return fetch(
23
- `https://iframe.ly/api/iframely?url=${url}&api_key=${apiKey}`
24
- )
25
- .then((res) => res.json())
26
- .then((data) => {
27
- if (options.get('url') === url) {
28
- if (data.html) {
29
- options.set('content', data.html);
30
- } else {
31
- options.set('content', 'Invalid url, please try another');
32
- }
33
- }
34
- })
35
- .catch((_err) => {
36
- options.set(
37
- 'content',
38
- 'There was an error embedding this URL, please try again or another URL'
39
- );
40
- });
41
- } else {
42
- options.delete('content');
43
- }
44
- }
45
- ),
46
- },
47
- {
48
- name: 'content',
49
- type: 'html',
50
- defaultValue:
51
- '<div style="padding: 20px; text-align: center">(Choose an embed URL)<div>',
52
- hideFromUI: true,
53
- },
54
- ],
55
- };
@@ -1,59 +0,0 @@
1
- "use client";
2
- import * as React from "react";
3
- import { useState, useRef, useEffect } from "react";
4
-
5
- export interface EmbedProps {
6
- content: string;
7
- }
8
-
9
- import { isJsScript } from "./helpers.js";
10
-
11
- function Embed(props: EmbedProps) {
12
- const elem = useRef<HTMLDivElement>(null);
13
- const [scriptsInserted, setScriptsInserted] = useState(() => []);
14
-
15
- const [scriptsRun, setScriptsRun] = useState(() => []);
16
-
17
- const [ranInitFn, setRanInitFn] = useState(() => false);
18
-
19
- function findAndRunScripts() {
20
- if (!elem.current || !elem.current.getElementsByTagName) return;
21
- const scripts = elem.current.getElementsByTagName("script");
22
-
23
- for (let i = 0; i < scripts.length; i++) {
24
- const script = scripts[i];
25
-
26
- if (script.src && !scriptsInserted.includes(script.src)) {
27
- scriptsInserted.push(script.src);
28
- const newScript = document.createElement("script");
29
- newScript.async = true;
30
- newScript.src = script.src;
31
- document.head.appendChild(newScript);
32
- } else if (isJsScript(script) && !scriptsRun.includes(script.innerText)) {
33
- try {
34
- scriptsRun.push(script.innerText);
35
- new Function(script.innerText)();
36
- } catch (error) {
37
- console.warn("`Embed`: Error running script:", error);
38
- }
39
- }
40
- }
41
- }
42
-
43
- useEffect(() => {
44
- if (elem.current && !ranInitFn) {
45
- setRanInitFn(true);
46
- findAndRunScripts();
47
- }
48
- }, [elem.current, ranInitFn]);
49
-
50
- return (
51
- <div
52
- className="builder-embed"
53
- ref={elem}
54
- dangerouslySetInnerHTML={{ __html: props.content }}
55
- />
56
- );
57
- }
58
-
59
- export default Embed;
@@ -1,8 +0,0 @@
1
- const SCRIPT_MIME_TYPES = [
2
- 'text/javascript',
3
- 'application/javascript',
4
- 'application/ecmascript',
5
- ];
6
-
7
- export const isJsScript = (script: HTMLScriptElement) =>
8
- SCRIPT_MIME_TYPES.includes(script.type);