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