@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.
Files changed (275) hide show
  1. package/dist/UI/Components/CircularProgress.d.ts +8 -0
  2. package/dist/UI/Components/CircularProgress.d.ts.map +1 -0
  3. package/dist/UI/Components/CircularProgress.js +104 -0
  4. package/dist/UI/Components/CircularProgress.js.map +1 -0
  5. package/dist/UI/Components/ProgressBar.d.ts +12 -0
  6. package/dist/UI/Components/ProgressBar.d.ts.map +1 -0
  7. package/dist/UI/Components/ProgressBar.js +121 -0
  8. package/dist/UI/Components/ProgressBar.js.map +1 -0
  9. package/dist/UI/Components/StaggeredTextList.d.ts +11 -0
  10. package/dist/UI/Components/StaggeredTextList.d.ts.map +1 -0
  11. package/dist/UI/Components/StaggeredTextList.js +111 -0
  12. package/dist/UI/Components/StaggeredTextList.js.map +1 -0
  13. package/dist/UI/Components/index.d.ts +4 -0
  14. package/dist/UI/Components/index.d.ts.map +1 -0
  15. package/dist/UI/Components/index.js +20 -0
  16. package/dist/UI/Components/index.js.map +1 -0
  17. package/dist/UI/ErrorBoundary/ErrorBoundary.d.ts +19 -0
  18. package/dist/UI/ErrorBoundary/ErrorBoundary.d.ts.map +1 -0
  19. package/dist/UI/ErrorBoundary/ErrorBoundary.js +123 -0
  20. package/dist/UI/ErrorBoundary/ErrorBoundary.js.map +1 -0
  21. package/dist/UI/ErrorBoundary/index.d.ts +3 -0
  22. package/dist/UI/ErrorBoundary/index.d.ts.map +1 -0
  23. package/dist/UI/ErrorBoundary/index.js +8 -0
  24. package/dist/UI/ErrorBoundary/index.js.map +1 -0
  25. package/dist/UI/ErrorBoundary/withErrorBoundary.d.ts +6 -0
  26. package/dist/UI/ErrorBoundary/withErrorBoundary.d.ts.map +1 -0
  27. package/dist/UI/ErrorBoundary/withErrorBoundary.js +13 -0
  28. package/dist/UI/ErrorBoundary/withErrorBoundary.js.map +1 -0
  29. package/dist/UI/OnboardingPage.d.ts +16 -0
  30. package/dist/UI/OnboardingPage.d.ts.map +1 -0
  31. package/dist/UI/OnboardingPage.js +38 -0
  32. package/dist/UI/OnboardingPage.js.map +1 -0
  33. package/dist/UI/Pages/Carousel/Renderer.d.ts +13 -0
  34. package/dist/UI/Pages/Carousel/Renderer.d.ts.map +1 -0
  35. package/dist/UI/Pages/Carousel/Renderer.js +121 -0
  36. package/dist/UI/Pages/Carousel/Renderer.js.map +1 -0
  37. package/dist/UI/Pages/Carousel/index.d.ts +3 -0
  38. package/dist/UI/Pages/Carousel/index.d.ts.map +1 -0
  39. package/dist/UI/Pages/Carousel/index.js +19 -0
  40. package/dist/UI/Pages/Carousel/index.js.map +1 -0
  41. package/dist/UI/Pages/Carousel/types.d.ts +32 -0
  42. package/dist/UI/Pages/Carousel/types.d.ts.map +1 -0
  43. package/dist/UI/Pages/Carousel/types.js +24 -0
  44. package/dist/UI/Pages/Carousel/types.js.map +1 -0
  45. package/dist/UI/Pages/Commitment/Renderer.d.ts +13 -0
  46. package/dist/UI/Pages/Commitment/Renderer.d.ts.map +1 -0
  47. package/dist/UI/Pages/Commitment/Renderer.js +173 -0
  48. package/dist/UI/Pages/Commitment/Renderer.js.map +1 -0
  49. package/dist/UI/Pages/Commitment/index.d.ts +3 -0
  50. package/dist/UI/Pages/Commitment/index.d.ts.map +1 -0
  51. package/dist/UI/Pages/Commitment/index.js +19 -0
  52. package/dist/UI/Pages/Commitment/index.js.map +1 -0
  53. package/dist/UI/Pages/Commitment/types.d.ts +41 -0
  54. package/dist/UI/Pages/Commitment/types.d.ts.map +1 -0
  55. package/dist/UI/Pages/Commitment/types.js +27 -0
  56. package/dist/UI/Pages/Commitment/types.js.map +1 -0
  57. package/dist/UI/Pages/Loader/Renderer.d.ts +10 -0
  58. package/dist/UI/Pages/Loader/Renderer.d.ts.map +1 -0
  59. package/dist/UI/Pages/Loader/Renderer.js +215 -0
  60. package/dist/UI/Pages/Loader/Renderer.js.map +1 -0
  61. package/dist/UI/Pages/Loader/index.d.ts +3 -0
  62. package/dist/UI/Pages/Loader/index.d.ts.map +1 -0
  63. package/dist/UI/Pages/Loader/index.js +19 -0
  64. package/dist/UI/Pages/Loader/index.js.map +1 -0
  65. package/dist/UI/Pages/Loader/types.d.ts +57 -0
  66. package/dist/UI/Pages/Loader/types.d.ts.map +1 -0
  67. package/dist/UI/Pages/Loader/types.js +30 -0
  68. package/dist/UI/Pages/Loader/types.js.map +1 -0
  69. package/dist/UI/Pages/MediaContent/Renderer.d.ts +13 -0
  70. package/dist/UI/Pages/MediaContent/Renderer.d.ts.map +1 -0
  71. package/dist/UI/Pages/MediaContent/Renderer.js +76 -0
  72. package/dist/UI/Pages/MediaContent/Renderer.js.map +1 -0
  73. package/dist/UI/Pages/MediaContent/index.d.ts +3 -0
  74. package/dist/UI/Pages/MediaContent/index.d.ts.map +1 -0
  75. package/dist/UI/Pages/MediaContent/index.js +19 -0
  76. package/dist/UI/Pages/MediaContent/index.js.map +1 -0
  77. package/dist/UI/Pages/MediaContent/types.d.ts +44 -0
  78. package/dist/UI/Pages/MediaContent/types.d.ts.map +1 -0
  79. package/dist/UI/Pages/MediaContent/types.js +22 -0
  80. package/dist/UI/Pages/MediaContent/types.js.map +1 -0
  81. package/dist/UI/Pages/Picker/Renderer.d.ts +13 -0
  82. package/dist/UI/Pages/Picker/Renderer.d.ts.map +1 -0
  83. package/dist/UI/Pages/Picker/Renderer.js +268 -0
  84. package/dist/UI/Pages/Picker/Renderer.js.map +1 -0
  85. package/dist/UI/Pages/Picker/index.d.ts +3 -0
  86. package/dist/UI/Pages/Picker/index.d.ts.map +1 -0
  87. package/dist/UI/Pages/Picker/index.js +19 -0
  88. package/dist/UI/Pages/Picker/index.js.map +1 -0
  89. package/dist/UI/Pages/Picker/types.d.ts +49 -0
  90. package/dist/UI/Pages/Picker/types.d.ts.map +1 -0
  91. package/dist/UI/Pages/Picker/types.js +30 -0
  92. package/dist/UI/Pages/Picker/types.js.map +1 -0
  93. package/dist/UI/Pages/Question/Renderer.d.ts +18 -0
  94. package/dist/UI/Pages/Question/Renderer.d.ts.map +1 -0
  95. package/dist/UI/Pages/Question/Renderer.js +128 -0
  96. package/dist/UI/Pages/Question/Renderer.js.map +1 -0
  97. package/dist/UI/Pages/Question/components.d.ts +57 -0
  98. package/dist/UI/Pages/Question/components.d.ts.map +1 -0
  99. package/dist/UI/Pages/Question/components.js +57 -0
  100. package/dist/UI/Pages/Question/components.js.map +1 -0
  101. package/dist/UI/Pages/Question/index.d.ts +4 -0
  102. package/dist/UI/Pages/Question/index.d.ts.map +1 -0
  103. package/dist/UI/Pages/Question/index.js +20 -0
  104. package/dist/UI/Pages/Question/index.js.map +1 -0
  105. package/dist/UI/Pages/Question/types.d.ts +47 -0
  106. package/dist/UI/Pages/Question/types.d.ts.map +1 -0
  107. package/dist/UI/Pages/Question/types.js +28 -0
  108. package/dist/UI/Pages/Question/types.js.map +1 -0
  109. package/dist/UI/Pages/Ratings/Renderer.d.ts +13 -0
  110. package/dist/UI/Pages/Ratings/Renderer.d.ts.map +1 -0
  111. package/dist/UI/Pages/Ratings/Renderer.js +201 -0
  112. package/dist/UI/Pages/Ratings/Renderer.js.map +1 -0
  113. package/dist/UI/Pages/Ratings/index.d.ts +3 -0
  114. package/dist/UI/Pages/Ratings/index.d.ts.map +1 -0
  115. package/dist/UI/Pages/Ratings/index.js +19 -0
  116. package/dist/UI/Pages/Ratings/index.js.map +1 -0
  117. package/dist/UI/Pages/Ratings/types.d.ts +32 -0
  118. package/dist/UI/Pages/Ratings/types.d.ts.map +1 -0
  119. package/dist/UI/Pages/Ratings/types.js +25 -0
  120. package/dist/UI/Pages/Ratings/types.js.map +1 -0
  121. package/dist/UI/Pages/index.d.ts +9 -0
  122. package/dist/UI/Pages/index.d.ts.map +1 -0
  123. package/dist/UI/Pages/index.js +26 -0
  124. package/dist/UI/Pages/index.js.map +1 -0
  125. package/dist/UI/Pages/types.d.ts +19 -0
  126. package/dist/UI/Pages/types.d.ts.map +1 -0
  127. package/dist/UI/Pages/types.js +25 -0
  128. package/dist/UI/Pages/types.js.map +1 -0
  129. package/dist/UI/Provider/OnboardingProgressProvider.d.ts +18 -0
  130. package/dist/UI/Provider/OnboardingProgressProvider.d.ts.map +1 -0
  131. package/dist/UI/Provider/OnboardingProgressProvider.js +23 -0
  132. package/dist/UI/Provider/OnboardingProgressProvider.js.map +1 -0
  133. package/dist/UI/Provider/index.d.ts +2 -0
  134. package/dist/UI/Provider/index.d.ts.map +1 -0
  135. package/dist/UI/Provider/index.js +7 -0
  136. package/dist/UI/Provider/index.js.map +1 -0
  137. package/dist/UI/Templates/OnboardingTemplate.d.ts +15 -0
  138. package/dist/UI/Templates/OnboardingTemplate.d.ts.map +1 -0
  139. package/dist/UI/Templates/OnboardingTemplate.js +48 -0
  140. package/dist/UI/Templates/OnboardingTemplate.js.map +1 -0
  141. package/dist/UI/Templates/index.d.ts +2 -0
  142. package/dist/UI/Templates/index.d.ts.map +1 -0
  143. package/dist/UI/Templates/index.js +6 -0
  144. package/dist/UI/Templates/index.js.map +1 -0
  145. package/dist/UI/Theme/ThemeProvider.d.ts +27 -0
  146. package/dist/UI/Theme/ThemeProvider.d.ts.map +1 -0
  147. package/dist/UI/Theme/ThemeProvider.js +49 -0
  148. package/dist/UI/Theme/ThemeProvider.js.map +1 -0
  149. package/dist/UI/Theme/defaultTheme.d.ts +7 -0
  150. package/dist/UI/Theme/defaultTheme.d.ts.map +1 -0
  151. package/dist/UI/Theme/defaultTheme.js +14 -0
  152. package/dist/UI/Theme/defaultTheme.js.map +1 -0
  153. package/dist/UI/Theme/helpers.d.ts +12 -0
  154. package/dist/UI/Theme/helpers.d.ts.map +1 -0
  155. package/dist/UI/Theme/helpers.js +21 -0
  156. package/dist/UI/Theme/helpers.js.map +1 -0
  157. package/dist/UI/Theme/index.d.ts +8 -0
  158. package/dist/UI/Theme/index.d.ts.map +1 -0
  159. package/dist/UI/Theme/index.js +24 -0
  160. package/dist/UI/Theme/index.js.map +1 -0
  161. package/dist/UI/Theme/token.d.ts +107 -0
  162. package/dist/UI/Theme/token.d.ts.map +1 -0
  163. package/dist/UI/Theme/token.js +108 -0
  164. package/dist/UI/Theme/token.js.map +1 -0
  165. package/dist/UI/Theme/tokens/darkTokens.d.ts +24 -0
  166. package/dist/UI/Theme/tokens/darkTokens.d.ts.map +1 -0
  167. package/dist/UI/Theme/tokens/darkTokens.js +27 -0
  168. package/dist/UI/Theme/tokens/darkTokens.js.map +1 -0
  169. package/dist/UI/Theme/tokens/index.d.ts +4 -0
  170. package/dist/UI/Theme/tokens/index.d.ts.map +1 -0
  171. package/dist/UI/Theme/tokens/index.js +20 -0
  172. package/dist/UI/Theme/tokens/index.js.map +1 -0
  173. package/dist/UI/Theme/tokens/lightTokens.d.ts +24 -0
  174. package/dist/UI/Theme/tokens/lightTokens.d.ts.map +1 -0
  175. package/dist/UI/Theme/tokens/lightTokens.js +27 -0
  176. package/dist/UI/Theme/tokens/lightTokens.js.map +1 -0
  177. package/dist/UI/Theme/tokens/typography.d.ts +65 -0
  178. package/dist/UI/Theme/tokens/typography.d.ts.map +1 -0
  179. package/dist/UI/Theme/tokens/typography.js +68 -0
  180. package/dist/UI/Theme/tokens/typography.js.map +1 -0
  181. package/dist/UI/Theme/types.d.ts +65 -0
  182. package/dist/UI/Theme/types.d.ts.map +1 -0
  183. package/dist/UI/Theme/types.js +3 -0
  184. package/dist/UI/Theme/types.js.map +1 -0
  185. package/dist/UI/Theme/useTheme.d.ts +7 -0
  186. package/dist/UI/Theme/useTheme.d.ts.map +1 -0
  187. package/dist/UI/Theme/useTheme.js +23 -0
  188. package/dist/UI/Theme/useTheme.js.map +1 -0
  189. package/dist/UI/Theme/utils.d.ts +12 -0
  190. package/dist/UI/Theme/utils.d.ts.map +1 -0
  191. package/dist/UI/Theme/utils.js +55 -0
  192. package/dist/UI/Theme/utils.js.map +1 -0
  193. package/dist/UI/index.d.ts +8 -0
  194. package/dist/UI/index.d.ts.map +1 -0
  195. package/dist/UI/index.js +24 -0
  196. package/dist/UI/index.js.map +1 -0
  197. package/dist/UI/types.d.ts +23 -0
  198. package/dist/UI/types.d.ts.map +1 -0
  199. package/dist/UI/types.js +3 -0
  200. package/dist/UI/types.js.map +1 -0
  201. package/dist/assets/laurel-left.png +0 -0
  202. package/dist/assets/laurel-right.png +0 -0
  203. package/dist/assets/star-filled.png +0 -0
  204. package/dist/index.d.ts +9 -0
  205. package/dist/index.d.ts.map +1 -0
  206. package/dist/index.js +33 -0
  207. package/dist/index.js.map +1 -0
  208. package/dist/provider/CustomComponentsContext.d.ts +57 -0
  209. package/dist/provider/CustomComponentsContext.d.ts.map +1 -0
  210. package/dist/provider/CustomComponentsContext.js +19 -0
  211. package/dist/provider/CustomComponentsContext.js.map +1 -0
  212. package/dist/provider/OnboardingUIProvider.d.ts +44 -0
  213. package/dist/provider/OnboardingUIProvider.d.ts.map +1 -0
  214. package/dist/provider/OnboardingUIProvider.js +33 -0
  215. package/dist/provider/OnboardingUIProvider.js.map +1 -0
  216. package/dist/provider/OnboardingUIProvider.old.d.ts +60 -0
  217. package/dist/provider/OnboardingUIProvider.old.d.ts.map +1 -0
  218. package/dist/provider/OnboardingUIProvider.old.js +53 -0
  219. package/dist/provider/OnboardingUIProvider.old.js.map +1 -0
  220. package/package.json +77 -0
  221. package/src/UI/Components/CircularProgress.tsx +146 -0
  222. package/src/UI/Components/ProgressBar.tsx +143 -0
  223. package/src/UI/Components/StaggeredTextList.tsx +152 -0
  224. package/src/UI/Components/index.ts +3 -0
  225. package/src/UI/ErrorBoundary/ErrorBoundary.tsx +181 -0
  226. package/src/UI/ErrorBoundary/README.md +71 -0
  227. package/src/UI/ErrorBoundary/index.ts +2 -0
  228. package/src/UI/ErrorBoundary/withErrorBoundary.tsx +19 -0
  229. package/src/UI/OnboardingPage.tsx +53 -0
  230. package/src/UI/Pages/Carousel/Renderer.tsx +210 -0
  231. package/src/UI/Pages/Carousel/index.ts +2 -0
  232. package/src/UI/Pages/Carousel/types.ts +26 -0
  233. package/src/UI/Pages/Commitment/Renderer.tsx +312 -0
  234. package/src/UI/Pages/Commitment/index.ts +2 -0
  235. package/src/UI/Pages/Commitment/types.ts +28 -0
  236. package/src/UI/Pages/Loader/Renderer.tsx +417 -0
  237. package/src/UI/Pages/Loader/index.ts +2 -0
  238. package/src/UI/Pages/Loader/types.ts +32 -0
  239. package/src/UI/Pages/MediaContent/Renderer.tsx +130 -0
  240. package/src/UI/Pages/MediaContent/index.ts +2 -0
  241. package/src/UI/Pages/MediaContent/types.ts +26 -0
  242. package/src/UI/Pages/Picker/Renderer.tsx +618 -0
  243. package/src/UI/Pages/Picker/index.ts +2 -0
  244. package/src/UI/Pages/Picker/types.ts +34 -0
  245. package/src/UI/Pages/Question/Renderer.tsx +208 -0
  246. package/src/UI/Pages/Question/components.tsx +130 -0
  247. package/src/UI/Pages/Question/index.ts +3 -0
  248. package/src/UI/Pages/Question/types.ts +29 -0
  249. package/src/UI/Pages/Ratings/Renderer.tsx +282 -0
  250. package/src/UI/Pages/Ratings/index.ts +2 -0
  251. package/src/UI/Pages/Ratings/types.ts +22 -0
  252. package/src/UI/Pages/index.ts +10 -0
  253. package/src/UI/Pages/types.ts +25 -0
  254. package/src/UI/Provider/OnboardingProgressProvider.tsx +40 -0
  255. package/src/UI/Provider/index.ts +1 -0
  256. package/src/UI/Templates/OnboardingTemplate.tsx +86 -0
  257. package/src/UI/Templates/index.ts +1 -0
  258. package/src/UI/Theme/ThemeProvider.tsx +100 -0
  259. package/src/UI/Theme/defaultTheme.ts +12 -0
  260. package/src/UI/Theme/helpers.ts +24 -0
  261. package/src/UI/Theme/index.ts +7 -0
  262. package/src/UI/Theme/token.ts +106 -0
  263. package/src/UI/Theme/tokens/darkTokens.ts +25 -0
  264. package/src/UI/Theme/tokens/index.ts +3 -0
  265. package/src/UI/Theme/tokens/lightTokens.ts +25 -0
  266. package/src/UI/Theme/tokens/typography.ts +66 -0
  267. package/src/UI/Theme/types.ts +72 -0
  268. package/src/UI/Theme/useTheme.ts +22 -0
  269. package/src/UI/Theme/utils.ts +67 -0
  270. package/src/UI/index.ts +7 -0
  271. package/src/UI/types.ts +41 -0
  272. package/src/assets/laurel-left.png +0 -0
  273. package/src/assets/laurel-right.png +0 -0
  274. package/src/assets/star-filled.png +0 -0
  275. 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,4 @@
1
+ export * from "./ProgressBar";
2
+ export * from "./CircularProgress";
3
+ export * from "./StaggeredTextList";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ export { ErrorBoundary } from './ErrorBoundary';
2
+ export { withErrorBoundary } from './withErrorBoundary';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}