@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
@@ -9,180 +9,75 @@ const componentInfo = {
9
9
  }
10
10
  },
11
11
  image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fef36d2a846134910b64b88e6d18c5ca5",
12
- inputs: [
13
- {
14
- name: "sendSubmissionsTo",
15
- type: "string",
16
- enum: [
17
- {
18
- label: "Send to email",
19
- value: "email",
20
- helperText: "Send form submissions to the email address of your choosing"
21
- },
22
- {
23
- label: "Custom",
24
- value: "custom",
25
- helperText: "Handle where the form requests go manually with a little code, e.g. to your own custom backend"
26
- }
27
- ],
28
- defaultValue: "email"
29
- },
30
- {
31
- name: "sendSubmissionsToEmail",
32
- type: "string",
33
- required: true,
34
- defaultValue: "your@email.com",
35
- showIf: 'options.get("sendSubmissionsTo") === "email"'
36
- },
37
- {
38
- name: "sendWithJs",
39
- type: "boolean",
40
- helperText: "Set to false to use basic html form action",
41
- defaultValue: true,
42
- showIf: 'options.get("sendSubmissionsTo") === "custom"'
43
- },
44
- {
45
- name: "name",
46
- type: "string",
47
- defaultValue: "My form"
48
- },
49
- {
50
- name: "action",
51
- type: "string",
52
- helperText: "URL to send the form data to",
53
- showIf: 'options.get("sendSubmissionsTo") === "custom"'
54
- },
55
- {
56
- name: "contentType",
57
- type: "string",
58
- defaultValue: "application/json",
59
- advanced: true,
60
- enum: [
61
- "application/json",
62
- "multipart/form-data",
63
- "application/x-www-form-urlencoded"
64
- ],
65
- showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
66
- },
67
- {
68
- name: "method",
69
- type: "string",
70
- showIf: 'options.get("sendSubmissionsTo") === "custom"',
71
- defaultValue: "POST",
72
- advanced: true
73
- },
74
- {
75
- name: "previewState",
76
- type: "string",
77
- enum: ["unsubmitted", "sending", "success", "error"],
78
- defaultValue: "unsubmitted",
79
- helperText: 'Choose a state to edit, e.g. choose "success" to show what users see on success and edit the message',
80
- showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
81
- },
82
- {
83
- name: "successUrl",
84
- type: "url",
85
- helperText: "Optional URL to redirect the user to on form submission success",
86
- showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
87
- },
88
- {
89
- name: "resetFormOnSubmit",
90
- type: "boolean",
91
- showIf: "options.get('sendSubmissionsTo') === 'custom' && options.get('sendWithJs') === true",
92
- advanced: true
93
- },
94
- {
95
- name: "successMessage",
96
- type: "uiBlocks",
97
- hideFromUI: true,
98
- defaultValue: [
99
- {
100
- "@type": "@builder.io/sdk:Element",
101
- responsiveStyles: {
102
- large: {
103
- marginTop: "10px"
104
- }
105
- },
106
- component: {
107
- name: "Text",
108
- options: {
109
- text: "<span>Thanks!</span>"
110
- }
111
- }
112
- }
113
- ]
114
- },
115
- {
116
- name: "validate",
117
- type: "boolean",
118
- defaultValue: true,
119
- advanced: true
120
- },
121
- {
122
- name: "errorMessagePath",
123
- type: "text",
124
- advanced: true,
125
- helperText: 'Path to where to get the error message from in a JSON response to display to the user, e.g. "error.message" for a response like { "error": { "message": "this username is taken" }}'
126
- },
127
- {
128
- name: "errorMessage",
129
- type: "uiBlocks",
130
- hideFromUI: true,
131
- defaultValue: [
132
- {
133
- "@type": "@builder.io/sdk:Element",
134
- responsiveStyles: {
135
- large: {
136
- marginTop: "10px"
137
- }
138
- },
139
- bindings: {
140
- "component.options.text": "state.formErrorMessage || block.component.options.text"
141
- },
142
- component: {
143
- name: "Text",
144
- options: {
145
- text: "<span>Form submission error :( Please check your answers and try again</span>"
146
- }
147
- }
148
- }
149
- ]
150
- },
151
- {
152
- name: "sendingMessage",
153
- type: "uiBlocks",
154
- hideFromUI: true,
155
- defaultValue: [
156
- {
157
- "@type": "@builder.io/sdk:Element",
158
- responsiveStyles: {
159
- large: {
160
- marginTop: "10px"
161
- }
162
- },
163
- component: {
164
- name: "Text",
165
- options: {
166
- text: "<span>Sending...</span>"
167
- }
168
- }
169
- }
170
- ]
171
- },
172
- {
173
- name: "customHeaders",
174
- type: "map",
175
- valueType: {
176
- type: "string"
177
- },
178
- advanced: true,
179
- showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
180
- }
181
- ],
182
- noWrap: true,
183
- canHaveChildren: true,
184
- defaultChildren: [
185
- {
12
+ inputs: [{
13
+ name: "sendSubmissionsTo",
14
+ type: "string",
15
+ enum: [{
16
+ label: "Send to email",
17
+ value: "email",
18
+ helperText: "Send form submissions to the email address of your choosing"
19
+ }, {
20
+ label: "Custom",
21
+ value: "custom",
22
+ helperText: "Handle where the form requests go manually with a little code, e.g. to your own custom backend"
23
+ }],
24
+ defaultValue: "email"
25
+ }, {
26
+ name: "sendSubmissionsToEmail",
27
+ type: "string",
28
+ required: true,
29
+ defaultValue: "your@email.com",
30
+ showIf: 'options.get("sendSubmissionsTo") === "email"'
31
+ }, {
32
+ name: "sendWithJs",
33
+ type: "boolean",
34
+ helperText: "Set to false to use basic html form action",
35
+ defaultValue: true,
36
+ showIf: 'options.get("sendSubmissionsTo") === "custom"'
37
+ }, {
38
+ name: "name",
39
+ type: "string",
40
+ defaultValue: "My form"
41
+ }, {
42
+ name: "action",
43
+ type: "string",
44
+ helperText: "URL to send the form data to",
45
+ showIf: 'options.get("sendSubmissionsTo") === "custom"'
46
+ }, {
47
+ name: "contentType",
48
+ type: "string",
49
+ defaultValue: "application/json",
50
+ advanced: true,
51
+ enum: ["application/json", "multipart/form-data", "application/x-www-form-urlencoded"],
52
+ showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
53
+ }, {
54
+ name: "method",
55
+ type: "string",
56
+ showIf: 'options.get("sendSubmissionsTo") === "custom"',
57
+ defaultValue: "POST",
58
+ advanced: true
59
+ }, {
60
+ name: "previewState",
61
+ type: "string",
62
+ enum: ["unsubmitted", "sending", "success", "error"],
63
+ defaultValue: "unsubmitted",
64
+ helperText: 'Choose a state to edit, e.g. choose "success" to show what users see on success and edit the message',
65
+ showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
66
+ }, {
67
+ name: "successUrl",
68
+ type: "url",
69
+ helperText: "Optional URL to redirect the user to on form submission success",
70
+ showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
71
+ }, {
72
+ name: "resetFormOnSubmit",
73
+ type: "boolean",
74
+ showIf: "options.get('sendSubmissionsTo') === 'custom' && options.get('sendWithJs') === true",
75
+ advanced: true
76
+ }, {
77
+ name: "successMessage",
78
+ type: "uiBlocks",
79
+ hideFromUI: true,
80
+ defaultValue: [{
186
81
  "@type": "@builder.io/sdk:Element",
187
82
  responsiveStyles: {
188
83
  large: {
@@ -192,26 +87,46 @@ const componentInfo = {
192
87
  component: {
193
88
  name: "Text",
194
89
  options: {
195
- text: "<span>Enter your name</span>"
90
+ text: "<span>Thanks!</span>"
196
91
  }
197
92
  }
198
- },
199
- {
93
+ }]
94
+ }, {
95
+ name: "validate",
96
+ type: "boolean",
97
+ defaultValue: true,
98
+ advanced: true
99
+ }, {
100
+ name: "errorMessagePath",
101
+ type: "text",
102
+ advanced: true,
103
+ helperText: 'Path to where to get the error message from in a JSON response to display to the user, e.g. "error.message" for a response like { "error": { "message": "this username is taken" }}'
104
+ }, {
105
+ name: "errorMessage",
106
+ type: "uiBlocks",
107
+ hideFromUI: true,
108
+ defaultValue: [{
200
109
  "@type": "@builder.io/sdk:Element",
201
110
  responsiveStyles: {
202
111
  large: {
203
112
  marginTop: "10px"
204
113
  }
205
114
  },
115
+ bindings: {
116
+ "component.options.text": "state.formErrorMessage || block.component.options.text"
117
+ },
206
118
  component: {
207
- name: "Form:Input",
119
+ name: "Text",
208
120
  options: {
209
- name: "name",
210
- placeholder: "Jane Doe"
121
+ text: "<span>Form submission error :( Please check your answers and try again</span>"
211
122
  }
212
123
  }
213
- },
214
- {
124
+ }]
125
+ }, {
126
+ name: "sendingMessage",
127
+ type: "uiBlocks",
128
+ hideFromUI: true,
129
+ defaultValue: [{
215
130
  "@type": "@builder.io/sdk:Element",
216
131
  responsiveStyles: {
217
132
  large: {
@@ -221,41 +136,88 @@ const componentInfo = {
221
136
  component: {
222
137
  name: "Text",
223
138
  options: {
224
- text: "<span>Enter your email</span>"
139
+ text: "<span>Sending...</span>"
225
140
  }
226
141
  }
142
+ }]
143
+ }, {
144
+ name: "customHeaders",
145
+ type: "map",
146
+ valueType: {
147
+ type: "string"
148
+ },
149
+ advanced: true,
150
+ showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
151
+ }],
152
+ noWrap: true,
153
+ canHaveChildren: true,
154
+ defaultChildren: [{
155
+ "@type": "@builder.io/sdk:Element",
156
+ responsiveStyles: {
157
+ large: {
158
+ marginTop: "10px"
159
+ }
227
160
  },
228
- {
229
- "@type": "@builder.io/sdk:Element",
230
- responsiveStyles: {
231
- large: {
232
- marginTop: "10px"
233
- }
234
- },
235
- component: {
236
- name: "Form:Input",
237
- options: {
238
- name: "email",
239
- placeholder: "jane@doe.com"
240
- }
161
+ component: {
162
+ name: "Text",
163
+ options: {
164
+ text: "<span>Enter your name</span>"
165
+ }
166
+ }
167
+ }, {
168
+ "@type": "@builder.io/sdk:Element",
169
+ responsiveStyles: {
170
+ large: {
171
+ marginTop: "10px"
241
172
  }
242
173
  },
243
- {
244
- "@type": "@builder.io/sdk:Element",
245
- responsiveStyles: {
246
- large: {
247
- marginTop: "10px"
248
- }
249
- },
250
- component: {
251
- name: "Form:SubmitButton",
252
- options: {
253
- text: "Submit"
254
- }
174
+ component: {
175
+ name: "Form:Input",
176
+ options: {
177
+ name: "name",
178
+ placeholder: "Jane Doe"
255
179
  }
256
180
  }
257
- ]
258
- };
259
- export {
260
- componentInfo
181
+ }, {
182
+ "@type": "@builder.io/sdk:Element",
183
+ responsiveStyles: {
184
+ large: {
185
+ marginTop: "10px"
186
+ }
187
+ },
188
+ component: {
189
+ name: "Text",
190
+ options: {
191
+ text: "<span>Enter your email</span>"
192
+ }
193
+ }
194
+ }, {
195
+ "@type": "@builder.io/sdk:Element",
196
+ responsiveStyles: {
197
+ large: {
198
+ marginTop: "10px"
199
+ }
200
+ },
201
+ component: {
202
+ name: "Form:Input",
203
+ options: {
204
+ name: "email",
205
+ placeholder: "jane@doe.com"
206
+ }
207
+ }
208
+ }, {
209
+ "@type": "@builder.io/sdk:Element",
210
+ responsiveStyles: {
211
+ large: {
212
+ marginTop: "10px"
213
+ }
214
+ },
215
+ component: {
216
+ name: "Form:SubmitButton",
217
+ options: {
218
+ text: "Submit"
219
+ }
220
+ }
221
+ }]
261
222
  };
223
+ export { componentInfo }
@@ -1,5 +1,4 @@
1
- 'use client';
2
- import BaseText from "../BaseText";
1
+ "use client";
3
2
  import * as React from "react";
4
3
  import {
5
4
  FlatList,
@@ -9,252 +8,9 @@ import {
9
8
  Image,
10
9
  Text,
11
10
  } from "react-native";
12
- import { useState, useContext, useRef } from "react";
13
- import RenderBlock from "../../components/render-block/render-block";
14
- import BuilderBlocks from "../../components/render-blocks";
15
- import { isEditing } from "../../functions/is-editing.js";
16
11
 
17
12
  function FormComponent(props) {
18
- const formRef = useRef(null);
19
- const [formState, setFormState] = useState(() => "unsubmitted");
20
-
21
- const [responseData, setResponseData] = useState(() => null);
22
-
23
- const [formErrorMessage, setFormErrorMessage] = useState(() => "");
24
-
25
- function submissionState() {
26
- return (isEditing() && props.previewState) || formState;
27
- }
28
-
29
- function onSubmit(event) {
30
- const sendWithJs = props.sendWithJs || props.sendSubmissionsTo === "email";
31
- if (props.sendSubmissionsTo === "zapier") {
32
- event.preventDefault();
33
- } else if (sendWithJs) {
34
- if (!(props.action || props.sendSubmissionsTo === "email")) {
35
- event.preventDefault();
36
- return;
37
- }
38
- event.preventDefault();
39
- const el = event.currentTarget;
40
- const headers = props.customHeaders || {};
41
- let body;
42
- const formData = new FormData(el);
43
-
44
- // TODO: maybe support null
45
- const formPairs = Array.from(
46
- event.currentTarget.querySelectorAll("input,select,textarea")
47
- )
48
- .filter((el) => !!el.name)
49
- .map((el) => {
50
- let value;
51
- const key = el.name;
52
- if (el instanceof HTMLInputElement) {
53
- if (el.type === "radio") {
54
- if (el.checked) {
55
- value = el.name;
56
- return {
57
- key,
58
- value,
59
- };
60
- }
61
- } else if (el.type === "checkbox") {
62
- value = el.checked;
63
- } else if (el.type === "number" || el.type === "range") {
64
- const num = el.valueAsNumber;
65
- if (!isNaN(num)) {
66
- value = num;
67
- }
68
- } else if (el.type === "file") {
69
- // TODO: one vs multiple files
70
- value = el.files;
71
- } else {
72
- value = el.value;
73
- }
74
- } else {
75
- value = el.value;
76
- }
77
- return {
78
- key,
79
- value,
80
- };
81
- });
82
- let contentType = props.contentType;
83
- if (props.sendSubmissionsTo === "email") {
84
- contentType = "multipart/form-data";
85
- }
86
- Array.from(formPairs).forEach(({ value }) => {
87
- if (
88
- value instanceof File ||
89
- (Array.isArray(value) && value[0] instanceof File) ||
90
- value instanceof FileList
91
- ) {
92
- contentType = "multipart/form-data";
93
- }
94
- });
95
-
96
- // TODO: send as urlEncoded or multipart by default
97
- // because of ease of use and reliability in browser API
98
- // for encoding the form?
99
- if (contentType !== "application/json") {
100
- body = formData;
101
- } else {
102
- // Json
103
- const json = {};
104
- Array.from(formPairs).forEach(({ value, key }) => {
105
- set(json, key, value);
106
- });
107
- body = JSON.stringify(json);
108
- }
109
- if (contentType && contentType !== "multipart/form-data") {
110
- if (
111
- /* Zapier doesn't allow content-type header to be sent from browsers */ !(
112
- sendWithJs && props.action?.includes("zapier.com")
113
- )
114
- ) {
115
- headers["content-type"] = contentType;
116
- }
117
- }
118
- const presubmitEvent = new CustomEvent("presubmit", { detail: { body } });
119
- if (formRef.current) {
120
- formRef.current.dispatchEvent(presubmitEvent);
121
- if (presubmitEvent.defaultPrevented) {
122
- return;
123
- }
124
- }
125
- setFormState("sending");
126
- const formUrl = `${
127
- builder.env === "dev" ? "http://localhost:5000" : "https://builder.io"
128
- }/api/v1/form-submit?apiKey=${builder.apiKey}&to=${btoa(
129
- props.sendSubmissionsToEmail || ""
130
- )}&name=${encodeURIComponent(props.name || "")}`;
131
- fetch(
132
- props.sendSubmissionsTo === "email"
133
- ? formUrl
134
- : props.action /* TODO: throw error if no action URL */,
135
- { body, headers, method: props.method || "post" }
136
- ).then(
137
- async (res) => {
138
- let body;
139
- const contentType = res.headers.get("content-type");
140
- if (contentType && contentType.indexOf("application/json") !== -1) {
141
- body = await res.json();
142
- } else {
143
- body = await res.text();
144
- }
145
- if (!res.ok && props.errorMessagePath) {
146
- /* TODO: allow supplying an error formatter function */ let message =
147
- get(body, props.errorMessagePath);
148
- if (message) {
149
- if (typeof message !== "string") {
150
- /* TODO: ideally convert json to yaml so it woul dbe like error: - email has been taken */ message =
151
- JSON.stringify(message);
152
- }
153
- setFormErrorMessage(message);
154
- }
155
- }
156
- setResponseData(body);
157
- setFormState(res.ok ? "success" : "error");
158
- if (res.ok) {
159
- const submitSuccessEvent = new CustomEvent("submit:success", {
160
- detail: { res, body },
161
- });
162
- if (formRef.current) {
163
- formRef.current.dispatchEvent(submitSuccessEvent);
164
- if (submitSuccessEvent.defaultPrevented) {
165
- return;
166
- }
167
- /* TODO: option to turn this on/off? */ if (
168
- props.resetFormOnSubmit !== false
169
- ) {
170
- formRef.current.reset();
171
- }
172
- }
173
- /* TODO: client side route event first that can be preventDefaulted */ if (
174
- props.successUrl
175
- ) {
176
- if (formRef.current) {
177
- const event = new CustomEvent("route", {
178
- detail: { url: props.successUrl },
179
- });
180
- formRef.current.dispatchEvent(event);
181
- if (!event.defaultPrevented) {
182
- location.href = props.successUrl;
183
- }
184
- } else {
185
- location.href = props.successUrl;
186
- }
187
- }
188
- }
189
- },
190
- (err) => {
191
- const submitErrorEvent = new CustomEvent("submit:error", {
192
- detail: { error: err },
193
- });
194
- if (formRef.current) {
195
- formRef.current.dispatchEvent(submitErrorEvent);
196
- if (submitErrorEvent.defaultPrevented) {
197
- return;
198
- }
199
- }
200
- setResponseData(err);
201
- setFormState("error");
202
- }
203
- );
204
- }
205
- }
206
- const builderContext = useContext(BuilderContext);
207
- return (
208
- <View
209
- validate={props.validate}
210
- ref={formRef}
211
- action={!props.sendWithJs && props.action}
212
- method={props.method}
213
- name={props.name}
214
- onSubmit={(event) => onSubmit(event)}
215
- {...props.attributes}
216
- >
217
- {" "}
218
- {props.builderBlock && props.builderBlock.children ? (
219
- <>
220
- {props.builderBlock?.children?.map((block) => (
221
- <RenderBlock block={block} context={builderContext} />
222
- ))}
223
- </>
224
- ) : null}{" "}
225
- {submissionState() === "error" ? (
226
- <>
227
- <BuilderBlocks dataPath="errorMessage" blocks={props.errorMessage} />
228
- </>
229
- ) : null}{" "}
230
- {submissionState() === "sending" ? (
231
- <>
232
- <BuilderBlocks
233
- dataPath="sendingMessage"
234
- blocks={props.sendingMessage}
235
- />
236
- </>
237
- ) : null}{" "}
238
- {submissionState() === "error" && responseData ? (
239
- <>
240
- <View style={styles.view1}>
241
- {" "}
242
- <BaseText>{JSON.stringify(responseData, null, 2)}</BaseText>{" "}
243
- </View>
244
- </>
245
- ) : null}{" "}
246
- {submissionState() === "success" ? (
247
- <>
248
- <BuilderBlocks
249
- dataPath="successMessage"
250
- blocks={props.successMessage}
251
- />
252
- </>
253
- ) : null}{" "}
254
- </View>
255
- );
13
+ return <></>;
256
14
  }
257
- const styles = StyleSheet.create({
258
- view1: { padding: 10, color: "red", textAlign: "center" },
259
- });
15
+
260
16
  export default FormComponent;
@@ -5,6 +5,4 @@ const componentInfo = {
5
5
  canHaveChildren: true,
6
6
  noWrap: true
7
7
  };
8
- export {
9
- componentInfo
10
- };
8
+ export { componentInfo }