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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (288) hide show
  1. package/README.md +72 -3
  2. package/dist/sdk/blocks/columns/columns.js +5 -5
  3. package/dist/sdk/blocks/image/image.js +8 -7
  4. package/dist/sdk/blocks/symbol/symbol.js +3 -2
  5. package/dist/sdk/blocks/video/video.js +4 -1
  6. package/dist/sdk/components/render-block/block-styles.js +3 -1
  7. package/dist/sdk/components/render-block/render-block.helpers.d.ts +0 -1
  8. package/dist/sdk/components/render-block/render-block.helpers.js +8 -20
  9. package/dist/sdk/components/render-block/render-block.js +24 -15
  10. package/dist/sdk/components/render-block/render-repeated-block.js +3 -2
  11. package/dist/sdk/components/render-content/render-content.js +31 -12
  12. package/dist/sdk/components/render-content-variants/helpers.d.ts +12 -0
  13. package/dist/sdk/components/render-content-variants/helpers.js +154 -0
  14. package/dist/sdk/components/render-content-variants/render-content-variants.d.ts +5 -0
  15. package/dist/sdk/components/render-content-variants/render-content-variants.js +29 -0
  16. package/dist/sdk/components/render-inlined-styles.js +2 -2
  17. package/dist/sdk/constants/sdk-version.d.ts +1 -0
  18. package/dist/sdk/constants/sdk-version.js +1 -0
  19. package/dist/sdk/context/builder.context.js +3 -2
  20. package/dist/sdk/context/types.d.ts +17 -2
  21. package/dist/sdk/functions/evaluate.d.ts +4 -3
  22. package/dist/sdk/functions/evaluate.js +23 -2
  23. package/dist/sdk/functions/evaluate.test.d.ts +1 -0
  24. package/dist/sdk/functions/evaluate.test.js +17 -0
  25. package/dist/sdk/functions/get-block-actions-handler.d.ts +1 -1
  26. package/dist/sdk/functions/get-block-actions-handler.js +3 -1
  27. package/dist/sdk/functions/get-block-actions.d.ts +1 -1
  28. package/dist/sdk/functions/get-processed-block.d.ts +2 -2
  29. package/dist/sdk/functions/get-processed-block.js +16 -4
  30. package/dist/sdk/functions/get-processed-block.test.js +3 -1
  31. package/dist/sdk/helpers/canTrack.d.ts +1 -0
  32. package/dist/sdk/helpers/canTrack.js +2 -0
  33. package/dist/sdk/index.d.ts +1 -0
  34. package/dist/sdk/scripts/init-editing.js +2 -0
  35. package/package.json +5 -5
  36. package/CHANGELOG.md +0 -25
  37. package/packages/react/src/blocks/BaseText.tsx +0 -19
  38. package/packages/react/src/blocks/button/button.tsx +0 -45
  39. package/packages/react/src/blocks/button/component-info.ts +0 -42
  40. package/packages/react/src/blocks/columns/columns.tsx +0 -211
  41. package/packages/react/src/blocks/columns/component-info.ts +0 -254
  42. package/packages/react/src/blocks/custom-code/component-info.ts +0 -31
  43. package/packages/react/src/blocks/custom-code/custom-code.tsx +0 -76
  44. package/packages/react/src/blocks/embed/component-info.ts +0 -55
  45. package/packages/react/src/blocks/embed/embed.tsx +0 -59
  46. package/packages/react/src/blocks/embed/helpers.ts +0 -8
  47. package/packages/react/src/blocks/form/component-info.ts +0 -282
  48. package/packages/react/src/blocks/form/form.tsx +0 -320
  49. package/packages/react/src/blocks/fragment/component-info.ts +0 -10
  50. package/packages/react/src/blocks/fragment/fragment.tsx +0 -14
  51. package/packages/react/src/blocks/image/component-info.ts +0 -172
  52. package/packages/react/src/blocks/image/image.helpers.ts +0 -75
  53. package/packages/react/src/blocks/image/image.tsx +0 -144
  54. package/packages/react/src/blocks/img/component-info.ts +0 -21
  55. package/packages/react/src/blocks/img/img.tsx +0 -40
  56. package/packages/react/src/blocks/input/component-info.ts +0 -78
  57. package/packages/react/src/blocks/input/input.tsx +0 -33
  58. package/packages/react/src/blocks/raw-text/component-info.ts +0 -15
  59. package/packages/react/src/blocks/raw-text/raw-text.tsx +0 -18
  60. package/packages/react/src/blocks/section/component-info.ts +0 -50
  61. package/packages/react/src/blocks/section/section.tsx +0 -33
  62. package/packages/react/src/blocks/select/component-info.ts +0 -61
  63. package/packages/react/src/blocks/select/select.tsx +0 -35
  64. package/packages/react/src/blocks/submit-button/component-info.ts +0 -32
  65. package/packages/react/src/blocks/submit-button/submit-button.tsx +0 -17
  66. package/packages/react/src/blocks/symbol/component-info.ts +0 -43
  67. package/packages/react/src/blocks/symbol/symbol.tsx +0 -111
  68. package/packages/react/src/blocks/text/component-info.ts +0 -24
  69. package/packages/react/src/blocks/text/text.tsx +0 -20
  70. package/packages/react/src/blocks/textarea/component-info.ts +0 -48
  71. package/packages/react/src/blocks/textarea/textarea.tsx +0 -24
  72. package/packages/react/src/blocks/util.ts +0 -18
  73. package/packages/react/src/blocks/video/component-info.ts +0 -109
  74. package/packages/react/src/blocks/video/video.tsx +0 -84
  75. package/packages/react/src/components/render-block/block-styles.tsx +0 -98
  76. package/packages/react/src/components/render-block/render-block.helpers.ts +0 -138
  77. package/packages/react/src/components/render-block/render-block.tsx +0 -216
  78. package/packages/react/src/components/render-block/render-component.tsx +0 -52
  79. package/packages/react/src/components/render-block/render-repeated-block.tsx +0 -43
  80. package/packages/react/src/components/render-block/types.ts +0 -7
  81. package/packages/react/src/components/render-blocks.tsx +0 -97
  82. package/packages/react/src/components/render-content/builder-editing.tsx +0 -8
  83. package/packages/react/src/components/render-content/components/render-styles.helpers.ts +0 -79
  84. package/packages/react/src/components/render-content/components/render-styles.tsx +0 -45
  85. package/packages/react/src/components/render-content/index.ts +0 -1
  86. package/packages/react/src/components/render-content/render-content.helpers.ts +0 -48
  87. package/packages/react/src/components/render-content/render-content.tsx +0 -410
  88. package/packages/react/src/components/render-content/render-content.types.ts +0 -33
  89. package/packages/react/src/components/render-inlined-styles.tsx +0 -36
  90. package/packages/react/src/constants/builder-registered-components.ts +0 -42
  91. package/packages/react/src/constants/device-sizes.ts +0 -65
  92. package/packages/react/src/constants/target.ts +0 -2
  93. package/packages/react/src/context/builder.context.ts +0 -12
  94. package/packages/react/src/context/types.ts +0 -26
  95. package/packages/react/src/functions/camel-to-kebab-case.ts +0 -2
  96. package/packages/react/src/functions/evaluate.ts +0 -57
  97. package/packages/react/src/functions/event-handler-name.ts +0 -6
  98. package/packages/react/src/functions/extract-text-styles.ts +0 -39
  99. package/packages/react/src/functions/fast-clone.ts +0 -5
  100. package/packages/react/src/functions/get-block-actions-handler.ts +0 -20
  101. package/packages/react/src/functions/get-block-actions.ts +0 -25
  102. package/packages/react/src/functions/get-block-component-options.ts +0 -12
  103. package/packages/react/src/functions/get-block-properties.ts +0 -75
  104. package/packages/react/src/functions/get-builder-search-params/fn.test.ts +0 -19
  105. package/packages/react/src/functions/get-builder-search-params/index.ts +0 -50
  106. package/packages/react/src/functions/get-content/ab-testing.ts +0 -132
  107. package/packages/react/src/functions/get-content/generate-content-url.test.ts +0 -95
  108. package/packages/react/src/functions/get-content/generate-content-url.ts +0 -59
  109. package/packages/react/src/functions/get-content/index.ts +0 -62
  110. package/packages/react/src/functions/get-content/types.ts +0 -53
  111. package/packages/react/src/functions/get-fetch.ts +0 -18
  112. package/packages/react/src/functions/get-global-this.ts +0 -17
  113. package/packages/react/src/functions/get-processed-block.test.ts +0 -33
  114. package/packages/react/src/functions/get-processed-block.ts +0 -54
  115. package/packages/react/src/functions/get-react-native-block-styles.ts +0 -33
  116. package/packages/react/src/functions/if-target.ts +0 -20
  117. package/packages/react/src/functions/is-browser.ts +0 -3
  118. package/packages/react/src/functions/is-editing.ts +0 -10
  119. package/packages/react/src/functions/is-iframe.ts +0 -5
  120. package/packages/react/src/functions/is-previewing.ts +0 -14
  121. package/packages/react/src/functions/on-change.test.ts +0 -23
  122. package/packages/react/src/functions/on-change.ts +0 -29
  123. package/packages/react/src/functions/register-component.ts +0 -50
  124. package/packages/react/src/functions/register.ts +0 -46
  125. package/packages/react/src/functions/sanitize-react-native-block-styles.ts +0 -65
  126. package/packages/react/src/functions/set-editor-settings.ts +0 -16
  127. package/packages/react/src/functions/set.test.ts +0 -19
  128. package/packages/react/src/functions/set.ts +0 -26
  129. package/packages/react/src/functions/track/helpers.ts +0 -67
  130. package/packages/react/src/functions/track/index.ts +0 -136
  131. package/packages/react/src/functions/track/interaction.ts +0 -80
  132. package/packages/react/src/functions/transform-block-properties.ts +0 -3
  133. package/packages/react/src/functions/transform-block.ts +0 -6
  134. package/packages/react/src/helpers/ab-tests.ts +0 -22
  135. package/packages/react/src/helpers/cookie.ts +0 -107
  136. package/packages/react/src/helpers/css.ts +0 -42
  137. package/packages/react/src/helpers/flatten.ts +0 -24
  138. package/packages/react/src/helpers/localStorage.ts +0 -40
  139. package/packages/react/src/helpers/logger.ts +0 -6
  140. package/packages/react/src/helpers/nullable.ts +0 -4
  141. package/packages/react/src/helpers/sessionId.ts +0 -38
  142. package/packages/react/src/helpers/time.ts +0 -4
  143. package/packages/react/src/helpers/url.test.ts +0 -23
  144. package/packages/react/src/helpers/url.ts +0 -16
  145. package/packages/react/src/helpers/uuid.ts +0 -17
  146. package/packages/react/src/helpers/visitorId.ts +0 -40
  147. package/packages/react/src/index-helpers/blocks-exports.ts +0 -10
  148. package/packages/react/src/index-helpers/top-of-file.ts +0 -4
  149. package/packages/react/src/index.ts +0 -14
  150. package/packages/react/src/scripts/init-editing.ts +0 -123
  151. package/packages/react/src/types/api-version.ts +0 -2
  152. package/packages/react/src/types/builder-block.ts +0 -69
  153. package/packages/react/src/types/builder-content.ts +0 -46
  154. package/packages/react/src/types/can-track.ts +0 -3
  155. package/packages/react/src/types/components.ts +0 -117
  156. package/packages/react/src/types/deep-partial.ts +0 -7
  157. package/packages/react/src/types/element.ts +0 -60
  158. package/packages/react/src/types/input.ts +0 -125
  159. package/packages/react/src/types/targets.ts +0 -6
  160. package/packages/react/src/types/typescript.ts +0 -7
  161. package/packages/rsc/src/blocks/BaseText.jsx +0 -12
  162. package/packages/rsc/src/blocks/button/button.jsx +0 -37
  163. package/packages/rsc/src/blocks/button/component-info.js +0 -40
  164. package/packages/rsc/src/blocks/columns/columns.jsx +0 -172
  165. package/packages/rsc/src/blocks/columns/component-info.js +0 -241
  166. package/packages/rsc/src/blocks/custom-code/component-info.js +0 -30
  167. package/packages/rsc/src/blocks/custom-code/custom-code.jsx +0 -57
  168. package/packages/rsc/src/blocks/embed/component-info.js +0 -43
  169. package/packages/rsc/src/blocks/embed/embed.jsx +0 -45
  170. package/packages/rsc/src/blocks/embed/helpers.js +0 -9
  171. package/packages/rsc/src/blocks/form/component-info.js +0 -261
  172. package/packages/rsc/src/blocks/form/form.jsx +0 -260
  173. package/packages/rsc/src/blocks/fragment/component-info.js +0 -10
  174. package/packages/rsc/src/blocks/fragment/fragment.jsx +0 -9
  175. package/packages/rsc/src/blocks/image/component-info.js +0 -150
  176. package/packages/rsc/src/blocks/image/image.helpers.js +0 -48
  177. package/packages/rsc/src/blocks/image/image.jsx +0 -122
  178. package/packages/rsc/src/blocks/img/component-info.js +0 -19
  179. package/packages/rsc/src/blocks/img/img.jsx +0 -21
  180. package/packages/rsc/src/blocks/input/component-info.js +0 -73
  181. package/packages/rsc/src/blocks/input/input.jsx +0 -23
  182. package/packages/rsc/src/blocks/raw-text/component-info.js +0 -15
  183. package/packages/rsc/src/blocks/raw-text/raw-text.jsx +0 -14
  184. package/packages/rsc/src/blocks/section/component-info.js +0 -48
  185. package/packages/rsc/src/blocks/section/section.jsx +0 -27
  186. package/packages/rsc/src/blocks/select/component-info.js +0 -58
  187. package/packages/rsc/src/blocks/select/select.jsx +0 -24
  188. package/packages/rsc/src/blocks/submit-button/component-info.js +0 -27
  189. package/packages/rsc/src/blocks/submit-button/submit-button.jsx +0 -13
  190. package/packages/rsc/src/blocks/symbol/component-info.js +0 -42
  191. package/packages/rsc/src/blocks/symbol/symbol.jsx +0 -89
  192. package/packages/rsc/src/blocks/text/component-info.js +0 -23
  193. package/packages/rsc/src/blocks/text/text.jsx +0 -17
  194. package/packages/rsc/src/blocks/textarea/component-info.js +0 -46
  195. package/packages/rsc/src/blocks/textarea/textarea.jsx +0 -17
  196. package/packages/rsc/src/blocks/util.js +0 -8
  197. package/packages/rsc/src/blocks/video/component-info.js +0 -105
  198. package/packages/rsc/src/blocks/video/video.jsx +0 -63
  199. package/packages/rsc/src/components/render-block/block-styles.jsx +0 -88
  200. package/packages/rsc/src/components/render-block/render-block.helpers.js +0 -129
  201. package/packages/rsc/src/components/render-block/render-block.jsx +0 -201
  202. package/packages/rsc/src/components/render-block/render-component.jsx +0 -39
  203. package/packages/rsc/src/components/render-block/render-repeated-block.jsx +0 -27
  204. package/packages/rsc/src/components/render-block/types.js +0 -0
  205. package/packages/rsc/src/components/render-blocks.jsx +0 -92
  206. package/packages/rsc/src/components/render-content/builder-editing.jsx +0 -64
  207. package/packages/rsc/src/components/render-content/components/render-styles.helpers.js +0 -57
  208. package/packages/rsc/src/components/render-content/components/render-styles.jsx +0 -39
  209. package/packages/rsc/src/components/render-content/index.js +0 -4
  210. package/packages/rsc/src/components/render-content/render-content.helpers.js +0 -48
  211. package/packages/rsc/src/components/render-content/render-content.jsx +0 -253
  212. package/packages/rsc/src/components/render-content/render-content.types.js +0 -0
  213. package/packages/rsc/src/components/render-inlined-styles.jsx +0 -33
  214. package/packages/rsc/src/constants/builder-registered-components.js +0 -54
  215. package/packages/rsc/src/constants/device-sizes.js +0 -48
  216. package/packages/rsc/src/constants/target.js +0 -4
  217. package/packages/rsc/src/context/builder.context.js +0 -14
  218. package/packages/rsc/src/context/types.js +0 -0
  219. package/packages/rsc/src/functions/camel-to-kebab-case.js +0 -4
  220. package/packages/rsc/src/functions/evaluate.js +0 -6
  221. package/packages/rsc/src/functions/event-handler-name.js +0 -7
  222. package/packages/rsc/src/functions/extract-text-styles.js +0 -22
  223. package/packages/rsc/src/functions/fast-clone.js +0 -4
  224. package/packages/rsc/src/functions/get-block-actions-handler.js +0 -11
  225. package/packages/rsc/src/functions/get-block-actions.js +0 -18
  226. package/packages/rsc/src/functions/get-block-component-options.js +0 -28
  227. package/packages/rsc/src/functions/get-block-properties.js +0 -53
  228. package/packages/rsc/src/functions/get-builder-search-params/fn.test.js +0 -13
  229. package/packages/rsc/src/functions/get-builder-search-params/index.js +0 -38
  230. package/packages/rsc/src/functions/get-content/ab-testing.js +0 -99
  231. package/packages/rsc/src/functions/get-content/generate-content-url.js +0 -60
  232. package/packages/rsc/src/functions/get-content/generate-content-url.test.js +0 -82
  233. package/packages/rsc/src/functions/get-content/index.js +0 -83
  234. package/packages/rsc/src/functions/get-content/types.js +0 -0
  235. package/packages/rsc/src/functions/get-fetch.js +0 -14
  236. package/packages/rsc/src/functions/get-global-this.js +0 -18
  237. package/packages/rsc/src/functions/get-processed-block.js +0 -59
  238. package/packages/rsc/src/functions/get-processed-block.test.js +0 -32
  239. package/packages/rsc/src/functions/get-react-native-block-styles.js +0 -33
  240. package/packages/rsc/src/functions/if-target.js +0 -15
  241. package/packages/rsc/src/functions/is-browser.js +0 -6
  242. package/packages/rsc/src/functions/is-editing.js +0 -8
  243. package/packages/rsc/src/functions/is-iframe.js +0 -7
  244. package/packages/rsc/src/functions/is-previewing.js +0 -14
  245. package/packages/rsc/src/functions/on-change.js +0 -27
  246. package/packages/rsc/src/functions/on-change.test.js +0 -19
  247. package/packages/rsc/src/functions/register-component.js +0 -68
  248. package/packages/rsc/src/functions/register.js +0 -29
  249. package/packages/rsc/src/functions/sanitize-react-native-block-styles.js +0 -66
  250. package/packages/rsc/src/functions/set-editor-settings.js +0 -15
  251. package/packages/rsc/src/functions/set.js +0 -11
  252. package/packages/rsc/src/functions/set.test.js +0 -16
  253. package/packages/rsc/src/functions/track/helpers.js +0 -50
  254. package/packages/rsc/src/functions/track/index.js +0 -129
  255. package/packages/rsc/src/functions/track/interaction.js +0 -53
  256. package/packages/rsc/src/functions/transform-block-properties.js +0 -6
  257. package/packages/rsc/src/functions/transform-block.js +0 -6
  258. package/packages/rsc/src/helpers/ab-tests.js +0 -16
  259. package/packages/rsc/src/helpers/cookie.js +0 -81
  260. package/packages/rsc/src/helpers/css.js +0 -34
  261. package/packages/rsc/src/helpers/flatten.js +0 -34
  262. package/packages/rsc/src/helpers/localStorage.js +0 -35
  263. package/packages/rsc/src/helpers/logger.js +0 -9
  264. package/packages/rsc/src/helpers/nullable.js +0 -4
  265. package/packages/rsc/src/helpers/sessionId.js +0 -52
  266. package/packages/rsc/src/helpers/time.js +0 -5
  267. package/packages/rsc/src/helpers/url.js +0 -13
  268. package/packages/rsc/src/helpers/url.test.js +0 -21
  269. package/packages/rsc/src/helpers/uuid.js +0 -13
  270. package/packages/rsc/src/helpers/visitorId.js +0 -34
  271. package/packages/rsc/src/index-helpers/blocks-exports.js +0 -22
  272. package/packages/rsc/src/index-helpers/top-of-file.js +0 -2
  273. package/packages/rsc/src/index.js +0 -13
  274. package/packages/rsc/src/scripts/init-editing.js +0 -93
  275. package/packages/rsc/src/types/api-version.js +0 -4
  276. package/packages/rsc/src/types/builder-block.js +0 -0
  277. package/packages/rsc/src/types/builder-content.js +0 -0
  278. package/packages/rsc/src/types/can-track.js +0 -0
  279. package/packages/rsc/src/types/components.js +0 -0
  280. package/packages/rsc/src/types/deep-partial.js +0 -0
  281. package/packages/rsc/src/types/element.js +0 -0
  282. package/packages/rsc/src/types/input.js +0 -0
  283. package/packages/rsc/src/types/targets.js +0 -0
  284. package/packages/rsc/src/types/typescript.js +0 -0
  285. package/tsconfig.json +0 -28
  286. package/tsconfig.sdk.json +0 -10
  287. package/tsconfig.server.json +0 -10
  288. package/vite.config.ts +0 -91
@@ -1,14 +0,0 @@
1
- import { getGlobalThis } from "./get-global-this.js";
2
- function getFetch() {
3
- const globalFetch = getGlobalThis().fetch;
4
- if (typeof globalFetch === "undefined") {
5
- console.warn(`Builder SDK could not find a global fetch function. Make sure you have a polyfill for fetch in your project.
6
- For more information, read https://github.com/BuilderIO/this-package-uses-fetch`);
7
- throw new Error("Builder SDK could not find a global `fetch` function");
8
- }
9
- return globalFetch;
10
- }
11
- const fetch = getFetch();
12
- export {
13
- fetch
14
- };
@@ -1,18 +0,0 @@
1
- function getGlobalThis() {
2
- if (typeof globalThis !== "undefined") {
3
- return globalThis;
4
- }
5
- if (typeof window !== "undefined") {
6
- return window;
7
- }
8
- if (typeof global !== "undefined") {
9
- return global;
10
- }
11
- if (typeof self !== "undefined") {
12
- return self;
13
- }
14
- return globalThis;
15
- }
16
- export {
17
- getGlobalThis
18
- };
@@ -1,59 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- import { evaluate } from "./evaluate.js";
21
- import { fastClone } from "./fast-clone.js";
22
- import { set } from "./set.js";
23
- import { transformBlock } from "./transform-block.js";
24
- const evaluateBindings = ({
25
- block,
26
- context,
27
- state
28
- }) => {
29
- if (!block.bindings) {
30
- return block;
31
- }
32
- const copy = fastClone(block);
33
- const copied = __spreadProps(__spreadValues({}, copy), {
34
- properties: __spreadValues({}, copy.properties),
35
- actions: __spreadValues({}, copy.actions)
36
- });
37
- for (const binding in block.bindings) {
38
- const expression = block.bindings[binding];
39
- const value = evaluate({ code: expression, state, context });
40
- set(copied, binding, value);
41
- }
42
- return copied;
43
- };
44
- function getProcessedBlock({
45
- block,
46
- context,
47
- shouldEvaluateBindings,
48
- state
49
- }) {
50
- const transformedBlock = transformBlock(block);
51
- if (shouldEvaluateBindings) {
52
- return evaluateBindings({ block: transformedBlock, state, context });
53
- } else {
54
- return transformedBlock;
55
- }
56
- }
57
- export {
58
- getProcessedBlock
59
- };
@@ -1,32 +0,0 @@
1
- import { getProcessedBlock } from "./get-processed-block.js";
2
- test("Can process bindings", () => {
3
- var _a, _b, _c, _d, _e, _f;
4
- const block = {
5
- "@type": "@builder.io/sdk:Element",
6
- properties: {
7
- foo: "bar"
8
- },
9
- bindings: {
10
- "properties.foo": '"baz"',
11
- "responsiveStyles.large.zIndex": "1 + 1",
12
- "properties.test": "state.test",
13
- "properties.block": `
14
- const foo = 'bar';
15
- return foo;
16
- `,
17
- "properties.isEditing": "builder.isEditing"
18
- }
19
- };
20
- const processed = getProcessedBlock({
21
- block,
22
- context: {},
23
- state: { test: "hello" },
24
- shouldEvaluateBindings: true
25
- });
26
- expect(processed).not.toEqual(block);
27
- expect((_a = processed.properties) == null ? void 0 : _a.foo).toEqual("baz");
28
- expect((_b = processed.properties) == null ? void 0 : _b.test).toEqual("hello");
29
- expect((_c = processed.properties) == null ? void 0 : _c.block).toEqual("bar");
30
- expect((_d = processed.properties) == null ? void 0 : _d.isEditing).toEqual(false);
31
- expect((_f = (_e = processed.responsiveStyles) == null ? void 0 : _e.large) == null ? void 0 : _f.zIndex).toEqual(2);
32
- });
@@ -1,33 +0,0 @@
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, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __spreadValues = (a, b) => {
7
- for (var prop in b || (b = {}))
8
- if (__hasOwnProp.call(b, prop))
9
- __defNormalProp(a, prop, b[prop]);
10
- if (__getOwnPropSymbols)
11
- for (var prop of __getOwnPropSymbols(b)) {
12
- if (__propIsEnum.call(b, prop))
13
- __defNormalProp(a, prop, b[prop]);
14
- }
15
- return a;
16
- };
17
- import { sanitizeReactNativeBlockStyles } from "./sanitize-react-native-block-styles.js";
18
- function getReactNativeBlockStyles({
19
- block,
20
- context,
21
- blockStyles
22
- }) {
23
- const responsiveStyles = block.responsiveStyles;
24
- if (!responsiveStyles) {
25
- return {};
26
- }
27
- const styles = __spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues({}, context.inheritedStyles), responsiveStyles.large || {}), responsiveStyles.medium || {}), responsiveStyles.small || {}), blockStyles);
28
- const newStyles = sanitizeReactNativeBlockStyles(styles);
29
- return newStyles;
30
- }
31
- export {
32
- getReactNativeBlockStyles
33
- };
@@ -1,15 +0,0 @@
1
- import { TARGET } from "../constants/target.js";
2
- function ifTarget({
3
- targets,
4
- doThing,
5
- elseThing
6
- }) {
7
- if (TARGET && targets.includes(TARGET)) {
8
- return doThing();
9
- } else {
10
- return elseThing == null ? void 0 : elseThing();
11
- }
12
- }
13
- export {
14
- ifTarget
15
- };
@@ -1,6 +0,0 @@
1
- function isBrowser() {
2
- return typeof window !== "undefined" && typeof document !== "undefined";
3
- }
4
- export {
5
- isBrowser
6
- };
@@ -1,8 +0,0 @@
1
- import { TARGET } from "../constants/target.js";
2
- import { isIframe } from "./is-iframe.js";
3
- function isEditing() {
4
- return isIframe() && (TARGET === "reactNative" || window.location.search.indexOf("builder.frameEditing=") !== -1);
5
- }
6
- export {
7
- isEditing
8
- };
@@ -1,7 +0,0 @@
1
- import { isBrowser } from "./is-browser.js";
2
- function isIframe() {
3
- return isBrowser() && window.self !== window.top;
4
- }
5
- export {
6
- isIframe
7
- };
@@ -1,14 +0,0 @@
1
- import { isBrowser } from "./is-browser.js";
2
- import { isEditing } from "./is-editing.js";
3
- function isPreviewing() {
4
- if (!isBrowser()) {
5
- return false;
6
- }
7
- if (isEditing()) {
8
- return false;
9
- }
10
- return Boolean(location.search.indexOf("builder.preview=") !== -1);
11
- }
12
- export {
13
- isPreviewing
14
- };
@@ -1,27 +0,0 @@
1
- const onChangeProxySymbol = Symbol("onChangeProxySymbol");
2
- function onChange(obj, cb) {
3
- return new Proxy(obj, {
4
- get(target, key) {
5
- if (key === onChangeProxySymbol) {
6
- return true;
7
- }
8
- const value = Reflect.get(target, key);
9
- if (value && typeof value === "object") {
10
- if (value[onChangeProxySymbol]) {
11
- return value;
12
- }
13
- return onChange(value, cb);
14
- }
15
- return value;
16
- },
17
- set(target, key, value) {
18
- const returnValue = Reflect.set(target, key, value);
19
- cb();
20
- return returnValue;
21
- }
22
- });
23
- }
24
- export {
25
- onChange,
26
- onChangeProxySymbol
27
- };
@@ -1,19 +0,0 @@
1
- import { onChange } from "./on-change.js";
2
- test("onChange can observe a shallow change", () => {
3
- let changeHappend = false;
4
- const obj = onChange({ foo: "hi" }, () => changeHappend = true);
5
- obj.foo = "yo";
6
- expect(changeHappend).toBe(true);
7
- });
8
- test("onChange can observe a deep change", () => {
9
- let changeHappend = false;
10
- const obj = onChange({ foo: { bar: "hi" } }, () => changeHappend = true);
11
- obj.foo.bar = "yo";
12
- expect(changeHappend).toBe(true);
13
- });
14
- test("Smoke test: callback is not fired if no properties updated", () => {
15
- let changeHappend = false;
16
- const obj = onChange({ foo: { bar: "hi" } }, () => changeHappend = true);
17
- obj.foo.bar;
18
- expect(changeHappend).toBe(false);
19
- });
@@ -1,68 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- import { serializeFn } from "../blocks/util.js";
33
- import { fastClone } from "./fast-clone.js";
34
- const components = [];
35
- function registerComponent(component, info) {
36
- components.push(__spreadValues({ component }, info));
37
- console.warn("registerComponent is deprecated. Use the `customComponents` prop in RenderContent instead to provide your custom components to the builder SDK.");
38
- return component;
39
- }
40
- const createRegisterComponentMessage = (_a) => {
41
- var _b = _a, {
42
- component: _
43
- } = _b, info = __objRest(_b, [
44
- "component"
45
- ]);
46
- return {
47
- type: "builder.registerComponent",
48
- data: prepareComponentInfoToSend(info)
49
- };
50
- };
51
- const serializeValue = (value) => typeof value === "function" ? serializeFn(value) : fastClone(value);
52
- const prepareComponentInfoToSend = (_c) => {
53
- var _d = _c, {
54
- inputs
55
- } = _d, info = __objRest(_d, [
56
- "inputs"
57
- ]);
58
- return __spreadProps(__spreadValues({}, fastClone(info)), {
59
- inputs: inputs == null ? void 0 : inputs.map((input) => Object.entries(input).reduce((acc, [key, value]) => __spreadProps(__spreadValues({}, acc), {
60
- [key]: serializeValue(value)
61
- }), {}))
62
- });
63
- };
64
- export {
65
- components,
66
- createRegisterComponentMessage,
67
- registerComponent
68
- };
@@ -1,29 +0,0 @@
1
- import { isBrowser } from "./is-browser.js";
2
- const registry = {};
3
- function register(type, info) {
4
- let typeList = registry[type];
5
- if (!typeList) {
6
- typeList = registry[type] = [];
7
- }
8
- typeList.push(info);
9
- if (isBrowser()) {
10
- const message = {
11
- type: "builder.register",
12
- data: {
13
- type,
14
- info
15
- }
16
- };
17
- try {
18
- parent.postMessage(message, "*");
19
- if (parent !== window) {
20
- window.postMessage(message, "*");
21
- }
22
- } catch (err) {
23
- console.debug("Could not postmessage", err);
24
- }
25
- }
26
- }
27
- export {
28
- register
29
- };
@@ -1,66 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- const propertiesThatMustBeNumber = new Set(["lineHeight"]);
21
- const displayValues = new Set(["flex", "none"]);
22
- const SHOW_WARNINGS = false;
23
- const normalizeNumber = (value) => {
24
- if (Number.isNaN(value)) {
25
- return void 0;
26
- } else if (value < 0) {
27
- return 0;
28
- } else {
29
- return value;
30
- }
31
- };
32
- const sanitizeReactNativeBlockStyles = (styles) => {
33
- return Object.keys(styles).reduce((acc, key) => {
34
- const propertyValue = styles[key];
35
- if (key === "display" && !displayValues.has(propertyValue)) {
36
- if (SHOW_WARNINGS) {
37
- console.warn(`Style value for key "display" must be "flex" or "none" but had ${propertyValue}`);
38
- }
39
- return acc;
40
- }
41
- if (propertiesThatMustBeNumber.has(key) && typeof propertyValue !== "number") {
42
- if (SHOW_WARNINGS) {
43
- console.warn(`Style key ${key} must be a number, but had value \`${styles[key]}\``);
44
- }
45
- return acc;
46
- }
47
- if (typeof propertyValue === "string") {
48
- const isPixelUnit = propertyValue.match(/^-?(\d*)(\.?)(\d*)*px$/);
49
- if (isPixelUnit) {
50
- const newValue = parseFloat(propertyValue);
51
- const normalizedValue = normalizeNumber(newValue);
52
- if (normalizedValue) {
53
- return __spreadProps(__spreadValues({}, acc), { [key]: normalizedValue });
54
- } else {
55
- return acc;
56
- }
57
- } else if (propertyValue === "0") {
58
- return __spreadProps(__spreadValues({}, acc), { [key]: 0 });
59
- }
60
- }
61
- return __spreadProps(__spreadValues({}, acc), { [key]: propertyValue });
62
- }, {});
63
- };
64
- export {
65
- sanitizeReactNativeBlockStyles
66
- };
@@ -1,15 +0,0 @@
1
- import { isBrowser } from "./is-browser.js";
2
- const settings = {};
3
- function setEditorSettings(newSettings) {
4
- if (isBrowser()) {
5
- Object.assign(settings, newSettings);
6
- const message = {
7
- type: "builder.settingsChange",
8
- data: settings
9
- };
10
- parent.postMessage(message, "*");
11
- }
12
- }
13
- export {
14
- setEditorSettings
15
- };
@@ -1,11 +0,0 @@
1
- const set = (obj, _path, value) => {
2
- if (Object(obj) !== obj) {
3
- return obj;
4
- }
5
- const path = Array.isArray(_path) ? _path : _path.toString().match(/[^.[\]]+/g);
6
- path.slice(0, -1).reduce((a, c, i) => Object(a[c]) === a[c] ? a[c] : a[c] = Math.abs(Number(path[i + 1])) >> 0 === +path[i + 1] ? [] : {}, obj)[path[path.length - 1]] = value;
7
- return obj;
8
- };
9
- export {
10
- set
11
- };
@@ -1,16 +0,0 @@
1
- import { set } from "./set.js";
2
- test("can shallow set a property", () => {
3
- const obj = { foo: "bar" };
4
- set(obj, "foo", "baz");
5
- expect(obj.foo).toBe("baz");
6
- });
7
- test("can deeply set a property", () => {
8
- const obj = { foo: "bar" };
9
- set(obj, "foo.bar", "baz");
10
- expect(obj.foo.bar).toBe("baz");
11
- });
12
- test("can deeply create arrays", () => {
13
- const obj = { foo: "bar" };
14
- set(obj, "foo.bar.0", "hi");
15
- expect(obj.foo.bar).toEqual(["hi"]);
16
- });
@@ -1,50 +0,0 @@
1
- import { TARGET } from "../../constants/target";
2
- import { isBrowser } from "../is-browser";
3
- const getLocation = () => {
4
- if (TARGET === "reactNative") {
5
- return null;
6
- } else if (isBrowser()) {
7
- const parsedLocation = new URL(location.href);
8
- if (parsedLocation.pathname === "") {
9
- parsedLocation.pathname = "/";
10
- }
11
- return parsedLocation;
12
- } else {
13
- console.warn("Cannot get location for tracking in non-browser environment");
14
- return null;
15
- }
16
- };
17
- const getUserAgent = () => typeof navigator === "object" && navigator.userAgent || "";
18
- const getUserAttributes = () => {
19
- const userAgent = getUserAgent();
20
- const isMobile = {
21
- Android() {
22
- return userAgent.match(/Android/i);
23
- },
24
- BlackBerry() {
25
- return userAgent.match(/BlackBerry/i);
26
- },
27
- iOS() {
28
- return userAgent.match(/iPhone|iPod/i);
29
- },
30
- Opera() {
31
- return userAgent.match(/Opera Mini/i);
32
- },
33
- Windows() {
34
- return userAgent.match(/IEMobile/i) || userAgent.match(/WPDesktop/i);
35
- },
36
- any() {
37
- return isMobile.Android() || isMobile.BlackBerry() || isMobile.iOS() || isMobile.Opera() || isMobile.Windows() || TARGET === "reactNative";
38
- }
39
- };
40
- const isTablet = userAgent.match(/Tablet|iPad/i);
41
- const url = getLocation();
42
- return {
43
- urlPath: url == null ? void 0 : url.pathname,
44
- host: (url == null ? void 0 : url.host) || (url == null ? void 0 : url.hostname),
45
- device: isTablet ? "tablet" : isMobile.any() ? "mobile" : "desktop"
46
- };
47
- };
48
- export {
49
- getUserAttributes
50
- };
@@ -1,129 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- var __async = (__this, __arguments, generator) => {
33
- return new Promise((resolve, reject) => {
34
- var fulfilled = (value) => {
35
- try {
36
- step(generator.next(value));
37
- } catch (e) {
38
- reject(e);
39
- }
40
- };
41
- var rejected = (value) => {
42
- try {
43
- step(generator.throw(value));
44
- } catch (e) {
45
- reject(e);
46
- }
47
- };
48
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
49
- step((generator = generator.apply(__this, __arguments)).next());
50
- });
51
- };
52
- import { TARGET } from "../../constants/target.js";
53
- import { logger } from "../../helpers/logger.js";
54
- import { getSessionId } from "../../helpers/sessionId.js";
55
- import { getVisitorId } from "../../helpers/visitorId.js";
56
- import { isBrowser } from "../is-browser.js";
57
- import { isEditing } from "../is-editing.js";
58
- import { getUserAttributes } from "./helpers.js";
59
- const getTrackingEventData = (_0) => __async(void 0, [_0], function* ({
60
- canTrack
61
- }) {
62
- if (!canTrack) {
63
- return { visitorId: void 0, sessionId: void 0 };
64
- }
65
- const sessionId = yield getSessionId({ canTrack });
66
- const visitorId = getVisitorId({ canTrack });
67
- return {
68
- sessionId,
69
- visitorId
70
- };
71
- });
72
- const createEvent = (_a) => __async(void 0, null, function* () {
73
- var _b = _a, {
74
- type: eventType,
75
- canTrack,
76
- apiKey,
77
- metadata
78
- } = _b, properties = __objRest(_b, [
79
- "type",
80
- "canTrack",
81
- "apiKey",
82
- "metadata"
83
- ]);
84
- return {
85
- type: eventType,
86
- data: __spreadProps(__spreadValues(__spreadProps(__spreadValues({}, properties), {
87
- metadata: __spreadValues({
88
- url: location.href
89
- }, metadata)
90
- }), yield getTrackingEventData({ canTrack })), {
91
- userAttributes: getUserAttributes(),
92
- ownerId: apiKey
93
- })
94
- };
95
- });
96
- function _track(eventProps) {
97
- return __async(this, null, function* () {
98
- if (!eventProps.apiKey) {
99
- logger.error("Missing API key for track call. Please provide your API key.");
100
- return;
101
- }
102
- if (!eventProps.canTrack) {
103
- return;
104
- }
105
- if (isEditing()) {
106
- return;
107
- }
108
- if (!(isBrowser() || TARGET === "reactNative")) {
109
- return;
110
- }
111
- return fetch(`https://builder.io/api/v1/track`, {
112
- method: "POST",
113
- body: JSON.stringify({
114
- events: [yield createEvent(eventProps)]
115
- }),
116
- headers: {
117
- "content-type": "application/json"
118
- },
119
- mode: "cors"
120
- }).catch((err) => {
121
- console.error("Failed to track: ", err);
122
- });
123
- });
124
- }
125
- const track = (args) => _track(__spreadProps(__spreadValues({}, args), { canTrack: true }));
126
- export {
127
- _track,
128
- track
129
- };