@builder.io/sdk-react-native 0.4.4 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (393) hide show
  1. package/dist/blocks/button/button.js +6 -2
  2. package/dist/blocks/button/component-info.js +4 -8
  3. package/dist/blocks/columns/columns.js +19 -23
  4. package/dist/blocks/columns/component-info.js +27 -48
  5. package/dist/blocks/custom-code/component-info.js +4 -8
  6. package/dist/blocks/custom-code/custom-code.js +1 -1
  7. package/dist/blocks/embed/component-info.js +7 -11
  8. package/dist/blocks/embed/embed.js +1 -1
  9. package/dist/blocks/embed/helpers.js +2 -6
  10. package/dist/blocks/form/component-info.js +33 -69
  11. package/dist/blocks/form/form.js +2 -203
  12. package/dist/blocks/fragment/fragment.js +1 -1
  13. package/dist/blocks/helpers.js +33 -0
  14. package/dist/blocks/image/component-info.js +21 -47
  15. package/dist/blocks/image/image.helpers.js +2 -2
  16. package/dist/blocks/img/component-info.js +2 -4
  17. package/dist/blocks/img/img.js +2 -1
  18. package/dist/blocks/input/component-info.js +8 -34
  19. package/dist/blocks/input/input.js +2 -1
  20. package/dist/blocks/raw-text/component-info.js +2 -4
  21. package/dist/blocks/raw-text/raw-text.js +3 -2
  22. package/dist/blocks/section/component-info.js +5 -10
  23. package/dist/blocks/section/section.js +2 -1
  24. package/dist/blocks/select/component-info.js +12 -24
  25. package/dist/blocks/select/select.js +2 -1
  26. package/dist/blocks/submit-button/component-info.js +2 -4
  27. package/dist/blocks/submit-button/submit-button.js +2 -1
  28. package/dist/blocks/symbol/component-info.js +7 -12
  29. package/dist/blocks/symbol/symbol.helpers.js +66 -0
  30. package/dist/blocks/symbol/symbol.js +23 -50
  31. package/dist/blocks/text/component-info.js +3 -4
  32. package/dist/blocks/textarea/component-info.js +6 -12
  33. package/dist/blocks/textarea/textarea.js +2 -1
  34. package/dist/blocks/video/component-info.js +21 -41
  35. package/dist/components/block/block.helpers.js +102 -0
  36. package/dist/components/block/block.js +141 -0
  37. package/dist/components/block/components/block-styles.js +95 -0
  38. package/dist/components/block/components/block-wrapper/block-wrapper.js +41 -0
  39. package/dist/components/block/components/block-wrapper.js +56 -0
  40. package/dist/components/block/components/component-ref/component-ref.helpers.js +40 -0
  41. package/dist/components/block/components/component-ref/component-ref.js +63 -0
  42. package/dist/components/block/components/component-ref.js +81 -0
  43. package/dist/components/block/components/component.js +41 -0
  44. package/dist/components/block/components/interactive-element/interactive-element.helpers.js +35 -0
  45. package/dist/components/block/components/interactive-element/interactive-element.js +36 -0
  46. package/dist/components/block/components/interactive-element.js +46 -0
  47. package/dist/components/block/components/repeated-block.js +40 -0
  48. package/dist/components/block/types.js +1 -0
  49. package/dist/components/blocks/blocks-wrapper.js +69 -0
  50. package/dist/components/blocks/blocks.js +41 -0
  51. package/dist/components/content/builder-editing.js +32 -0
  52. package/dist/components/content/components/content-styles.helpers.js +55 -0
  53. package/dist/components/content/components/content-styles.js +61 -0
  54. package/dist/components/content/components/enable-editor.js +310 -0
  55. package/dist/components/content/components/styles.helpers.js +55 -0
  56. package/dist/components/content/components/styles.js +61 -0
  57. package/dist/components/content/content.helpers.js +49 -0
  58. package/dist/components/content/content.js +110 -0
  59. package/dist/components/content/content.types.js +1 -0
  60. package/dist/components/content/index.js +8 -0
  61. package/dist/components/content/wrap-component-ref.js +5 -0
  62. package/dist/components/content-variants/content-variants.js +77 -0
  63. package/dist/components/content-variants/content-variants.types.js +1 -0
  64. package/dist/components/content-variants/helpers.js +175 -0
  65. package/dist/components/inlined-script.js +32 -0
  66. package/dist/components/{render-inlined-styles.js → inlined-styles.js} +3 -3
  67. package/dist/components/render-block/block-styles.js +2 -2
  68. package/dist/components/render-content/components/render-styles.js +2 -2
  69. package/dist/components/render-content/render-content.js +10 -8
  70. package/dist/components/render-content-variants/helpers.js +49 -20
  71. package/dist/components/render-content-variants/render-content-variants.js +29 -24
  72. package/dist/components/render-content-variants/render-content-variants.types.js +1 -0
  73. package/dist/constants/device-sizes.js +2 -2
  74. package/dist/constants/sdk-version.js +1 -1
  75. package/dist/context/builder.context.js +1 -1
  76. package/dist/functions/apply-patch-with-mutation.js +75 -0
  77. package/dist/functions/apply-patch-with-mutation.test.js +55 -0
  78. package/dist/functions/camel-to-kebab-case.js +1 -1
  79. package/dist/functions/evaluate/acorn.js +1691 -0
  80. package/dist/functions/evaluate/evaluate.js +72 -0
  81. package/dist/functions/evaluate/index.js +5 -0
  82. package/dist/functions/evaluate/interpreter.js +2903 -0
  83. package/dist/functions/evaluate/non-node-runtime.js +97 -0
  84. package/dist/functions/evaluate/types.js +1 -0
  85. package/dist/functions/evaluate.test.js +12 -6
  86. package/dist/functions/event-handler-name.js +1 -1
  87. package/dist/functions/extract-text-styles.js +3 -9
  88. package/dist/functions/fast-clone.js +1 -1
  89. package/dist/functions/get-block-actions-handler.js +2 -2
  90. package/dist/functions/get-block-actions.js +14 -1
  91. package/dist/functions/get-block-component-options.js +6 -1
  92. package/dist/functions/get-block-properties.js +21 -8
  93. package/dist/functions/get-builder-search-params/fn.test.js +3 -3
  94. package/dist/functions/get-builder-search-params/index.js +4 -4
  95. package/dist/functions/get-content/generate-content-url.js +12 -5
  96. package/dist/functions/get-content/generate-content-url.test.js +31 -17
  97. package/dist/functions/get-content/index.js +36 -12
  98. package/dist/functions/get-content/processCookies.js +7 -0
  99. package/dist/functions/get-processed-block.js +8 -3
  100. package/dist/functions/get-processed-block.test.js +3 -1
  101. package/dist/functions/get-react-native-block-styles.js +6 -1
  102. package/dist/functions/is-non-node-server.js +12 -0
  103. package/dist/functions/on-change.test.js +13 -3
  104. package/dist/functions/register-component.js +24 -19
  105. package/dist/functions/sanitize-react-native-block-styles.js +17 -6
  106. package/dist/functions/set.test.js +9 -3
  107. package/dist/functions/track/helpers.js +5 -5
  108. package/dist/functions/track/index.js +29 -18
  109. package/dist/functions/track/interaction.js +10 -4
  110. package/dist/functions/transform-block-properties.js +2 -0
  111. package/dist/helpers/ab-tests.js +38 -14
  112. package/dist/helpers/canTrack.js +2 -2
  113. package/dist/helpers/css.js +2 -2
  114. package/dist/helpers/flatten.js +10 -7
  115. package/dist/helpers/nullable.js +1 -1
  116. package/dist/helpers/preview-lru-cache/get.js +11 -0
  117. package/dist/helpers/preview-lru-cache/helpers.js +13 -0
  118. package/dist/helpers/preview-lru-cache/init.js +13 -0
  119. package/dist/helpers/preview-lru-cache/set.js +37 -0
  120. package/dist/helpers/preview-lru-cache/types.js +1 -0
  121. package/dist/helpers/sessionId.js +13 -6
  122. package/dist/helpers/url.js +1 -1
  123. package/dist/helpers/visitorId.js +4 -1
  124. package/dist/index-helpers/blocks-exports.js +2 -2
  125. package/dist/scripts/init-editing.js +61 -46
  126. package/dist/types/builder-props.js +1 -0
  127. package/dist/types/enforced-partials.js +1 -0
  128. package/package.json +2 -2
  129. package/src/blocks/button/button.jsx +11 -2
  130. package/src/blocks/button/component-info.js +16 -22
  131. package/src/blocks/columns/columns.jsx +29 -28
  132. package/src/blocks/columns/component-info.js +203 -226
  133. package/src/blocks/custom-code/component-info.js +19 -25
  134. package/src/blocks/custom-code/custom-code.jsx +1 -1
  135. package/src/blocks/embed/component-info.js +31 -37
  136. package/src/blocks/embed/embed.jsx +1 -1
  137. package/src/blocks/embed/helpers.js +3 -9
  138. package/src/blocks/form/component-info.js +174 -212
  139. package/src/blocks/form/form.jsx +3 -247
  140. package/src/blocks/fragment/component-info.js +1 -3
  141. package/src/blocks/fragment/fragment.jsx +1 -1
  142. package/src/blocks/helpers.js +27 -0
  143. package/src/blocks/image/component-info.js +105 -133
  144. package/src/blocks/image/image.helpers.js +3 -5
  145. package/src/blocks/img/component-info.js +8 -12
  146. package/src/blocks/img/img.jsx +3 -1
  147. package/src/blocks/input/component-info.js +29 -57
  148. package/src/blocks/input/input.jsx +3 -1
  149. package/src/blocks/raw-text/component-info.js +7 -11
  150. package/src/blocks/raw-text/raw-text.jsx +4 -2
  151. package/src/blocks/section/component-info.js +24 -31
  152. package/src/blocks/section/section.jsx +3 -1
  153. package/src/blocks/select/component-info.js +34 -48
  154. package/src/blocks/select/select.jsx +3 -1
  155. package/src/blocks/submit-button/component-info.js +6 -10
  156. package/src/blocks/submit-button/submit-button.jsx +3 -2
  157. package/src/blocks/symbol/component-info.js +30 -37
  158. package/src/blocks/symbol/symbol.helpers.js +60 -0
  159. package/src/blocks/symbol/symbol.jsx +34 -59
  160. package/src/blocks/text/component-info.js +10 -13
  161. package/src/blocks/textarea/component-info.js +22 -30
  162. package/src/blocks/textarea/textarea.jsx +3 -1
  163. package/src/blocks/video/component-info.js +74 -96
  164. package/src/components/{render-block/render-block.helpers.js → block/block.helpers.js} +26 -44
  165. package/src/components/{render-block/render-block.jsx → block/block.jsx} +68 -81
  166. package/src/components/{render-block → block/components}/block-styles.jsx +19 -18
  167. package/src/components/block/components/block-wrapper.jsx +58 -0
  168. package/src/components/block/components/component-ref/component-ref.helpers.js +41 -0
  169. package/src/components/block/components/component-ref/component-ref.jsx +72 -0
  170. package/src/components/block/components/interactive-element.jsx +37 -0
  171. package/src/components/{render-block/render-repeated-block.jsx → block/components/repeated-block.jsx} +10 -6
  172. package/src/components/blocks/blocks-wrapper.jsx +74 -0
  173. package/src/components/blocks/blocks.jsx +51 -0
  174. package/src/components/{render-content/render-content.jsx → content/components/enable-editor.jsx} +81 -165
  175. package/src/components/{render-content/components/render-styles.helpers.js → content/components/styles.helpers.js} +6 -7
  176. package/src/components/{render-content/components/render-styles.jsx → content/components/styles.jsx} +7 -7
  177. package/src/components/{render-content/render-content.helpers.js → content/content.helpers.js} +15 -15
  178. package/src/components/content/content.jsx +141 -0
  179. package/src/components/content/content.types.js +0 -0
  180. package/src/components/content/index.js +2 -0
  181. package/src/components/content/wrap-component-ref.js +2 -0
  182. package/src/components/content-variants/content-variants.jsx +120 -0
  183. package/src/components/{render-content-variants → content-variants}/helpers.js +58 -41
  184. package/src/components/inlined-script.jsx +18 -0
  185. package/src/components/{render-inlined-styles.jsx → inlined-styles.jsx} +3 -3
  186. package/src/constants/device-sizes.js +6 -6
  187. package/src/constants/sdk-version.js +1 -1
  188. package/src/context/builder.context.js +1 -1
  189. package/src/functions/apply-patch-with-mutation.js +66 -0
  190. package/src/functions/camel-to-kebab-case.js +2 -4
  191. package/src/functions/evaluate/acorn.js +1595 -0
  192. package/src/functions/{evaluate.js → evaluate/evaluate.js} +36 -10
  193. package/src/functions/evaluate/index.js +2 -0
  194. package/src/functions/evaluate/interpreter.js +2801 -0
  195. package/src/functions/evaluate/non-node-runtime.js +92 -0
  196. package/src/functions/evaluate/types.js +0 -0
  197. package/src/functions/event-handler-name.js +2 -4
  198. package/src/functions/extract-text-styles.js +4 -12
  199. package/src/functions/fast-clone.js +2 -4
  200. package/src/functions/get-block-actions-handler.js +3 -5
  201. package/src/functions/get-block-actions.js +15 -4
  202. package/src/functions/get-block-component-options.js +11 -12
  203. package/src/functions/get-block-properties.js +29 -19
  204. package/src/functions/get-builder-search-params/index.js +5 -10
  205. package/src/functions/get-content/generate-content-url.js +17 -19
  206. package/src/functions/get-content/index.js +43 -29
  207. package/src/functions/get-fetch.js +1 -3
  208. package/src/functions/get-global-this.js +1 -3
  209. package/src/functions/get-processed-block.js +12 -13
  210. package/src/functions/get-react-native-block-styles.js +11 -12
  211. package/src/functions/if-target.js +1 -3
  212. package/src/functions/is-browser.js +1 -3
  213. package/src/functions/is-editing.js +1 -3
  214. package/src/functions/is-iframe.js +1 -3
  215. package/src/functions/is-non-node-server.js +9 -0
  216. package/src/functions/is-previewing.js +1 -3
  217. package/src/functions/on-change.js +1 -4
  218. package/src/functions/register-component.js +34 -42
  219. package/src/functions/register.js +1 -3
  220. package/src/functions/sanitize-react-native-block-styles.js +22 -17
  221. package/src/functions/set-editor-settings.js +1 -3
  222. package/src/functions/set.js +1 -3
  223. package/src/functions/track/helpers.js +3 -5
  224. package/src/functions/track/index.js +45 -43
  225. package/src/functions/track/interaction.js +11 -7
  226. package/src/functions/transform-block-properties.js +2 -0
  227. package/src/helpers/ab-tests.js +46 -26
  228. package/src/helpers/canTrack.js +3 -5
  229. package/src/helpers/css.js +3 -7
  230. package/src/helpers/flatten.js +15 -18
  231. package/src/helpers/localStorage.js +1 -4
  232. package/src/helpers/logger.js +1 -3
  233. package/src/helpers/nullable.js +2 -4
  234. package/src/helpers/preview-lru-cache/get.js +8 -0
  235. package/src/helpers/preview-lru-cache/helpers.js +10 -0
  236. package/src/helpers/preview-lru-cache/init.js +10 -0
  237. package/src/helpers/preview-lru-cache/set.js +35 -0
  238. package/src/helpers/preview-lru-cache/types.js +0 -0
  239. package/src/helpers/sessionId.js +14 -11
  240. package/src/helpers/time.js +1 -3
  241. package/src/helpers/url.js +2 -4
  242. package/src/helpers/uuid.js +4 -6
  243. package/src/helpers/visitorId.js +8 -7
  244. package/src/index-helpers/blocks-exports.js +1 -1
  245. package/src/index.js +2 -17
  246. package/src/scripts/init-editing.js +62 -48
  247. package/src/types/api-version.js +1 -3
  248. package/src/types/builder-props.js +0 -0
  249. package/src/types/enforced-partials.js +0 -0
  250. package/dist/blocks/BaseText.d.ts +0 -6
  251. package/dist/blocks/button/button.d.ts +0 -9
  252. package/dist/blocks/button/component-info.d.ts +0 -2
  253. package/dist/blocks/columns/columns.d.ts +0 -16
  254. package/dist/blocks/columns/component-info.d.ts +0 -2
  255. package/dist/blocks/custom-code/component-info.d.ts +0 -2
  256. package/dist/blocks/custom-code/custom-code.d.ts +0 -5
  257. package/dist/blocks/embed/component-info.d.ts +0 -2
  258. package/dist/blocks/embed/embed.d.ts +0 -5
  259. package/dist/blocks/embed/helpers.d.ts +0 -1
  260. package/dist/blocks/form/component-info.d.ts +0 -2
  261. package/dist/blocks/form/form.d.ts +0 -28
  262. package/dist/blocks/fragment/component-info.d.ts +0 -2
  263. package/dist/blocks/fragment/fragment.d.ts +0 -8
  264. package/dist/blocks/image/component-info.d.ts +0 -2
  265. package/dist/blocks/image/image.d.ts +0 -17
  266. package/dist/blocks/image/image.helpers.d.ts +0 -1
  267. package/dist/blocks/img/component-info.d.ts +0 -2
  268. package/dist/blocks/img/img.d.ts +0 -11
  269. package/dist/blocks/input/component-info.d.ts +0 -2
  270. package/dist/blocks/input/input.d.ts +0 -12
  271. package/dist/blocks/raw-text/component-info.d.ts +0 -2
  272. package/dist/blocks/raw-text/raw-text.d.ts +0 -5
  273. package/dist/blocks/section/component-info.d.ts +0 -2
  274. package/dist/blocks/section/section.d.ts +0 -9
  275. package/dist/blocks/select/component-info.d.ts +0 -2
  276. package/dist/blocks/select/select.d.ts +0 -13
  277. package/dist/blocks/submit-button/component-info.d.ts +0 -2
  278. package/dist/blocks/submit-button/submit-button.d.ts +0 -7
  279. package/dist/blocks/symbol/component-info.d.ts +0 -2
  280. package/dist/blocks/symbol/symbol.d.ts +0 -21
  281. package/dist/blocks/text/component-info.d.ts +0 -2
  282. package/dist/blocks/text/text.d.ts +0 -7
  283. package/dist/blocks/textarea/component-info.d.ts +0 -2
  284. package/dist/blocks/textarea/textarea.d.ts +0 -10
  285. package/dist/blocks/util.d.ts +0 -4
  286. package/dist/blocks/video/component-info.d.ts +0 -2
  287. package/dist/blocks/video/video.d.ts +0 -31
  288. package/dist/components/render-block/block-styles.d.ts +0 -9
  289. package/dist/components/render-block/render-block.d.ts +0 -9
  290. package/dist/components/render-block/render-block.helpers.d.ts +0 -12
  291. package/dist/components/render-block/render-component.d.ts +0 -17
  292. package/dist/components/render-block/render-repeated-block.d.ts +0 -9
  293. package/dist/components/render-block/types.d.ts +0 -6
  294. package/dist/components/render-blocks.d.ts +0 -10
  295. package/dist/components/render-content/builder-editing.d.ts +0 -3
  296. package/dist/components/render-content/components/render-styles.d.ts +0 -9
  297. package/dist/components/render-content/components/render-styles.helpers.d.ts +0 -15
  298. package/dist/components/render-content/index.d.ts +0 -1
  299. package/dist/components/render-content/render-content.d.ts +0 -4
  300. package/dist/components/render-content/render-content.helpers.d.ts +0 -7
  301. package/dist/components/render-content/render-content.types.d.ts +0 -38
  302. package/dist/components/render-content/wrap-component-ref.d.ts +0 -6
  303. package/dist/components/render-content-variants/helpers.d.ts +0 -17
  304. package/dist/components/render-content-variants/render-content-variants.d.ts +0 -5
  305. package/dist/components/render-inlined-styles.d.ts +0 -7
  306. package/dist/constants/builder-registered-components.d.ts +0 -6
  307. package/dist/constants/device-sizes.d.ts +0 -13
  308. package/dist/constants/sdk-version.d.ts +0 -1
  309. package/dist/constants/target.d.ts +0 -3
  310. package/dist/context/builder.context.d.ts +0 -3
  311. package/dist/context/types.d.ts +0 -35
  312. package/dist/functions/camel-to-kebab-case.d.ts +0 -1
  313. package/dist/functions/evaluate.d.ts +0 -7
  314. package/dist/functions/evaluate.test.d.ts +0 -1
  315. package/dist/functions/event-handler-name.d.ts +0 -1
  316. package/dist/functions/extract-text-styles.d.ts +0 -4
  317. package/dist/functions/fast-clone.d.ts +0 -4
  318. package/dist/functions/get-block-actions-handler.d.ts +0 -8
  319. package/dist/functions/get-block-actions.d.ts +0 -9
  320. package/dist/functions/get-block-component-options.d.ts +0 -2
  321. package/dist/functions/get-block-properties.d.ts +0 -2
  322. package/dist/functions/get-builder-search-params/fn.test.d.ts +0 -1
  323. package/dist/functions/get-builder-search-params/index.d.ts +0 -12
  324. package/dist/functions/get-content/generate-content-url.d.ts +0 -2
  325. package/dist/functions/get-content/generate-content-url.test.d.ts +0 -1
  326. package/dist/functions/get-content/index.d.ts +0 -16
  327. package/dist/functions/get-content/types.d.ts +0 -51
  328. package/dist/functions/get-fetch.d.ts +0 -1
  329. package/dist/functions/get-processed-block.d.ts +0 -10
  330. package/dist/functions/get-processed-block.test.d.ts +0 -1
  331. package/dist/functions/get-react-native-block-styles.d.ts +0 -7
  332. package/dist/functions/if-target.d.ts +0 -7
  333. package/dist/functions/is-browser.d.ts +0 -1
  334. package/dist/functions/is-editing.d.ts +0 -1
  335. package/dist/functions/is-iframe.d.ts +0 -1
  336. package/dist/functions/is-previewing.d.ts +0 -1
  337. package/dist/functions/on-change.d.ts +0 -7
  338. package/dist/functions/on-change.test.d.ts +0 -1
  339. package/dist/functions/register-component.d.ts +0 -14
  340. package/dist/functions/register.d.ts +0 -16
  341. package/dist/functions/sanitize-react-native-block-styles.d.ts +0 -3
  342. package/dist/functions/set-editor-settings.d.ts +0 -4
  343. package/dist/functions/set.d.ts +0 -7
  344. package/dist/functions/set.test.d.ts +0 -1
  345. package/dist/functions/track/helpers.d.ts +0 -5
  346. package/dist/functions/track/index.d.ts +0 -51
  347. package/dist/functions/track/interaction.d.ts +0 -13
  348. package/dist/functions/transform-block-properties.d.ts +0 -3
  349. package/dist/functions/transform-block.d.ts +0 -2
  350. package/dist/helpers/ab-tests.d.ts +0 -9
  351. package/dist/helpers/canTrack.d.ts +0 -1
  352. package/dist/helpers/cookie.d.ts +0 -9
  353. package/dist/helpers/css.d.ts +0 -7
  354. package/dist/helpers/flatten.d.ts +0 -6
  355. package/dist/helpers/localStorage.d.ts +0 -9
  356. package/dist/helpers/logger.d.ts +0 -6
  357. package/dist/helpers/nullable.d.ts +0 -2
  358. package/dist/helpers/sessionId.d.ts +0 -6
  359. package/dist/helpers/time.d.ts +0 -1
  360. package/dist/helpers/url.d.ts +0 -6
  361. package/dist/helpers/url.test.d.ts +0 -1
  362. package/dist/helpers/uuid.d.ts +0 -8
  363. package/dist/helpers/visitorId.d.ts +0 -6
  364. package/dist/index-helpers/blocks-exports.d.ts +0 -8
  365. package/dist/index-helpers/top-of-file.d.ts +0 -1
  366. package/dist/index.d.ts +0 -15
  367. package/dist/scripts/init-editing.d.ts +0 -6
  368. package/dist/types/api-version.d.ts +0 -2
  369. package/dist/types/builder-block.d.ts +0 -66
  370. package/dist/types/builder-content.d.ts +0 -44
  371. package/dist/types/can-track.d.ts +0 -3
  372. package/dist/types/components.d.ts +0 -105
  373. package/dist/types/deep-partial.d.ts +0 -3
  374. package/dist/types/element.d.ts +0 -59
  375. package/dist/types/input.d.ts +0 -121
  376. package/dist/types/targets.d.ts +0 -3
  377. package/dist/types/typescript.d.ts +0 -5
  378. package/src/blocks/util.js +0 -8
  379. package/src/components/render-block/render-component.jsx +0 -55
  380. package/src/components/render-blocks.jsx +0 -101
  381. package/src/components/render-content/builder-editing.jsx +0 -16
  382. package/src/components/render-content/index.js +0 -4
  383. package/src/components/render-content/wrap-component-ref.js +0 -4
  384. package/src/components/render-content-variants/render-content-variants.jsx +0 -101
  385. package/src/functions/evaluate.test.js +0 -17
  386. package/src/functions/get-builder-search-params/fn.test.js +0 -13
  387. package/src/functions/get-content/generate-content-url.test.js +0 -97
  388. package/src/functions/get-processed-block.test.js +0 -34
  389. package/src/functions/on-change.test.js +0 -19
  390. package/src/functions/set.test.js +0 -16
  391. package/src/helpers/url.test.js +0 -21
  392. /package/src/components/{render-block → block}/types.js +0 -0
  393. /package/src/components/{render-content/render-content.types.js → content-variants/content-variants.types.js} +0 -0
@@ -1,241 +1,218 @@
1
- import { serializeFn } from "../util.js";
2
1
  const componentInfo = {
3
2
  name: "Columns",
4
- inputs: [
5
- {
6
- name: "columns",
3
+ isRSC: true,
4
+ inputs: [{
5
+ name: "columns",
6
+ type: "array",
7
+ broadcast: true,
8
+ subFields: [{
9
+ name: "blocks",
7
10
  type: "array",
8
- broadcast: true,
9
- subFields: [
10
- {
11
- name: "blocks",
12
- type: "array",
13
- hideFromUI: true,
14
- defaultValue: [
15
- {
16
- "@type": "@builder.io/sdk:Element",
17
- responsiveStyles: {
18
- large: {
19
- display: "flex",
20
- flexDirection: "column",
21
- alignItems: "stretch",
22
- flexShrink: "0",
23
- position: "relative",
24
- marginTop: "30px",
25
- textAlign: "center",
26
- lineHeight: "normal",
27
- height: "auto",
28
- minHeight: "20px",
29
- minWidth: "20px",
30
- overflow: "hidden"
31
- }
32
- },
33
- component: {
34
- name: "Image",
35
- options: {
36
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
37
- backgroundPosition: "center",
38
- backgroundSize: "cover",
39
- aspectRatio: 0.7004048582995948
40
- }
41
- }
42
- },
43
- {
44
- "@type": "@builder.io/sdk:Element",
45
- responsiveStyles: {
46
- large: {
47
- display: "flex",
48
- flexDirection: "column",
49
- alignItems: "stretch",
50
- flexShrink: "0",
51
- position: "relative",
52
- marginTop: "30px",
53
- textAlign: "center",
54
- lineHeight: "normal",
55
- height: "auto"
56
- }
57
- },
58
- component: {
59
- name: "Text",
60
- options: {
61
- text: "<p>Enter some text...</p>"
62
- }
63
- }
64
- }
65
- ]
11
+ hideFromUI: true,
12
+ defaultValue: [{
13
+ "@type": "@builder.io/sdk:Element",
14
+ responsiveStyles: {
15
+ large: {
16
+ display: "flex",
17
+ flexDirection: "column",
18
+ alignItems: "stretch",
19
+ flexShrink: "0",
20
+ position: "relative",
21
+ marginTop: "30px",
22
+ textAlign: "center",
23
+ lineHeight: "normal",
24
+ height: "auto",
25
+ minHeight: "20px",
26
+ minWidth: "20px",
27
+ overflow: "hidden"
28
+ }
66
29
  },
67
- {
68
- name: "width",
69
- type: "number",
70
- hideFromUI: true,
71
- helperText: "Width %, e.g. set to 50 to fill half of the space"
30
+ component: {
31
+ name: "Image",
32
+ options: {
33
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
34
+ backgroundPosition: "center",
35
+ backgroundSize: "cover",
36
+ aspectRatio: 0.7004048582995948
37
+ }
38
+ }
39
+ }, {
40
+ "@type": "@builder.io/sdk:Element",
41
+ responsiveStyles: {
42
+ large: {
43
+ display: "flex",
44
+ flexDirection: "column",
45
+ alignItems: "stretch",
46
+ flexShrink: "0",
47
+ position: "relative",
48
+ marginTop: "30px",
49
+ textAlign: "center",
50
+ lineHeight: "normal",
51
+ height: "auto"
52
+ }
72
53
  },
73
- {
74
- name: "link",
75
- type: "url",
76
- helperText: "Optionally set a url that clicking this column will link to"
54
+ component: {
55
+ name: "Text",
56
+ options: {
57
+ text: "<p>Enter some text...</p>"
58
+ }
77
59
  }
78
- ],
79
- defaultValue: [
80
- {
81
- blocks: [
82
- {
83
- "@type": "@builder.io/sdk:Element",
84
- responsiveStyles: {
85
- large: {
86
- display: "flex",
87
- flexDirection: "column",
88
- alignItems: "stretch",
89
- flexShrink: "0",
90
- position: "relative",
91
- marginTop: "30px",
92
- textAlign: "center",
93
- lineHeight: "normal",
94
- height: "auto",
95
- minHeight: "20px",
96
- minWidth: "20px",
97
- overflow: "hidden"
98
- }
99
- },
100
- component: {
101
- name: "Image",
102
- options: {
103
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
104
- backgroundPosition: "center",
105
- backgroundSize: "cover",
106
- aspectRatio: 0.7004048582995948
107
- }
108
- }
109
- },
110
- {
111
- "@type": "@builder.io/sdk:Element",
112
- responsiveStyles: {
113
- large: {
114
- display: "flex",
115
- flexDirection: "column",
116
- alignItems: "stretch",
117
- flexShrink: "0",
118
- position: "relative",
119
- marginTop: "30px",
120
- textAlign: "center",
121
- lineHeight: "normal",
122
- height: "auto"
123
- }
124
- },
125
- component: {
126
- name: "Text",
127
- options: {
128
- text: "<p>Enter some text...</p>"
129
- }
130
- }
131
- }
132
- ]
60
+ }]
61
+ }, {
62
+ name: "width",
63
+ type: "number",
64
+ hideFromUI: true,
65
+ helperText: "Width %, e.g. set to 50 to fill half of the space"
66
+ }, {
67
+ name: "link",
68
+ type: "url",
69
+ helperText: "Optionally set a url that clicking this column will link to"
70
+ }],
71
+ defaultValue: [{
72
+ blocks: [{
73
+ "@type": "@builder.io/sdk:Element",
74
+ responsiveStyles: {
75
+ large: {
76
+ display: "flex",
77
+ flexDirection: "column",
78
+ alignItems: "stretch",
79
+ flexShrink: "0",
80
+ position: "relative",
81
+ marginTop: "30px",
82
+ textAlign: "center",
83
+ lineHeight: "normal",
84
+ height: "auto",
85
+ minHeight: "20px",
86
+ minWidth: "20px",
87
+ overflow: "hidden"
88
+ }
133
89
  },
134
- {
135
- blocks: [
136
- {
137
- "@type": "@builder.io/sdk:Element",
138
- responsiveStyles: {
139
- large: {
140
- display: "flex",
141
- flexDirection: "column",
142
- alignItems: "stretch",
143
- flexShrink: "0",
144
- position: "relative",
145
- marginTop: "30px",
146
- textAlign: "center",
147
- lineHeight: "normal",
148
- height: "auto",
149
- minHeight: "20px",
150
- minWidth: "20px",
151
- overflow: "hidden"
152
- }
153
- },
154
- component: {
155
- name: "Image",
156
- options: {
157
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
158
- backgroundPosition: "center",
159
- backgroundSize: "cover",
160
- aspectRatio: 0.7004048582995948
161
- }
162
- }
163
- },
164
- {
165
- "@type": "@builder.io/sdk:Element",
166
- responsiveStyles: {
167
- large: {
168
- display: "flex",
169
- flexDirection: "column",
170
- alignItems: "stretch",
171
- flexShrink: "0",
172
- position: "relative",
173
- marginTop: "30px",
174
- textAlign: "center",
175
- lineHeight: "normal",
176
- height: "auto"
177
- }
178
- },
179
- component: {
180
- name: "Text",
181
- options: {
182
- text: "<p>Enter some text...</p>"
183
- }
184
- }
185
- }
186
- ]
90
+ component: {
91
+ name: "Image",
92
+ options: {
93
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
94
+ backgroundPosition: "center",
95
+ backgroundSize: "cover",
96
+ aspectRatio: 0.7004048582995948
97
+ }
98
+ }
99
+ }, {
100
+ "@type": "@builder.io/sdk:Element",
101
+ responsiveStyles: {
102
+ large: {
103
+ display: "flex",
104
+ flexDirection: "column",
105
+ alignItems: "stretch",
106
+ flexShrink: "0",
107
+ position: "relative",
108
+ marginTop: "30px",
109
+ textAlign: "center",
110
+ lineHeight: "normal",
111
+ height: "auto"
112
+ }
113
+ },
114
+ component: {
115
+ name: "Text",
116
+ options: {
117
+ text: "<p>Enter some text...</p>"
118
+ }
119
+ }
120
+ }]
121
+ }, {
122
+ blocks: [{
123
+ "@type": "@builder.io/sdk:Element",
124
+ responsiveStyles: {
125
+ large: {
126
+ display: "flex",
127
+ flexDirection: "column",
128
+ alignItems: "stretch",
129
+ flexShrink: "0",
130
+ position: "relative",
131
+ marginTop: "30px",
132
+ textAlign: "center",
133
+ lineHeight: "normal",
134
+ height: "auto",
135
+ minHeight: "20px",
136
+ minWidth: "20px",
137
+ overflow: "hidden"
138
+ }
139
+ },
140
+ component: {
141
+ name: "Image",
142
+ options: {
143
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
144
+ backgroundPosition: "center",
145
+ backgroundSize: "cover",
146
+ aspectRatio: 0.7004048582995948
147
+ }
187
148
  }
188
- ],
189
- onChange: serializeFn((options) => {
190
- function clearWidths() {
191
- columns.forEach((col) => {
192
- col.delete("width");
193
- });
149
+ }, {
150
+ "@type": "@builder.io/sdk:Element",
151
+ responsiveStyles: {
152
+ large: {
153
+ display: "flex",
154
+ flexDirection: "column",
155
+ alignItems: "stretch",
156
+ flexShrink: "0",
157
+ position: "relative",
158
+ marginTop: "30px",
159
+ textAlign: "center",
160
+ lineHeight: "normal",
161
+ height: "auto"
162
+ }
163
+ },
164
+ component: {
165
+ name: "Text",
166
+ options: {
167
+ text: "<p>Enter some text...</p>"
168
+ }
194
169
  }
195
- const columns = options.get("columns");
196
- if (Array.isArray(columns)) {
197
- const containsColumnWithWidth = !!columns.find((col) => col.get("width"));
198
- if (containsColumnWithWidth) {
199
- const containsColumnWithoutWidth = !!columns.find((col) => !col.get("width"));
200
- if (containsColumnWithoutWidth) {
170
+ }]
171
+ }],
172
+ onChange: options => {
173
+ function clearWidths() {
174
+ columns.forEach(col => {
175
+ col.delete("width");
176
+ });
177
+ }
178
+ const columns = options.get("columns");
179
+ if (Array.isArray(columns)) {
180
+ const containsColumnWithWidth = !!columns.find(col => col.get("width"));
181
+ if (containsColumnWithWidth) {
182
+ const containsColumnWithoutWidth = !!columns.find(col => !col.get("width"));
183
+ if (containsColumnWithoutWidth) {
184
+ clearWidths();
185
+ } else {
186
+ const sumWidths = columns.reduce((memo, col) => {
187
+ return memo + col.get("width");
188
+ }, 0);
189
+ const widthsDontAddUp = sumWidths !== 100;
190
+ if (widthsDontAddUp) {
201
191
  clearWidths();
202
- } else {
203
- const sumWidths = columns.reduce((memo, col) => {
204
- return memo + col.get("width");
205
- }, 0);
206
- const widthsDontAddUp = sumWidths !== 100;
207
- if (widthsDontAddUp) {
208
- clearWidths();
209
- }
210
192
  }
211
193
  }
212
194
  }
213
- })
214
- },
215
- {
216
- name: "space",
217
- type: "number",
218
- defaultValue: 20,
219
- helperText: "Size of gap between columns",
220
- advanced: true
221
- },
222
- {
223
- name: "stackColumnsAt",
224
- type: "string",
225
- defaultValue: "tablet",
226
- helperText: "Convert horizontal columns to vertical at what device size",
227
- enum: ["tablet", "mobile", "never"],
228
- advanced: true
229
- },
230
- {
231
- name: "reverseColumnsWhenStacked",
232
- type: "boolean",
233
- defaultValue: false,
234
- helperText: "When stacking columns for mobile devices, reverse the ordering",
235
- advanced: true
195
+ }
236
196
  }
237
- ]
238
- };
239
- export {
240
- componentInfo
197
+ }, {
198
+ name: "space",
199
+ type: "number",
200
+ defaultValue: 20,
201
+ helperText: "Size of gap between columns",
202
+ advanced: true
203
+ }, {
204
+ name: "stackColumnsAt",
205
+ type: "string",
206
+ defaultValue: "tablet",
207
+ helperText: "Convert horizontal columns to vertical at what device size",
208
+ enum: ["tablet", "mobile", "never"],
209
+ advanced: true
210
+ }, {
211
+ name: "reverseColumnsWhenStacked",
212
+ type: "boolean",
213
+ defaultValue: false,
214
+ helperText: "When stacking columns for mobile devices, reverse the ordering",
215
+ advanced: true
216
+ }]
241
217
  };
218
+ export { componentInfo }
@@ -2,29 +2,23 @@ const componentInfo = {
2
2
  name: "Custom Code",
3
3
  static: true,
4
4
  requiredPermissions: ["editCode"],
5
- inputs: [
6
- {
7
- name: "code",
8
- type: "html",
9
- required: true,
10
- defaultValue: "<p>Hello there, I am custom HTML code!</p>",
11
- code: true
12
- },
13
- {
14
- name: "replaceNodes",
15
- type: "boolean",
16
- helperText: "Preserve server rendered dom nodes",
17
- advanced: true
18
- },
19
- {
20
- name: "scriptsClientOnly",
21
- type: "boolean",
22
- defaultValue: false,
23
- helperText: "Only print and run scripts on the client. Important when scripts influence DOM that could be replaced when client loads",
24
- advanced: true
25
- }
26
- ]
27
- };
28
- export {
29
- componentInfo
5
+ inputs: [{
6
+ name: "code",
7
+ type: "html",
8
+ required: true,
9
+ defaultValue: "<p>Hello there, I am custom HTML code!</p>",
10
+ code: true
11
+ }, {
12
+ name: "replaceNodes",
13
+ type: "boolean",
14
+ helperText: "Preserve server rendered dom nodes",
15
+ advanced: true
16
+ }, {
17
+ name: "scriptsClientOnly",
18
+ type: "boolean",
19
+ defaultValue: false,
20
+ helperText: "Only print and run scripts on the client. Important when scripts influence DOM that could be replaced when client loads",
21
+ advanced: true
22
+ }]
30
23
  };
24
+ export { componentInfo }
@@ -1,4 +1,4 @@
1
- 'use client';
1
+ "use client";
2
2
  import * as React from "react";
3
3
  import {
4
4
  FlatList,
@@ -1,43 +1,37 @@
1
- import { serializeFn } from "../util.js";
2
1
  const componentInfo = {
3
2
  name: "Embed",
4
3
  static: true,
5
- inputs: [
6
- {
7
- name: "url",
8
- type: "url",
9
- required: true,
10
- defaultValue: "",
11
- helperText: "e.g. enter a youtube url, google map, etc",
12
- onChange: serializeFn((options) => {
13
- const url = options.get("url");
14
- if (url) {
15
- options.set("content", "Loading...");
16
- const apiKey = "ae0e60e78201a3f2b0de4b";
17
- return fetch(`https://iframe.ly/api/iframely?url=${url}&api_key=${apiKey}`).then((res) => res.json()).then((data) => {
18
- if (options.get("url") === url) {
19
- if (data.html) {
20
- options.set("content", data.html);
21
- } else {
22
- options.set("content", "Invalid url, please try another");
23
- }
4
+ inputs: [{
5
+ name: "url",
6
+ type: "url",
7
+ required: true,
8
+ defaultValue: "",
9
+ helperText: "e.g. enter a youtube url, google map, etc",
10
+ onChange: options => {
11
+ const url = options.get("url");
12
+ if (url) {
13
+ options.set("content", "Loading...");
14
+ const apiKey = "ae0e60e78201a3f2b0de4b";
15
+ return fetch(`https://iframe.ly/api/iframely?url=${url}&api_key=${apiKey}`).then(res => res.json()).then(data => {
16
+ if (options.get("url") === url) {
17
+ if (data.html) {
18
+ options.set("content", data.html);
19
+ } else {
20
+ options.set("content", "Invalid url, please try another");
24
21
  }
25
- }).catch((_err) => {
26
- options.set("content", "There was an error embedding this URL, please try again or another URL");
27
- });
28
- } else {
29
- options.delete("content");
30
- }
31
- })
32
- },
33
- {
34
- name: "content",
35
- type: "html",
36
- defaultValue: '<div style="padding: 20px; text-align: center">(Choose an embed URL)<div>',
37
- hideFromUI: true
22
+ }
23
+ }).catch(_err => {
24
+ options.set("content", "There was an error embedding this URL, please try again or another URL");
25
+ });
26
+ } else {
27
+ options.delete("content");
28
+ }
38
29
  }
39
- ]
40
- };
41
- export {
42
- componentInfo
30
+ }, {
31
+ name: "content",
32
+ type: "html",
33
+ defaultValue: '<div style="padding: 20px; text-align: center">(Choose an embed URL)<div>',
34
+ hideFromUI: true
35
+ }]
43
36
  };
37
+ export { componentInfo }
@@ -1,4 +1,4 @@
1
- 'use client';
1
+ "use client";
2
2
  import * as React from "react";
3
3
  import {
4
4
  FlatList,
@@ -1,9 +1,3 @@
1
- const SCRIPT_MIME_TYPES = [
2
- "text/javascript",
3
- "application/javascript",
4
- "application/ecmascript"
5
- ];
6
- const isJsScript = (script) => SCRIPT_MIME_TYPES.includes(script.type);
7
- export {
8
- isJsScript
9
- };
1
+ const SCRIPT_MIME_TYPES = ["text/javascript", "application/javascript", "application/ecmascript"];
2
+ const isJsScript = script => SCRIPT_MIME_TYPES.includes(script.type);
3
+ export { isJsScript }