@rocapine/react-native-onboarding-ui 1.6.0 → 1.8.0

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 (84) hide show
  1. package/dist/UI/OnboardingPage.js +1 -1
  2. package/dist/UI/OnboardingPage.js.map +1 -1
  3. package/dist/UI/Pages/ComposableScreen/Renderer.d.ts +0 -2
  4. package/dist/UI/Pages/ComposableScreen/Renderer.d.ts.map +1 -1
  5. package/dist/UI/Pages/ComposableScreen/Renderer.js +13 -273
  6. package/dist/UI/Pages/ComposableScreen/Renderer.js.map +1 -1
  7. package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.d.ts +30 -0
  8. package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.d.ts.map +1 -0
  9. package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.js +19 -0
  10. package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.js.map +1 -0
  11. package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.d.ts +67 -0
  12. package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.d.ts.map +1 -0
  13. package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.js +65 -0
  14. package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.js.map +1 -0
  15. package/dist/UI/Pages/ComposableScreen/elements/IconElement.d.ts +41 -0
  16. package/dist/UI/Pages/ComposableScreen/elements/IconElement.d.ts.map +1 -0
  17. package/dist/UI/Pages/ComposableScreen/elements/IconElement.js +37 -0
  18. package/dist/UI/Pages/ComposableScreen/elements/IconElement.js.map +1 -0
  19. package/dist/UI/Pages/ComposableScreen/elements/ImageElement.d.ts +42 -0
  20. package/dist/UI/Pages/ComposableScreen/elements/ImageElement.d.ts.map +1 -0
  21. package/dist/UI/Pages/ComposableScreen/elements/ImageElement.js +34 -0
  22. package/dist/UI/Pages/ComposableScreen/elements/ImageElement.js.map +1 -0
  23. package/dist/UI/Pages/ComposableScreen/elements/InputElement.d.ts +102 -0
  24. package/dist/UI/Pages/ComposableScreen/elements/InputElement.d.ts.map +1 -0
  25. package/dist/UI/Pages/ComposableScreen/elements/InputElement.js +68 -0
  26. package/dist/UI/Pages/ComposableScreen/elements/InputElement.js.map +1 -0
  27. package/dist/UI/Pages/ComposableScreen/elements/LottieElement.d.ts +39 -0
  28. package/dist/UI/Pages/ComposableScreen/elements/LottieElement.d.ts.map +1 -0
  29. package/dist/UI/Pages/ComposableScreen/elements/LottieElement.js +60 -0
  30. package/dist/UI/Pages/ComposableScreen/elements/LottieElement.js.map +1 -0
  31. package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.d.ts +78 -0
  32. package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.d.ts.map +1 -0
  33. package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.js +119 -0
  34. package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.js.map +1 -0
  35. package/dist/UI/Pages/ComposableScreen/elements/RiveElement.d.ts +62 -0
  36. package/dist/UI/Pages/ComposableScreen/elements/RiveElement.d.ts.map +1 -0
  37. package/dist/UI/Pages/ComposableScreen/elements/RiveElement.js +68 -0
  38. package/dist/UI/Pages/ComposableScreen/elements/RiveElement.js.map +1 -0
  39. package/dist/UI/Pages/ComposableScreen/elements/StackElement.d.ts +85 -0
  40. package/dist/UI/Pages/ComposableScreen/elements/StackElement.d.ts.map +1 -0
  41. package/dist/UI/Pages/ComposableScreen/elements/StackElement.js +64 -0
  42. package/dist/UI/Pages/ComposableScreen/elements/StackElement.js.map +1 -0
  43. package/dist/UI/Pages/ComposableScreen/elements/TextElement.d.ts +66 -0
  44. package/dist/UI/Pages/ComposableScreen/elements/TextElement.d.ts.map +1 -0
  45. package/dist/UI/Pages/ComposableScreen/elements/TextElement.js +59 -0
  46. package/dist/UI/Pages/ComposableScreen/elements/TextElement.js.map +1 -0
  47. package/dist/UI/Pages/ComposableScreen/elements/VideoElement.d.ts +41 -0
  48. package/dist/UI/Pages/ComposableScreen/elements/VideoElement.d.ts.map +1 -0
  49. package/dist/UI/Pages/ComposableScreen/elements/VideoElement.js +84 -0
  50. package/dist/UI/Pages/ComposableScreen/elements/VideoElement.js.map +1 -0
  51. package/dist/UI/Pages/ComposableScreen/elements/renderElement.d.ts +5 -0
  52. package/dist/UI/Pages/ComposableScreen/elements/renderElement.d.ts.map +1 -0
  53. package/dist/UI/Pages/ComposableScreen/elements/renderElement.js +49 -0
  54. package/dist/UI/Pages/ComposableScreen/elements/renderElement.js.map +1 -0
  55. package/dist/UI/Pages/ComposableScreen/elements/shared.d.ts +13 -0
  56. package/dist/UI/Pages/ComposableScreen/elements/shared.d.ts.map +1 -0
  57. package/dist/UI/Pages/ComposableScreen/elements/shared.js +6 -0
  58. package/dist/UI/Pages/ComposableScreen/elements/shared.js.map +1 -0
  59. package/dist/UI/Pages/ComposableScreen/types.d.ts +40 -113
  60. package/dist/UI/Pages/ComposableScreen/types.d.ts.map +1 -1
  61. package/dist/UI/Pages/ComposableScreen/types.js +33 -121
  62. package/dist/UI/Pages/ComposableScreen/types.js.map +1 -1
  63. package/dist/UI/Provider/OnboardingProgressProvider.d.ts +6 -2
  64. package/dist/UI/Provider/OnboardingProgressProvider.d.ts.map +1 -1
  65. package/dist/UI/Provider/OnboardingProgressProvider.js +4 -3
  66. package/dist/UI/Provider/OnboardingProgressProvider.js.map +1 -1
  67. package/package.json +2 -2
  68. package/src/UI/OnboardingPage.tsx +1 -1
  69. package/src/UI/Pages/ComposableScreen/Renderer.tsx +22 -430
  70. package/src/UI/Pages/ComposableScreen/elements/BaseBoxProps.ts +31 -0
  71. package/src/UI/Pages/ComposableScreen/elements/ButtonElement.tsx +96 -0
  72. package/src/UI/Pages/ComposableScreen/elements/IconElement.tsx +67 -0
  73. package/src/UI/Pages/ComposableScreen/elements/ImageElement.tsx +52 -0
  74. package/src/UI/Pages/ComposableScreen/elements/InputElement.tsx +115 -0
  75. package/src/UI/Pages/ComposableScreen/elements/LottieElement.tsx +97 -0
  76. package/src/UI/Pages/ComposableScreen/elements/RadioGroupElement.tsx +181 -0
  77. package/src/UI/Pages/ComposableScreen/elements/RiveElement.tsx +105 -0
  78. package/src/UI/Pages/ComposableScreen/elements/StackElement.tsx +103 -0
  79. package/src/UI/Pages/ComposableScreen/elements/TextElement.tsx +95 -0
  80. package/src/UI/Pages/ComposableScreen/elements/VideoElement.tsx +113 -0
  81. package/src/UI/Pages/ComposableScreen/elements/renderElement.tsx +61 -0
  82. package/src/UI/Pages/ComposableScreen/elements/shared.ts +15 -0
  83. package/src/UI/Pages/ComposableScreen/types.ts +56 -233
  84. package/src/UI/Provider/OnboardingProgressProvider.tsx +8 -5
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RadioGroupComponent = exports.RadioGroupElementPropsSchema = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const zod_1 = require("zod");
7
+ const react_native_1 = require("react-native");
8
+ const BaseBoxProps_1 = require("./BaseBoxProps");
9
+ exports.RadioGroupElementPropsSchema = BaseBoxProps_1.BaseBoxPropsSchema.extend({
10
+ variableName: zod_1.z.string().optional(),
11
+ defaultValue: zod_1.z.string().optional(),
12
+ gap: zod_1.z.number().optional(),
13
+ direction: zod_1.z.enum(["vertical", "horizontal"]).optional(),
14
+ items: zod_1.z.array(zod_1.z.object({ label: zod_1.z.string().trim().min(1, "item label must not be empty"), value: zod_1.z.string().trim().min(1, "item value must not be empty") })).min(1, "items must not be empty"),
15
+ itemBackgroundColor: zod_1.z.string().optional(),
16
+ itemSelectedBackgroundColor: zod_1.z.string().optional(),
17
+ itemBorderColor: zod_1.z.string().optional(),
18
+ itemSelectedBorderColor: zod_1.z.string().optional(),
19
+ itemBorderRadius: zod_1.z.number().optional(),
20
+ itemBorderWidth: zod_1.z.number().optional(),
21
+ itemColor: zod_1.z.string().optional(),
22
+ itemSelectedColor: zod_1.z.string().optional(),
23
+ itemFontSize: zod_1.z.number().optional(),
24
+ itemFontWeight: zod_1.z.string().optional(),
25
+ itemFontFamily: zod_1.z.string().optional(),
26
+ itemPadding: zod_1.z.number().optional(),
27
+ itemPaddingHorizontal: zod_1.z.number().optional(),
28
+ itemPaddingVertical: zod_1.z.number().optional(),
29
+ }).superRefine((data, ctx) => {
30
+ const values = data.items.map((i) => i.value);
31
+ const unique = new Set(values);
32
+ if (unique.size !== values.length) {
33
+ ctx.addIssue({ code: zod_1.z.ZodIssueCode.custom, message: "item values must be unique", path: ["items"] });
34
+ }
35
+ if (data.defaultValue !== undefined && !unique.has(data.defaultValue)) {
36
+ ctx.addIssue({ code: zod_1.z.ZodIssueCode.custom, message: "defaultValue must match one of the item values", path: ["defaultValue"] });
37
+ }
38
+ });
39
+ const RadioGroupComponent = ({ element, ctx }) => {
40
+ var _a, _b;
41
+ const { theme, variables, setVariable } = ctx;
42
+ const selectedValue = element.props.variableName ? (_a = variables[element.props.variableName]) === null || _a === void 0 ? void 0 : _a.value : undefined;
43
+ (0, react_1.useEffect)(() => {
44
+ if (element.props.variableName && element.props.defaultValue && selectedValue === undefined) {
45
+ const defaultItem = element.props.items.find((i) => i.value === element.props.defaultValue);
46
+ setVariable(element.props.variableName, { value: element.props.defaultValue, label: defaultItem === null || defaultItem === void 0 ? void 0 : defaultItem.label });
47
+ }
48
+ }, [element.props.variableName, element.props.defaultValue, element.props.items, selectedValue]);
49
+ const handleSelect = (value, label) => {
50
+ if (element.props.variableName) {
51
+ setVariable(element.props.variableName, { value, label });
52
+ }
53
+ };
54
+ const isHorizontal = element.props.direction === "horizontal";
55
+ return ((0, jsx_runtime_1.jsx)(react_native_1.View, { accessibilityRole: "radiogroup", style: {
56
+ flexDirection: isHorizontal ? "row" : "column",
57
+ flexWrap: isHorizontal ? "wrap" : undefined,
58
+ gap: (_b = element.props.gap) !== null && _b !== void 0 ? _b : 8,
59
+ width: element.props.width,
60
+ height: element.props.height,
61
+ margin: element.props.margin,
62
+ marginHorizontal: element.props.marginHorizontal,
63
+ marginVertical: element.props.marginVertical,
64
+ padding: element.props.padding,
65
+ paddingHorizontal: element.props.paddingHorizontal,
66
+ paddingVertical: element.props.paddingVertical,
67
+ borderWidth: element.props.borderWidth,
68
+ borderRadius: element.props.borderRadius,
69
+ borderColor: element.props.borderColor,
70
+ opacity: element.props.opacity,
71
+ }, children: element.props.items.map((item) => {
72
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
73
+ const isSelected = selectedValue === item.value;
74
+ // Note: "+ "15"" appends hex alpha (≈8% opacity) assuming a 6-digit hex primary color.
75
+ // This works for standard hex colors but may produce unexpected results for other color formats.
76
+ const bgColor = isSelected
77
+ ? ((_a = element.props.itemSelectedBackgroundColor) !== null && _a !== void 0 ? _a : theme.colors.primary + "15")
78
+ : ((_b = element.props.itemBackgroundColor) !== null && _b !== void 0 ? _b : "transparent");
79
+ const textColor = isSelected
80
+ ? ((_c = element.props.itemSelectedColor) !== null && _c !== void 0 ? _c : theme.colors.primary)
81
+ : ((_d = element.props.itemColor) !== null && _d !== void 0 ? _d : theme.colors.text.primary);
82
+ const borderColor = isSelected
83
+ ? ((_e = element.props.itemSelectedBorderColor) !== null && _e !== void 0 ? _e : theme.colors.primary)
84
+ : ((_f = element.props.itemBorderColor) !== null && _f !== void 0 ? _f : theme.colors.neutral.low);
85
+ return ((0, jsx_runtime_1.jsxs)(react_native_1.TouchableOpacity, { activeOpacity: 0.7, onPress: () => handleSelect(item.value, item.label), accessibilityRole: "radio", accessibilityState: { selected: isSelected, checked: isSelected }, accessibilityLabel: item.label, style: {
86
+ flexDirection: "row",
87
+ alignItems: "center",
88
+ gap: 12,
89
+ backgroundColor: bgColor,
90
+ borderRadius: (_g = element.props.itemBorderRadius) !== null && _g !== void 0 ? _g : 8,
91
+ borderWidth: (_h = element.props.itemBorderWidth) !== null && _h !== void 0 ? _h : 1,
92
+ borderColor: borderColor,
93
+ padding: (_j = element.props.itemPadding) !== null && _j !== void 0 ? _j : (element.props.itemPaddingHorizontal === undefined && element.props.itemPaddingVertical === undefined ? 12 : undefined),
94
+ paddingHorizontal: element.props.itemPaddingHorizontal,
95
+ paddingVertical: element.props.itemPaddingVertical,
96
+ }, children: [(0, jsx_runtime_1.jsx)(react_native_1.View, { style: {
97
+ width: 20,
98
+ height: 20,
99
+ borderRadius: 10,
100
+ borderWidth: 2,
101
+ borderColor: isSelected ? theme.colors.primary : theme.colors.neutral.medium,
102
+ alignItems: "center",
103
+ justifyContent: "center",
104
+ }, children: isSelected && ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: {
105
+ width: 10,
106
+ height: 10,
107
+ borderRadius: 5,
108
+ backgroundColor: theme.colors.primary,
109
+ } })) }), (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: {
110
+ flex: 1,
111
+ color: textColor,
112
+ fontSize: (_k = element.props.itemFontSize) !== null && _k !== void 0 ? _k : theme.typography.textStyles.body.fontSize,
113
+ fontWeight: (_l = element.props.itemFontWeight) !== null && _l !== void 0 ? _l : theme.typography.textStyles.body.fontWeight,
114
+ fontFamily: element.props.itemFontFamily,
115
+ }, children: item.label })] }, item.value));
116
+ }) }));
117
+ };
118
+ exports.RadioGroupComponent = RadioGroupComponent;
119
+ //# sourceMappingURL=RadioGroupElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioGroupElement.js","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/RadioGroupElement.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,62 @@
1
+ import React from "react";
2
+ import { z } from "zod";
3
+ import { BaseBoxProps } from "./BaseBoxProps";
4
+ import { UIElement } from "../types";
5
+ import { RenderContext } from "./shared";
6
+ export type RiveElementProps = BaseBoxProps & {
7
+ url: string;
8
+ autoplay?: boolean;
9
+ fit?: "Contain" | "Cover" | "Fill" | "FitWidth" | "FitHeight" | "None" | "ScaleDown" | "Layout";
10
+ alignment?: "TopLeft" | "TopCenter" | "TopRight" | "CenterLeft" | "Center" | "CenterRight" | "BottomLeft" | "BottomCenter" | "BottomRight";
11
+ artboardName?: string;
12
+ stateMachineName?: string;
13
+ };
14
+ export declare const RiveElementPropsSchema: z.ZodObject<{
15
+ width: z.ZodOptional<z.ZodNumber>;
16
+ height: z.ZodOptional<z.ZodNumber>;
17
+ opacity: z.ZodOptional<z.ZodNumber>;
18
+ margin: z.ZodOptional<z.ZodNumber>;
19
+ marginHorizontal: z.ZodOptional<z.ZodNumber>;
20
+ marginVertical: z.ZodOptional<z.ZodNumber>;
21
+ padding: z.ZodOptional<z.ZodNumber>;
22
+ paddingHorizontal: z.ZodOptional<z.ZodNumber>;
23
+ paddingVertical: z.ZodOptional<z.ZodNumber>;
24
+ borderWidth: z.ZodOptional<z.ZodNumber>;
25
+ borderRadius: z.ZodOptional<z.ZodNumber>;
26
+ borderColor: z.ZodOptional<z.ZodString>;
27
+ url: z.ZodString;
28
+ autoplay: z.ZodOptional<z.ZodBoolean>;
29
+ fit: z.ZodOptional<z.ZodEnum<{
30
+ Contain: "Contain";
31
+ Cover: "Cover";
32
+ Fill: "Fill";
33
+ FitWidth: "FitWidth";
34
+ FitHeight: "FitHeight";
35
+ None: "None";
36
+ ScaleDown: "ScaleDown";
37
+ Layout: "Layout";
38
+ }>>;
39
+ alignment: z.ZodOptional<z.ZodEnum<{
40
+ TopLeft: "TopLeft";
41
+ TopCenter: "TopCenter";
42
+ TopRight: "TopRight";
43
+ CenterLeft: "CenterLeft";
44
+ Center: "Center";
45
+ CenterRight: "CenterRight";
46
+ BottomLeft: "BottomLeft";
47
+ BottomCenter: "BottomCenter";
48
+ BottomRight: "BottomRight";
49
+ }>>;
50
+ artboardName: z.ZodOptional<z.ZodString>;
51
+ stateMachineName: z.ZodOptional<z.ZodString>;
52
+ }, z.core.$strip>;
53
+ type RiveUIElement = Extract<UIElement, {
54
+ type: "Rive";
55
+ }>;
56
+ type Props = {
57
+ element: RiveUIElement;
58
+ ctx: RenderContext;
59
+ };
60
+ export declare const RiveElementRenderer: ({ element, ctx }: Props) => React.ReactElement;
61
+ export {};
62
+ //# sourceMappingURL=RiveElement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RiveElement.d.ts","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/RiveElement.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,YAAY,EAAsB,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGzC,MAAM,MAAM,gBAAgB,GAAG,YAAY,GAAG;IAC5C,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,GAAG,CAAC,EAAE,SAAS,GAAG,OAAO,GAAG,MAAM,GAAG,UAAU,GAAG,WAAW,GAAG,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IAChG,SAAS,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,UAAU,GAAG,YAAY,GAAG,QAAQ,GAAG,aAAa,GAAG,YAAY,GAAG,cAAc,GAAG,aAAa,CAAC;IAC3I,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAOjC,CAAC;AAEH,KAAK,aAAa,GAAG,OAAO,CAAC,SAAS,EAAE;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAyB1D,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,aAAa,CAAC;IACvB,GAAG,EAAE,aAAa,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,kBAAkB,KAAK,KAAG,KAAK,CAAC,YAiCnE,CAAC"}
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RiveElementRenderer = exports.RiveElementPropsSchema = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const zod_1 = require("zod");
6
+ const react_native_1 = require("react-native");
7
+ const BaseBoxProps_1 = require("./BaseBoxProps");
8
+ const helpers_1 = require("../../../Theme/helpers");
9
+ exports.RiveElementPropsSchema = BaseBoxProps_1.BaseBoxPropsSchema.extend({
10
+ url: zod_1.z.string().min(1, "url must not be empty"),
11
+ autoplay: zod_1.z.boolean().optional(),
12
+ fit: zod_1.z.enum(["Contain", "Cover", "Fill", "FitWidth", "FitHeight", "None", "ScaleDown", "Layout"]).optional(),
13
+ alignment: zod_1.z.enum(["TopLeft", "TopCenter", "TopRight", "CenterLeft", "Center", "CenterRight", "BottomLeft", "BottomCenter", "BottomRight"]).optional(),
14
+ artboardName: zod_1.z.string().optional(),
15
+ stateMachineName: zod_1.z.string().optional(),
16
+ });
17
+ let RiveElementComponent = null;
18
+ try {
19
+ const riveModule = require("rive-react-native");
20
+ const Rive = riveModule.default;
21
+ const { Fit, Alignment } = riveModule;
22
+ RiveElementComponent = ({ element, riveStyle }) => {
23
+ var _a;
24
+ return ((0, jsx_runtime_1.jsx)(Rive, { url: element.props.url, autoplay: (_a = element.props.autoplay) !== null && _a !== void 0 ? _a : true, fit: element.props.fit ? Fit[element.props.fit] : Fit.Contain, alignment: element.props.alignment ? Alignment[element.props.alignment] : Alignment.Center, artboardName: element.props.artboardName, stateMachineName: element.props.stateMachineName, style: riveStyle, onError: console.error }));
25
+ };
26
+ }
27
+ catch (_a) {
28
+ // rive-react-native not installed - will show fallback if Rive is used
29
+ }
30
+ const RiveElementRenderer = ({ element, ctx }) => {
31
+ var _a, _b;
32
+ const { theme } = ctx;
33
+ const wrapperStyle = {
34
+ width: (_a = element.props.width) !== null && _a !== void 0 ? _a : "100%",
35
+ height: (_b = element.props.height) !== null && _b !== void 0 ? _b : 200,
36
+ opacity: element.props.opacity,
37
+ margin: element.props.margin,
38
+ marginHorizontal: element.props.marginHorizontal,
39
+ marginVertical: element.props.marginVertical,
40
+ padding: element.props.padding,
41
+ paddingHorizontal: element.props.paddingHorizontal,
42
+ paddingVertical: element.props.paddingVertical,
43
+ borderWidth: element.props.borderWidth,
44
+ borderRadius: element.props.borderRadius,
45
+ borderColor: element.props.borderColor,
46
+ overflow: "hidden",
47
+ };
48
+ if (!RiveElementComponent) {
49
+ return ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: [wrapperStyle, styles.mediaFallback, { backgroundColor: theme.colors.neutral.lowest }], children: (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: [styles.mediaFallbackText, (0, helpers_1.getTextStyle)(theme, "caption"), { color: theme.colors.text.tertiary }], children: "Install rive-react-native to render Rive animations." }) }));
50
+ }
51
+ return ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: wrapperStyle, children: (0, jsx_runtime_1.jsx)(RiveElementComponent, { element: element, riveStyle: styles.fill }) }));
52
+ };
53
+ exports.RiveElementRenderer = RiveElementRenderer;
54
+ const styles = react_native_1.StyleSheet.create({
55
+ fill: {
56
+ width: "100%",
57
+ height: "100%",
58
+ },
59
+ mediaFallback: {
60
+ alignItems: "center",
61
+ justifyContent: "center",
62
+ },
63
+ mediaFallbackText: {
64
+ textAlign: "center",
65
+ paddingHorizontal: 16,
66
+ },
67
+ });
68
+ //# sourceMappingURL=RiveElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RiveElement.js","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/RiveElement.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,85 @@
1
+ import React from "react";
2
+ import { z } from "zod";
3
+ import { UIElement } from "../types";
4
+ import { RenderContext } from "./shared";
5
+ export type StackElementProps = {
6
+ gap?: number;
7
+ padding?: number;
8
+ paddingHorizontal?: number;
9
+ paddingVertical?: number;
10
+ margin?: number;
11
+ marginHorizontal?: number;
12
+ marginVertical?: number;
13
+ flex?: number;
14
+ width?: number;
15
+ height?: number;
16
+ minWidth?: number;
17
+ maxWidth?: number;
18
+ minHeight?: number;
19
+ maxHeight?: number;
20
+ alignItems?: "flex-start" | "center" | "flex-end" | "stretch";
21
+ justifyContent?: "flex-start" | "center" | "flex-end" | "space-between" | "space-around";
22
+ backgroundColor?: string;
23
+ flexWrap?: "wrap" | "nowrap";
24
+ flexShrink?: number;
25
+ borderWidth?: number;
26
+ borderRadius?: number;
27
+ borderColor?: string;
28
+ overflow?: "hidden" | "visible" | "scroll";
29
+ opacity?: number;
30
+ };
31
+ export declare const StackElementPropsSchema: z.ZodObject<{
32
+ gap: z.ZodOptional<z.ZodNumber>;
33
+ padding: z.ZodOptional<z.ZodNumber>;
34
+ paddingHorizontal: z.ZodOptional<z.ZodNumber>;
35
+ paddingVertical: z.ZodOptional<z.ZodNumber>;
36
+ margin: z.ZodOptional<z.ZodNumber>;
37
+ marginHorizontal: z.ZodOptional<z.ZodNumber>;
38
+ marginVertical: z.ZodOptional<z.ZodNumber>;
39
+ flex: z.ZodOptional<z.ZodNumber>;
40
+ width: z.ZodOptional<z.ZodNumber>;
41
+ height: z.ZodOptional<z.ZodNumber>;
42
+ minWidth: z.ZodOptional<z.ZodNumber>;
43
+ maxWidth: z.ZodOptional<z.ZodNumber>;
44
+ minHeight: z.ZodOptional<z.ZodNumber>;
45
+ maxHeight: z.ZodOptional<z.ZodNumber>;
46
+ alignItems: z.ZodOptional<z.ZodEnum<{
47
+ center: "center";
48
+ "flex-start": "flex-start";
49
+ "flex-end": "flex-end";
50
+ stretch: "stretch";
51
+ }>>;
52
+ justifyContent: z.ZodOptional<z.ZodEnum<{
53
+ center: "center";
54
+ "flex-start": "flex-start";
55
+ "flex-end": "flex-end";
56
+ "space-between": "space-between";
57
+ "space-around": "space-around";
58
+ }>>;
59
+ backgroundColor: z.ZodOptional<z.ZodString>;
60
+ flexWrap: z.ZodOptional<z.ZodEnum<{
61
+ wrap: "wrap";
62
+ nowrap: "nowrap";
63
+ }>>;
64
+ flexShrink: z.ZodOptional<z.ZodNumber>;
65
+ borderWidth: z.ZodOptional<z.ZodNumber>;
66
+ borderRadius: z.ZodOptional<z.ZodNumber>;
67
+ borderColor: z.ZodOptional<z.ZodString>;
68
+ overflow: z.ZodOptional<z.ZodEnum<{
69
+ visible: "visible";
70
+ hidden: "hidden";
71
+ scroll: "scroll";
72
+ }>>;
73
+ opacity: z.ZodOptional<z.ZodNumber>;
74
+ }, z.core.$strip>;
75
+ type StackUIElement = Extract<UIElement, {
76
+ type: "YStack" | "XStack";
77
+ }>;
78
+ type Props = {
79
+ element: StackUIElement;
80
+ ctx: RenderContext;
81
+ parentType?: "XStack" | "YStack";
82
+ };
83
+ export declare const StackElementComponent: ({ element, ctx, parentType }: Props) => React.ReactElement;
84
+ export {};
85
+ //# sourceMappingURL=StackElement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StackElement.d.ts","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/StackElement.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,YAAY,GAAG,QAAQ,GAAG,UAAU,GAAG,SAAS,CAAC;IAC9D,cAAc,CAAC,EAAE,YAAY,GAAG,QAAQ,GAAG,UAAU,GAAG,eAAe,GAAG,cAAc,CAAC;IACzF,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,QAAQ,GAAG,SAAS,GAAG,QAAQ,CAAC;IAC3C,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAyBlC,CAAC;AAEH,KAAK,cAAc,GAAG,OAAO,CAAC,SAAS,EAAE;IAAE,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAA;CAAE,CAAC,CAAC;AAExE,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,cAAc,CAAC;IACxB,GAAG,EAAE,aAAa,CAAC;IACnB,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;CAClC,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,8BAA8B,KAAK,KAAG,KAAK,CAAC,YAkCjF,CAAC"}
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StackElementComponent = exports.StackElementPropsSchema = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const zod_1 = require("zod");
6
+ const react_native_1 = require("react-native");
7
+ exports.StackElementPropsSchema = zod_1.z.object({
8
+ gap: zod_1.z.number().optional(),
9
+ padding: zod_1.z.number().optional(),
10
+ paddingHorizontal: zod_1.z.number().optional(),
11
+ paddingVertical: zod_1.z.number().optional(),
12
+ margin: zod_1.z.number().optional(),
13
+ marginHorizontal: zod_1.z.number().optional(),
14
+ marginVertical: zod_1.z.number().optional(),
15
+ flex: zod_1.z.number().optional(),
16
+ width: zod_1.z.number().optional(),
17
+ height: zod_1.z.number().optional(),
18
+ minWidth: zod_1.z.number().optional(),
19
+ maxWidth: zod_1.z.number().optional(),
20
+ minHeight: zod_1.z.number().optional(),
21
+ maxHeight: zod_1.z.number().optional(),
22
+ alignItems: zod_1.z.enum(["flex-start", "center", "flex-end", "stretch"]).optional(),
23
+ justifyContent: zod_1.z.enum(["flex-start", "center", "flex-end", "space-between", "space-around"]).optional(),
24
+ backgroundColor: zod_1.z.string().optional(),
25
+ flexWrap: zod_1.z.enum(["wrap", "nowrap"]).optional(),
26
+ flexShrink: zod_1.z.number().optional(),
27
+ borderWidth: zod_1.z.number().optional(),
28
+ borderRadius: zod_1.z.number().optional(),
29
+ borderColor: zod_1.z.string().optional(),
30
+ overflow: zod_1.z.enum(["hidden", "visible", "scroll"]).optional(),
31
+ opacity: zod_1.z.number().min(0).max(1).optional(),
32
+ });
33
+ const StackElementComponent = ({ element, ctx, parentType }) => {
34
+ var _a;
35
+ return ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: {
36
+ flexDirection: element.type === "XStack" ? "row" : "column",
37
+ gap: element.props.gap,
38
+ padding: element.props.padding,
39
+ paddingHorizontal: element.props.paddingHorizontal,
40
+ paddingVertical: element.props.paddingVertical,
41
+ margin: element.props.margin,
42
+ marginHorizontal: element.props.marginHorizontal,
43
+ marginVertical: element.props.marginVertical,
44
+ flex: element.props.flex,
45
+ width: element.props.width,
46
+ height: element.props.height,
47
+ minWidth: element.props.minWidth,
48
+ maxWidth: element.props.maxWidth,
49
+ minHeight: element.props.minHeight,
50
+ maxHeight: element.props.maxHeight,
51
+ flexShrink: (_a = element.props.flexShrink) !== null && _a !== void 0 ? _a : (parentType === "XStack" ? 1 : undefined),
52
+ flexWrap: element.props.flexWrap,
53
+ alignItems: element.props.alignItems,
54
+ justifyContent: element.props.justifyContent,
55
+ backgroundColor: element.props.backgroundColor,
56
+ borderWidth: element.props.borderWidth,
57
+ borderRadius: element.props.borderRadius,
58
+ borderColor: element.props.borderColor,
59
+ overflow: element.props.overflow,
60
+ opacity: element.props.opacity,
61
+ }, children: ctx.renderChildren(element.children, element.type) }));
62
+ };
63
+ exports.StackElementComponent = StackElementComponent;
64
+ //# sourceMappingURL=StackElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StackElement.js","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/StackElement.tsx"],"names":[],"mappings":";;;;AACA,6BAAwB;AACxB,+CAAoC;AA+BvB,QAAA,uBAAuB,GAAG,OAAC,CAAC,MAAM,CAAC;IAC9C,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC1B,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC9B,iBAAiB,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACxC,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACtC,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,gBAAgB,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACvC,cAAc,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACrC,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,KAAK,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC5B,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC/B,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC/B,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,UAAU,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC9E,cAAc,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC,CAAC,QAAQ,EAAE;IACxG,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACtC,QAAQ,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC/C,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACjC,WAAW,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAClC,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACnC,WAAW,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAClC,QAAQ,EAAE,OAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE;IAC5D,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;CAC7C,CAAC,CAAC;AAUI,MAAM,qBAAqB,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,UAAU,EAAS,EAAsB,EAAE;;IAC/F,OAAO,CACL,uBAAC,mBAAI,IACH,KAAK,EAAE;YACL,aAAa,EAAE,OAAO,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;YAC3D,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG;YACtB,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO;YAC9B,iBAAiB,EAAE,OAAO,CAAC,KAAK,CAAC,iBAAiB;YAClD,eAAe,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe;YAC9C,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM;YAC5B,gBAAgB,EAAE,OAAO,CAAC,KAAK,CAAC,gBAAgB;YAChD,cAAc,EAAE,OAAO,CAAC,KAAK,CAAC,cAAc;YAC5C,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI;YACxB,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK;YAC1B,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM;YAC5B,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ;YAChC,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ;YAChC,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,SAAS;YAClC,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,SAAS;YAClC,UAAU,EAAE,MAAA,OAAO,CAAC,KAAK,CAAC,UAAU,mCAAI,CAAC,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YACjF,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ;YAChC,UAAU,EAAE,OAAO,CAAC,KAAK,CAAC,UAAU;YACpC,cAAc,EAAE,OAAO,CAAC,KAAK,CAAC,cAAc;YAC5C,eAAe,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe;YAC9C,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,WAAW;YACtC,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,YAAY;YACxC,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,WAAW;YACtC,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ;YAChC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO;SAC/B,YAEA,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,GAC9C,CACR,CAAC;AACJ,CAAC,CAAC;AAlCW,QAAA,qBAAqB,yBAkChC"}
@@ -0,0 +1,66 @@
1
+ import React from "react";
2
+ import { z } from "zod";
3
+ import { UIElement } from "../types";
4
+ import { RenderContext } from "./shared";
5
+ export type TextElementProps = {
6
+ content: string;
7
+ mode?: "plain" | "expression";
8
+ fontSize?: number;
9
+ fontWeight?: string;
10
+ fontFamily?: string;
11
+ color?: string;
12
+ textAlign?: "left" | "center" | "right";
13
+ letterSpacing?: number;
14
+ lineHeight?: number;
15
+ backgroundColor?: string;
16
+ padding?: number;
17
+ paddingHorizontal?: number;
18
+ paddingVertical?: number;
19
+ margin?: number;
20
+ marginHorizontal?: number;
21
+ marginVertical?: number;
22
+ borderWidth?: number;
23
+ borderRadius?: number;
24
+ borderColor?: string;
25
+ opacity?: number;
26
+ };
27
+ export declare const TextElementPropsSchema: z.ZodObject<{
28
+ content: z.ZodString;
29
+ mode: z.ZodOptional<z.ZodEnum<{
30
+ plain: "plain";
31
+ expression: "expression";
32
+ }>>;
33
+ fontSize: z.ZodOptional<z.ZodNumber>;
34
+ fontWeight: z.ZodOptional<z.ZodString>;
35
+ fontFamily: z.ZodOptional<z.ZodString>;
36
+ color: z.ZodOptional<z.ZodString>;
37
+ textAlign: z.ZodOptional<z.ZodEnum<{
38
+ left: "left";
39
+ right: "right";
40
+ center: "center";
41
+ }>>;
42
+ letterSpacing: z.ZodOptional<z.ZodNumber>;
43
+ lineHeight: z.ZodOptional<z.ZodNumber>;
44
+ backgroundColor: z.ZodOptional<z.ZodString>;
45
+ padding: z.ZodOptional<z.ZodNumber>;
46
+ paddingHorizontal: z.ZodOptional<z.ZodNumber>;
47
+ paddingVertical: z.ZodOptional<z.ZodNumber>;
48
+ margin: z.ZodOptional<z.ZodNumber>;
49
+ marginHorizontal: z.ZodOptional<z.ZodNumber>;
50
+ marginVertical: z.ZodOptional<z.ZodNumber>;
51
+ borderWidth: z.ZodOptional<z.ZodNumber>;
52
+ borderRadius: z.ZodOptional<z.ZodNumber>;
53
+ borderColor: z.ZodOptional<z.ZodString>;
54
+ opacity: z.ZodOptional<z.ZodNumber>;
55
+ }, z.core.$strip>;
56
+ type TextUIElement = Extract<UIElement, {
57
+ type: "Text";
58
+ }>;
59
+ type Props = {
60
+ element: TextUIElement;
61
+ ctx: RenderContext;
62
+ parentType?: "XStack" | "YStack";
63
+ };
64
+ export declare const TextElementComponent: ({ element, ctx, parentType }: Props) => React.ReactElement;
65
+ export {};
66
+ //# sourceMappingURL=TextElement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextElement.d.ts","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/TextElement.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,aAAa,EAAe,MAAM,UAAU,CAAC;AAEtD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,OAAO,GAAG,YAAY,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IACxC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAqBjC,CAAC;AAEH,KAAK,aAAa,GAAG,OAAO,CAAC,SAAS,EAAE;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE1D,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,aAAa,CAAC;IACvB,GAAG,EAAE,aAAa,CAAC;IACnB,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;CAClC,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,8BAA8B,KAAK,KAAG,KAAK,CAAC,YAkChF,CAAC"}
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TextElementComponent = exports.TextElementPropsSchema = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const zod_1 = require("zod");
6
+ const react_native_1 = require("react-native");
7
+ const shared_1 = require("./shared");
8
+ exports.TextElementPropsSchema = zod_1.z.object({
9
+ content: zod_1.z.string(),
10
+ mode: zod_1.z.enum(["plain", "expression"]).optional(),
11
+ fontSize: zod_1.z.number().optional(),
12
+ fontWeight: zod_1.z.string().optional(),
13
+ fontFamily: zod_1.z.string().optional(),
14
+ color: zod_1.z.string().optional(),
15
+ textAlign: zod_1.z.enum(["left", "center", "right"]).optional(),
16
+ letterSpacing: zod_1.z.number().optional(),
17
+ lineHeight: zod_1.z.number().optional(),
18
+ backgroundColor: zod_1.z.string().optional(),
19
+ padding: zod_1.z.number().optional(),
20
+ paddingHorizontal: zod_1.z.number().optional(),
21
+ paddingVertical: zod_1.z.number().optional(),
22
+ margin: zod_1.z.number().optional(),
23
+ marginHorizontal: zod_1.z.number().optional(),
24
+ marginVertical: zod_1.z.number().optional(),
25
+ borderWidth: zod_1.z.number().optional(),
26
+ borderRadius: zod_1.z.number().optional(),
27
+ borderColor: zod_1.z.string().optional(),
28
+ opacity: zod_1.z.number().min(0).max(1).optional(),
29
+ });
30
+ const TextElementComponent = ({ element, ctx, parentType }) => {
31
+ var _a;
32
+ const { theme, variables } = ctx;
33
+ const content = element.props.mode === "expression"
34
+ ? (0, shared_1.interpolate)(element.props.content, variables)
35
+ : element.props.content;
36
+ return ((0, jsx_runtime_1.jsx)(react_native_1.Text, { style: {
37
+ fontSize: element.props.fontSize,
38
+ fontWeight: element.props.fontWeight,
39
+ fontFamily: element.props.fontFamily,
40
+ color: (_a = element.props.color) !== null && _a !== void 0 ? _a : theme.colors.text.primary,
41
+ textAlign: element.props.textAlign,
42
+ letterSpacing: element.props.letterSpacing,
43
+ lineHeight: element.props.lineHeight,
44
+ backgroundColor: element.props.backgroundColor,
45
+ padding: element.props.padding,
46
+ paddingHorizontal: element.props.paddingHorizontal,
47
+ paddingVertical: element.props.paddingVertical,
48
+ margin: element.props.margin,
49
+ marginHorizontal: element.props.marginHorizontal,
50
+ marginVertical: element.props.marginVertical,
51
+ borderWidth: element.props.borderWidth,
52
+ borderRadius: element.props.borderRadius,
53
+ borderColor: element.props.borderColor,
54
+ opacity: element.props.opacity,
55
+ flexShrink: parentType === "XStack" ? 1 : undefined,
56
+ }, children: content }));
57
+ };
58
+ exports.TextElementComponent = TextElementComponent;
59
+ //# sourceMappingURL=TextElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextElement.js","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/TextElement.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,41 @@
1
+ import React from "react";
2
+ import { z } from "zod";
3
+ import { BaseBoxProps } from "./BaseBoxProps";
4
+ import { UIElement } from "../types";
5
+ import { RenderContext } from "./shared";
6
+ export type VideoElementProps = BaseBoxProps & {
7
+ url: string;
8
+ autoPlay?: boolean;
9
+ loop?: boolean;
10
+ muted?: boolean;
11
+ controls?: boolean;
12
+ };
13
+ export declare const VideoElementPropsSchema: z.ZodObject<{
14
+ width: z.ZodOptional<z.ZodNumber>;
15
+ height: z.ZodOptional<z.ZodNumber>;
16
+ opacity: z.ZodOptional<z.ZodNumber>;
17
+ margin: z.ZodOptional<z.ZodNumber>;
18
+ marginHorizontal: z.ZodOptional<z.ZodNumber>;
19
+ marginVertical: z.ZodOptional<z.ZodNumber>;
20
+ padding: z.ZodOptional<z.ZodNumber>;
21
+ paddingHorizontal: z.ZodOptional<z.ZodNumber>;
22
+ paddingVertical: z.ZodOptional<z.ZodNumber>;
23
+ borderWidth: z.ZodOptional<z.ZodNumber>;
24
+ borderRadius: z.ZodOptional<z.ZodNumber>;
25
+ borderColor: z.ZodOptional<z.ZodString>;
26
+ url: z.ZodString;
27
+ autoPlay: z.ZodOptional<z.ZodBoolean>;
28
+ loop: z.ZodOptional<z.ZodBoolean>;
29
+ muted: z.ZodOptional<z.ZodBoolean>;
30
+ controls: z.ZodOptional<z.ZodBoolean>;
31
+ }, z.core.$strip>;
32
+ type VideoUIElement = Extract<UIElement, {
33
+ type: "Video";
34
+ }>;
35
+ type Props = {
36
+ element: VideoUIElement;
37
+ ctx: RenderContext;
38
+ };
39
+ export declare const VideoElementRenderer: ({ element, ctx }: Props) => React.ReactElement;
40
+ export {};
41
+ //# sourceMappingURL=VideoElement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VideoElement.d.ts","sourceRoot":"","sources":["../../../../../src/UI/Pages/ComposableScreen/elements/VideoElement.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,YAAY,EAAsB,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGzC,MAAM,MAAM,iBAAiB,GAAG,YAAY,GAAG;IAC7C,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;iBAMlC,CAAC;AAEH,KAAK,cAAc,GAAG,OAAO,CAAC,SAAS,EAAE;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE,CAAC,CAAC;AAmC5D,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,cAAc,CAAC;IACxB,GAAG,EAAE,aAAa,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,kBAAkB,KAAK,KAAG,KAAK,CAAC,YAiCpE,CAAC"}