@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
@@ -4,55 +4,41 @@ const componentInfo = {
4
4
  defaultStyles: {
5
5
  alignSelf: "flex-start"
6
6
  },
7
- inputs: [
8
- {
9
- name: "options",
10
- type: "list",
11
- required: true,
12
- subFields: [
13
- {
14
- name: "value",
15
- type: "text",
16
- required: true
17
- },
18
- {
19
- name: "name",
20
- type: "text"
21
- }
22
- ],
23
- defaultValue: [
24
- {
25
- value: "option 1"
26
- },
27
- {
28
- value: "option 2"
29
- }
30
- ]
31
- },
32
- {
33
- name: "name",
34
- type: "string",
35
- required: true,
36
- helperText: 'Every select in a form needs a unique name describing what it gets, e.g. "email"'
37
- },
38
- {
39
- name: "defaultValue",
40
- type: "string"
41
- },
42
- {
7
+ inputs: [{
8
+ name: "options",
9
+ type: "list",
10
+ required: true,
11
+ subFields: [{
43
12
  name: "value",
44
- type: "string",
45
- advanced: true
46
- },
47
- {
48
- name: "required",
49
- type: "boolean",
50
- defaultValue: false
51
- }
52
- ],
13
+ type: "text",
14
+ required: true
15
+ }, {
16
+ name: "name",
17
+ type: "text"
18
+ }],
19
+ defaultValue: [{
20
+ value: "option 1"
21
+ }, {
22
+ value: "option 2"
23
+ }]
24
+ }, {
25
+ name: "name",
26
+ type: "string",
27
+ required: true,
28
+ helperText: 'Every select in a form needs a unique name describing what it gets, e.g. "email"'
29
+ }, {
30
+ name: "defaultValue",
31
+ type: "string"
32
+ }, {
33
+ name: "value",
34
+ type: "string",
35
+ advanced: true
36
+ }, {
37
+ name: "required",
38
+ type: "boolean",
39
+ defaultValue: false
40
+ }],
53
41
  static: true,
54
42
  noWrap: true
55
43
  };
56
- export {
57
- componentInfo
58
- };
44
+ export { componentInfo }
@@ -1,5 +1,5 @@
1
- 'use client';
2
1
  import BaseText from "../BaseText";
2
+ ("use client");
3
3
  import * as React from "react";
4
4
  import {
5
5
  FlatList,
@@ -10,10 +10,12 @@ import {
10
10
  Text,
11
11
  } from "react-native";
12
12
  import { isEditing } from "../../functions/is-editing.js";
13
+ import { filterAttrs } from "../helpers.js";
13
14
 
14
15
  function SelectComponent(props) {
15
16
  return (
16
17
  <View
18
+ {...{}}
17
19
  {...props.attributes}
18
20
  value={props.value}
19
21
  key={
@@ -12,16 +12,12 @@ const componentInfo = {
12
12
  borderRadius: "4px",
13
13
  cursor: "pointer"
14
14
  },
15
- inputs: [
16
- {
17
- name: "text",
18
- type: "text",
19
- defaultValue: "Click me"
20
- }
21
- ],
15
+ inputs: [{
16
+ name: "text",
17
+ type: "text",
18
+ defaultValue: "Click me"
19
+ }],
22
20
  static: true,
23
21
  noWrap: true
24
22
  };
25
- export {
26
- componentInfo
27
- };
23
+ export { componentInfo }
@@ -1,5 +1,5 @@
1
- 'use client';
2
1
  import BaseText from "../BaseText";
2
+ ("use client");
3
3
  import * as React from "react";
4
4
  import {
5
5
  FlatList,
@@ -9,10 +9,11 @@ import {
9
9
  Image,
10
10
  Text,
11
11
  } from "react-native";
12
+ import { filterAttrs } from "../helpers.js";
12
13
 
13
14
  function SubmitButton(props) {
14
15
  return (
15
- <View type="submit" {...props.attributes}>
16
+ <View type="submit" {...{}} {...props.attributes}>
16
17
  <BaseText>{props.text}</BaseText>
17
18
  </View>
18
19
  );
@@ -2,41 +2,34 @@ const componentInfo = {
2
2
  name: "Symbol",
3
3
  noWrap: true,
4
4
  static: true,
5
- inputs: [
6
- {
7
- name: "symbol",
8
- type: "uiSymbol"
9
- },
10
- {
11
- name: "dataOnly",
12
- helperText: "Make this a data symbol that doesn't display any UI",
13
- type: "boolean",
14
- defaultValue: false,
15
- advanced: true,
16
- hideFromUI: true
17
- },
18
- {
19
- name: "inheritState",
20
- helperText: "Inherit the parent component state and data",
21
- type: "boolean",
22
- defaultValue: false,
23
- advanced: true
24
- },
25
- {
26
- name: "renderToLiquid",
27
- helperText: "Render this symbols contents to liquid. Turn off to fetch with javascript and use custom targeting",
28
- type: "boolean",
29
- defaultValue: false,
30
- advanced: true,
31
- hideFromUI: true
32
- },
33
- {
34
- name: "useChildren",
35
- hideFromUI: true,
36
- type: "boolean"
37
- }
38
- ]
39
- };
40
- export {
41
- componentInfo
5
+ isRSC: true,
6
+ inputs: [{
7
+ name: "symbol",
8
+ type: "uiSymbol"
9
+ }, {
10
+ name: "dataOnly",
11
+ helperText: "Make this a data symbol that doesn't display any UI",
12
+ type: "boolean",
13
+ defaultValue: false,
14
+ advanced: true,
15
+ hideFromUI: true
16
+ }, {
17
+ name: "inheritState",
18
+ helperText: "Inherit the parent component state and data",
19
+ type: "boolean",
20
+ defaultValue: false,
21
+ advanced: true
22
+ }, {
23
+ name: "renderToLiquid",
24
+ helperText: "Render this symbols contents to liquid. Turn off to fetch with javascript and use custom targeting",
25
+ type: "boolean",
26
+ defaultValue: false,
27
+ advanced: true,
28
+ hideFromUI: true
29
+ }, {
30
+ name: "useChildren",
31
+ hideFromUI: true,
32
+ type: "boolean"
33
+ }]
42
34
  };
35
+ export { componentInfo }
@@ -0,0 +1,60 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
4
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {
6
+ enumerable: true,
7
+ configurable: true,
8
+ writable: true,
9
+ value
10
+ }) : obj[key] = value;
11
+ var __spreadValues = (a, b) => {
12
+ for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]);
13
+ if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]);
15
+ }
16
+ return a;
17
+ };
18
+ var __async = (__this, __arguments, generator) => {
19
+ return new Promise((resolve, reject) => {
20
+ var fulfilled = value => {
21
+ try {
22
+ step(generator.next(value));
23
+ } catch (e) {
24
+ reject(e);
25
+ }
26
+ };
27
+ var rejected = value => {
28
+ try {
29
+ step(generator.throw(value));
30
+ } catch (e) {
31
+ reject(e);
32
+ }
33
+ };
34
+ var step = x => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
35
+ step((generator = generator.apply(__this, __arguments)).next());
36
+ });
37
+ };
38
+ import { getContent } from "../../functions/get-content/index.js";
39
+ import { logger } from "../../helpers/logger.js";
40
+ const fetchContent = _0 => __async(void 0, [_0], function* ({
41
+ builderContextValue,
42
+ symbol
43
+ }) {
44
+ if ((symbol == null ? void 0 : symbol.model) && (builderContextValue == null ? void 0 : builderContextValue.apiKey)) {
45
+ return getContent(__spreadValues({
46
+ model: symbol.model,
47
+ apiKey: builderContextValue.apiKey,
48
+ apiVersion: builderContextValue.apiVersion
49
+ }, (symbol == null ? void 0 : symbol.entry) && {
50
+ query: {
51
+ id: symbol.entry
52
+ }
53
+ })).catch(err => {
54
+ logger.error("Could not fetch symbol content: ", err);
55
+ return void 0;
56
+ });
57
+ }
58
+ return void 0;
59
+ });
60
+ export { fetchContent }
@@ -1,4 +1,4 @@
1
- 'use client';
1
+ "use client";
2
2
  import * as React from "react";
3
3
  import {
4
4
  FlatList,
@@ -8,19 +8,15 @@ import {
8
8
  Image,
9
9
  Text,
10
10
  } from "react-native";
11
- import { useState, useContext, useEffect } from "react";
12
- import RenderContentVariants from "../../components/render-content-variants/render-content-variants";
13
- import BuilderContext from "../../context/builder.context.js";
14
- import { getContent } from "../../functions/get-content/index.js";
15
- import { TARGET } from "../../constants/target";
16
- import { logger } from "../../helpers/logger";
11
+ import { useState, useEffect } from "react";
12
+ import ContentVariants from "../../components/content-variants/content-variants";
13
+ import { filterAttrs } from "../helpers.js";
14
+ import { fetchContent } from "./symbol.helpers.js";
17
15
 
18
16
  function Symbol(props) {
19
- const [className, setClassName] = useState(() =>
20
- [
21
- ...(TARGET === "vue2" || TARGET === "vue3"
22
- ? Object.keys(props.attributes.class)
23
- : [props.attributes.class]),
17
+ function className() {
18
+ return [
19
+ ...[],
24
20
  "builder-symbol",
25
21
  props.symbol?.inline ? "builder-inline-symbol" : undefined,
26
22
  props.symbol?.dynamic || props.dynamic
@@ -28,74 +24,50 @@ function Symbol(props) {
28
24
  : undefined,
29
25
  ]
30
26
  .filter(Boolean)
31
- .join(" ")
32
- );
27
+ .join(" ");
28
+ }
33
29
 
34
30
  const [contentToUse, setContentToUse] = useState(() => props.symbol?.content);
35
31
 
36
- function fetchContent() {
37
- /**
38
- * If:
39
- * - we have a symbol prop
40
- * - yet it does not have any content
41
- * - and we have not already stored content from before
42
- * - and it has a model name
43
- *
44
- * then we want to re-fetch the symbol content.
45
- */
46
- if (
47
- !contentToUse &&
48
- props.symbol?.model &&
49
- // This is a hack, we should not need to check for this, but it is needed for Svelte.
50
- builderContext?.apiKey
51
- ) {
52
- getContent({
53
- model: props.symbol.model,
54
- apiKey: builderContext.apiKey,
55
- apiVersion: builderContext.apiVersion,
56
- ...(props.symbol?.entry && {
57
- query: {
58
- id: props.symbol.entry,
59
- },
60
- }),
61
- })
62
- .then((response) => {
63
- if (response) {
64
- setContentToUse(response);
65
- }
66
- })
67
- .catch((err) => {
68
- logger.error("Could not fetch symbol content: ", err);
69
- });
70
- }
32
+ function setContent() {
33
+ if (contentToUse) return;
34
+ fetchContent({
35
+ symbol: props.symbol,
36
+ builderContextValue: props.builderContext,
37
+ }).then((newContent) => {
38
+ if (newContent) {
39
+ setContentToUse(newContent);
40
+ }
41
+ });
71
42
  }
72
43
 
73
- const builderContext = useContext(BuilderContext);
74
-
75
44
  useEffect(() => {
76
- fetchContent();
45
+ setContent();
77
46
  }, []);
78
47
 
79
48
  useEffect(() => {
80
- fetchContent();
49
+ setContent();
81
50
  }, [props.symbol]);
82
51
 
83
52
  return (
84
53
  <View
54
+ {...{}}
85
55
  {...props.attributes}
86
- dataSet={{
87
- class: className,
56
+ {...{
57
+ dataSet: {
58
+ class: className(),
59
+ },
88
60
  }}
89
61
  >
90
- <RenderContentVariants
62
+ <ContentVariants
91
63
  __isNestedRender={true}
92
- apiVersion={builderContext.apiVersion}
93
- apiKey={builderContext.apiKey}
94
- context={builderContext.context}
95
- customComponents={Object.values(builderContext.registeredComponents)}
64
+ apiVersion={props.builderContext.apiVersion}
65
+ apiKey={props.builderContext.apiKey}
66
+ context={props.builderContext.context}
67
+ customComponents={Object.values(props.builderComponents)}
96
68
  data={{
97
69
  ...props.symbol?.data,
98
- ...builderContext.localState,
70
+ ...props.builderContext.localState,
99
71
  ...contentToUse?.data?.state,
100
72
  }}
101
73
  model={props.symbol?.model}
@@ -1,23 +1,20 @@
1
1
  const componentInfo = {
2
2
  name: "Text",
3
3
  static: true,
4
+ isRSC: true,
4
5
  image: "https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-text_fields-24px%20(1).svg?alt=media&token=12177b73-0ee3-42ca-98c6-0dd003de1929",
5
- inputs: [
6
- {
7
- name: "text",
8
- type: "html",
9
- required: true,
10
- autoFocus: true,
11
- bubble: true,
12
- defaultValue: "Enter some text..."
13
- }
14
- ],
6
+ inputs: [{
7
+ name: "text",
8
+ type: "html",
9
+ required: true,
10
+ autoFocus: true,
11
+ bubble: true,
12
+ defaultValue: "Enter some text..."
13
+ }],
15
14
  defaultStyles: {
16
15
  lineHeight: "normal",
17
16
  height: "auto",
18
17
  textAlign: "center"
19
18
  }
20
19
  };
21
- export {
22
- componentInfo
23
- };
20
+ export { componentInfo }
@@ -1,33 +1,27 @@
1
1
  const componentInfo = {
2
2
  name: "Form:TextArea",
3
3
  image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Ff74a2f3de58c4c3e939204e5b6b8f6c3",
4
- inputs: [
5
- {
6
- advanced: true,
7
- name: "value",
8
- type: "string"
9
- },
10
- {
11
- name: "name",
12
- type: "string",
13
- required: true,
14
- helperText: 'Every input in a form needs a unique name describing what it gets, e.g. "email"'
15
- },
16
- {
17
- name: "defaultValue",
18
- type: "string"
19
- },
20
- {
21
- name: "placeholder",
22
- type: "string",
23
- defaultValue: "Hello there"
24
- },
25
- {
26
- name: "required",
27
- type: "boolean",
28
- defaultValue: false
29
- }
30
- ],
4
+ inputs: [{
5
+ advanced: true,
6
+ name: "value",
7
+ type: "string"
8
+ }, {
9
+ name: "name",
10
+ type: "string",
11
+ required: true,
12
+ helperText: 'Every input in a form needs a unique name describing what it gets, e.g. "email"'
13
+ }, {
14
+ name: "defaultValue",
15
+ type: "string"
16
+ }, {
17
+ name: "placeholder",
18
+ type: "string",
19
+ defaultValue: "Hello there"
20
+ }, {
21
+ name: "required",
22
+ type: "boolean",
23
+ defaultValue: false
24
+ }],
31
25
  defaultStyles: {
32
26
  paddingTop: "10px",
33
27
  paddingBottom: "10px",
@@ -41,6 +35,4 @@ const componentInfo = {
41
35
  static: true,
42
36
  noWrap: true
43
37
  };
44
- export {
45
- componentInfo
46
- };
38
+ export { componentInfo }
@@ -1,4 +1,4 @@
1
- 'use client';
1
+ "use client";
2
2
  import * as React from "react";
3
3
  import {
4
4
  FlatList,
@@ -8,10 +8,12 @@ import {
8
8
  Image,
9
9
  Text,
10
10
  } from "react-native";
11
+ import { filterAttrs } from "../helpers.js";
11
12
 
12
13
  function Textarea(props) {
13
14
  return (
14
15
  <View
16
+ {...{}}
15
17
  {...props.attributes}
16
18
  placeholder={props.placeholder}
17
19
  name={props.name}