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