@rocapine/react-native-onboarding-ui 1.0.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/Components/CircularProgress.d.ts +8 -0
- package/dist/UI/Components/CircularProgress.d.ts.map +1 -0
- package/dist/UI/Components/CircularProgress.js +104 -0
- package/dist/UI/Components/CircularProgress.js.map +1 -0
- package/dist/UI/Components/ProgressBar.d.ts +12 -0
- package/dist/UI/Components/ProgressBar.d.ts.map +1 -0
- package/dist/UI/Components/ProgressBar.js +121 -0
- package/dist/UI/Components/ProgressBar.js.map +1 -0
- package/dist/UI/Components/StaggeredTextList.d.ts +11 -0
- package/dist/UI/Components/StaggeredTextList.d.ts.map +1 -0
- package/dist/UI/Components/StaggeredTextList.js +111 -0
- package/dist/UI/Components/StaggeredTextList.js.map +1 -0
- package/dist/UI/Components/index.d.ts +4 -0
- package/dist/UI/Components/index.d.ts.map +1 -0
- package/dist/UI/Components/index.js +20 -0
- package/dist/UI/Components/index.js.map +1 -0
- package/dist/UI/ErrorBoundary/ErrorBoundary.d.ts +19 -0
- package/dist/UI/ErrorBoundary/ErrorBoundary.d.ts.map +1 -0
- package/dist/UI/ErrorBoundary/ErrorBoundary.js +123 -0
- package/dist/UI/ErrorBoundary/ErrorBoundary.js.map +1 -0
- package/dist/UI/ErrorBoundary/index.d.ts +3 -0
- package/dist/UI/ErrorBoundary/index.d.ts.map +1 -0
- package/dist/UI/ErrorBoundary/index.js +8 -0
- package/dist/UI/ErrorBoundary/index.js.map +1 -0
- package/dist/UI/ErrorBoundary/withErrorBoundary.d.ts +6 -0
- package/dist/UI/ErrorBoundary/withErrorBoundary.d.ts.map +1 -0
- package/dist/UI/ErrorBoundary/withErrorBoundary.js +13 -0
- package/dist/UI/ErrorBoundary/withErrorBoundary.js.map +1 -0
- package/dist/UI/OnboardingPage.d.ts +16 -0
- package/dist/UI/OnboardingPage.d.ts.map +1 -0
- package/dist/UI/OnboardingPage.js +38 -0
- package/dist/UI/OnboardingPage.js.map +1 -0
- package/dist/UI/Pages/Carousel/Renderer.d.ts +13 -0
- package/dist/UI/Pages/Carousel/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Carousel/Renderer.js +121 -0
- package/dist/UI/Pages/Carousel/Renderer.js.map +1 -0
- package/dist/UI/Pages/Carousel/index.d.ts +3 -0
- package/dist/UI/Pages/Carousel/index.d.ts.map +1 -0
- package/dist/UI/Pages/Carousel/index.js +19 -0
- package/dist/UI/Pages/Carousel/index.js.map +1 -0
- package/dist/UI/Pages/Carousel/types.d.ts +32 -0
- package/dist/UI/Pages/Carousel/types.d.ts.map +1 -0
- package/dist/UI/Pages/Carousel/types.js +24 -0
- package/dist/UI/Pages/Carousel/types.js.map +1 -0
- package/dist/UI/Pages/Commitment/Renderer.d.ts +13 -0
- package/dist/UI/Pages/Commitment/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Commitment/Renderer.js +173 -0
- package/dist/UI/Pages/Commitment/Renderer.js.map +1 -0
- package/dist/UI/Pages/Commitment/index.d.ts +3 -0
- package/dist/UI/Pages/Commitment/index.d.ts.map +1 -0
- package/dist/UI/Pages/Commitment/index.js +19 -0
- package/dist/UI/Pages/Commitment/index.js.map +1 -0
- package/dist/UI/Pages/Commitment/types.d.ts +41 -0
- package/dist/UI/Pages/Commitment/types.d.ts.map +1 -0
- package/dist/UI/Pages/Commitment/types.js +27 -0
- package/dist/UI/Pages/Commitment/types.js.map +1 -0
- package/dist/UI/Pages/Loader/Renderer.d.ts +10 -0
- package/dist/UI/Pages/Loader/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Loader/Renderer.js +215 -0
- package/dist/UI/Pages/Loader/Renderer.js.map +1 -0
- package/dist/UI/Pages/Loader/index.d.ts +3 -0
- package/dist/UI/Pages/Loader/index.d.ts.map +1 -0
- package/dist/UI/Pages/Loader/index.js +19 -0
- package/dist/UI/Pages/Loader/index.js.map +1 -0
- package/dist/UI/Pages/Loader/types.d.ts +57 -0
- package/dist/UI/Pages/Loader/types.d.ts.map +1 -0
- package/dist/UI/Pages/Loader/types.js +30 -0
- package/dist/UI/Pages/Loader/types.js.map +1 -0
- package/dist/UI/Pages/MediaContent/Renderer.d.ts +13 -0
- package/dist/UI/Pages/MediaContent/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/MediaContent/Renderer.js +76 -0
- package/dist/UI/Pages/MediaContent/Renderer.js.map +1 -0
- package/dist/UI/Pages/MediaContent/index.d.ts +3 -0
- package/dist/UI/Pages/MediaContent/index.d.ts.map +1 -0
- package/dist/UI/Pages/MediaContent/index.js +19 -0
- package/dist/UI/Pages/MediaContent/index.js.map +1 -0
- package/dist/UI/Pages/MediaContent/types.d.ts +44 -0
- package/dist/UI/Pages/MediaContent/types.d.ts.map +1 -0
- package/dist/UI/Pages/MediaContent/types.js +22 -0
- package/dist/UI/Pages/MediaContent/types.js.map +1 -0
- package/dist/UI/Pages/Picker/Renderer.d.ts +13 -0
- package/dist/UI/Pages/Picker/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Picker/Renderer.js +268 -0
- package/dist/UI/Pages/Picker/Renderer.js.map +1 -0
- package/dist/UI/Pages/Picker/index.d.ts +3 -0
- package/dist/UI/Pages/Picker/index.d.ts.map +1 -0
- package/dist/UI/Pages/Picker/index.js +19 -0
- package/dist/UI/Pages/Picker/index.js.map +1 -0
- package/dist/UI/Pages/Picker/types.d.ts +49 -0
- package/dist/UI/Pages/Picker/types.d.ts.map +1 -0
- package/dist/UI/Pages/Picker/types.js +30 -0
- package/dist/UI/Pages/Picker/types.js.map +1 -0
- package/dist/UI/Pages/Question/Renderer.d.ts +18 -0
- package/dist/UI/Pages/Question/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Question/Renderer.js +128 -0
- package/dist/UI/Pages/Question/Renderer.js.map +1 -0
- package/dist/UI/Pages/Question/components.d.ts +57 -0
- package/dist/UI/Pages/Question/components.d.ts.map +1 -0
- package/dist/UI/Pages/Question/components.js +57 -0
- package/dist/UI/Pages/Question/components.js.map +1 -0
- package/dist/UI/Pages/Question/index.d.ts +4 -0
- package/dist/UI/Pages/Question/index.d.ts.map +1 -0
- package/dist/UI/Pages/Question/index.js +20 -0
- package/dist/UI/Pages/Question/index.js.map +1 -0
- package/dist/UI/Pages/Question/types.d.ts +47 -0
- package/dist/UI/Pages/Question/types.d.ts.map +1 -0
- package/dist/UI/Pages/Question/types.js +28 -0
- package/dist/UI/Pages/Question/types.js.map +1 -0
- package/dist/UI/Pages/Ratings/Renderer.d.ts +13 -0
- package/dist/UI/Pages/Ratings/Renderer.d.ts.map +1 -0
- package/dist/UI/Pages/Ratings/Renderer.js +201 -0
- package/dist/UI/Pages/Ratings/Renderer.js.map +1 -0
- package/dist/UI/Pages/Ratings/index.d.ts +3 -0
- package/dist/UI/Pages/Ratings/index.d.ts.map +1 -0
- package/dist/UI/Pages/Ratings/index.js +19 -0
- package/dist/UI/Pages/Ratings/index.js.map +1 -0
- package/dist/UI/Pages/Ratings/types.d.ts +32 -0
- package/dist/UI/Pages/Ratings/types.d.ts.map +1 -0
- package/dist/UI/Pages/Ratings/types.js +25 -0
- package/dist/UI/Pages/Ratings/types.js.map +1 -0
- package/dist/UI/Pages/index.d.ts +9 -0
- package/dist/UI/Pages/index.d.ts.map +1 -0
- package/dist/UI/Pages/index.js +26 -0
- package/dist/UI/Pages/index.js.map +1 -0
- package/dist/UI/Pages/types.d.ts +19 -0
- package/dist/UI/Pages/types.d.ts.map +1 -0
- package/dist/UI/Pages/types.js +25 -0
- package/dist/UI/Pages/types.js.map +1 -0
- package/dist/UI/Provider/OnboardingProgressProvider.d.ts +18 -0
- package/dist/UI/Provider/OnboardingProgressProvider.d.ts.map +1 -0
- package/dist/UI/Provider/OnboardingProgressProvider.js +23 -0
- package/dist/UI/Provider/OnboardingProgressProvider.js.map +1 -0
- package/dist/UI/Provider/index.d.ts +2 -0
- package/dist/UI/Provider/index.d.ts.map +1 -0
- package/dist/UI/Provider/index.js +7 -0
- package/dist/UI/Provider/index.js.map +1 -0
- package/dist/UI/Templates/OnboardingTemplate.d.ts +15 -0
- package/dist/UI/Templates/OnboardingTemplate.d.ts.map +1 -0
- package/dist/UI/Templates/OnboardingTemplate.js +48 -0
- package/dist/UI/Templates/OnboardingTemplate.js.map +1 -0
- package/dist/UI/Templates/index.d.ts +2 -0
- package/dist/UI/Templates/index.d.ts.map +1 -0
- package/dist/UI/Templates/index.js +6 -0
- package/dist/UI/Templates/index.js.map +1 -0
- package/dist/UI/Theme/ThemeProvider.d.ts +27 -0
- package/dist/UI/Theme/ThemeProvider.d.ts.map +1 -0
- package/dist/UI/Theme/ThemeProvider.js +49 -0
- package/dist/UI/Theme/ThemeProvider.js.map +1 -0
- package/dist/UI/Theme/defaultTheme.d.ts +7 -0
- package/dist/UI/Theme/defaultTheme.d.ts.map +1 -0
- package/dist/UI/Theme/defaultTheme.js +14 -0
- package/dist/UI/Theme/defaultTheme.js.map +1 -0
- package/dist/UI/Theme/helpers.d.ts +12 -0
- package/dist/UI/Theme/helpers.d.ts.map +1 -0
- package/dist/UI/Theme/helpers.js +21 -0
- package/dist/UI/Theme/helpers.js.map +1 -0
- package/dist/UI/Theme/index.d.ts +8 -0
- package/dist/UI/Theme/index.d.ts.map +1 -0
- package/dist/UI/Theme/index.js +24 -0
- package/dist/UI/Theme/index.js.map +1 -0
- package/dist/UI/Theme/token.d.ts +107 -0
- package/dist/UI/Theme/token.d.ts.map +1 -0
- package/dist/UI/Theme/token.js +108 -0
- package/dist/UI/Theme/token.js.map +1 -0
- package/dist/UI/Theme/tokens/darkTokens.d.ts +24 -0
- package/dist/UI/Theme/tokens/darkTokens.d.ts.map +1 -0
- package/dist/UI/Theme/tokens/darkTokens.js +27 -0
- package/dist/UI/Theme/tokens/darkTokens.js.map +1 -0
- package/dist/UI/Theme/tokens/index.d.ts +4 -0
- package/dist/UI/Theme/tokens/index.d.ts.map +1 -0
- package/dist/UI/Theme/tokens/index.js +20 -0
- package/dist/UI/Theme/tokens/index.js.map +1 -0
- package/dist/UI/Theme/tokens/lightTokens.d.ts +24 -0
- package/dist/UI/Theme/tokens/lightTokens.d.ts.map +1 -0
- package/dist/UI/Theme/tokens/lightTokens.js +27 -0
- package/dist/UI/Theme/tokens/lightTokens.js.map +1 -0
- package/dist/UI/Theme/tokens/typography.d.ts +65 -0
- package/dist/UI/Theme/tokens/typography.d.ts.map +1 -0
- package/dist/UI/Theme/tokens/typography.js +68 -0
- package/dist/UI/Theme/tokens/typography.js.map +1 -0
- package/dist/UI/Theme/types.d.ts +65 -0
- package/dist/UI/Theme/types.d.ts.map +1 -0
- package/dist/UI/Theme/types.js +3 -0
- package/dist/UI/Theme/types.js.map +1 -0
- package/dist/UI/Theme/useTheme.d.ts +7 -0
- package/dist/UI/Theme/useTheme.d.ts.map +1 -0
- package/dist/UI/Theme/useTheme.js +23 -0
- package/dist/UI/Theme/useTheme.js.map +1 -0
- package/dist/UI/Theme/utils.d.ts +12 -0
- package/dist/UI/Theme/utils.d.ts.map +1 -0
- package/dist/UI/Theme/utils.js +55 -0
- package/dist/UI/Theme/utils.js.map +1 -0
- package/dist/UI/index.d.ts +8 -0
- package/dist/UI/index.d.ts.map +1 -0
- package/dist/UI/index.js +24 -0
- package/dist/UI/index.js.map +1 -0
- package/dist/UI/types.d.ts +23 -0
- package/dist/UI/types.d.ts.map +1 -0
- package/dist/UI/types.js +3 -0
- package/dist/UI/types.js.map +1 -0
- package/dist/assets/laurel-left.png +0 -0
- package/dist/assets/laurel-right.png +0 -0
- package/dist/assets/star-filled.png +0 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +33 -0
- package/dist/index.js.map +1 -0
- package/dist/provider/CustomComponentsContext.d.ts +57 -0
- package/dist/provider/CustomComponentsContext.d.ts.map +1 -0
- package/dist/provider/CustomComponentsContext.js +19 -0
- package/dist/provider/CustomComponentsContext.js.map +1 -0
- package/dist/provider/OnboardingUIProvider.d.ts +44 -0
- package/dist/provider/OnboardingUIProvider.d.ts.map +1 -0
- package/dist/provider/OnboardingUIProvider.js +33 -0
- package/dist/provider/OnboardingUIProvider.js.map +1 -0
- package/dist/provider/OnboardingUIProvider.old.d.ts +60 -0
- package/dist/provider/OnboardingUIProvider.old.d.ts.map +1 -0
- package/dist/provider/OnboardingUIProvider.old.js +53 -0
- package/dist/provider/OnboardingUIProvider.old.js.map +1 -0
- package/package.json +77 -0
- package/src/UI/Components/CircularProgress.tsx +146 -0
- package/src/UI/Components/ProgressBar.tsx +143 -0
- package/src/UI/Components/StaggeredTextList.tsx +152 -0
- package/src/UI/Components/index.ts +3 -0
- package/src/UI/ErrorBoundary/ErrorBoundary.tsx +181 -0
- package/src/UI/ErrorBoundary/README.md +71 -0
- package/src/UI/ErrorBoundary/index.ts +2 -0
- package/src/UI/ErrorBoundary/withErrorBoundary.tsx +19 -0
- package/src/UI/OnboardingPage.tsx +53 -0
- package/src/UI/Pages/Carousel/Renderer.tsx +210 -0
- package/src/UI/Pages/Carousel/index.ts +2 -0
- package/src/UI/Pages/Carousel/types.ts +26 -0
- package/src/UI/Pages/Commitment/Renderer.tsx +312 -0
- package/src/UI/Pages/Commitment/index.ts +2 -0
- package/src/UI/Pages/Commitment/types.ts +28 -0
- package/src/UI/Pages/Loader/Renderer.tsx +417 -0
- package/src/UI/Pages/Loader/index.ts +2 -0
- package/src/UI/Pages/Loader/types.ts +32 -0
- package/src/UI/Pages/MediaContent/Renderer.tsx +130 -0
- package/src/UI/Pages/MediaContent/index.ts +2 -0
- package/src/UI/Pages/MediaContent/types.ts +26 -0
- package/src/UI/Pages/Picker/Renderer.tsx +618 -0
- package/src/UI/Pages/Picker/index.ts +2 -0
- package/src/UI/Pages/Picker/types.ts +34 -0
- package/src/UI/Pages/Question/Renderer.tsx +208 -0
- package/src/UI/Pages/Question/components.tsx +130 -0
- package/src/UI/Pages/Question/index.ts +3 -0
- package/src/UI/Pages/Question/types.ts +29 -0
- package/src/UI/Pages/Ratings/Renderer.tsx +282 -0
- package/src/UI/Pages/Ratings/index.ts +2 -0
- package/src/UI/Pages/Ratings/types.ts +22 -0
- package/src/UI/Pages/index.ts +10 -0
- package/src/UI/Pages/types.ts +25 -0
- package/src/UI/Provider/OnboardingProgressProvider.tsx +40 -0
- package/src/UI/Provider/index.ts +1 -0
- package/src/UI/Templates/OnboardingTemplate.tsx +86 -0
- package/src/UI/Templates/index.ts +1 -0
- package/src/UI/Theme/ThemeProvider.tsx +100 -0
- package/src/UI/Theme/defaultTheme.ts +12 -0
- package/src/UI/Theme/helpers.ts +24 -0
- package/src/UI/Theme/index.ts +7 -0
- package/src/UI/Theme/token.ts +106 -0
- package/src/UI/Theme/tokens/darkTokens.ts +25 -0
- package/src/UI/Theme/tokens/index.ts +3 -0
- package/src/UI/Theme/tokens/lightTokens.ts +25 -0
- package/src/UI/Theme/tokens/typography.ts +66 -0
- package/src/UI/Theme/types.ts +72 -0
- package/src/UI/Theme/useTheme.ts +22 -0
- package/src/UI/Theme/utils.ts +67 -0
- package/src/UI/index.ts +7 -0
- package/src/UI/types.ts +41 -0
- package/src/assets/laurel-left.png +0 -0
- package/src/assets/laurel-right.png +0 -0
- package/src/assets/star-filled.png +0 -0
- package/src/index.ts +28 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
type CircularProgressProps = {
|
|
2
|
+
onProgressComplete?: () => void;
|
|
3
|
+
duration: number;
|
|
4
|
+
totalSteps: number;
|
|
5
|
+
};
|
|
6
|
+
export declare const CircularProgress: ({ onProgressComplete, duration, totalSteps, }: CircularProgressProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=CircularProgress.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CircularProgress.d.ts","sourceRoot":"","sources":["../../../src/UI/Components/CircularProgress.tsx"],"names":[],"mappings":"AAgBA,KAAK,qBAAqB,GAAG;IAC3B,kBAAkB,CAAC,EAAE,MAAM,IAAI,CAAC;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,+CAI9B,qBAAqB,4CA4FvB,CAAC"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.CircularProgress = void 0;
|
|
37
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
38
|
+
const react_1 = require("react");
|
|
39
|
+
const react_native_1 = require("react-native");
|
|
40
|
+
const react_native_reanimated_1 = __importStar(require("react-native-reanimated"));
|
|
41
|
+
const react_native_svg_1 = __importStar(require("react-native-svg"));
|
|
42
|
+
const useTheme_1 = require("../Theme/useTheme");
|
|
43
|
+
const AnimatedCircle = react_native_reanimated_1.default.createAnimatedComponent(react_native_svg_1.Circle);
|
|
44
|
+
const CircularProgress = ({ onProgressComplete, duration, totalSteps, }) => {
|
|
45
|
+
const { theme } = (0, useTheme_1.useTheme)();
|
|
46
|
+
const { width } = react_native_1.Dimensions.get("window");
|
|
47
|
+
const CIRCLE_RADIUS = 45;
|
|
48
|
+
const CIRCUMFERENCE = 2 * Math.PI * CIRCLE_RADIUS;
|
|
49
|
+
const strokeWidth = width * 0.02;
|
|
50
|
+
const progress = (0, react_native_reanimated_1.useSharedValue)(0);
|
|
51
|
+
const [percentage, setPercentage] = (0, react_1.useState)(0);
|
|
52
|
+
// Update percentage text using useAnimatedReaction
|
|
53
|
+
(0, react_native_reanimated_1.useAnimatedReaction)(() => progress.value, (currentValue) => {
|
|
54
|
+
(0, react_native_reanimated_1.runOnJS)(setPercentage)(Math.round(currentValue));
|
|
55
|
+
});
|
|
56
|
+
(0, react_1.useEffect)(() => {
|
|
57
|
+
// Reset progress
|
|
58
|
+
progress.value = 0;
|
|
59
|
+
// Match StaggeredTextList timing: (totalSteps - 1) * duration + duration * 1.5
|
|
60
|
+
const totalDuration = duration * (totalSteps + 0.5);
|
|
61
|
+
// Animate progress from 0 to 100
|
|
62
|
+
progress.value = (0, react_native_reanimated_1.withTiming)(100, {
|
|
63
|
+
duration: totalDuration,
|
|
64
|
+
easing: react_native_reanimated_1.Easing.bezier(0.25, 0.1, 0.25, 1),
|
|
65
|
+
}, (finished) => {
|
|
66
|
+
if (finished && onProgressComplete) {
|
|
67
|
+
(0, react_native_reanimated_1.runOnJS)(onProgressComplete)();
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}, [progress, duration, totalSteps, onProgressComplete]);
|
|
71
|
+
// Animate strokeDashoffset based on progress
|
|
72
|
+
const animatedCircleProps = (0, react_native_reanimated_1.useAnimatedProps)(() => ({
|
|
73
|
+
strokeDashoffset: CIRCUMFERENCE * (1 - progress.value / 100),
|
|
74
|
+
}));
|
|
75
|
+
const styles = createStyles(theme, width);
|
|
76
|
+
return ((0, jsx_runtime_1.jsxs)(react_native_1.View, { style: styles.container, children: [(0, jsx_runtime_1.jsxs)(react_native_svg_1.default, { height: "100%", width: "100%", viewBox: "0 0 100 100", children: [(0, jsx_runtime_1.jsx)(react_native_svg_1.Defs, { children: (0, jsx_runtime_1.jsxs)(react_native_svg_1.LinearGradient, { id: "progressGrad", x1: "0", y1: "0", x2: "0.2", y2: "1.1", children: [(0, jsx_runtime_1.jsx)(react_native_svg_1.Stop, { offset: "0", stopColor: theme.colors.neutral.medium }), (0, jsx_runtime_1.jsx)(react_native_svg_1.Stop, { offset: "0.33", stopColor: theme.colors.neutral.medium }), (0, jsx_runtime_1.jsx)(react_native_svg_1.Stop, { offset: "0.67", stopColor: theme.colors.neutral.low }), (0, jsx_runtime_1.jsx)(react_native_svg_1.Stop, { offset: "1", stopColor: theme.colors.neutral.low })] }) }), (0, jsx_runtime_1.jsx)(react_native_svg_1.Circle, { cx: "50", cy: "50", r: CIRCLE_RADIUS, stroke: theme.colors.neutral.lower, strokeWidth: strokeWidth, fill: "none" }), (0, jsx_runtime_1.jsx)(AnimatedCircle, { cx: "50", cy: "50", r: CIRCLE_RADIUS, stroke: "url(#progressGrad)", strokeWidth: strokeWidth, fill: "none", strokeDasharray: CIRCUMFERENCE, animatedProps: animatedCircleProps, strokeLinecap: "round", rotation: "-90", origin: "50, 50" })] }), (0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.textContainer, children: (0, jsx_runtime_1.jsxs)(react_native_1.Text, { style: styles.percentageText, children: [percentage, "%"] }) })] }));
|
|
77
|
+
};
|
|
78
|
+
exports.CircularProgress = CircularProgress;
|
|
79
|
+
const createStyles = (theme, width) => react_native_1.StyleSheet.create({
|
|
80
|
+
container: {
|
|
81
|
+
width: width * 0.7,
|
|
82
|
+
height: width * 0.7,
|
|
83
|
+
justifyContent: "center",
|
|
84
|
+
alignItems: "center",
|
|
85
|
+
position: "relative",
|
|
86
|
+
},
|
|
87
|
+
textContainer: {
|
|
88
|
+
position: "absolute",
|
|
89
|
+
justifyContent: "center",
|
|
90
|
+
alignItems: "center",
|
|
91
|
+
width: "100%",
|
|
92
|
+
height: "100%",
|
|
93
|
+
},
|
|
94
|
+
percentageText: {
|
|
95
|
+
fontFamily: theme.typography.textStyles.heading1.fontFamily,
|
|
96
|
+
fontSize: theme.typography.textStyles.heading1.fontSize,
|
|
97
|
+
fontWeight: theme.typography.fontWeight.bold,
|
|
98
|
+
color: theme.colors.text.primary,
|
|
99
|
+
textAlign: "center",
|
|
100
|
+
includeFontPadding: false,
|
|
101
|
+
padding: 0,
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
//# sourceMappingURL=CircularProgress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CircularProgress.js","sourceRoot":"","sources":["../../../src/UI/Components/CircularProgress.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Theme } from "../Theme";
|
|
3
|
+
interface ProgressBarProps {
|
|
4
|
+
backgroundColor?: string;
|
|
5
|
+
progressColor?: string;
|
|
6
|
+
progressPercentage: number;
|
|
7
|
+
theme?: Theme;
|
|
8
|
+
isProgressBarVisible?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare const ProgressBar: React.FC<ProgressBarProps>;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=ProgressBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../../src/UI/Components/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAUzC,OAAO,EAAgB,KAAK,EAAE,MAAM,UAAU,CAAC;AAE/C,UAAU,gBAAgB;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,oBAAoB,CAAC,EAAE,OAAO,CAAA;CAC/B;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAiFlD,CAAC"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.ProgressBar = void 0;
|
|
37
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
38
|
+
const react_1 = require("react");
|
|
39
|
+
const react_native_1 = require("react-native");
|
|
40
|
+
const react_native_reanimated_1 = __importStar(require("react-native-reanimated"));
|
|
41
|
+
const react_native_safe_area_context_1 = require("react-native-safe-area-context");
|
|
42
|
+
const lucide_react_native_1 = require("lucide-react-native");
|
|
43
|
+
const expo_router_1 = require("expo-router");
|
|
44
|
+
const Theme_1 = require("../Theme");
|
|
45
|
+
const ProgressBar = ({ backgroundColor, progressColor, progressPercentage = 0, theme = Theme_1.defaultTheme, isProgressBarVisible = true, }) => {
|
|
46
|
+
const animated = true;
|
|
47
|
+
const router = (0, expo_router_1.useRouter)();
|
|
48
|
+
const { top } = (0, react_native_safe_area_context_1.useSafeAreaInsets)();
|
|
49
|
+
const height = 12;
|
|
50
|
+
// Use Reanimated shared value for smooth animations
|
|
51
|
+
const progress = (0, react_native_reanimated_1.useSharedValue)(0);
|
|
52
|
+
(0, react_1.useEffect)(() => {
|
|
53
|
+
if (animated) {
|
|
54
|
+
progress.value = (0, react_native_reanimated_1.withTiming)(progressPercentage, {
|
|
55
|
+
duration: 300,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
progress.value = progressPercentage;
|
|
60
|
+
}
|
|
61
|
+
}, [progressPercentage, animated]);
|
|
62
|
+
// Animated style for the progress bar
|
|
63
|
+
const animatedStyle = (0, react_native_reanimated_1.useAnimatedStyle)(() => {
|
|
64
|
+
return {
|
|
65
|
+
width: `${progress.value}%`,
|
|
66
|
+
};
|
|
67
|
+
});
|
|
68
|
+
// Use theme colors with fallback to props
|
|
69
|
+
const trackBgColor = backgroundColor || theme.colors.neutral.lower;
|
|
70
|
+
const barColor = progressColor || theme.colors.primary;
|
|
71
|
+
return (isProgressBarVisible && ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: [styles.container, { paddingTop: top }], children: (0, jsx_runtime_1.jsxs)(react_native_1.View, { style: styles.progressBarContainer, children: [(0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.backButtonSection, children: router.canGoBack() && ((0, jsx_runtime_1.jsx)(react_native_1.TouchableOpacity, { onPress: () => router.back(), hitSlop: { top: 10, bottom: 10, left: 10, right: 10 }, style: styles.backButton, children: (0, jsx_runtime_1.jsx)(lucide_react_native_1.ChevronLeft, { size: 24, color: theme.colors.text.primary, strokeWidth: 2 }) })) }), (0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.progressSection, children: (0, jsx_runtime_1.jsx)(react_native_1.View, { style: [styles.track, { height, backgroundColor: trackBgColor }], children: (0, jsx_runtime_1.jsx)(react_native_reanimated_1.default.View, { style: [
|
|
72
|
+
styles.progress,
|
|
73
|
+
{
|
|
74
|
+
height,
|
|
75
|
+
backgroundColor: barColor,
|
|
76
|
+
},
|
|
77
|
+
animatedStyle,
|
|
78
|
+
] }) }) }), (0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.spacerSection })] }) })));
|
|
79
|
+
};
|
|
80
|
+
exports.ProgressBar = ProgressBar;
|
|
81
|
+
const styles = react_native_1.StyleSheet.create({
|
|
82
|
+
container: {
|
|
83
|
+
position: "absolute",
|
|
84
|
+
top: 0,
|
|
85
|
+
left: 0,
|
|
86
|
+
right: 0,
|
|
87
|
+
zIndex: 10,
|
|
88
|
+
justifyContent: "center",
|
|
89
|
+
paddingBottom: 24,
|
|
90
|
+
},
|
|
91
|
+
progressBarContainer: {
|
|
92
|
+
width: "100%",
|
|
93
|
+
flexDirection: "row",
|
|
94
|
+
alignItems: "center",
|
|
95
|
+
gap: 16,
|
|
96
|
+
paddingHorizontal: 16,
|
|
97
|
+
},
|
|
98
|
+
backButtonSection: {
|
|
99
|
+
flex: 1,
|
|
100
|
+
alignItems: "flex-start",
|
|
101
|
+
},
|
|
102
|
+
backButton: {
|
|
103
|
+
padding: 4,
|
|
104
|
+
},
|
|
105
|
+
progressSection: {
|
|
106
|
+
flex: 5,
|
|
107
|
+
alignItems: "flex-end",
|
|
108
|
+
},
|
|
109
|
+
spacerSection: {
|
|
110
|
+
flex: 1,
|
|
111
|
+
},
|
|
112
|
+
track: {
|
|
113
|
+
width: "100%",
|
|
114
|
+
borderRadius: 10,
|
|
115
|
+
overflow: "hidden",
|
|
116
|
+
},
|
|
117
|
+
progress: {
|
|
118
|
+
borderRadius: 10,
|
|
119
|
+
},
|
|
120
|
+
});
|
|
121
|
+
//# sourceMappingURL=ProgressBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../../src/UI/Components/ProgressBar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
type TextItem = {
|
|
2
|
+
label: string;
|
|
3
|
+
completed: string;
|
|
4
|
+
};
|
|
5
|
+
type StaggeredTextListProps = {
|
|
6
|
+
items: TextItem[];
|
|
7
|
+
duration: number;
|
|
8
|
+
};
|
|
9
|
+
export declare const StaggeredTextList: ({ items, duration, }: StaggeredTextListProps) => import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=StaggeredTextList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaggeredTextList.d.ts","sourceRoot":"","sources":["../../../src/UI/Components/StaggeredTextList.tsx"],"names":[],"mappings":"AAcA,KAAK,QAAQ,GAAG;IACd,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,KAAK,sBAAsB,GAAG;IAC5B,KAAK,EAAE,QAAQ,EAAE,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,iBAAiB,GAAI,sBAG/B,sBAAsB,4CAuCxB,CAAC"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.StaggeredTextList = void 0;
|
|
37
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
38
|
+
const react_1 = require("react");
|
|
39
|
+
const react_native_1 = require("react-native");
|
|
40
|
+
const react_native_reanimated_1 = __importStar(require("react-native-reanimated"));
|
|
41
|
+
const useTheme_1 = require("../Theme/useTheme");
|
|
42
|
+
const StaggeredTextList = ({ items, duration, }) => {
|
|
43
|
+
const { theme } = (0, useTheme_1.useTheme)();
|
|
44
|
+
const styles = createStyles(theme);
|
|
45
|
+
// Create a shared value to track the current active index
|
|
46
|
+
const activeIndex = (0, react_native_reanimated_1.useSharedValue)(0);
|
|
47
|
+
(0, react_1.useEffect)(() => {
|
|
48
|
+
// Reset animation
|
|
49
|
+
activeIndex.value = 0;
|
|
50
|
+
// Animate sequentially through each text
|
|
51
|
+
const animateSequentially = async () => {
|
|
52
|
+
for (let i = 0; i < items.length; i++) {
|
|
53
|
+
activeIndex.value = i;
|
|
54
|
+
// Wait for duration before moving to next
|
|
55
|
+
// Last item stays longer
|
|
56
|
+
const waitTime = i === items.length - 1 ? duration * 1.5 : duration;
|
|
57
|
+
await new Promise((resolve) => setTimeout(resolve, waitTime));
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
animateSequentially();
|
|
61
|
+
}, [items, duration, activeIndex]);
|
|
62
|
+
return ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.container, children: items.map((item, index) => ((0, jsx_runtime_1.jsx)(AnimatedTextItem, { item: item, index: index, activeIndex: activeIndex, totalItems: items.length }, index))) }));
|
|
63
|
+
};
|
|
64
|
+
exports.StaggeredTextList = StaggeredTextList;
|
|
65
|
+
const AnimatedTextItem = ({ item, index, activeIndex, totalItems, }) => {
|
|
66
|
+
const { theme } = (0, useTheme_1.useTheme)();
|
|
67
|
+
const styles = createStyles(theme);
|
|
68
|
+
const animatedStyle = (0, react_native_reanimated_1.useAnimatedStyle)(() => {
|
|
69
|
+
const isActive = activeIndex.value === index;
|
|
70
|
+
const wasActive = activeIndex.value > index;
|
|
71
|
+
const willBeActive = activeIndex.value < index;
|
|
72
|
+
// Opacity animation
|
|
73
|
+
const opacity = (0, react_native_reanimated_1.withTiming)(isActive ? 1 : wasActive ? 0.6 : willBeActive ? 0.4 : 0.4, {
|
|
74
|
+
duration: 400,
|
|
75
|
+
easing: react_native_reanimated_1.Easing.bezier(0.25, 0.1, 0.25, 1),
|
|
76
|
+
});
|
|
77
|
+
// Color interpolation
|
|
78
|
+
const color = (0, react_native_reanimated_1.interpolateColor)(isActive ? 1 : 0, [0, 1], [theme.colors.text.disable, theme.colors.text.primary]);
|
|
79
|
+
// Subtle translateY for active text
|
|
80
|
+
const translateY = (0, react_native_reanimated_1.withTiming)(isActive ? 0 : 2, {
|
|
81
|
+
duration: 300,
|
|
82
|
+
easing: react_native_reanimated_1.Easing.bezier(0.25, 0.1, 0.25, 1),
|
|
83
|
+
});
|
|
84
|
+
// Pulse effect for the last active item
|
|
85
|
+
const scale = isActive && index === totalItems - 1
|
|
86
|
+
? (0, react_native_reanimated_1.withSequence)((0, react_native_reanimated_1.withTiming)(1, { duration: 1000 }), (0, react_native_reanimated_1.withTiming)(1.05, { duration: 1000 }), (0, react_native_reanimated_1.withTiming)(1, { duration: 1000 }))
|
|
87
|
+
: 1;
|
|
88
|
+
return {
|
|
89
|
+
opacity,
|
|
90
|
+
color,
|
|
91
|
+
transform: [{ translateY }, { scale }],
|
|
92
|
+
};
|
|
93
|
+
});
|
|
94
|
+
return ((0, jsx_runtime_1.jsx)(react_native_reanimated_1.default.Text, { style: [styles.text, animatedStyle], children: item.label }));
|
|
95
|
+
};
|
|
96
|
+
const createStyles = (theme) => react_native_1.StyleSheet.create({
|
|
97
|
+
container: {
|
|
98
|
+
gap: 8,
|
|
99
|
+
alignItems: "center",
|
|
100
|
+
width: "100%",
|
|
101
|
+
},
|
|
102
|
+
text: {
|
|
103
|
+
fontFamily: theme.typography.textStyles.heading3.fontFamily,
|
|
104
|
+
fontSize: theme.typography.textStyles.heading3.fontSize,
|
|
105
|
+
fontWeight: theme.typography.fontWeight.medium,
|
|
106
|
+
textAlign: "center",
|
|
107
|
+
lineHeight: theme.typography.textStyles.heading3.fontSize * theme.typography.lineHeight.normal,
|
|
108
|
+
letterSpacing: 0.3,
|
|
109
|
+
},
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=StaggeredTextList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaggeredTextList.js","sourceRoot":"","sources":["../../../src/UI/Components/StaggeredTextList.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/UI/Components/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./ProgressBar"), exports);
|
|
18
|
+
__exportStar(require("./CircularProgress"), exports);
|
|
19
|
+
__exportStar(require("./StaggeredTextList"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/UI/Components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,qDAAmC;AACnC,sDAAoC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React, { Component, ReactNode } from 'react';
|
|
2
|
+
import { ZodError } from 'zod';
|
|
3
|
+
interface ErrorBoundaryProps {
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
stepType?: string;
|
|
6
|
+
}
|
|
7
|
+
interface ErrorBoundaryState {
|
|
8
|
+
hasError: boolean;
|
|
9
|
+
error: Error | null;
|
|
10
|
+
}
|
|
11
|
+
export declare class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
|
|
12
|
+
constructor(props: ErrorBoundaryProps);
|
|
13
|
+
static getDerivedStateFromError(error: Error): ErrorBoundaryState;
|
|
14
|
+
componentDidCatch(error: Error, errorInfo: React.ErrorInfo): void;
|
|
15
|
+
formatZodError(error: ZodError<any>): string;
|
|
16
|
+
render(): string | number | bigint | boolean | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | import("react/jsx-runtime").JSX.Element | null | undefined;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=ErrorBoundary.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorBoundary.d.ts","sourceRoot":"","sources":["../../../src/UI/ErrorBoundary/ErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEpD,OAAO,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAE/B,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,SAAS,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;CACrB;AAED,qBAAa,aAAc,SAAQ,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;gBACtE,KAAK,EAAE,kBAAkB;IAKrC,MAAM,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,GAAG,kBAAkB;IAIjE,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS;IAI1D,cAAc,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,MAAM;IAgB5C,MAAM;CAyDP"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ErrorBoundary = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const react_native_1 = require("react-native");
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
class ErrorBoundary extends react_1.Component {
|
|
9
|
+
constructor(props) {
|
|
10
|
+
super(props);
|
|
11
|
+
this.state = { hasError: false, error: null };
|
|
12
|
+
}
|
|
13
|
+
static getDerivedStateFromError(error) {
|
|
14
|
+
return { hasError: true, error };
|
|
15
|
+
}
|
|
16
|
+
componentDidCatch(error, errorInfo) {
|
|
17
|
+
console.error('ErrorBoundary caught an error:', error, errorInfo);
|
|
18
|
+
}
|
|
19
|
+
formatZodError(error) {
|
|
20
|
+
try {
|
|
21
|
+
// @ts-ignore
|
|
22
|
+
return error.errors
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
.map((err) => {
|
|
25
|
+
const path = err.path.join(' > ');
|
|
26
|
+
return `• ${path || 'root'}: ${err.message}`;
|
|
27
|
+
})
|
|
28
|
+
.join('\n');
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
console.error('Error formatting Zod error:', error);
|
|
32
|
+
return 'An error occurred while formatting the Zod error';
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
render() {
|
|
36
|
+
if (this.state.hasError && this.state.error) {
|
|
37
|
+
const isZodError = this.state.error instanceof zod_1.ZodError;
|
|
38
|
+
const { stepType } = this.props;
|
|
39
|
+
return ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.container, children: (0, jsx_runtime_1.jsxs)(react_native_1.View, { style: styles.content, children: [(0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.emoji, children: "\u26A0\uFE0F" }), (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.title, children: isZodError ? 'Invalid Step Payload' : 'Something went wrong' }), stepType && ((0, jsx_runtime_1.jsxs)(react_native_1.Text, { style: styles.stepType, children: ["Step Type: ", stepType] })), (0, jsx_runtime_1.jsx)(react_native_1.ScrollView, { style: styles.errorScroll, contentContainerStyle: styles.errorScrollContent, children: isZodError ? ((0, jsx_runtime_1.jsxs)(react_native_1.View, { style: styles.errorSection, children: [(0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorLabel, children: "Validation Errors:" }), (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorMessage, children: this.formatZodError(this.state.error) })] })) : ((0, jsx_runtime_1.jsxs)(react_native_1.View, { style: styles.errorSection, children: [(0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorLabel, children: "Error Message:" }), (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorMessage, children: this.state.error.message }), this.state.error.stack && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorLabel, children: "Stack Trace:" }), (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.errorStack, children: this.state.error.stack })] }))] })) }), isZodError && ((0, jsx_runtime_1.jsx)(react_native_1.View, { style: styles.hint, children: (0, jsx_runtime_1.jsx)(react_native_1.Text, { style: styles.hintText, children: "\uD83D\uDCA1 Check the step payload structure and ensure all required fields match the schema." }) }))] }) }));
|
|
40
|
+
}
|
|
41
|
+
return this.props.children;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.ErrorBoundary = ErrorBoundary;
|
|
45
|
+
const styles = react_native_1.StyleSheet.create({
|
|
46
|
+
container: {
|
|
47
|
+
flex: 1,
|
|
48
|
+
backgroundColor: '#fff',
|
|
49
|
+
justifyContent: 'center',
|
|
50
|
+
alignItems: 'center',
|
|
51
|
+
padding: 20,
|
|
52
|
+
},
|
|
53
|
+
content: {
|
|
54
|
+
maxWidth: 600,
|
|
55
|
+
width: '100%',
|
|
56
|
+
alignItems: 'center',
|
|
57
|
+
},
|
|
58
|
+
emoji: {
|
|
59
|
+
fontSize: 48,
|
|
60
|
+
marginBottom: 16,
|
|
61
|
+
},
|
|
62
|
+
title: {
|
|
63
|
+
fontSize: 24,
|
|
64
|
+
fontWeight: '600',
|
|
65
|
+
color: '#dc2626',
|
|
66
|
+
marginBottom: 8,
|
|
67
|
+
textAlign: 'center',
|
|
68
|
+
},
|
|
69
|
+
stepType: {
|
|
70
|
+
fontSize: 16,
|
|
71
|
+
fontWeight: '500',
|
|
72
|
+
color: '#6b7280',
|
|
73
|
+
marginBottom: 24,
|
|
74
|
+
textAlign: 'center',
|
|
75
|
+
},
|
|
76
|
+
errorScroll: {
|
|
77
|
+
maxHeight: 400,
|
|
78
|
+
width: '100%',
|
|
79
|
+
},
|
|
80
|
+
errorScrollContent: {
|
|
81
|
+
paddingVertical: 16,
|
|
82
|
+
},
|
|
83
|
+
errorSection: {
|
|
84
|
+
backgroundColor: '#fef2f2',
|
|
85
|
+
borderRadius: 12,
|
|
86
|
+
padding: 16,
|
|
87
|
+
borderLeftWidth: 4,
|
|
88
|
+
borderLeftColor: '#dc2626',
|
|
89
|
+
},
|
|
90
|
+
errorLabel: {
|
|
91
|
+
fontSize: 14,
|
|
92
|
+
fontWeight: '600',
|
|
93
|
+
color: '#991b1b',
|
|
94
|
+
marginBottom: 8,
|
|
95
|
+
},
|
|
96
|
+
errorMessage: {
|
|
97
|
+
fontSize: 14,
|
|
98
|
+
color: '#7f1d1d',
|
|
99
|
+
fontFamily: 'Courier',
|
|
100
|
+
lineHeight: 20,
|
|
101
|
+
},
|
|
102
|
+
errorStack: {
|
|
103
|
+
fontSize: 12,
|
|
104
|
+
color: '#991b1b',
|
|
105
|
+
fontFamily: 'Courier',
|
|
106
|
+
lineHeight: 16,
|
|
107
|
+
marginTop: 8,
|
|
108
|
+
},
|
|
109
|
+
hint: {
|
|
110
|
+
marginTop: 24,
|
|
111
|
+
backgroundColor: '#eff6ff',
|
|
112
|
+
borderRadius: 8,
|
|
113
|
+
padding: 12,
|
|
114
|
+
borderLeftWidth: 3,
|
|
115
|
+
borderLeftColor: '#3b82f6',
|
|
116
|
+
},
|
|
117
|
+
hintText: {
|
|
118
|
+
fontSize: 14,
|
|
119
|
+
color: '#1e40af',
|
|
120
|
+
lineHeight: 20,
|
|
121
|
+
},
|
|
122
|
+
});
|
|
123
|
+
//# sourceMappingURL=ErrorBoundary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorBoundary.js","sourceRoot":"","sources":["../../../src/UI/ErrorBoundary/ErrorBoundary.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/UI/ErrorBoundary/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.withErrorBoundary = exports.ErrorBoundary = void 0;
|
|
4
|
+
var ErrorBoundary_1 = require("./ErrorBoundary");
|
|
5
|
+
Object.defineProperty(exports, "ErrorBoundary", { enumerable: true, get: function () { return ErrorBoundary_1.ErrorBoundary; } });
|
|
6
|
+
var withErrorBoundary_1 = require("./withErrorBoundary");
|
|
7
|
+
Object.defineProperty(exports, "withErrorBoundary", { enumerable: true, get: function () { return withErrorBoundary_1.withErrorBoundary; } });
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/UI/ErrorBoundary/index.ts"],"names":[],"mappings":";;;AAAA,iDAAgD;AAAvC,8GAAA,aAAa,OAAA;AACtB,yDAAwD;AAA/C,sHAAA,iBAAiB,OAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare function withErrorBoundary<P extends object>(Component: React.ComponentType<P>, stepType?: string): {
|
|
3
|
+
(props: P): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
displayName: string;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=withErrorBoundary.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withErrorBoundary.d.ts","sourceRoot":"","sources":["../../../src/UI/ErrorBoundary/withErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,wBAAgB,iBAAiB,CAAC,CAAC,SAAS,MAAM,EAChD,SAAS,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,EACjC,QAAQ,CAAC,EAAE,MAAM;YAEgB,CAAC;;EAWnC"}
|