zero-to-app 2.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 (282) hide show
  1. package/README.md +929 -0
  2. package/dist/brand/brandConfig.d.ts +48 -0
  3. package/dist/brand/brandConfig.d.ts.map +1 -0
  4. package/dist/brand/brandConfig.js +41 -0
  5. package/dist/brand/brandConfig.js.map +1 -0
  6. package/dist/brand/brandContext.d.ts +10 -0
  7. package/dist/brand/brandContext.d.ts.map +1 -0
  8. package/dist/brand/brandContext.js +16 -0
  9. package/dist/brand/brandContext.js.map +1 -0
  10. package/dist/brand/brandTypes.d.ts +54 -0
  11. package/dist/brand/brandTypes.d.ts.map +1 -0
  12. package/dist/brand/brandTypes.js +2 -0
  13. package/dist/brand/brandTypes.js.map +1 -0
  14. package/dist/brand/index.d.ts +4 -0
  15. package/dist/brand/index.d.ts.map +1 -0
  16. package/dist/brand/index.js +5 -0
  17. package/dist/brand/index.js.map +1 -0
  18. package/dist/components/action/ActionRow.d.ts +25 -0
  19. package/dist/components/action/ActionRow.d.ts.map +1 -0
  20. package/dist/components/action/ActionRow.js +66 -0
  21. package/dist/components/action/ActionRow.js.map +1 -0
  22. package/dist/components/action/index.d.ts +2 -0
  23. package/dist/components/action/index.d.ts.map +1 -0
  24. package/dist/components/action/index.js +3 -0
  25. package/dist/components/action/index.js.map +1 -0
  26. package/dist/components/card/Card.d.ts +11 -0
  27. package/dist/components/card/Card.d.ts.map +1 -0
  28. package/dist/components/card/Card.js +32 -0
  29. package/dist/components/card/Card.js.map +1 -0
  30. package/dist/components/card/index.d.ts +2 -0
  31. package/dist/components/card/index.d.ts.map +1 -0
  32. package/dist/components/card/index.js +2 -0
  33. package/dist/components/card/index.js.map +1 -0
  34. package/dist/components/chat/ChatContainer.d.ts +27 -0
  35. package/dist/components/chat/ChatContainer.d.ts.map +1 -0
  36. package/dist/components/chat/ChatContainer.js +52 -0
  37. package/dist/components/chat/ChatContainer.js.map +1 -0
  38. package/dist/components/chat/ChatInput.d.ts +9 -0
  39. package/dist/components/chat/ChatInput.d.ts.map +1 -0
  40. package/dist/components/chat/ChatInput.js +219 -0
  41. package/dist/components/chat/ChatInput.js.map +1 -0
  42. package/dist/components/chat/ChatMessages.d.ts +9 -0
  43. package/dist/components/chat/ChatMessages.d.ts.map +1 -0
  44. package/dist/components/chat/ChatMessages.js +35 -0
  45. package/dist/components/chat/ChatMessages.js.map +1 -0
  46. package/dist/components/chat/EmptyChat.d.ts +18 -0
  47. package/dist/components/chat/EmptyChat.d.ts.map +1 -0
  48. package/dist/components/chat/EmptyChat.js +64 -0
  49. package/dist/components/chat/EmptyChat.js.map +1 -0
  50. package/dist/components/chat/Message.d.ts +8 -0
  51. package/dist/components/chat/Message.d.ts.map +1 -0
  52. package/dist/components/chat/Message.js +47 -0
  53. package/dist/components/chat/Message.js.map +1 -0
  54. package/dist/components/chat/index.d.ts +6 -0
  55. package/dist/components/chat/index.d.ts.map +1 -0
  56. package/dist/components/chat/index.js +7 -0
  57. package/dist/components/chat/index.js.map +1 -0
  58. package/dist/components/chat/types.d.ts +34 -0
  59. package/dist/components/chat/types.d.ts.map +1 -0
  60. package/dist/components/chat/types.js +2 -0
  61. package/dist/components/chat/types.js.map +1 -0
  62. package/dist/components/form/DropDownSelect.d.ts +12 -0
  63. package/dist/components/form/DropDownSelect.d.ts.map +1 -0
  64. package/dist/components/form/DropDownSelect.js +63 -0
  65. package/dist/components/form/DropDownSelect.js.map +1 -0
  66. package/dist/components/form/EmailSubscriptionForm.d.ts +14 -0
  67. package/dist/components/form/EmailSubscriptionForm.d.ts.map +1 -0
  68. package/dist/components/form/EmailSubscriptionForm.js +58 -0
  69. package/dist/components/form/EmailSubscriptionForm.js.map +1 -0
  70. package/dist/components/form/FormErrors.d.ts +7 -0
  71. package/dist/components/form/FormErrors.d.ts.map +1 -0
  72. package/dist/components/form/FormErrors.js +35 -0
  73. package/dist/components/form/FormErrors.js.map +1 -0
  74. package/dist/components/form/FormInput.d.ts +14 -0
  75. package/dist/components/form/FormInput.d.ts.map +1 -0
  76. package/dist/components/form/FormInput.js +35 -0
  77. package/dist/components/form/FormInput.js.map +1 -0
  78. package/dist/components/form/FormSeparator.d.ts +6 -0
  79. package/dist/components/form/FormSeparator.d.ts.map +1 -0
  80. package/dist/components/form/FormSeparator.js +25 -0
  81. package/dist/components/form/FormSeparator.js.map +1 -0
  82. package/dist/components/form/index.d.ts +6 -0
  83. package/dist/components/form/index.d.ts.map +1 -0
  84. package/dist/components/form/index.js +7 -0
  85. package/dist/components/form/index.js.map +1 -0
  86. package/dist/components/index.d.ts +11 -0
  87. package/dist/components/index.d.ts.map +1 -0
  88. package/dist/components/index.js +12 -0
  89. package/dist/components/index.js.map +1 -0
  90. package/dist/components/layout/Footer.d.ts +3 -0
  91. package/dist/components/layout/Footer.d.ts.map +1 -0
  92. package/dist/components/layout/Footer.js +60 -0
  93. package/dist/components/layout/Footer.js.map +1 -0
  94. package/dist/components/layout/MinimalFooter.d.ts +8 -0
  95. package/dist/components/layout/MinimalFooter.d.ts.map +1 -0
  96. package/dist/components/layout/MinimalFooter.js +57 -0
  97. package/dist/components/layout/MinimalFooter.js.map +1 -0
  98. package/dist/components/layout/MobileFooterBar.d.ts +7 -0
  99. package/dist/components/layout/MobileFooterBar.d.ts.map +1 -0
  100. package/dist/components/layout/MobileFooterBar.js +18 -0
  101. package/dist/components/layout/MobileFooterBar.js.map +1 -0
  102. package/dist/components/layout/ParallaxScrollView.d.ts +11 -0
  103. package/dist/components/layout/ParallaxScrollView.d.ts.map +1 -0
  104. package/dist/components/layout/ParallaxScrollView.js +67 -0
  105. package/dist/components/layout/ParallaxScrollView.js.map +1 -0
  106. package/dist/components/layout/WebPageLayout.d.ts +17 -0
  107. package/dist/components/layout/WebPageLayout.d.ts.map +1 -0
  108. package/dist/components/layout/WebPageLayout.js +103 -0
  109. package/dist/components/layout/WebPageLayout.js.map +1 -0
  110. package/dist/components/layout/index.d.ts +6 -0
  111. package/dist/components/layout/index.d.ts.map +1 -0
  112. package/dist/components/layout/index.js +9 -0
  113. package/dist/components/layout/index.js.map +1 -0
  114. package/dist/components/list/List.d.ts +10 -0
  115. package/dist/components/list/List.d.ts.map +1 -0
  116. package/dist/components/list/List.js +18 -0
  117. package/dist/components/list/List.js.map +1 -0
  118. package/dist/components/list/ListButton.d.ts +13 -0
  119. package/dist/components/list/ListButton.d.ts.map +1 -0
  120. package/dist/components/list/ListButton.js +24 -0
  121. package/dist/components/list/ListButton.js.map +1 -0
  122. package/dist/components/list/ListDivider.d.ts +7 -0
  123. package/dist/components/list/ListDivider.d.ts.map +1 -0
  124. package/dist/components/list/ListDivider.js +23 -0
  125. package/dist/components/list/ListDivider.js.map +1 -0
  126. package/dist/components/list/index.d.ts +4 -0
  127. package/dist/components/list/index.d.ts.map +1 -0
  128. package/dist/components/list/index.js +4 -0
  129. package/dist/components/list/index.js.map +1 -0
  130. package/dist/components/media/Carousel.d.ts +18 -0
  131. package/dist/components/media/Carousel.d.ts.map +1 -0
  132. package/dist/components/media/Carousel.js +60 -0
  133. package/dist/components/media/Carousel.js.map +1 -0
  134. package/dist/components/media/FeatureCard.d.ts +9 -0
  135. package/dist/components/media/FeatureCard.d.ts.map +1 -0
  136. package/dist/components/media/FeatureCard.js +68 -0
  137. package/dist/components/media/FeatureCard.js.map +1 -0
  138. package/dist/components/media/HorizontalCarousel.d.ts +17 -0
  139. package/dist/components/media/HorizontalCarousel.d.ts.map +1 -0
  140. package/dist/components/media/HorizontalCarousel.js +60 -0
  141. package/dist/components/media/HorizontalCarousel.js.map +1 -0
  142. package/dist/components/media/ImageCarousel.d.ts +14 -0
  143. package/dist/components/media/ImageCarousel.d.ts.map +1 -0
  144. package/dist/components/media/ImageCarousel.js +21 -0
  145. package/dist/components/media/ImageCarousel.js.map +1 -0
  146. package/dist/components/media/MediaTile.d.ts +30 -0
  147. package/dist/components/media/MediaTile.d.ts.map +1 -0
  148. package/dist/components/media/MediaTile.js +51 -0
  149. package/dist/components/media/MediaTile.js.map +1 -0
  150. package/dist/components/media/SkeletonMediaTile.d.ts +17 -0
  151. package/dist/components/media/SkeletonMediaTile.d.ts.map +1 -0
  152. package/dist/components/media/SkeletonMediaTile.js +67 -0
  153. package/dist/components/media/SkeletonMediaTile.js.map +1 -0
  154. package/dist/components/media/index.d.ts +7 -0
  155. package/dist/components/media/index.d.ts.map +1 -0
  156. package/dist/components/media/index.js +8 -0
  157. package/dist/components/media/index.js.map +1 -0
  158. package/dist/components/navigation/AppbarWeb.d.ts +18 -0
  159. package/dist/components/navigation/AppbarWeb.d.ts.map +1 -0
  160. package/dist/components/navigation/AppbarWeb.js +70 -0
  161. package/dist/components/navigation/AppbarWeb.js.map +1 -0
  162. package/dist/components/navigation/IconButtonGroup.d.ts +7 -0
  163. package/dist/components/navigation/IconButtonGroup.d.ts.map +1 -0
  164. package/dist/components/navigation/IconButtonGroup.js +33 -0
  165. package/dist/components/navigation/IconButtonGroup.js.map +1 -0
  166. package/dist/components/navigation/Logo.d.ts +16 -0
  167. package/dist/components/navigation/Logo.d.ts.map +1 -0
  168. package/dist/components/navigation/Logo.js +64 -0
  169. package/dist/components/navigation/Logo.js.map +1 -0
  170. package/dist/components/navigation/MobileMenuDrawer.d.ts +13 -0
  171. package/dist/components/navigation/MobileMenuDrawer.d.ts.map +1 -0
  172. package/dist/components/navigation/MobileMenuDrawer.js +184 -0
  173. package/dist/components/navigation/MobileMenuDrawer.js.map +1 -0
  174. package/dist/components/navigation/ScreenHeader.d.ts +30 -0
  175. package/dist/components/navigation/ScreenHeader.d.ts.map +1 -0
  176. package/dist/components/navigation/ScreenHeader.js +127 -0
  177. package/dist/components/navigation/ScreenHeader.js.map +1 -0
  178. package/dist/components/navigation/iconUtils.d.ts +24 -0
  179. package/dist/components/navigation/iconUtils.d.ts.map +1 -0
  180. package/dist/components/navigation/iconUtils.js +53 -0
  181. package/dist/components/navigation/iconUtils.js.map +1 -0
  182. package/dist/components/navigation/index.d.ts +6 -0
  183. package/dist/components/navigation/index.d.ts.map +1 -0
  184. package/dist/components/navigation/index.js +7 -0
  185. package/dist/components/navigation/index.js.map +1 -0
  186. package/dist/components/tile/Tile.d.ts +18 -0
  187. package/dist/components/tile/Tile.d.ts.map +1 -0
  188. package/dist/components/tile/Tile.js +41 -0
  189. package/dist/components/tile/Tile.js.map +1 -0
  190. package/dist/components/tile/index.d.ts +2 -0
  191. package/dist/components/tile/index.d.ts.map +1 -0
  192. package/dist/components/tile/index.js +2 -0
  193. package/dist/components/tile/index.js.map +1 -0
  194. package/dist/components/ui/ArrowButton.d.ts +8 -0
  195. package/dist/components/ui/ArrowButton.d.ts.map +1 -0
  196. package/dist/components/ui/ArrowButton.js +30 -0
  197. package/dist/components/ui/ArrowButton.js.map +1 -0
  198. package/dist/components/ui/BlurButton.d.ts +16 -0
  199. package/dist/components/ui/BlurButton.d.ts.map +1 -0
  200. package/dist/components/ui/BlurButton.js +26 -0
  201. package/dist/components/ui/BlurButton.js.map +1 -0
  202. package/dist/components/ui/Button.d.ts +24 -0
  203. package/dist/components/ui/Button.d.ts.map +1 -0
  204. package/dist/components/ui/Button.js +60 -0
  205. package/dist/components/ui/Button.js.map +1 -0
  206. package/dist/components/ui/ErrorBoundary.d.ts +18 -0
  207. package/dist/components/ui/ErrorBoundary.d.ts.map +1 -0
  208. package/dist/components/ui/ErrorBoundary.js +37 -0
  209. package/dist/components/ui/ErrorBoundary.js.map +1 -0
  210. package/dist/components/ui/IconButton.d.ts +13 -0
  211. package/dist/components/ui/IconButton.d.ts.map +1 -0
  212. package/dist/components/ui/IconButton.js +27 -0
  213. package/dist/components/ui/IconButton.js.map +1 -0
  214. package/dist/components/ui/LoadingIndicator.d.ts +6 -0
  215. package/dist/components/ui/LoadingIndicator.d.ts.map +1 -0
  216. package/dist/components/ui/LoadingIndicator.js +15 -0
  217. package/dist/components/ui/LoadingIndicator.js.map +1 -0
  218. package/dist/components/ui/NotificationBadge.d.ts +8 -0
  219. package/dist/components/ui/NotificationBadge.d.ts.map +1 -0
  220. package/dist/components/ui/NotificationBadge.js +24 -0
  221. package/dist/components/ui/NotificationBadge.js.map +1 -0
  222. package/dist/components/ui/SkeletonCard.d.ts +14 -0
  223. package/dist/components/ui/SkeletonCard.d.ts.map +1 -0
  224. package/dist/components/ui/SkeletonCard.js +50 -0
  225. package/dist/components/ui/SkeletonCard.js.map +1 -0
  226. package/dist/components/ui/StyledText.d.ts +17 -0
  227. package/dist/components/ui/StyledText.d.ts.map +1 -0
  228. package/dist/components/ui/StyledText.js +27 -0
  229. package/dist/components/ui/StyledText.js.map +1 -0
  230. package/dist/components/ui/StyledTextInput.d.ts +10 -0
  231. package/dist/components/ui/StyledTextInput.d.ts.map +1 -0
  232. package/dist/components/ui/StyledTextInput.js +62 -0
  233. package/dist/components/ui/StyledTextInput.js.map +1 -0
  234. package/dist/components/ui/TextLink.d.ts +14 -0
  235. package/dist/components/ui/TextLink.d.ts.map +1 -0
  236. package/dist/components/ui/TextLink.js +25 -0
  237. package/dist/components/ui/TextLink.js.map +1 -0
  238. package/dist/components/ui/ToggleIconButton.d.ts +14 -0
  239. package/dist/components/ui/ToggleIconButton.d.ts.map +1 -0
  240. package/dist/components/ui/ToggleIconButton.js +19 -0
  241. package/dist/components/ui/ToggleIconButton.js.map +1 -0
  242. package/dist/components/ui/index.d.ts +13 -0
  243. package/dist/components/ui/index.d.ts.map +1 -0
  244. package/dist/components/ui/index.js +14 -0
  245. package/dist/components/ui/index.js.map +1 -0
  246. package/dist/context/scrollContext.d.ts +8 -0
  247. package/dist/context/scrollContext.d.ts.map +1 -0
  248. package/dist/context/scrollContext.js +16 -0
  249. package/dist/context/scrollContext.js.map +1 -0
  250. package/dist/hooks/index.d.ts +4 -0
  251. package/dist/hooks/index.d.ts.map +1 -0
  252. package/dist/hooks/index.js +5 -0
  253. package/dist/hooks/index.js.map +1 -0
  254. package/dist/hooks/useDimensions.d.ts +31 -0
  255. package/dist/hooks/useDimensions.d.ts.map +1 -0
  256. package/dist/hooks/useDimensions.js +44 -0
  257. package/dist/hooks/useDimensions.js.map +1 -0
  258. package/dist/hooks/useWindowHeight.d.ts +7 -0
  259. package/dist/hooks/useWindowHeight.d.ts.map +1 -0
  260. package/dist/hooks/useWindowHeight.js +10 -0
  261. package/dist/hooks/useWindowHeight.js.map +1 -0
  262. package/dist/hooks/useWindowWidth.d.ts +20 -0
  263. package/dist/hooks/useWindowWidth.d.ts.map +1 -0
  264. package/dist/hooks/useWindowWidth.js +27 -0
  265. package/dist/hooks/useWindowWidth.js.map +1 -0
  266. package/dist/index.d.ts +6 -0
  267. package/dist/index.d.ts.map +1 -0
  268. package/dist/index.js +9 -0
  269. package/dist/index.js.map +1 -0
  270. package/dist/theme/index.d.ts +3 -0
  271. package/dist/theme/index.d.ts.map +1 -0
  272. package/dist/theme/index.js +4 -0
  273. package/dist/theme/index.js.map +1 -0
  274. package/dist/theme/theme.d.ts +15 -0
  275. package/dist/theme/theme.d.ts.map +1 -0
  276. package/dist/theme/theme.js +38 -0
  277. package/dist/theme/theme.js.map +1 -0
  278. package/dist/theme/themeConfig.d.ts +19 -0
  279. package/dist/theme/themeConfig.d.ts.map +1 -0
  280. package/dist/theme/themeConfig.js +43 -0
  281. package/dist/theme/themeConfig.js.map +1 -0
  282. package/package.json +104 -0
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { Animated } from 'react-native';
3
+ interface BlurButtonProps {
4
+ onPress: () => void;
5
+ children: React.ReactNode;
6
+ intensity?: number;
7
+ tint?: 'light' | 'dark' | 'default';
8
+ style?: any;
9
+ scaleValue?: Animated.Value;
10
+ onPressIn?: () => void;
11
+ onPressOut?: () => void;
12
+ activeOpacity?: number;
13
+ }
14
+ declare const BlurButton: React.FC<BlurButtonProps>;
15
+ export { BlurButton };
16
+ //# sourceMappingURL=BlurButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlurButton.d.ts","sourceRoot":"","sources":["../../../components/ui/BlurButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAsC,QAAQ,EAAE,MAAM,cAAc,CAAC;AAK5E,UAAU,eAAe;IACvB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;IACpC,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,UAAU,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA2BzC,CAAC;AAkBF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { StyleSheet, TouchableOpacity, Animated } from 'react-native';
4
+ import { BlurView } from 'expo-blur';
5
+ import { ThemeContext } from '../../theme';
6
+ const BlurButton = ({ onPress, children, intensity = 80, tint = 'dark', style, scaleValue, onPressIn, onPressOut, activeOpacity = 0.9, }) => {
7
+ const theme = useContext(ThemeContext);
8
+ return (_jsx(Animated.View, { style: scaleValue ? { transform: [{ scale: scaleValue }] } : undefined, children: _jsx(BlurView, { intensity: intensity, tint: tint, style: [styles.blurButton, { borderColor: theme.values.borderColor }, style], children: _jsx(TouchableOpacity, { style: styles.touchable, onPress: onPress, onPressIn: onPressIn, onPressOut: onPressOut, activeOpacity: activeOpacity, children: children }) }) }));
9
+ };
10
+ const styles = StyleSheet.create({
11
+ blurButton: {
12
+ borderRadius: 100,
13
+ justifyContent: 'center',
14
+ alignItems: 'center',
15
+ paddingHorizontal: 10,
16
+ paddingVertical: 10,
17
+ borderWidth: 0.5,
18
+ overflow: 'hidden',
19
+ },
20
+ touchable: {
21
+ paddingHorizontal: 20,
22
+ paddingVertical: 8,
23
+ },
24
+ });
25
+ export { BlurButton };
26
+ //# sourceMappingURL=BlurButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlurButton.js","sourceRoot":"","sources":["../../../components/ui/BlurButton.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAQ,UAAU,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAc3C,MAAM,UAAU,GAA8B,CAAC,EAC7C,OAAO,EACP,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,IAAI,GAAG,MAAM,EACb,KAAK,EACL,UAAU,EACV,SAAS,EACT,UAAU,EACV,aAAa,GAAG,GAAG,GACpB,EAAE,EAAE;IACH,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,OAAO,CACL,KAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,YACnF,KAAC,QAAQ,IAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,YACtH,KAAC,gBAAgB,IACf,KAAK,EAAE,MAAM,CAAC,SAAS,EACvB,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,YAE3B,QAAQ,GACQ,GACV,GACG,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,UAAU,EAAE;QACV,YAAY,EAAE,GAAG;QACjB,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,iBAAiB,EAAE,EAAE;QACrB,eAAe,EAAE,EAAE;QACnB,WAAW,EAAE,GAAG;QAChB,QAAQ,EAAE,QAAQ;KACnB;IACD,SAAS,EAAE;QACT,iBAAiB,EAAE,EAAE;QACrB,eAAe,EAAE,CAAC;KACnB;CACF,CAAC,CAAC;AAEH,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { GestureResponderEvent } from 'react-native';
2
+ import * as Icons from '@expo/vector-icons';
3
+ type IconLibrary = keyof typeof Icons;
4
+ type ButtonProps = {
5
+ title: string;
6
+ onPress: (event: GestureResponderEvent) => void;
7
+ secondary?: boolean;
8
+ loading?: boolean;
9
+ icon?: {
10
+ library: IconLibrary;
11
+ name: string;
12
+ size?: number;
13
+ color?: string;
14
+ };
15
+ iconPosition?: 'left' | 'right';
16
+ style?: any;
17
+ };
18
+ /**
19
+ * A reusable button component that can be customized with different styles,
20
+ * loading states, and behavior based on props. It can also display an optional icon.
21
+ */
22
+ declare const Button: ({ title, secondary, loading, icon, onPress, iconPosition, style, }: ButtonProps) => import("react/jsx-runtime").JSX.Element;
23
+ export { Button };
24
+ //# sourceMappingURL=Button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../components/ui/Button.tsx"],"names":[],"mappings":"AACA,OAAO,EAEL,qBAAqB,EAItB,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,KAAK,MAAM,oBAAoB,CAAC;AAK5C,KAAK,WAAW,GAAG,MAAM,OAAO,KAAK,CAAC;AAEtC,KAAK,WAAW,GAAG;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,CAAC,KAAK,EAAE,qBAAqB,KAAK,IAAI,CAAC;IAChD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE;QACL,OAAO,EAAE,WAAW,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAChC,KAAK,CAAC,EAAE,GAAG,CAAC;CACb,CAAC;AAEF;;;GAGG;AAEH,QAAA,MAAM,MAAM,GAAI,oEAQb,WAAW,4CA8Eb,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useContext, useMemo } from 'react';
3
+ import { ActivityIndicator, Pressable, StyleSheet, View, } from 'react-native';
4
+ import * as Icons from '@expo/vector-icons';
5
+ import { useBrand } from '../../brand';
6
+ import { StyledText } from './StyledText';
7
+ import { ThemeContext } from '../../theme';
8
+ /**
9
+ * A reusable button component that can be customized with different styles,
10
+ * loading states, and behavior based on props. It can also display an optional icon.
11
+ */
12
+ const Button = ({ title, secondary, loading, icon, onPress, iconPosition = 'right', style, }) => {
13
+ const theme = useContext(ThemeContext);
14
+ const brand = useBrand();
15
+ const styles = useMemo(() => StyleSheet.create({
16
+ primary: {
17
+ maxHeight: 100,
18
+ minWidth: 200,
19
+ alignItems: 'center',
20
+ justifyContent: 'center',
21
+ padding: 15,
22
+ borderRadius: brand.borderRadius,
23
+ backgroundColor: brand.colors.primary,
24
+ },
25
+ secondary: {
26
+ maxHeight: 100,
27
+ minWidth: 200,
28
+ alignItems: 'center',
29
+ justifyContent: 'center',
30
+ padding: 15,
31
+ borderRadius: brand.borderRadius,
32
+ backgroundColor: 'transparent',
33
+ borderWidth: 2,
34
+ borderColor: brand.colors.secondary,
35
+ },
36
+ contentContainer: {
37
+ flexDirection: 'row', // Ensures icon and text are in a row
38
+ alignItems: 'center', // Vertically centers icon and text
39
+ justifyContent: 'center', // Horizontally centers icon and text
40
+ },
41
+ icon: {
42
+ marginLeft: 8, // Adds spacing between icon and text
43
+ },
44
+ }), [brand]);
45
+ return loading ? (_jsx(View, { children: _jsx(ActivityIndicator, { size: "small", color: secondary ? brand.colors.secondary : brand.colors.primary }) })) : (_jsx(Pressable, { onPress: onPress, style: [secondary ? styles.secondary : styles.primary, style], children: _jsxs(View, { style: styles.contentContainer, children: [icon && iconPosition === 'left' && (_jsx(View, { style: { marginRight: 8 }, children: icon.library && Icons[icon.library]
46
+ ? React.createElement(Icons[icon.library], {
47
+ name: icon.name,
48
+ size: icon.size || 20,
49
+ color: icon.color || (!secondary ? '#fff' : theme.values.color),
50
+ })
51
+ : null })), _jsx(StyledText, { fontSize: 'sm', color: !secondary ? '#FFFFFF' : theme.values.color, fontWeight: 500, numberOfLines: 1, align: "center", children: title }), icon && iconPosition === 'right' && (_jsx(View, { style: { marginLeft: 8 }, children: icon.library && Icons[icon.library]
52
+ ? React.createElement(Icons[icon.library], {
53
+ name: icon.name,
54
+ size: icon.size || 20,
55
+ color: icon.color || (!secondary ? '#fff' : theme.values.color),
56
+ })
57
+ : null }))] }) }));
58
+ };
59
+ export { Button };
60
+ //# sourceMappingURL=Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../components/ui/Button.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EACL,iBAAiB,EAEjB,SAAS,EACT,UAAU,EACV,IAAI,GACL,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,KAAK,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAmB3C;;;GAGG;AAEH,MAAM,MAAM,GAAG,CAAC,EACd,KAAK,EACL,SAAS,EACT,OAAO,EACP,IAAI,EACJ,OAAO,EACP,YAAY,GAAG,OAAO,EACtB,KAAK,GACO,EAAE,EAAE;IAChB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,OAAO,EAAE;YACP,SAAS,EAAE,GAAG;YACd,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,OAAO,EAAE,EAAE;YACX,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO;SACtC;QACD,SAAS,EAAE;YACT,SAAS,EAAE,GAAG;YACd,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,OAAO,EAAE,EAAE;YACX,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,eAAe,EAAE,aAAa;YAC9B,WAAW,EAAE,CAAC;YACd,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,SAAS;SACpC;QACD,gBAAgB,EAAE;YAChB,aAAa,EAAE,KAAK,EAAE,qCAAqC;YAC3D,UAAU,EAAE,QAAQ,EAAE,mCAAmC;YACzD,cAAc,EAAE,QAAQ,EAAE,qCAAqC;SAChE;QACD,IAAI,EAAE;YACJ,UAAU,EAAE,CAAC,EAAE,qCAAqC;SACrD;KACF,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,OAAO,OAAO,CAAC,CAAC,CAAC,CACf,KAAC,IAAI,cACH,KAAC,iBAAiB,IAChB,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,GAChE,GACG,CACR,CAAC,CAAC,CAAC,CACF,KAAC,SAAS,IAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,YACxF,MAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,gBAAgB,aACjC,IAAI,IAAI,YAAY,KAAK,MAAM,IAAI,CAClC,KAAC,IAAI,IAAC,KAAK,EAAE,EAAE,WAAW,EAAE,CAAC,EAAE,YAC5B,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC;wBAClC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;4BACvC,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE;4BACrB,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;yBAChE,CAAC;wBACJ,CAAC,CAAC,IAAI,GACH,CACR,EACD,KAAC,UAAU,IACT,QAAQ,EAAE,IAAI,EACd,KAAK,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAClD,UAAU,EAAE,GAAG,EACf,aAAa,EAAE,CAAC,EAChB,KAAK,EAAC,QAAQ,YACb,KAAK,GACK,EACZ,IAAI,IAAI,YAAY,KAAK,OAAO,IAAI,CACnC,KAAC,IAAI,IAAC,KAAK,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,YAC3B,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC;wBAClC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;4BACvC,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE;4BACrB,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;yBAChE,CAAC;wBACJ,CAAC,CAAC,IAAI,GACH,CACR,IACI,GACG,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ interface ErrorBoundaryState {
3
+ hasError: boolean;
4
+ error?: Error;
5
+ }
6
+ interface ErrorBoundaryProps {
7
+ children: React.ReactNode;
8
+ fallback?: React.ReactNode;
9
+ onError?: (error: Error, errorInfo: React.ErrorInfo) => void;
10
+ }
11
+ declare class ErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundaryState> {
12
+ constructor(props: ErrorBoundaryProps);
13
+ static getDerivedStateFromError(error: Error): ErrorBoundaryState;
14
+ componentDidCatch(error: Error, errorInfo: React.ErrorInfo): void;
15
+ 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;
16
+ }
17
+ export { ErrorBoundary };
18
+ //# sourceMappingURL=ErrorBoundary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorBoundary.d.ts","sourceRoot":"","sources":["../../../components/ui/ErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,CAAC;CACf;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC;CAC9D;AAED,cAAM,aAAc,SAAQ,KAAK,CAAC,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;gBACrE,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;IAK1D,MAAM;CAiBP;AAYD,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { View, StyleSheet } from 'react-native';
4
+ import { StyledText } from './StyledText';
5
+ class ErrorBoundary extends React.Component {
6
+ constructor(props) {
7
+ super(props);
8
+ this.state = { hasError: false };
9
+ }
10
+ static getDerivedStateFromError(error) {
11
+ return { hasError: true, error };
12
+ }
13
+ componentDidCatch(error, errorInfo) {
14
+ console.error('ErrorBoundary caught an error:', error, errorInfo);
15
+ this.props.onError?.(error, errorInfo);
16
+ }
17
+ render() {
18
+ if (this.state.hasError) {
19
+ if (this.props.fallback) {
20
+ return this.props.fallback;
21
+ }
22
+ return (_jsx(View, { style: styles.errorContainer, children: _jsx(StyledText, { fontSize: "sm", color: "#666", align: "center", children: "Content temporarily unavailable" }) }));
23
+ }
24
+ return this.props.children;
25
+ }
26
+ }
27
+ const styles = StyleSheet.create({
28
+ errorContainer: {
29
+ padding: 20,
30
+ justifyContent: 'center',
31
+ alignItems: 'center',
32
+ backgroundColor: '#f5f5f5',
33
+ borderRadius: 8,
34
+ },
35
+ });
36
+ export { ErrorBoundary };
37
+ //# sourceMappingURL=ErrorBoundary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorBoundary.js","sourceRoot":"","sources":["../../../components/ui/ErrorBoundary.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAa1C,MAAM,aAAc,SAAQ,KAAK,CAAC,SAAiD;IACjF,YAAY,KAAyB;QACnC,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,MAAM,CAAC,wBAAwB,CAAC,KAAY;QAC1C,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,KAAY,EAAE,SAA0B;QACxD,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YACxB,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACxB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YAC7B,CAAC;YAED,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,cAAc,YAChC,KAAC,UAAU,IAAC,QAAQ,EAAC,IAAI,EAAC,KAAK,EAAC,MAAM,EAAC,KAAK,EAAC,QAAQ,gDAExC,GACR,CACR,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;CACF;AAED,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,cAAc,EAAE;QACd,OAAO,EAAE,EAAE;QACX,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,eAAe,EAAE,SAAS;QAC1B,YAAY,EAAE,CAAC;KAChB;CACF,CAAC,CAAC;AAEH,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -0,0 +1,13 @@
1
+ import Feather from '@expo/vector-icons/Feather';
2
+ type IconButtonProps = {
3
+ iconName: keyof typeof Feather.glyphMap;
4
+ onPress: () => void;
5
+ color?: string;
6
+ backgroundColor?: string;
7
+ };
8
+ /**
9
+ * Renders rounded icon button with icon from expo-vector icons.
10
+ */
11
+ declare const IconButton: ({ iconName, onPress, color, backgroundColor }: IconButtonProps) => import("react/jsx-runtime").JSX.Element;
12
+ export { IconButton };
13
+ //# sourceMappingURL=IconButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconButton.d.ts","sourceRoot":"","sources":["../../../components/ui/IconButton.tsx"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,4BAA4B,CAAC;AAGjD,KAAK,eAAe,GAAG;IACrB,QAAQ,EAAE,MAAM,OAAO,OAAO,CAAC,QAAQ,CAAC;IACxC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF;;GAEG;AAEH,QAAA,MAAM,UAAU,GAAI,+CAA+C,eAAe,4CAcjF,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { StyleSheet, Pressable } from 'react-native';
4
+ import Feather from '@expo/vector-icons/Feather';
5
+ import { ThemeContext } from '../../theme';
6
+ /**
7
+ * Renders rounded icon button with icon from expo-vector icons.
8
+ */
9
+ const IconButton = ({ iconName, onPress, color, backgroundColor }) => {
10
+ //Initialize theme
11
+ const theme = useContext(ThemeContext);
12
+ return (_jsx(Pressable, { onPress: onPress, style: {
13
+ ...styles.container,
14
+ backgroundColor: backgroundColor ?? 'transparent',
15
+ }, children: _jsx(Feather, { name: iconName, size: 20, color: color ? theme.values.iconButtonIconColor : theme.values.color }) }));
16
+ };
17
+ export { IconButton };
18
+ const styles = StyleSheet.create({
19
+ container: {
20
+ justifyContent: 'center',
21
+ alignItems: 'center',
22
+ width: 40,
23
+ height: 40,
24
+ borderRadius: 25,
25
+ },
26
+ });
27
+ //# sourceMappingURL=IconButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconButton.js","sourceRoot":"","sources":["../../../components/ui/IconButton.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,OAAO,MAAM,4BAA4B,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAS3C;;GAEG;AAEH,MAAM,UAAU,GAAG,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,eAAe,EAAmB,EAAE,EAAE;IACpF,kBAAkB;IAClB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,OAAO,CACL,KAAC,SAAS,IACR,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,SAAS;YACnB,eAAe,EAAE,eAAe,IAAI,aAAa;SAClD,YACD,KAAC,OAAO,IAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,GAAI,GACjG,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC;AAEtB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,SAAS,EAAE;QACT,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,EAAE;QACV,YAAY,EAAE,EAAE;KACjB;CACF,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Loading indicator
3
+ */
4
+ declare const LoadingIndicator: () => import("react/jsx-runtime").JSX.Element;
5
+ export { LoadingIndicator };
6
+ //# sourceMappingURL=LoadingIndicator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoadingIndicator.d.ts","sourceRoot":"","sources":["../../../components/ui/LoadingIndicator.tsx"],"names":[],"mappings":"AAMA;;GAEG;AAEH,QAAA,MAAM,gBAAgB,+CAKrB,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ //A spinner component that uses theme values to style the spinner.
3
+ import { useContext } from 'react';
4
+ import { ActivityIndicator } from 'react-native';
5
+ import { ThemeContext } from '../../theme';
6
+ /**
7
+ * Loading indicator
8
+ */
9
+ const LoadingIndicator = () => {
10
+ // Initialize theme
11
+ const theme = useContext(ThemeContext);
12
+ return _jsx(ActivityIndicator, { size: "large", color: theme.values.highlightColor });
13
+ };
14
+ export { LoadingIndicator };
15
+ //# sourceMappingURL=LoadingIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoadingIndicator.js","sourceRoot":"","sources":["../../../components/ui/LoadingIndicator.tsx"],"names":[],"mappings":";AAAA,kEAAkE;AAElE,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C;;GAEG;AAEH,MAAM,gBAAgB,GAAG,GAAG,EAAE;IAC5B,mBAAmB;IACnB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,OAAO,KAAC,iBAAiB,IAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,cAAc,GAAI,CAAC;AAChF,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ interface NotificationBadgeProps {
3
+ count: number;
4
+ maxCount?: number;
5
+ }
6
+ export declare const NotificationBadge: React.FC<NotificationBadgeProps>;
7
+ export {};
8
+ //# sourceMappingURL=NotificationBadge.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationBadge.d.ts","sourceRoot":"","sources":["../../../components/ui/NotificationBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,sBAAsB;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAoB9D,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { View, StyleSheet } from 'react-native';
3
+ import { StyledText } from './StyledText';
4
+ export const NotificationBadge = ({ count, maxCount = 99 }) => {
5
+ if (count <= 0)
6
+ return null;
7
+ const displayCount = count > maxCount ? `${maxCount}+` : count.toString();
8
+ return (_jsx(View, { style: styles.badge, children: _jsx(StyledText, { color: "white", fontSize: "sm", fontWeight: 600, align: "center", children: displayCount }) }));
9
+ };
10
+ const styles = StyleSheet.create({
11
+ badge: {
12
+ position: 'absolute',
13
+ top: -4,
14
+ right: -4,
15
+ backgroundColor: '#CC3366', // Using brand primary color
16
+ borderRadius: 8,
17
+ minWidth: 16,
18
+ height: 16,
19
+ alignItems: 'center',
20
+ justifyContent: 'center',
21
+ paddingHorizontal: 4,
22
+ },
23
+ });
24
+ //# sourceMappingURL=NotificationBadge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationBadge.js","sourceRoot":"","sources":["../../../components/ui/NotificationBadge.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAO1C,MAAM,CAAC,MAAM,iBAAiB,GAAqC,CAAC,EAClE,KAAK,EACL,QAAQ,GAAG,EAAE,EACd,EAAE,EAAE;IACH,IAAI,KAAK,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAE5B,MAAM,YAAY,GAAG,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IAE1E,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,YACvB,KAAC,UAAU,IACT,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAE,GAAG,EACf,KAAK,EAAC,QAAQ,YAEb,YAAY,GACF,GACR,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,KAAK,EAAE;QACL,QAAQ,EAAE,UAAU;QACpB,GAAG,EAAE,CAAC,CAAC;QACP,KAAK,EAAE,CAAC,CAAC;QACT,eAAe,EAAE,SAAS,EAAE,4BAA4B;QACxD,YAAY,EAAE,CAAC;QACf,QAAQ,EAAE,EAAE;QACZ,MAAM,EAAE,EAAE;QACV,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,iBAAiB,EAAE,CAAC;KACrB;CACF,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ interface SkeletonCardProps {
2
+ width?: number | {
3
+ mobile: number;
4
+ web: number;
5
+ };
6
+ imageHeight?: number | {
7
+ mobile: number;
8
+ web: number;
9
+ };
10
+ textLines?: number[];
11
+ }
12
+ declare function SkeletonCard({ width, imageHeight, textLines, }: SkeletonCardProps): import("react/jsx-runtime").JSX.Element;
13
+ export { SkeletonCard };
14
+ //# sourceMappingURL=SkeletonCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkeletonCard.d.ts","sourceRoot":"","sources":["../../../components/ui/SkeletonCard.tsx"],"names":[],"mappings":"AAMA,UAAU,iBAAiB;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IACjD,WAAW,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IACvD,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;CACtB;AAED,iBAAS,YAAY,CAAC,EACpB,KAAK,EACL,WAAW,EACX,SAAwB,GACzB,EAAE,iBAAiB,2CA4DnB;AAED,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,50 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { View, StyleSheet } from 'react-native';
4
+ import { useBrand } from '../../brand';
5
+ import { ThemeContext } from '../../theme';
6
+ import { useDimensions, breakpoints } from '../../hooks';
7
+ function SkeletonCard({ width, imageHeight, textLines = [70, 40, 30], // Default: 3 lines with different widths
8
+ }) {
9
+ const theme = useContext(ThemeContext);
10
+ const dimensions = useDimensions();
11
+ const brand = useBrand();
12
+ const styles = useMemo(() => StyleSheet.create({
13
+ skeletonImage: {
14
+ width: '100%',
15
+ borderRadius: brand.borderRadius,
16
+ },
17
+ infoContainer: {
18
+ marginTop: 10,
19
+ gap: 5,
20
+ },
21
+ skeletonText: {
22
+ height: 10,
23
+ borderRadius: 4,
24
+ marginTop: 5,
25
+ },
26
+ }), [brand]);
27
+ // Determine responsive dimensions
28
+ const cardWidth = typeof width === 'object'
29
+ ? dimensions.width > breakpoints.medium
30
+ ? width.web
31
+ : width.mobile
32
+ : width || (dimensions.width > breakpoints.medium ? 250 : 150);
33
+ const height = typeof imageHeight === 'object'
34
+ ? dimensions.width > breakpoints.medium
35
+ ? imageHeight.web
36
+ : imageHeight.mobile
37
+ : imageHeight || (dimensions.width > breakpoints.medium ? 150 : 200);
38
+ return (_jsxs(View, { style: [{ marginRight: 10 }, { width: cardWidth }], children: [_jsx(View, { style: [
39
+ styles.skeletonImage,
40
+ { backgroundColor: theme.values.isDark ? '#333333' : '#e0e0e0', height },
41
+ ] }), _jsx(View, { style: styles.infoContainer, children: textLines.map((widthPercent, index) => (_jsx(View, { style: [
42
+ styles.skeletonText,
43
+ {
44
+ width: `${widthPercent}%`,
45
+ backgroundColor: theme.values.isDark ? '#333333' : '#e0e0e0',
46
+ },
47
+ ] }, index))) })] }));
48
+ }
49
+ export { SkeletonCard };
50
+ //# sourceMappingURL=SkeletonCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkeletonCard.js","sourceRoot":"","sources":["../../../components/ui/SkeletonCard.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAQzD,SAAS,YAAY,CAAC,EACpB,KAAK,EACL,WAAW,EACX,SAAS,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,yCAAyC;EACjD;IAClB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,aAAa,EAAE;YACb,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,KAAK,CAAC,YAAY;SACjC;QACD,aAAa,EAAE;YACb,SAAS,EAAE,EAAE;YACb,GAAG,EAAE,CAAC;SACP;QACD,YAAY,EAAE;YACZ,MAAM,EAAE,EAAE;YACV,YAAY,EAAE,CAAC;YACf,SAAS,EAAE,CAAC;SACb;KACF,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,kCAAkC;IAClC,MAAM,SAAS,GACb,OAAO,KAAK,KAAK,QAAQ;QACvB,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;YACrC,CAAC,CAAC,KAAK,CAAC,GAAG;YACX,CAAC,CAAC,KAAK,CAAC,MAAM;QAChB,CAAC,CAAC,KAAK,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAEnE,MAAM,MAAM,GACV,OAAO,WAAW,KAAK,QAAQ;QAC7B,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;YACrC,CAAC,CAAC,WAAW,CAAC,GAAG;YACjB,CAAC,CAAC,WAAW,CAAC,MAAM;QACtB,CAAC,CAAC,WAAW,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAEzE,OAAO,CACL,MAAC,IAAI,IAAC,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,aACtD,KAAC,IAAI,IACH,KAAK,EAAE;oBACL,MAAM,CAAC,aAAa;oBACpB,EAAE,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE,MAAM,EAAE;iBACzE,GACD,EACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,aAAa,YAC9B,SAAS,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE,CAAC,CACtC,KAAC,IAAI,IAEH,KAAK,EAAE;wBACL,MAAM,CAAC,YAAY;wBACnB;4BACE,KAAK,EAAE,GAAG,YAAY,GAAG;4BACzB,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;yBAC7D;qBACF,IAPI,KAAK,CAQV,CACH,CAAC,GACG,IACF,CACR,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { TextStyle } from 'react-native';
3
+ type StyledTextProps = {
4
+ children: React.ReactNode;
5
+ fontSize?: 'sm' | 'md' | 'lg' | 'xl' | number;
6
+ align?: 'left' | 'center' | 'right';
7
+ color?: string;
8
+ bold?: boolean;
9
+ uppercase?: boolean;
10
+ numberOfLines?: number;
11
+ muted?: boolean;
12
+ fontWeight?: number;
13
+ style?: TextStyle;
14
+ };
15
+ export declare const StyledText: ({ children, fontSize, align, color, bold, numberOfLines, uppercase, muted, fontWeight, style, }: StyledTextProps) => React.ReactNode;
16
+ export {};
17
+ //# sourceMappingURL=StyledText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledText.d.ts","sourceRoot":"","sources":["../../../components/ui/StyledText.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,EAAoB,SAAS,EAAE,MAAM,cAAc,CAAC;AAI3D,KAAK,eAAe,GAAG;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;IAC9C,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,iGAWxB,eAAe,KAAG,KAAK,CAAC,SA2B1B,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { StyleSheet, Text } from 'react-native';
4
+ import { useBrand } from '../../brand';
5
+ import { ThemeContext } from '../../theme';
6
+ export const StyledText = ({ children, fontSize = 'md', align = 'left', color, bold = false, numberOfLines, uppercase = false, muted = false, fontWeight, style, }) => {
7
+ const theme = useContext(ThemeContext);
8
+ const brand = useBrand();
9
+ const styles = useMemo(() => StyleSheet.create({
10
+ sm: { fontSize: brand.fontSizes.small },
11
+ md: { fontSize: brand.fontSizes.medium },
12
+ lg: { fontSize: brand.fontSizes.large },
13
+ xl: { fontSize: brand.fontSizes.xlarge },
14
+ }), [brand]);
15
+ const textStyle = {
16
+ fontSize: typeof fontSize === 'number'
17
+ ? fontSize
18
+ : styles[fontSize]?.fontSize || brand.fontSizes.medium,
19
+ textAlign: align,
20
+ color: muted ? 'gray' : color || theme.values.color,
21
+ fontWeight: fontWeight ? fontWeight : bold ? '700' : 'normal',
22
+ letterSpacing: 1,
23
+ ...style, // Merge custom style if provided
24
+ };
25
+ return (_jsx(Text, { style: textStyle, numberOfLines: numberOfLines, children: uppercase ? children?.toString().toUpperCase() : children }));
26
+ };
27
+ //# sourceMappingURL=StyledText.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledText.js","sourceRoot":"","sources":["../../../components/ui/StyledText.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,IAAI,EAAa,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAe3C,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,QAAQ,EACR,QAAQ,GAAG,IAAI,EACf,KAAK,GAAG,MAAM,EACd,KAAK,EACL,IAAI,GAAG,KAAK,EACZ,aAAa,EACb,SAAS,GAAG,KAAK,EACjB,KAAK,GAAG,KAAK,EACb,UAAU,EACV,KAAK,GACW,EAAmB,EAAE;IACrC,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE;QACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE;QACxC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE;QACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE;KACzC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,MAAM,SAAS,GAAc;QAC3B,QAAQ,EACN,OAAO,QAAQ,KAAK,QAAQ;YAC1B,CAAC,CAAC,QAAQ;YACV,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,QAAQ,IAAI,KAAK,CAAC,SAAS,CAAC,MAAM;QAC1D,SAAS,EAAE,KAAK;QAChB,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK;QACnD,UAAU,EAAE,UAAU,CAAC,CAAC,CAAE,UAAsC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;QAC1F,aAAa,EAAE,CAAC;QAChB,GAAG,KAAK,EAAE,iCAAiC;KAC5C,CAAC;IACF,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,aAAa,YACjD,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,QAAQ,GACrD,CACR,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { TextInputProps } from 'react-native';
3
+ interface CustomTextInputProps extends TextInputProps {
4
+ value: string;
5
+ inputHeight?: number;
6
+ onKeyDown?: (e: any) => void;
7
+ }
8
+ declare const StyledTextInput: (props: CustomTextInputProps) => React.JSX.Element;
9
+ export { StyledTextInput };
10
+ //# sourceMappingURL=StyledTextInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledTextInput.d.ts","sourceRoot":"","sources":["../../../components/ui/StyledTextInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,EAIL,cAAc,EAEf,MAAM,cAAc,CAAC;AAKtB,UAAU,oBAAqB,SAAQ,cAAc;IACnD,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;CAC9B;AAED,QAAA,MAAM,eAAe,GAAI,OAAO,oBAAoB,KAAG,KAAK,CAAC,GAAG,CAAC,OAmEhE,CAAC;AAEF,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -0,0 +1,62 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { StyleSheet, View, TextInput as RNTextInput, Platform, } from 'react-native';
4
+ import { useBrand } from '../../brand';
5
+ import { ThemeContext } from '../../theme';
6
+ const StyledTextInput = (props) => {
7
+ const { value, inputHeight, ...textInputProps } = props;
8
+ const theme = useContext(ThemeContext);
9
+ const brand = useBrand();
10
+ const currentHeight = inputHeight || MIN_HEIGHT;
11
+ const isSingleLine = currentHeight <= MIN_HEIGHT;
12
+ const styles = useMemo(() => StyleSheet.create({
13
+ container: {
14
+ width: '100%',
15
+ maxHeight: 200,
16
+ padding: 5,
17
+ alignSelf: 'center',
18
+ borderRadius: brand.borderRadius,
19
+ },
20
+ textInput: {
21
+ width: '100%',
22
+ fontSize: brand.fontSizes.medium,
23
+ borderWidth: 0, // Remove any internal border from the StyledTextInput
24
+ paddingHorizontal: 10,
25
+ paddingVertical: 10,
26
+ minHeight: MIN_HEIGHT,
27
+ },
28
+ webInput: {
29
+ // @ts-ignore - Web-specific styles
30
+ outlineStyle: 'none',
31
+ WebkitAppearance: 'none',
32
+ MozAppearance: 'none',
33
+ appearance: 'none',
34
+ },
35
+ }), [brand]);
36
+ return (_jsx(View, { style: [
37
+ styles.container,
38
+ {
39
+ borderColor: theme.values.borderColor,
40
+ borderWidth: theme.values.isDark ? 0 : 1,
41
+ backgroundColor: theme.values.isDark
42
+ ? theme.values.borderColor
43
+ : theme.values.backgroundColor,
44
+ },
45
+ ], children: _jsx(RNTextInput, { ...textInputProps, onKeyPress: props.onKeyPress, onContentSizeChange: props.onContentSizeChange, value: value, multiline: true, style: [
46
+ styles.textInput,
47
+ {
48
+ color: theme.values.color,
49
+ height: inputHeight ? currentHeight : undefined, // Only set height if provided
50
+ minHeight: MIN_HEIGHT,
51
+ maxHeight: MAX_HEIGHT,
52
+ textAlignVertical: isSingleLine ? 'center' : 'top',
53
+ },
54
+ Platform.OS === 'web' && styles.webInput,
55
+ ], placeholderTextColor: theme.values.color,
56
+ // @ts-ignore - onKeyDown is web-specific and not in React Native types
57
+ onKeyDown: props.onKeyDown }) }));
58
+ };
59
+ export { StyledTextInput };
60
+ const MIN_HEIGHT = 40;
61
+ const MAX_HEIGHT = 120;
62
+ //# sourceMappingURL=StyledTextInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledTextInput.js","sourceRoot":"","sources":["../../../components/ui/StyledTextInput.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EACL,UAAU,EACV,IAAI,EACJ,SAAS,IAAI,WAAW,EAExB,QAAQ,GACT,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAS3C,MAAM,eAAe,GAAG,CAAC,KAA2B,EAAqB,EAAE;IACzE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,cAAc,EAAE,GAAG,KAAK,CAAC;IACxD,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,aAAa,GAAG,WAAW,IAAI,UAAU,CAAC;IAChD,MAAM,YAAY,GAAG,aAAa,IAAI,UAAU,CAAC;IAEjD,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,SAAS,EAAE;YACT,KAAK,EAAE,MAAM;YACb,SAAS,EAAE,GAAG;YACd,OAAO,EAAE,CAAC;YACV,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,KAAK,CAAC,YAAY;SACjC;QACD,SAAS,EAAE;YACT,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM;YAChC,WAAW,EAAE,CAAC,EAAE,sDAAsD;YACtE,iBAAiB,EAAE,EAAE;YACrB,eAAe,EAAE,EAAE;YACnB,SAAS,EAAE,UAAU;SACtB;QACD,QAAQ,EAAE;YACR,mCAAmC;YACnC,YAAY,EAAE,MAAM;YACpB,gBAAgB,EAAE,MAAM;YACxB,aAAa,EAAE,MAAM;YACrB,UAAU,EAAE,MAAM;SACnB;KACF,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,OAAO,CACL,KAAC,IAAI,IACH,KAAK,EAAE;YACL,MAAM,CAAC,SAAS;YAChB;gBACE,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,WAAW;gBACrC,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM;oBAClC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW;oBAC1B,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe;aACjC;SACF,YACD,KAAC,WAAW,OACN,cAAc,EAClB,UAAU,EAAE,KAAK,CAAC,UAAU,EAC5B,mBAAmB,EAAE,KAAK,CAAC,mBAAmB,EAC9C,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,IAAI,EACf,KAAK,EAAE;gBACL,MAAM,CAAC,SAAS;gBAChB;oBACE,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK;oBACzB,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,EAAE,8BAA8B;oBAC/E,SAAS,EAAE,UAAU;oBACrB,SAAS,EAAE,UAAU;oBACrB,iBAAiB,EAAE,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK;iBACnD;gBACD,QAAQ,CAAC,EAAE,KAAK,KAAK,IAAI,MAAM,CAAC,QAAQ;aACzC,EACD,oBAAoB,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK;YACxC,uEAAuE;YACvE,SAAS,EAAE,KAAK,CAAC,SAAS,GAC1B,GACG,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,eAAe,EAAE,CAAC;AAE3B,MAAM,UAAU,GAAG,EAAE,CAAC;AACtB,MAAM,UAAU,GAAG,GAAG,CAAC"}
@@ -0,0 +1,14 @@
1
+ type TextLinkProps = {
2
+ text: string;
3
+ onPress?: () => void;
4
+ href?: string;
5
+ align?: 'left' | 'center' | 'right';
6
+ color?: string;
7
+ fontSize?: 'sm' | 'md' | 'lg' | 'xl' | number;
8
+ };
9
+ /**
10
+ * A pressable text component that can navigate to a URL or trigger an action.
11
+ */
12
+ declare const TextLink: ({ text, onPress, href, align, color, fontSize }: TextLinkProps) => import("react/jsx-runtime").JSX.Element;
13
+ export { TextLink };
14
+ //# sourceMappingURL=TextLink.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextLink.d.ts","sourceRoot":"","sources":["../../../components/ui/TextLink.tsx"],"names":[],"mappings":"AAKA,KAAK,aAAa,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;CAC/C,CAAC;AAEF;;GAEG;AACH,QAAA,MAAM,QAAQ,GAAI,iDAAmE,aAAa,4CA4BjG,CAAC;AAEF,OAAO,EAAE,QAAQ,EAAE,CAAC"}
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useState, useContext } from 'react';
3
+ import { Linking, Pressable, Platform } from 'react-native';
4
+ import { StyledText } from './StyledText';
5
+ import { ThemeContext } from '../../theme';
6
+ /**
7
+ * A pressable text component that can navigate to a URL or trigger an action.
8
+ */
9
+ const TextLink = ({ text, onPress, href, align = 'center', color, fontSize = 'sm' }) => {
10
+ const [isHovered, setIsHovered] = useState(false);
11
+ const theme = useContext(ThemeContext);
12
+ const handlePress = () => {
13
+ if (href) {
14
+ Linking.openURL(href);
15
+ }
16
+ else if (onPress) {
17
+ onPress();
18
+ }
19
+ };
20
+ // On web, use primary color (highlightColor) when hovered, otherwise use provided color
21
+ const textColor = Platform.OS === 'web' && isHovered ? theme.values.highlightColor : color;
22
+ return (_jsx(Pressable, { onPress: handlePress, onHoverIn: () => setIsHovered(true), onHoverOut: () => setIsHovered(false), children: _jsx(StyledText, { align: align, color: textColor, fontSize: fontSize, children: text }) }));
23
+ };
24
+ export { TextLink };
25
+ //# sourceMappingURL=TextLink.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextLink.js","sourceRoot":"","sources":["../../../components/ui/TextLink.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAW3C;;GAEG;AACH,MAAM,QAAQ,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,GAAG,QAAQ,EAAE,KAAK,EAAE,QAAQ,GAAG,IAAI,EAAiB,EAAE,EAAE;IACpG,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;aAAM,IAAI,OAAO,EAAE,CAAC;YACnB,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,CAAC;IAEF,wFAAwF;IACxF,MAAM,SAAS,GAAG,QAAQ,CAAC,EAAE,KAAK,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC;IAE3F,OAAO,CACL,KAAC,SAAS,IACR,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EACnC,UAAU,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,YACrC,KAAC,UAAU,IACT,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,QAAQ,YACjB,IAAI,GACM,GACH,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,QAAQ,EAAE,CAAC"}