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

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 (261) hide show
  1. package/dist/sdk/blocks/columns/columns.js +4 -4
  2. package/dist/sdk/blocks/image/image.js +8 -7
  3. package/dist/sdk/blocks/symbol/symbol.js +2 -1
  4. package/dist/sdk/blocks/video/video.js +4 -1
  5. package/dist/sdk/components/render-block/render-block.js +4 -1
  6. package/dist/sdk/components/render-content/render-content.js +19 -5
  7. package/dist/sdk/index.d.ts +1 -0
  8. package/package.json +4 -1
  9. package/CHANGELOG.md +0 -25
  10. package/packages/react/src/blocks/BaseText.tsx +0 -19
  11. package/packages/react/src/blocks/button/button.tsx +0 -45
  12. package/packages/react/src/blocks/button/component-info.ts +0 -42
  13. package/packages/react/src/blocks/columns/columns.tsx +0 -211
  14. package/packages/react/src/blocks/columns/component-info.ts +0 -254
  15. package/packages/react/src/blocks/custom-code/component-info.ts +0 -31
  16. package/packages/react/src/blocks/custom-code/custom-code.tsx +0 -76
  17. package/packages/react/src/blocks/embed/component-info.ts +0 -55
  18. package/packages/react/src/blocks/embed/embed.tsx +0 -59
  19. package/packages/react/src/blocks/embed/helpers.ts +0 -8
  20. package/packages/react/src/blocks/form/component-info.ts +0 -282
  21. package/packages/react/src/blocks/form/form.tsx +0 -320
  22. package/packages/react/src/blocks/fragment/component-info.ts +0 -10
  23. package/packages/react/src/blocks/fragment/fragment.tsx +0 -14
  24. package/packages/react/src/blocks/image/component-info.ts +0 -172
  25. package/packages/react/src/blocks/image/image.helpers.ts +0 -75
  26. package/packages/react/src/blocks/image/image.tsx +0 -144
  27. package/packages/react/src/blocks/img/component-info.ts +0 -21
  28. package/packages/react/src/blocks/img/img.tsx +0 -40
  29. package/packages/react/src/blocks/input/component-info.ts +0 -78
  30. package/packages/react/src/blocks/input/input.tsx +0 -33
  31. package/packages/react/src/blocks/raw-text/component-info.ts +0 -15
  32. package/packages/react/src/blocks/raw-text/raw-text.tsx +0 -18
  33. package/packages/react/src/blocks/section/component-info.ts +0 -50
  34. package/packages/react/src/blocks/section/section.tsx +0 -33
  35. package/packages/react/src/blocks/select/component-info.ts +0 -61
  36. package/packages/react/src/blocks/select/select.tsx +0 -35
  37. package/packages/react/src/blocks/submit-button/component-info.ts +0 -32
  38. package/packages/react/src/blocks/submit-button/submit-button.tsx +0 -17
  39. package/packages/react/src/blocks/symbol/component-info.ts +0 -43
  40. package/packages/react/src/blocks/symbol/symbol.tsx +0 -111
  41. package/packages/react/src/blocks/text/component-info.ts +0 -24
  42. package/packages/react/src/blocks/text/text.tsx +0 -20
  43. package/packages/react/src/blocks/textarea/component-info.ts +0 -48
  44. package/packages/react/src/blocks/textarea/textarea.tsx +0 -24
  45. package/packages/react/src/blocks/util.ts +0 -18
  46. package/packages/react/src/blocks/video/component-info.ts +0 -109
  47. package/packages/react/src/blocks/video/video.tsx +0 -84
  48. package/packages/react/src/components/render-block/block-styles.tsx +0 -98
  49. package/packages/react/src/components/render-block/render-block.helpers.ts +0 -138
  50. package/packages/react/src/components/render-block/render-block.tsx +0 -216
  51. package/packages/react/src/components/render-block/render-component.tsx +0 -52
  52. package/packages/react/src/components/render-block/render-repeated-block.tsx +0 -43
  53. package/packages/react/src/components/render-block/types.ts +0 -7
  54. package/packages/react/src/components/render-blocks.tsx +0 -97
  55. package/packages/react/src/components/render-content/builder-editing.tsx +0 -8
  56. package/packages/react/src/components/render-content/components/render-styles.helpers.ts +0 -79
  57. package/packages/react/src/components/render-content/components/render-styles.tsx +0 -45
  58. package/packages/react/src/components/render-content/index.ts +0 -1
  59. package/packages/react/src/components/render-content/render-content.helpers.ts +0 -48
  60. package/packages/react/src/components/render-content/render-content.tsx +0 -410
  61. package/packages/react/src/components/render-content/render-content.types.ts +0 -33
  62. package/packages/react/src/components/render-inlined-styles.tsx +0 -36
  63. package/packages/react/src/constants/builder-registered-components.ts +0 -42
  64. package/packages/react/src/constants/device-sizes.ts +0 -65
  65. package/packages/react/src/constants/target.ts +0 -2
  66. package/packages/react/src/context/builder.context.ts +0 -12
  67. package/packages/react/src/context/types.ts +0 -26
  68. package/packages/react/src/functions/camel-to-kebab-case.ts +0 -2
  69. package/packages/react/src/functions/evaluate.ts +0 -57
  70. package/packages/react/src/functions/event-handler-name.ts +0 -6
  71. package/packages/react/src/functions/extract-text-styles.ts +0 -39
  72. package/packages/react/src/functions/fast-clone.ts +0 -5
  73. package/packages/react/src/functions/get-block-actions-handler.ts +0 -20
  74. package/packages/react/src/functions/get-block-actions.ts +0 -25
  75. package/packages/react/src/functions/get-block-component-options.ts +0 -12
  76. package/packages/react/src/functions/get-block-properties.ts +0 -75
  77. package/packages/react/src/functions/get-builder-search-params/fn.test.ts +0 -19
  78. package/packages/react/src/functions/get-builder-search-params/index.ts +0 -50
  79. package/packages/react/src/functions/get-content/ab-testing.ts +0 -132
  80. package/packages/react/src/functions/get-content/generate-content-url.test.ts +0 -95
  81. package/packages/react/src/functions/get-content/generate-content-url.ts +0 -59
  82. package/packages/react/src/functions/get-content/index.ts +0 -62
  83. package/packages/react/src/functions/get-content/types.ts +0 -53
  84. package/packages/react/src/functions/get-fetch.ts +0 -18
  85. package/packages/react/src/functions/get-global-this.ts +0 -17
  86. package/packages/react/src/functions/get-processed-block.test.ts +0 -33
  87. package/packages/react/src/functions/get-processed-block.ts +0 -54
  88. package/packages/react/src/functions/get-react-native-block-styles.ts +0 -33
  89. package/packages/react/src/functions/if-target.ts +0 -20
  90. package/packages/react/src/functions/is-browser.ts +0 -3
  91. package/packages/react/src/functions/is-editing.ts +0 -10
  92. package/packages/react/src/functions/is-iframe.ts +0 -5
  93. package/packages/react/src/functions/is-previewing.ts +0 -14
  94. package/packages/react/src/functions/on-change.test.ts +0 -23
  95. package/packages/react/src/functions/on-change.ts +0 -29
  96. package/packages/react/src/functions/register-component.ts +0 -50
  97. package/packages/react/src/functions/register.ts +0 -46
  98. package/packages/react/src/functions/sanitize-react-native-block-styles.ts +0 -65
  99. package/packages/react/src/functions/set-editor-settings.ts +0 -16
  100. package/packages/react/src/functions/set.test.ts +0 -19
  101. package/packages/react/src/functions/set.ts +0 -26
  102. package/packages/react/src/functions/track/helpers.ts +0 -67
  103. package/packages/react/src/functions/track/index.ts +0 -136
  104. package/packages/react/src/functions/track/interaction.ts +0 -80
  105. package/packages/react/src/functions/transform-block-properties.ts +0 -3
  106. package/packages/react/src/functions/transform-block.ts +0 -6
  107. package/packages/react/src/helpers/ab-tests.ts +0 -22
  108. package/packages/react/src/helpers/cookie.ts +0 -107
  109. package/packages/react/src/helpers/css.ts +0 -42
  110. package/packages/react/src/helpers/flatten.ts +0 -24
  111. package/packages/react/src/helpers/localStorage.ts +0 -40
  112. package/packages/react/src/helpers/logger.ts +0 -6
  113. package/packages/react/src/helpers/nullable.ts +0 -4
  114. package/packages/react/src/helpers/sessionId.ts +0 -38
  115. package/packages/react/src/helpers/time.ts +0 -4
  116. package/packages/react/src/helpers/url.test.ts +0 -23
  117. package/packages/react/src/helpers/url.ts +0 -16
  118. package/packages/react/src/helpers/uuid.ts +0 -17
  119. package/packages/react/src/helpers/visitorId.ts +0 -40
  120. package/packages/react/src/index-helpers/blocks-exports.ts +0 -10
  121. package/packages/react/src/index-helpers/top-of-file.ts +0 -4
  122. package/packages/react/src/index.ts +0 -14
  123. package/packages/react/src/scripts/init-editing.ts +0 -123
  124. package/packages/react/src/types/api-version.ts +0 -2
  125. package/packages/react/src/types/builder-block.ts +0 -69
  126. package/packages/react/src/types/builder-content.ts +0 -46
  127. package/packages/react/src/types/can-track.ts +0 -3
  128. package/packages/react/src/types/components.ts +0 -117
  129. package/packages/react/src/types/deep-partial.ts +0 -7
  130. package/packages/react/src/types/element.ts +0 -60
  131. package/packages/react/src/types/input.ts +0 -125
  132. package/packages/react/src/types/targets.ts +0 -6
  133. package/packages/react/src/types/typescript.ts +0 -7
  134. package/packages/rsc/src/blocks/BaseText.jsx +0 -12
  135. package/packages/rsc/src/blocks/button/button.jsx +0 -37
  136. package/packages/rsc/src/blocks/button/component-info.js +0 -40
  137. package/packages/rsc/src/blocks/columns/columns.jsx +0 -172
  138. package/packages/rsc/src/blocks/columns/component-info.js +0 -241
  139. package/packages/rsc/src/blocks/custom-code/component-info.js +0 -30
  140. package/packages/rsc/src/blocks/custom-code/custom-code.jsx +0 -57
  141. package/packages/rsc/src/blocks/embed/component-info.js +0 -43
  142. package/packages/rsc/src/blocks/embed/embed.jsx +0 -45
  143. package/packages/rsc/src/blocks/embed/helpers.js +0 -9
  144. package/packages/rsc/src/blocks/form/component-info.js +0 -261
  145. package/packages/rsc/src/blocks/form/form.jsx +0 -260
  146. package/packages/rsc/src/blocks/fragment/component-info.js +0 -10
  147. package/packages/rsc/src/blocks/fragment/fragment.jsx +0 -9
  148. package/packages/rsc/src/blocks/image/component-info.js +0 -150
  149. package/packages/rsc/src/blocks/image/image.helpers.js +0 -48
  150. package/packages/rsc/src/blocks/image/image.jsx +0 -122
  151. package/packages/rsc/src/blocks/img/component-info.js +0 -19
  152. package/packages/rsc/src/blocks/img/img.jsx +0 -21
  153. package/packages/rsc/src/blocks/input/component-info.js +0 -73
  154. package/packages/rsc/src/blocks/input/input.jsx +0 -23
  155. package/packages/rsc/src/blocks/raw-text/component-info.js +0 -15
  156. package/packages/rsc/src/blocks/raw-text/raw-text.jsx +0 -14
  157. package/packages/rsc/src/blocks/section/component-info.js +0 -48
  158. package/packages/rsc/src/blocks/section/section.jsx +0 -27
  159. package/packages/rsc/src/blocks/select/component-info.js +0 -58
  160. package/packages/rsc/src/blocks/select/select.jsx +0 -24
  161. package/packages/rsc/src/blocks/submit-button/component-info.js +0 -27
  162. package/packages/rsc/src/blocks/submit-button/submit-button.jsx +0 -13
  163. package/packages/rsc/src/blocks/symbol/component-info.js +0 -42
  164. package/packages/rsc/src/blocks/symbol/symbol.jsx +0 -89
  165. package/packages/rsc/src/blocks/text/component-info.js +0 -23
  166. package/packages/rsc/src/blocks/text/text.jsx +0 -17
  167. package/packages/rsc/src/blocks/textarea/component-info.js +0 -46
  168. package/packages/rsc/src/blocks/textarea/textarea.jsx +0 -17
  169. package/packages/rsc/src/blocks/util.js +0 -8
  170. package/packages/rsc/src/blocks/video/component-info.js +0 -105
  171. package/packages/rsc/src/blocks/video/video.jsx +0 -63
  172. package/packages/rsc/src/components/render-block/block-styles.jsx +0 -88
  173. package/packages/rsc/src/components/render-block/render-block.helpers.js +0 -129
  174. package/packages/rsc/src/components/render-block/render-block.jsx +0 -201
  175. package/packages/rsc/src/components/render-block/render-component.jsx +0 -39
  176. package/packages/rsc/src/components/render-block/render-repeated-block.jsx +0 -27
  177. package/packages/rsc/src/components/render-block/types.js +0 -0
  178. package/packages/rsc/src/components/render-blocks.jsx +0 -92
  179. package/packages/rsc/src/components/render-content/builder-editing.jsx +0 -64
  180. package/packages/rsc/src/components/render-content/components/render-styles.helpers.js +0 -57
  181. package/packages/rsc/src/components/render-content/components/render-styles.jsx +0 -39
  182. package/packages/rsc/src/components/render-content/index.js +0 -4
  183. package/packages/rsc/src/components/render-content/render-content.helpers.js +0 -48
  184. package/packages/rsc/src/components/render-content/render-content.jsx +0 -253
  185. package/packages/rsc/src/components/render-content/render-content.types.js +0 -0
  186. package/packages/rsc/src/components/render-inlined-styles.jsx +0 -33
  187. package/packages/rsc/src/constants/builder-registered-components.js +0 -54
  188. package/packages/rsc/src/constants/device-sizes.js +0 -48
  189. package/packages/rsc/src/constants/target.js +0 -4
  190. package/packages/rsc/src/context/builder.context.js +0 -14
  191. package/packages/rsc/src/context/types.js +0 -0
  192. package/packages/rsc/src/functions/camel-to-kebab-case.js +0 -4
  193. package/packages/rsc/src/functions/evaluate.js +0 -6
  194. package/packages/rsc/src/functions/event-handler-name.js +0 -7
  195. package/packages/rsc/src/functions/extract-text-styles.js +0 -22
  196. package/packages/rsc/src/functions/fast-clone.js +0 -4
  197. package/packages/rsc/src/functions/get-block-actions-handler.js +0 -11
  198. package/packages/rsc/src/functions/get-block-actions.js +0 -18
  199. package/packages/rsc/src/functions/get-block-component-options.js +0 -28
  200. package/packages/rsc/src/functions/get-block-properties.js +0 -53
  201. package/packages/rsc/src/functions/get-builder-search-params/fn.test.js +0 -13
  202. package/packages/rsc/src/functions/get-builder-search-params/index.js +0 -38
  203. package/packages/rsc/src/functions/get-content/ab-testing.js +0 -99
  204. package/packages/rsc/src/functions/get-content/generate-content-url.js +0 -60
  205. package/packages/rsc/src/functions/get-content/generate-content-url.test.js +0 -82
  206. package/packages/rsc/src/functions/get-content/index.js +0 -83
  207. package/packages/rsc/src/functions/get-content/types.js +0 -0
  208. package/packages/rsc/src/functions/get-fetch.js +0 -14
  209. package/packages/rsc/src/functions/get-global-this.js +0 -18
  210. package/packages/rsc/src/functions/get-processed-block.js +0 -59
  211. package/packages/rsc/src/functions/get-processed-block.test.js +0 -32
  212. package/packages/rsc/src/functions/get-react-native-block-styles.js +0 -33
  213. package/packages/rsc/src/functions/if-target.js +0 -15
  214. package/packages/rsc/src/functions/is-browser.js +0 -6
  215. package/packages/rsc/src/functions/is-editing.js +0 -8
  216. package/packages/rsc/src/functions/is-iframe.js +0 -7
  217. package/packages/rsc/src/functions/is-previewing.js +0 -14
  218. package/packages/rsc/src/functions/on-change.js +0 -27
  219. package/packages/rsc/src/functions/on-change.test.js +0 -19
  220. package/packages/rsc/src/functions/register-component.js +0 -68
  221. package/packages/rsc/src/functions/register.js +0 -29
  222. package/packages/rsc/src/functions/sanitize-react-native-block-styles.js +0 -66
  223. package/packages/rsc/src/functions/set-editor-settings.js +0 -15
  224. package/packages/rsc/src/functions/set.js +0 -11
  225. package/packages/rsc/src/functions/set.test.js +0 -16
  226. package/packages/rsc/src/functions/track/helpers.js +0 -50
  227. package/packages/rsc/src/functions/track/index.js +0 -129
  228. package/packages/rsc/src/functions/track/interaction.js +0 -53
  229. package/packages/rsc/src/functions/transform-block-properties.js +0 -6
  230. package/packages/rsc/src/functions/transform-block.js +0 -6
  231. package/packages/rsc/src/helpers/ab-tests.js +0 -16
  232. package/packages/rsc/src/helpers/cookie.js +0 -81
  233. package/packages/rsc/src/helpers/css.js +0 -34
  234. package/packages/rsc/src/helpers/flatten.js +0 -34
  235. package/packages/rsc/src/helpers/localStorage.js +0 -35
  236. package/packages/rsc/src/helpers/logger.js +0 -9
  237. package/packages/rsc/src/helpers/nullable.js +0 -4
  238. package/packages/rsc/src/helpers/sessionId.js +0 -52
  239. package/packages/rsc/src/helpers/time.js +0 -5
  240. package/packages/rsc/src/helpers/url.js +0 -13
  241. package/packages/rsc/src/helpers/url.test.js +0 -21
  242. package/packages/rsc/src/helpers/uuid.js +0 -13
  243. package/packages/rsc/src/helpers/visitorId.js +0 -34
  244. package/packages/rsc/src/index-helpers/blocks-exports.js +0 -22
  245. package/packages/rsc/src/index-helpers/top-of-file.js +0 -2
  246. package/packages/rsc/src/index.js +0 -13
  247. package/packages/rsc/src/scripts/init-editing.js +0 -93
  248. package/packages/rsc/src/types/api-version.js +0 -4
  249. package/packages/rsc/src/types/builder-block.js +0 -0
  250. package/packages/rsc/src/types/builder-content.js +0 -0
  251. package/packages/rsc/src/types/can-track.js +0 -0
  252. package/packages/rsc/src/types/components.js +0 -0
  253. package/packages/rsc/src/types/deep-partial.js +0 -0
  254. package/packages/rsc/src/types/element.js +0 -0
  255. package/packages/rsc/src/types/input.js +0 -0
  256. package/packages/rsc/src/types/targets.js +0 -0
  257. package/packages/rsc/src/types/typescript.js +0 -0
  258. package/tsconfig.json +0 -28
  259. package/tsconfig.sdk.json +0 -10
  260. package/tsconfig.server.json +0 -10
  261. 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;