@builder.io/sdk-react-native 2.0.26 → 2.0.28

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 (53) hide show
  1. package/lib/browser/commonjs/blocks/columns/columns.js +19 -12
  2. package/lib/browser/commonjs/blocks/columns/columns.js.map +1 -1
  3. package/lib/browser/commonjs/constants/sdk-version.js +1 -1
  4. package/lib/browser/commonjs/functions/evaluate/node-runtime/node-runtime.js +3 -3
  5. package/lib/browser/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  6. package/lib/browser/commonjs/functions/evaluate/node-runtime/setIvm.js +13 -0
  7. package/lib/browser/commonjs/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  8. package/lib/browser/module/blocks/columns/columns.js +18 -11
  9. package/lib/browser/module/blocks/columns/columns.js.map +1 -1
  10. package/lib/browser/module/constants/sdk-version.js +1 -1
  11. package/lib/browser/module/functions/evaluate/node-runtime/node-runtime.js +3 -3
  12. package/lib/browser/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  13. package/lib/browser/module/functions/evaluate/node-runtime/setIvm.js +2 -0
  14. package/lib/browser/module/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  15. package/lib/browser/typescript/blocks/columns/columns.d.ts.map +1 -1
  16. package/lib/browser/typescript/constants/sdk-version.d.ts +1 -1
  17. package/lib/edge/commonjs/blocks/columns/columns.js +19 -12
  18. package/lib/edge/commonjs/blocks/columns/columns.js.map +1 -1
  19. package/lib/edge/commonjs/constants/sdk-version.js +1 -1
  20. package/lib/edge/commonjs/functions/evaluate/node-runtime/node-runtime.js +3 -3
  21. package/lib/edge/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  22. package/lib/edge/commonjs/functions/evaluate/node-runtime/setIvm.js +13 -0
  23. package/lib/edge/commonjs/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  24. package/lib/edge/module/blocks/columns/columns.js +18 -11
  25. package/lib/edge/module/blocks/columns/columns.js.map +1 -1
  26. package/lib/edge/module/constants/sdk-version.js +1 -1
  27. package/lib/edge/module/functions/evaluate/node-runtime/node-runtime.js +3 -3
  28. package/lib/edge/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  29. package/lib/edge/module/functions/evaluate/node-runtime/setIvm.js +2 -0
  30. package/lib/edge/module/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  31. package/lib/edge/typescript/blocks/columns/columns.d.ts.map +1 -1
  32. package/lib/edge/typescript/constants/sdk-version.d.ts +1 -1
  33. package/lib/node/commonjs/blocks/columns/columns.js +19 -12
  34. package/lib/node/commonjs/blocks/columns/columns.js.map +1 -1
  35. package/lib/node/commonjs/constants/sdk-version.js +1 -1
  36. package/lib/node/commonjs/functions/evaluate/node-runtime/node-runtime.js +3 -3
  37. package/lib/node/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  38. package/lib/node/commonjs/functions/evaluate/node-runtime/setIvm.js +13 -0
  39. package/lib/node/commonjs/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  40. package/lib/node/module/blocks/columns/columns.js +18 -11
  41. package/lib/node/module/blocks/columns/columns.js.map +1 -1
  42. package/lib/node/module/constants/sdk-version.js +1 -1
  43. package/lib/node/module/functions/evaluate/node-runtime/node-runtime.js +3 -3
  44. package/lib/node/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
  45. package/lib/node/module/functions/evaluate/node-runtime/setIvm.js +2 -0
  46. package/lib/node/module/functions/evaluate/node-runtime/setIvm.js.map +1 -0
  47. package/lib/node/typescript/blocks/columns/columns.d.ts.map +1 -1
  48. package/lib/node/typescript/constants/sdk-version.d.ts +1 -1
  49. package/package.json +1 -1
  50. package/src/blocks/columns/columns.tsx +19 -18
  51. package/src/constants/sdk-version.ts +1 -1
  52. package/src/functions/evaluate/node-runtime/node-runtime.ts +3 -3
  53. package/src/functions/evaluate/node-runtime/setIvm.ts +1 -0
@@ -13,7 +13,6 @@ import {
13
13
  Button,
14
14
  Linking,
15
15
  } from "react-native";
16
- import { useState } from "react";
17
16
 
18
17
  type CSSVal = string | number;
19
18
  import Blocks from "../../components/blocks/blocks";
@@ -31,27 +30,29 @@ import type { Column, ColumnProps } from "./columns.types";
31
30
  import { getColumnsClass } from "./helpers";
32
31
 
33
32
  function Columns(props: ColumnProps) {
34
- const [gutterSize, setGutterSize] = useState(() =>
35
- typeof props.space === "number" ? props.space || 0 : 20
36
- );
33
+ function gutterSize() {
34
+ return typeof props.space === "number" ? props.space || 0 : 20;
35
+ }
37
36
 
38
- const [cols, setCols] = useState(() => props.columns || []);
37
+ function cols() {
38
+ return props.columns || [];
39
+ }
39
40
 
40
- const [stackAt, setStackAt] = useState(
41
- () => props.stackColumnsAt || "tablet"
42
- );
41
+ function stackAt() {
42
+ return props.stackColumnsAt || "tablet";
43
+ }
43
44
 
44
45
  function getTagName(column: Column) {
45
46
  return column.link ? props.builderLinkComponent || BaseText : View;
46
47
  }
47
48
 
48
49
  function getWidth(index: number) {
49
- return cols[index]?.width || 100 / cols.length;
50
+ return cols()[index]?.width || 100 / cols().length;
50
51
  }
51
52
 
52
53
  function getColumnCssWidth(index: number) {
53
54
  const width = getWidth(index);
54
- const subtractWidth = gutterSize * (cols.length - 1) * (width / 100);
55
+ const subtractWidth = gutterSize() * (cols().length - 1) * (width / 100);
55
56
  return `calc(${width}% - ${subtractWidth}px)`;
56
57
  }
57
58
 
@@ -62,7 +63,7 @@ function Columns(props: ColumnProps) {
62
63
  stackedStyle: CSSVal;
63
64
  desktopStyle: CSSVal;
64
65
  }) {
65
- return stackAt === "tablet" ? stackedStyle : desktopStyle;
66
+ return stackAt() === "tablet" ? stackedStyle : desktopStyle;
66
67
  }
67
68
 
68
69
  function getMobileStyle({
@@ -72,25 +73,25 @@ function Columns(props: ColumnProps) {
72
73
  stackedStyle: CSSVal;
73
74
  desktopStyle: CSSVal;
74
75
  }) {
75
- return stackAt === "never" ? desktopStyle : stackedStyle;
76
+ return stackAt() === "never" ? desktopStyle : stackedStyle;
76
77
  }
77
78
 
78
- const [flexDir, setFlexDir] = useState(() =>
79
- props.stackColumnsAt === "never"
79
+ function flexDir() {
80
+ return props.stackColumnsAt === "never"
80
81
  ? "row"
81
82
  : props.reverseColumnsWhenStacked
82
83
  ? "column-reverse"
83
- : "column"
84
- );
84
+ : "column";
85
+ }
85
86
 
86
87
  function columnsCssVars() {
87
88
  return {
88
- flexDirection: flexDir as "row" | "column" | "column-reverse",
89
+ flexDirection: flexDir() as "row" | "column" | "column-reverse",
89
90
  };
90
91
  }
91
92
 
92
93
  function columnCssVars(index: number) {
93
- const gutter = index === 0 ? 0 : gutterSize;
94
+ const gutter = index === 0 ? 0 : gutterSize();
94
95
  const width = getColumnCssWidth(index);
95
96
  const gutterPixels = `${gutter}px`;
96
97
  const mobileWidth = "100%";
@@ -1 +1 @@
1
- export const SDK_VERSION = "2.0.26"
1
+ export const SDK_VERSION = "2.0.28"
@@ -75,6 +75,7 @@ let IVM_CONTEXT: Context | null = null;
75
75
  * `safeDynamicRequire` trick to import the `isolated-vm` package.
76
76
  */
77
77
  export const setIvm = (ivm: IsolatedVMImport, options: IsolateOptions = {}) => {
78
+ if (IVM_INSTANCE) return;
78
79
  IVM_INSTANCE = ivm;
79
80
  setIsolateContext(options);
80
81
  };
@@ -102,6 +103,7 @@ const getIvm = (): IsolatedVMImport => {
102
103
  function setIsolateContext(options: IsolateOptions = {
103
104
  memoryLimit: 128
104
105
  }) {
106
+ if (IVM_CONTEXT) return IVM_CONTEXT;
105
107
  const ivm = getIvm();
106
108
  const isolate = new ivm.Isolate(options);
107
109
  const context = isolate.createContextSync();
@@ -120,9 +122,7 @@ function setIsolateContext(options: IsolateOptions = {
120
122
  return context;
121
123
  }
122
124
  const getIsolateContext = () => {
123
- if (IVM_CONTEXT) return IVM_CONTEXT;
124
- const context = setIsolateContext();
125
- return context;
125
+ return setIsolateContext();
126
126
  };
127
127
  export const runInNode = ({
128
128
  code,
@@ -0,0 +1 @@
1
+ export { setIvm } from './node-runtime'