@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.
- package/dist/UI/OnboardingPage.js +1 -1
- package/dist/UI/OnboardingPage.js.map +1 -1
- package/dist/UI/Pages/ComposableScreen/Renderer.d.ts +0 -2
- package/dist/UI/Pages/ComposableScreen/Renderer.d.ts.map +1 -1
- package/dist/UI/Pages/ComposableScreen/Renderer.js +13 -273
- package/dist/UI/Pages/ComposableScreen/Renderer.js.map +1 -1
- package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.d.ts +30 -0
- package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.js +19 -0
- package/dist/UI/Pages/ComposableScreen/elements/BaseBoxProps.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.d.ts +67 -0
- package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.js +65 -0
- package/dist/UI/Pages/ComposableScreen/elements/ButtonElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/IconElement.d.ts +41 -0
- package/dist/UI/Pages/ComposableScreen/elements/IconElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/IconElement.js +37 -0
- package/dist/UI/Pages/ComposableScreen/elements/IconElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/ImageElement.d.ts +42 -0
- package/dist/UI/Pages/ComposableScreen/elements/ImageElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/ImageElement.js +34 -0
- package/dist/UI/Pages/ComposableScreen/elements/ImageElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/InputElement.d.ts +102 -0
- package/dist/UI/Pages/ComposableScreen/elements/InputElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/InputElement.js +68 -0
- package/dist/UI/Pages/ComposableScreen/elements/InputElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/LottieElement.d.ts +39 -0
- package/dist/UI/Pages/ComposableScreen/elements/LottieElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/LottieElement.js +60 -0
- package/dist/UI/Pages/ComposableScreen/elements/LottieElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.d.ts +78 -0
- package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.js +119 -0
- package/dist/UI/Pages/ComposableScreen/elements/RadioGroupElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/RiveElement.d.ts +62 -0
- package/dist/UI/Pages/ComposableScreen/elements/RiveElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/RiveElement.js +68 -0
- package/dist/UI/Pages/ComposableScreen/elements/RiveElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/StackElement.d.ts +85 -0
- package/dist/UI/Pages/ComposableScreen/elements/StackElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/StackElement.js +64 -0
- package/dist/UI/Pages/ComposableScreen/elements/StackElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/TextElement.d.ts +66 -0
- package/dist/UI/Pages/ComposableScreen/elements/TextElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/TextElement.js +59 -0
- package/dist/UI/Pages/ComposableScreen/elements/TextElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/VideoElement.d.ts +41 -0
- package/dist/UI/Pages/ComposableScreen/elements/VideoElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/VideoElement.js +84 -0
- package/dist/UI/Pages/ComposableScreen/elements/VideoElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/renderElement.d.ts +5 -0
- package/dist/UI/Pages/ComposableScreen/elements/renderElement.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/renderElement.js +49 -0
- package/dist/UI/Pages/ComposableScreen/elements/renderElement.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/shared.d.ts +13 -0
- package/dist/UI/Pages/ComposableScreen/elements/shared.d.ts.map +1 -0
- package/dist/UI/Pages/ComposableScreen/elements/shared.js +6 -0
- package/dist/UI/Pages/ComposableScreen/elements/shared.js.map +1 -0
- package/dist/UI/Pages/ComposableScreen/types.d.ts +40 -113
- package/dist/UI/Pages/ComposableScreen/types.d.ts.map +1 -1
- package/dist/UI/Pages/ComposableScreen/types.js +33 -121
- package/dist/UI/Pages/ComposableScreen/types.js.map +1 -1
- package/dist/UI/Provider/OnboardingProgressProvider.d.ts +6 -2
- package/dist/UI/Provider/OnboardingProgressProvider.d.ts.map +1 -1
- package/dist/UI/Provider/OnboardingProgressProvider.js +4 -3
- package/dist/UI/Provider/OnboardingProgressProvider.js.map +1 -1
- package/package.json +2 -2
- package/src/UI/OnboardingPage.tsx +1 -1
- package/src/UI/Pages/ComposableScreen/Renderer.tsx +22 -430
- package/src/UI/Pages/ComposableScreen/elements/BaseBoxProps.ts +31 -0
- package/src/UI/Pages/ComposableScreen/elements/ButtonElement.tsx +96 -0
- package/src/UI/Pages/ComposableScreen/elements/IconElement.tsx +67 -0
- package/src/UI/Pages/ComposableScreen/elements/ImageElement.tsx +52 -0
- package/src/UI/Pages/ComposableScreen/elements/InputElement.tsx +115 -0
- package/src/UI/Pages/ComposableScreen/elements/LottieElement.tsx +97 -0
- package/src/UI/Pages/ComposableScreen/elements/RadioGroupElement.tsx +181 -0
- package/src/UI/Pages/ComposableScreen/elements/RiveElement.tsx +105 -0
- package/src/UI/Pages/ComposableScreen/elements/StackElement.tsx +103 -0
- package/src/UI/Pages/ComposableScreen/elements/TextElement.tsx +95 -0
- package/src/UI/Pages/ComposableScreen/elements/VideoElement.tsx +113 -0
- package/src/UI/Pages/ComposableScreen/elements/renderElement.tsx +61 -0
- package/src/UI/Pages/ComposableScreen/elements/shared.ts +15 -0
- package/src/UI/Pages/ComposableScreen/types.ts +56 -233
- 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":"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"}
|
|
@@ -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"}
|