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,103 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { ScrollView, StyleSheet, View, Platform } from 'react-native';
4
+ import { ThemeContext } from '../../theme';
5
+ import { useDimensions } from '../../hooks';
6
+ import Footer from './Footer';
7
+ import { useWindowDimensions } from 'react-native';
8
+ import { useBrand } from '../../brand';
9
+ /**
10
+ * Unified web page layout template that handles all conditional layout logic
11
+ * for mobile web and desktop/tablet, including automatic footer placement.
12
+ *
13
+ * - Mobile web (isWebSmall): Footer at bottom of ScrollView, fills width, reaches bottom
14
+ * - Desktop/Tablet (isWebLarge): Footer at bottom (fixed or end of ScrollView)
15
+ * - Supports optional bottomActions for pages that need fixed bottom buttons
16
+ */
17
+ const WebPageLayout = ({ children, bottomActions, showFooter = true }) => {
18
+ const theme = useContext(ThemeContext);
19
+ const dimensions = useDimensions();
20
+ const brand = useBrand();
21
+ const { height: windowHeight } = useWindowDimensions();
22
+ const styles = useMemo(() => StyleSheet.create({
23
+ container: {
24
+ flex: 1,
25
+ },
26
+ scrollContent: {
27
+ flexGrow: 1,
28
+ },
29
+ scrollContentMobile: {
30
+ flexGrow: 1,
31
+ },
32
+ content: {
33
+ // Don't use flex: 1, let content take only what it needs
34
+ },
35
+ contentMobile: {
36
+ // On mobile web, ensure content takes up at least viewport height
37
+ // minHeight is set dynamically to prevent content cutoff
38
+ },
39
+ contentDesktop: {
40
+ // On desktop, expand content to fill available space for fullscreen
41
+ flex: 1,
42
+ minHeight: 0, // Allow shrinking if needed
43
+ },
44
+ bottomActionsMobile: {
45
+ width: '100%',
46
+ paddingVertical: brand.spacing.md + 3,
47
+ },
48
+ footerWrapperMobile: {
49
+ width: '100%',
50
+ flexGrow: 1,
51
+ minHeight: 300, // Minimum height, will expand to fill remaining space
52
+ alignSelf: 'stretch', // Ensure full width
53
+ },
54
+ footerWrapperDesktop: {
55
+ width: '100%',
56
+ alignSelf: 'stretch', // Ensure full width
57
+ },
58
+ fixedBottomContainer: {
59
+ position: 'absolute',
60
+ bottom: 0,
61
+ left: 0,
62
+ right: 0,
63
+ width: '100%', // Ensure full width
64
+ },
65
+ }), [brand]);
66
+ // Mobile web layout: Footer fills remaining height and full width
67
+ if (Platform.OS === 'web' && dimensions.breakpoint === 'small') {
68
+ // Calculate minimum content height to ensure footer can fill remaining space
69
+ const minContentHeight = Platform.OS === 'web' && windowHeight
70
+ ? windowHeight
71
+ : undefined;
72
+ // Calculate minimum height for content area to fill viewport
73
+ // Account for footer minimum height (300px) to ensure content takes up at least one screen
74
+ const contentMinHeight = windowHeight ? Math.max(windowHeight - 300, windowHeight * 0.6) : undefined;
75
+ return (_jsx(View, { style: [styles.container, { backgroundColor: theme.values.backgroundColor }], children: _jsxs(ScrollView, { contentContainerStyle: [
76
+ styles.scrollContentMobile,
77
+ {
78
+ flexGrow: 1,
79
+ ...(minContentHeight && { minHeight: minContentHeight }),
80
+ },
81
+ ], children: [_jsx(View, { style: [
82
+ styles.content,
83
+ styles.contentMobile,
84
+ ...(contentMinHeight ? [{ minHeight: contentMinHeight }] : []),
85
+ ], children: children }), bottomActions && _jsx(View, { style: styles.bottomActionsMobile, children: bottomActions }), showFooter && (_jsx(View, { style: styles.footerWrapperMobile, children: _jsx(Footer, {}) }))] }) }));
86
+ }
87
+ // Desktop/Tablet layout: Footer at bottom (fixed if bottomActions, otherwise end of ScrollView)
88
+ // Calculate minimum height for desktop to ensure fullscreen
89
+ const isDesktop = Platform.OS === 'web' && dimensions.breakpoint !== 'small';
90
+ const appbarHeight = isDesktop ? 80 : 60;
91
+ const minContentHeight = Platform.OS === 'web' && windowHeight
92
+ ? windowHeight - appbarHeight
93
+ : undefined;
94
+ return (_jsxs(View, { style: [styles.container, { backgroundColor: theme.values.backgroundColor }], children: [_jsxs(ScrollView, { contentContainerStyle: [
95
+ styles.scrollContent,
96
+ ...(isDesktop && minContentHeight ? [{ minHeight: minContentHeight }] : []),
97
+ ], children: [_jsx(View, { style: [
98
+ styles.content,
99
+ isDesktop && styles.contentDesktop, // Expand content on desktop
100
+ ], children: children }), !bottomActions && showFooter && (_jsx(View, { style: styles.footerWrapperDesktop, children: _jsx(Footer, {}) }))] }), bottomActions && (_jsxs(View, { style: styles.fixedBottomContainer, children: [bottomActions, showFooter && (_jsx(View, { style: styles.footerWrapperDesktop, children: _jsx(Footer, {}) }))] }))] }));
101
+ };
102
+ export default WebPageLayout;
103
+ //# sourceMappingURL=WebPageLayout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WebPageLayout.js","sourceRoot":"","sources":["../../../components/layout/WebPageLayout.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export { default as ParallaxScrollView, HEADER_HEIGHT } from './ParallaxScrollView';
2
+ export { default as WebPageLayout } from './WebPageLayout';
3
+ export { default as Footer } from './Footer';
4
+ export { default as MinimalFooter } from './MinimalFooter';
5
+ export { default as MobileFooterBar } from './MobileFooterBar';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/layout/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGpF,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAG3D,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,9 @@
1
+ // Layout blocks
2
+ export { default as ParallaxScrollView, HEADER_HEIGHT } from './ParallaxScrollView';
3
+ // Unified web page layout template
4
+ export { default as WebPageLayout } from './WebPageLayout';
5
+ // Footer components
6
+ export { default as Footer } from './Footer';
7
+ export { default as MinimalFooter } from './MinimalFooter';
8
+ export { default as MobileFooterBar } from './MobileFooterBar';
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/layout/index.ts"],"names":[],"mappings":"AAAA,gBAAgB;AAChB,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAEpF,mCAAmC;AACnC,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAE3D,oBAAoB;AACpB,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ type ListProps = {
3
+ children: React.ReactNode | React.ReactNode[];
4
+ };
5
+ /**
6
+ * A list component that wraps th each child in a container with consistent padding and gap values.
7
+ */
8
+ declare const List: ({ children }: ListProps) => import("react/jsx-runtime").JSX.Element;
9
+ export { List };
10
+ //# sourceMappingURL=List.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"List.d.ts","sourceRoot":"","sources":["../../../components/list/List.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,KAAK,SAAS,GAAG;IACf,QAAQ,EAAE,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;CAC/C,CAAC;AAEF;;GAEG;AAEH,QAAA,MAAM,IAAI,GAAI,cAAc,SAAS,4CAEpC,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { StyleSheet, View } from 'react-native';
3
+ /**
4
+ * A list component that wraps th each child in a container with consistent padding and gap values.
5
+ */
6
+ const List = ({ children }) => {
7
+ return _jsx(View, { style: styles.list, children: children });
8
+ };
9
+ export { List };
10
+ const styles = StyleSheet.create({
11
+ list: {
12
+ alignSelf: 'center',
13
+ width: '100%',
14
+ padding: 15,
15
+ gap: 15,
16
+ },
17
+ });
18
+ //# sourceMappingURL=List.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"List.js","sourceRoot":"","sources":["../../../components/list/List.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAMhD;;GAEG;AAEH,MAAM,IAAI,GAAG,CAAC,EAAE,QAAQ,EAAa,EAAE,EAAE;IACvC,OAAO,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,IAAI,YAAG,QAAQ,GAAQ,CAAC;AACrD,CAAC,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,CAAC;AAEhB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,IAAI,EAAE;QACJ,SAAS,EAAE,QAAQ;QACnB,KAAK,EAAE,MAAM;QACb,OAAO,EAAE,EAAE;QACX,GAAG,EAAE,EAAE;KACR;CACF,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ import Feather from '@expo/vector-icons/Feather';
2
+ type ListButtonProps = {
3
+ text: string;
4
+ icon?: keyof typeof Feather.glyphMap;
5
+ onPress?: () => void;
6
+ uppercase?: boolean;
7
+ };
8
+ /**
9
+ * List Button component that displays a list button with an icon and text
10
+ */
11
+ declare const ListButton: ({ onPress, text, icon, uppercase }: ListButtonProps) => import("react/jsx-runtime").JSX.Element;
12
+ export { ListButton };
13
+ //# sourceMappingURL=ListButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListButton.d.ts","sourceRoot":"","sources":["../../../components/list/ListButton.tsx"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,4BAA4B,CAAC;AAIjD,KAAK,eAAe,GAAG;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,OAAO,OAAO,CAAC,QAAQ,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF;;GAEG;AAEH,QAAA,MAAM,UAAU,GAAI,oCAAoC,eAAe,4CAYtE,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } 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
+ import { StyledText } from '../ui';
7
+ /**
8
+ * List Button component that displays a list button with an icon and text
9
+ */
10
+ const ListButton = ({ onPress, text, icon, uppercase }) => {
11
+ // Initialize theme
12
+ const theme = useContext(ThemeContext);
13
+ return (_jsxs(Pressable, { style: styles.listButton, onPress: onPress, children: [_jsx(StyledText, { bold: true, uppercase: uppercase, children: text }), icon ? _jsx(Feather, { name: icon, size: 25, color: theme.values.color }) : null] }));
14
+ };
15
+ export { ListButton };
16
+ const styles = StyleSheet.create({
17
+ listButton: {
18
+ flexDirection: 'row',
19
+ justifyContent: 'space-between',
20
+ alignItems: 'center',
21
+ padding: 15,
22
+ },
23
+ });
24
+ //# sourceMappingURL=ListButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListButton.js","sourceRoot":"","sources":["../../../components/list/ListButton.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;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AASnC;;GAEG;AAEH,MAAM,UAAU,GAAG,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAmB,EAAE,EAAE;IACzE,mBAAmB;IACnB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,OAAO,CACL,MAAC,SAAS,IAAC,KAAK,EAAE,MAAM,CAAC,UAAU,EAAE,OAAO,EAAE,OAAO,aACnD,KAAC,UAAU,IAAC,IAAI,QAAC,SAAS,EAAE,SAAS,YAClC,IAAI,GACM,EACZ,IAAI,CAAC,CAAC,CAAC,KAAC,OAAO,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK,GAAI,CAAC,CAAC,CAAC,IAAI,IACjE,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC;AAEtB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,UAAU,EAAE;QACV,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,OAAO,EAAE,EAAE;KACZ;CACF,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Returns a line that extends the full width of the container
3
+ * Derives color from theme
4
+ */
5
+ declare const ListDivider: () => import("react/jsx-runtime").JSX.Element;
6
+ export { ListDivider };
7
+ //# sourceMappingURL=ListDivider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListDivider.d.ts","sourceRoot":"","sources":["../../../components/list/ListDivider.tsx"],"names":[],"mappings":"AAIA;;;GAGG;AAEH,QAAA,MAAM,WAAW,+CAShB,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { StyleSheet, View } from 'react-native';
4
+ import { ThemeContext } from '../../theme';
5
+ /**
6
+ * Returns a line that extends the full width of the container
7
+ * Derives color from theme
8
+ */
9
+ const ListDivider = () => {
10
+ const theme = useContext(ThemeContext);
11
+ return (_jsx(View, { style: {
12
+ backgroundColor: theme.values.dividerColor,
13
+ ...styles.listDivider,
14
+ } }));
15
+ };
16
+ export { ListDivider };
17
+ const styles = StyleSheet.create({
18
+ listDivider: {
19
+ width: '100%',
20
+ height: 1,
21
+ },
22
+ });
23
+ //# sourceMappingURL=ListDivider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListDivider.js","sourceRoot":"","sources":["../../../components/list/ListDivider.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C;;;GAGG;AAEH,MAAM,WAAW,GAAG,GAAG,EAAE;IACvB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,OAAO,CACL,KAAC,IAAI,IACH,KAAK,EAAE;YACL,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY;YAC1C,GAAG,MAAM,CAAC,WAAW;SACtB,GAAS,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,CAAC;AAEvB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,WAAW,EAAE;QACX,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,CAAC;KACV;CACF,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { List } from './List';
2
+ export { ListButton } from './ListButton';
3
+ export { ListDivider } from './ListDivider';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/list/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { List } from './List';
2
+ export { ListButton } from './ListButton';
3
+ export { ListDivider } from './ListDivider';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/list/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ export interface CarouselProps<T> {
3
+ data: T[];
4
+ renderItem: (item: T, index: number) => React.ReactNode;
5
+ pagination?: 'dots' | 'numbers' | false;
6
+ paginationPosition?: 'top' | 'bottom';
7
+ autoPlay?: boolean;
8
+ loop?: boolean;
9
+ width?: number;
10
+ height?: number;
11
+ onItemChange?: (index: number) => void;
12
+ }
13
+ /**
14
+ * Generic carousel component that works with any data type.
15
+ * Supports pagination dots and integrates with the design system.
16
+ */
17
+ export declare const Carousel: <T>({ data, renderItem, pagination, paginationPosition, autoPlay, loop, width, height, onItemChange, }: CarouselProps<T>) => import("react/jsx-runtime").JSX.Element;
18
+ //# sourceMappingURL=Carousel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Carousel.d.ts","sourceRoot":"","sources":["../../../components/media/Carousel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AAMjD,MAAM,WAAW,aAAa,CAAC,CAAC;IAC9B,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC;IACxD,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,KAAK,CAAC;IACxC,kBAAkB,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC;AAED;;;GAGG;AACH,eAAO,MAAM,QAAQ,GAAI,CAAC,EAAG,oGAU1B,aAAa,CAAC,CAAC,CAAC,4CAoDlB,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState, useMemo } from 'react';
3
+ import { StyleSheet, View, Dimensions } from 'react-native';
4
+ import ReanimatedCarousel from 'react-native-reanimated-carousel';
5
+ const { width: screenWidth } = Dimensions.get('window');
6
+ /**
7
+ * Generic carousel component that works with any data type.
8
+ * Supports pagination dots and integrates with the design system.
9
+ */
10
+ export const Carousel = ({ data, renderItem, pagination = 'dots', paginationPosition = 'bottom', autoPlay = false, loop = true, width = screenWidth, height = 250, onItemChange, }) => {
11
+ const [currentIndex, setCurrentIndex] = useState(0);
12
+ // Move useMemo to top level - hooks must be called at component top level
13
+ const paginationDots = useMemo(() => new Array(data.length).fill(0).map((_, index) => index), [data.length]);
14
+ const handleProgressChange = (offsetProgress, absoluteProgress) => {
15
+ const newIndex = Math.round(absoluteProgress) % data.length;
16
+ setCurrentIndex(newIndex);
17
+ onItemChange?.(newIndex);
18
+ };
19
+ const renderPagination = () => {
20
+ if (pagination === false || data.length <= 1)
21
+ return null;
22
+ return (_jsx(View, { style: [
23
+ styles.paginationWrapper,
24
+ paginationPosition === 'top' ? styles.paginationTop : styles.paginationBottom,
25
+ ], children: paginationDots.map((key, index) => (_jsx(View, { style: [
26
+ styles.paginationDot,
27
+ index === currentIndex ? styles.paginationDotActive : null,
28
+ ] }, `dot-${key}`))) }));
29
+ };
30
+ return (_jsxs(View, { style: { position: 'relative', height: height, width: width }, children: [_jsx(ReanimatedCarousel, { loop: loop, width: width, height: height, autoPlay: autoPlay, data: data, scrollAnimationDuration: 500, onProgressChange: (_, absoluteProgress) => handleProgressChange(_, absoluteProgress), renderItem: ({ item, index }) => _jsx(_Fragment, { children: renderItem(item, index) }) }), renderPagination()] }));
31
+ };
32
+ const styles = StyleSheet.create({
33
+ paginationWrapper: {
34
+ position: 'absolute',
35
+ left: 0,
36
+ right: 0,
37
+ zIndex: 1000,
38
+ flexDirection: 'row',
39
+ justifyContent: 'center',
40
+ alignItems: 'center',
41
+ },
42
+ paginationTop: {
43
+ top: 16,
44
+ },
45
+ paginationBottom: {
46
+ bottom: 16,
47
+ },
48
+ paginationDot: {
49
+ width: 6,
50
+ height: 6,
51
+ borderRadius: 3,
52
+ backgroundColor: 'white',
53
+ marginHorizontal: 4,
54
+ opacity: 0.5,
55
+ },
56
+ paginationDotActive: {
57
+ opacity: 1,
58
+ },
59
+ });
60
+ //# sourceMappingURL=Carousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Carousel.js","sourceRoot":"","sources":["../../../components/media/Carousel.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ interface FeatureCardProps {
2
+ image: string | number;
3
+ onPress: () => void;
4
+ buttonText?: string;
5
+ fallbackImage?: string | number;
6
+ }
7
+ declare const FeatureCard: ({ image, onPress, buttonText, fallbackImage, }: FeatureCardProps) => import("react/jsx-runtime").JSX.Element;
8
+ export default FeatureCard;
9
+ //# sourceMappingURL=FeatureCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureCard.d.ts","sourceRoot":"","sources":["../../../components/media/FeatureCard.tsx"],"names":[],"mappings":"AAOA,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACjC;AAED,QAAA,MAAM,WAAW,GAAI,gDAKlB,gBAAgB,4CAuFlB,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,68 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useMemo } from 'react';
3
+ import { View, StyleSheet, Animated } from 'react-native';
4
+ import { Image } from 'expo-image';
5
+ import { StyledText, BlurButton } from '../ui';
6
+ import { useBrand } from '../../brand';
7
+ import { ThemeContext } from '../../theme';
8
+ const FeatureCard = ({ image, onPress, buttonText = 'Ask me anything!', fallbackImage, }) => {
9
+ const theme = React.useContext(ThemeContext);
10
+ const brand = useBrand();
11
+ const scaleValue = React.useRef(new Animated.Value(1)).current;
12
+ const styles = useMemo(() => StyleSheet.create({
13
+ cardContainer: {
14
+ flex: 1,
15
+ borderRadius: brand.borderRadius,
16
+ },
17
+ card: {
18
+ flex: 1,
19
+ borderRadius: brand.borderRadius,
20
+ overflow: 'hidden',
21
+ borderWidth: 0.5,
22
+ backgroundColor: 'rgba(255, 255, 255, 0.05)',
23
+ },
24
+ image: {
25
+ width: '100%',
26
+ height: '100%',
27
+ },
28
+ actionButtonContainer: {
29
+ position: 'absolute',
30
+ bottom: 20,
31
+ left: 0,
32
+ right: 0,
33
+ alignItems: 'center',
34
+ },
35
+ actionButton: {
36
+ borderRadius: 100,
37
+ justifyContent: 'center',
38
+ alignItems: 'center',
39
+ paddingHorizontal: 10,
40
+ paddingVertical: 10,
41
+ borderWidth: 0.5,
42
+ overflow: 'hidden',
43
+ },
44
+ }), [brand]);
45
+ // Handle both local assets (require) and remote URLs
46
+ const imageSource = typeof image === 'string'
47
+ ? { uri: image || (typeof fallbackImage === 'string' ? fallbackImage : undefined) }
48
+ : image;
49
+ const handlePressIn = () => {
50
+ Animated.spring(scaleValue, {
51
+ toValue: 0.95,
52
+ useNativeDriver: true,
53
+ tension: 300,
54
+ friction: 10,
55
+ }).start();
56
+ };
57
+ const handlePressOut = () => {
58
+ Animated.spring(scaleValue, {
59
+ toValue: 1,
60
+ useNativeDriver: true,
61
+ tension: 300,
62
+ friction: 10,
63
+ }).start();
64
+ };
65
+ return (_jsx(View, { style: styles.cardContainer, children: _jsxs(View, { style: [styles.card, { borderColor: theme.values.borderColor }], children: [_jsx(Image, { source: imageSource, style: styles.image, contentFit: "cover" }), _jsx(View, { style: styles.actionButtonContainer, children: _jsx(BlurButton, { intensity: 80, tint: "dark", style: styles.actionButton, onPress: onPress, onPressIn: handlePressIn, onPressOut: handlePressOut, scaleValue: scaleValue, activeOpacity: 0.9, children: _jsx(StyledText, { fontSize: "lg", color: "white", fontWeight: 500, children: buttonText }) }) })] }) }));
66
+ };
67
+ export default FeatureCard;
68
+ //# sourceMappingURL=FeatureCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureCard.js","sourceRoot":"","sources":["../../../components/media/FeatureCard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ interface HorizontalCarouselProps<T> {
3
+ data: T[] | undefined;
4
+ renderItem: ({ item }: {
5
+ item: T;
6
+ }) => React.ReactElement;
7
+ keyExtractor: (item: T) => string;
8
+ headerWidth?: number;
9
+ }
10
+ /**
11
+ * HorizontalCarousel component with horizontal scrolling and arrow navigation
12
+ * Displays items in a horizontal scrollable list with optional arrow buttons
13
+ * Uses FlatList for performance
14
+ */
15
+ declare function HorizontalCarousel<T>({ data, renderItem, keyExtractor, headerWidth, }: HorizontalCarouselProps<T>): import("react/jsx-runtime").JSX.Element;
16
+ export { HorizontalCarousel };
17
+ //# sourceMappingURL=HorizontalCarousel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HorizontalCarousel.d.ts","sourceRoot":"","sources":["../../../components/media/HorizontalCarousel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA2B,MAAM,OAAO,CAAC;AAYhD,UAAU,uBAAuB,CAAC,CAAC;IACjC,IAAI,EAAE,CAAC,EAAE,GAAG,SAAS,CAAC;IACtB,UAAU,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAAE,IAAI,EAAE,CAAC,CAAA;KAAE,KAAK,KAAK,CAAC,YAAY,CAAC;IAC1D,YAAY,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;;;GAIG;AACH,iBAAS,kBAAkB,CAAC,CAAC,EAAE,EAC7B,IAAI,EACJ,UAAU,EACV,YAAY,EACZ,WAAW,GACZ,EAAE,uBAAuB,CAAC,CAAC,CAAC,2CAkE5B;AAyBD,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useRef, useState } from 'react';
3
+ import { FlatList, View, StyleSheet, Platform, } from 'react-native';
4
+ import { ArrowButton } from '../ui';
5
+ import { useDimensions, breakpoints } from '../../hooks';
6
+ /**
7
+ * HorizontalCarousel component with horizontal scrolling and arrow navigation
8
+ * Displays items in a horizontal scrollable list with optional arrow buttons
9
+ * Uses FlatList for performance
10
+ */
11
+ function HorizontalCarousel({ data, renderItem, keyExtractor, headerWidth, }) {
12
+ const flatListRef = useRef(null);
13
+ const [scrollOffset, setScrollOffset] = useState(0);
14
+ const [contentWidth, setContentWidth] = useState(0);
15
+ const scrollList = (direction) => {
16
+ if (flatListRef.current) {
17
+ const newOffset = direction === 'left'
18
+ ? Math.max(0, scrollOffset - (300 + 10) * 3)
19
+ : scrollOffset + (310 + 10) * 3;
20
+ flatListRef.current.scrollToOffset({
21
+ offset: newOffset,
22
+ animated: true,
23
+ });
24
+ }
25
+ };
26
+ const handleScroll = (event) => {
27
+ setScrollOffset(event.nativeEvent.contentOffset.x);
28
+ };
29
+ const handleContentSizeChange = (contentWidth) => {
30
+ setContentWidth(contentWidth);
31
+ };
32
+ const dimensions = useDimensions();
33
+ const hideLeftArrow = scrollOffset <= 0;
34
+ const hideRightArrow = scrollOffset >= contentWidth - dimensions.width;
35
+ return (_jsxs(View, { style: styles.container, children: [_jsx(FlatList, { ref: flatListRef, data: data, keyExtractor: keyExtractor, renderItem: renderItem, horizontal: true, ListHeaderComponent: Platform.OS === 'ios' ? _jsx(View, { style: { width: headerWidth || 20 } }) : null, showsHorizontalScrollIndicator: false, onScroll: handleScroll, scrollEventThrottle: 16, onContentSizeChange: handleContentSizeChange, style: styles.list }), dimensions.width > breakpoints.small && !hideLeftArrow && (_jsx(View, { style: styles.leftArrowContainer, children: _jsx(ArrowButton, { direction: "left", onPress: () => scrollList('left'), hidden: hideLeftArrow }) })), dimensions.width > breakpoints.small && !hideRightArrow && (_jsx(View, { style: styles.rightArrowContainer, children: _jsx(ArrowButton, { direction: "right", onPress: () => scrollList('right'), hidden: hideRightArrow }) }))] }));
36
+ }
37
+ const styles = StyleSheet.create({
38
+ container: {
39
+ flex: 1,
40
+ },
41
+ list: {
42
+ flex: 1,
43
+ },
44
+ leftArrowContainer: {
45
+ position: 'absolute',
46
+ left: -25,
47
+ top: '50%',
48
+ zIndex: 10,
49
+ transform: [{ translateY: -25 }],
50
+ },
51
+ rightArrowContainer: {
52
+ position: 'absolute',
53
+ right: -25,
54
+ top: '50%',
55
+ zIndex: 10,
56
+ transform: [{ translateY: -25 }],
57
+ },
58
+ });
59
+ export { HorizontalCarousel };
60
+ //# sourceMappingURL=HorizontalCarousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HorizontalCarousel.js","sourceRoot":"","sources":["../../../components/media/HorizontalCarousel.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ type ImageCarouselProps = {
2
+ images: string[];
3
+ loop?: boolean;
4
+ autoPlay?: boolean;
5
+ width?: number;
6
+ height?: number;
7
+ };
8
+ /**
9
+ * ImageCarousel component - uses generic Carousel for displaying images.
10
+ * Provides a convenient wrapper for image-specific carousel usage.
11
+ */
12
+ export declare const ImageCarousel: ({ images, autoPlay, loop, width, height, }: ImageCarouselProps) => import("react/jsx-runtime").JSX.Element;
13
+ export {};
14
+ //# sourceMappingURL=ImageCarousel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageCarousel.d.ts","sourceRoot":"","sources":["../../../components/media/ImageCarousel.tsx"],"names":[],"mappings":"AAOA,KAAK,kBAAkB,GAAG;IACxB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,aAAa,GAAI,4CAM3B,kBAAkB,4CAwBpB,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Image } from 'expo-image';
3
+ import { useMemo } from 'react';
4
+ import { Dimensions } from 'react-native';
5
+ import { Carousel } from './Carousel';
6
+ const { width: screenWidth } = Dimensions.get('window');
7
+ /**
8
+ * ImageCarousel component - uses generic Carousel for displaying images.
9
+ * Provides a convenient wrapper for image-specific carousel usage.
10
+ */
11
+ export const ImageCarousel = ({ images, autoPlay = false, loop = true, width = screenWidth, height = 250, }) => {
12
+ const imageStyle = useMemo(() => ({
13
+ width,
14
+ height,
15
+ }), [width, height]);
16
+ const renderImage = (imageUri) => {
17
+ return _jsx(Image, { source: { uri: imageUri }, style: imageStyle });
18
+ };
19
+ return (_jsx(Carousel, { data: images, renderItem: renderImage, pagination: "dots", autoPlay: autoPlay, loop: loop, width: width, height: height }));
20
+ };
21
+ //# sourceMappingURL=ImageCarousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageCarousel.js","sourceRoot":"","sources":["../../../components/media/ImageCarousel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAc,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAUxD;;;GAGG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,MAAM,EACN,QAAQ,GAAG,KAAK,EAChB,IAAI,GAAG,IAAI,EACX,KAAK,GAAG,WAAW,EACnB,MAAM,GAAG,GAAG,GACO,EAAE,EAAE;IACvB,MAAM,UAAU,GAAG,OAAO,CACxB,GAAG,EAAE,CAAC,CAAC;QACL,KAAK;QACL,MAAM;KACP,CAAC,EACF,CAAC,KAAK,EAAE,MAAM,CAAC,CAChB,CAAC;IAEF,MAAM,WAAW,GAAG,CAAC,QAAgB,EAAE,EAAE;QACvC,OAAO,KAAC,KAAK,IAAC,MAAM,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,UAAU,GAAI,CAAC;IACjE,CAAC,CAAC;IAEF,OAAO,CACL,KAAC,QAAQ,IACP,IAAI,EAAE,MAAM,EACZ,UAAU,EAAE,WAAW,EACvB,UAAU,EAAC,MAAM,EACjB,QAAQ,EAAE,QAAQ,EAClB,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,GACd,CACH,CAAC;AACJ,CAAC,CAAC"}