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.
- package/README.md +929 -0
- package/dist/brand/brandConfig.d.ts +48 -0
- package/dist/brand/brandConfig.d.ts.map +1 -0
- package/dist/brand/brandConfig.js +41 -0
- package/dist/brand/brandConfig.js.map +1 -0
- package/dist/brand/brandContext.d.ts +10 -0
- package/dist/brand/brandContext.d.ts.map +1 -0
- package/dist/brand/brandContext.js +16 -0
- package/dist/brand/brandContext.js.map +1 -0
- package/dist/brand/brandTypes.d.ts +54 -0
- package/dist/brand/brandTypes.d.ts.map +1 -0
- package/dist/brand/brandTypes.js +2 -0
- package/dist/brand/brandTypes.js.map +1 -0
- package/dist/brand/index.d.ts +4 -0
- package/dist/brand/index.d.ts.map +1 -0
- package/dist/brand/index.js +5 -0
- package/dist/brand/index.js.map +1 -0
- package/dist/components/action/ActionRow.d.ts +25 -0
- package/dist/components/action/ActionRow.d.ts.map +1 -0
- package/dist/components/action/ActionRow.js +66 -0
- package/dist/components/action/ActionRow.js.map +1 -0
- package/dist/components/action/index.d.ts +2 -0
- package/dist/components/action/index.d.ts.map +1 -0
- package/dist/components/action/index.js +3 -0
- package/dist/components/action/index.js.map +1 -0
- package/dist/components/card/Card.d.ts +11 -0
- package/dist/components/card/Card.d.ts.map +1 -0
- package/dist/components/card/Card.js +32 -0
- package/dist/components/card/Card.js.map +1 -0
- package/dist/components/card/index.d.ts +2 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/card/index.js +2 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/chat/ChatContainer.d.ts +27 -0
- package/dist/components/chat/ChatContainer.d.ts.map +1 -0
- package/dist/components/chat/ChatContainer.js +52 -0
- package/dist/components/chat/ChatContainer.js.map +1 -0
- package/dist/components/chat/ChatInput.d.ts +9 -0
- package/dist/components/chat/ChatInput.d.ts.map +1 -0
- package/dist/components/chat/ChatInput.js +219 -0
- package/dist/components/chat/ChatInput.js.map +1 -0
- package/dist/components/chat/ChatMessages.d.ts +9 -0
- package/dist/components/chat/ChatMessages.d.ts.map +1 -0
- package/dist/components/chat/ChatMessages.js +35 -0
- package/dist/components/chat/ChatMessages.js.map +1 -0
- package/dist/components/chat/EmptyChat.d.ts +18 -0
- package/dist/components/chat/EmptyChat.d.ts.map +1 -0
- package/dist/components/chat/EmptyChat.js +64 -0
- package/dist/components/chat/EmptyChat.js.map +1 -0
- package/dist/components/chat/Message.d.ts +8 -0
- package/dist/components/chat/Message.d.ts.map +1 -0
- package/dist/components/chat/Message.js +47 -0
- package/dist/components/chat/Message.js.map +1 -0
- package/dist/components/chat/index.d.ts +6 -0
- package/dist/components/chat/index.d.ts.map +1 -0
- package/dist/components/chat/index.js +7 -0
- package/dist/components/chat/index.js.map +1 -0
- package/dist/components/chat/types.d.ts +34 -0
- package/dist/components/chat/types.d.ts.map +1 -0
- package/dist/components/chat/types.js +2 -0
- package/dist/components/chat/types.js.map +1 -0
- package/dist/components/form/DropDownSelect.d.ts +12 -0
- package/dist/components/form/DropDownSelect.d.ts.map +1 -0
- package/dist/components/form/DropDownSelect.js +63 -0
- package/dist/components/form/DropDownSelect.js.map +1 -0
- package/dist/components/form/EmailSubscriptionForm.d.ts +14 -0
- package/dist/components/form/EmailSubscriptionForm.d.ts.map +1 -0
- package/dist/components/form/EmailSubscriptionForm.js +58 -0
- package/dist/components/form/EmailSubscriptionForm.js.map +1 -0
- package/dist/components/form/FormErrors.d.ts +7 -0
- package/dist/components/form/FormErrors.d.ts.map +1 -0
- package/dist/components/form/FormErrors.js +35 -0
- package/dist/components/form/FormErrors.js.map +1 -0
- package/dist/components/form/FormInput.d.ts +14 -0
- package/dist/components/form/FormInput.d.ts.map +1 -0
- package/dist/components/form/FormInput.js +35 -0
- package/dist/components/form/FormInput.js.map +1 -0
- package/dist/components/form/FormSeparator.d.ts +6 -0
- package/dist/components/form/FormSeparator.d.ts.map +1 -0
- package/dist/components/form/FormSeparator.js +25 -0
- package/dist/components/form/FormSeparator.js.map +1 -0
- package/dist/components/form/index.d.ts +6 -0
- package/dist/components/form/index.d.ts.map +1 -0
- package/dist/components/form/index.js +7 -0
- package/dist/components/form/index.js.map +1 -0
- package/dist/components/index.d.ts +11 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +12 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/layout/Footer.d.ts +3 -0
- package/dist/components/layout/Footer.d.ts.map +1 -0
- package/dist/components/layout/Footer.js +60 -0
- package/dist/components/layout/Footer.js.map +1 -0
- package/dist/components/layout/MinimalFooter.d.ts +8 -0
- package/dist/components/layout/MinimalFooter.d.ts.map +1 -0
- package/dist/components/layout/MinimalFooter.js +57 -0
- package/dist/components/layout/MinimalFooter.js.map +1 -0
- package/dist/components/layout/MobileFooterBar.d.ts +7 -0
- package/dist/components/layout/MobileFooterBar.d.ts.map +1 -0
- package/dist/components/layout/MobileFooterBar.js +18 -0
- package/dist/components/layout/MobileFooterBar.js.map +1 -0
- package/dist/components/layout/ParallaxScrollView.d.ts +11 -0
- package/dist/components/layout/ParallaxScrollView.d.ts.map +1 -0
- package/dist/components/layout/ParallaxScrollView.js +67 -0
- package/dist/components/layout/ParallaxScrollView.js.map +1 -0
- package/dist/components/layout/WebPageLayout.d.ts +17 -0
- package/dist/components/layout/WebPageLayout.d.ts.map +1 -0
- package/dist/components/layout/WebPageLayout.js +103 -0
- package/dist/components/layout/WebPageLayout.js.map +1 -0
- package/dist/components/layout/index.d.ts +6 -0
- package/dist/components/layout/index.d.ts.map +1 -0
- package/dist/components/layout/index.js +9 -0
- package/dist/components/layout/index.js.map +1 -0
- package/dist/components/list/List.d.ts +10 -0
- package/dist/components/list/List.d.ts.map +1 -0
- package/dist/components/list/List.js +18 -0
- package/dist/components/list/List.js.map +1 -0
- package/dist/components/list/ListButton.d.ts +13 -0
- package/dist/components/list/ListButton.d.ts.map +1 -0
- package/dist/components/list/ListButton.js +24 -0
- package/dist/components/list/ListButton.js.map +1 -0
- package/dist/components/list/ListDivider.d.ts +7 -0
- package/dist/components/list/ListDivider.d.ts.map +1 -0
- package/dist/components/list/ListDivider.js +23 -0
- package/dist/components/list/ListDivider.js.map +1 -0
- package/dist/components/list/index.d.ts +4 -0
- package/dist/components/list/index.d.ts.map +1 -0
- package/dist/components/list/index.js +4 -0
- package/dist/components/list/index.js.map +1 -0
- package/dist/components/media/Carousel.d.ts +18 -0
- package/dist/components/media/Carousel.d.ts.map +1 -0
- package/dist/components/media/Carousel.js +60 -0
- package/dist/components/media/Carousel.js.map +1 -0
- package/dist/components/media/FeatureCard.d.ts +9 -0
- package/dist/components/media/FeatureCard.d.ts.map +1 -0
- package/dist/components/media/FeatureCard.js +68 -0
- package/dist/components/media/FeatureCard.js.map +1 -0
- package/dist/components/media/HorizontalCarousel.d.ts +17 -0
- package/dist/components/media/HorizontalCarousel.d.ts.map +1 -0
- package/dist/components/media/HorizontalCarousel.js +60 -0
- package/dist/components/media/HorizontalCarousel.js.map +1 -0
- package/dist/components/media/ImageCarousel.d.ts +14 -0
- package/dist/components/media/ImageCarousel.d.ts.map +1 -0
- package/dist/components/media/ImageCarousel.js +21 -0
- package/dist/components/media/ImageCarousel.js.map +1 -0
- package/dist/components/media/MediaTile.d.ts +30 -0
- package/dist/components/media/MediaTile.d.ts.map +1 -0
- package/dist/components/media/MediaTile.js +51 -0
- package/dist/components/media/MediaTile.js.map +1 -0
- package/dist/components/media/SkeletonMediaTile.d.ts +17 -0
- package/dist/components/media/SkeletonMediaTile.d.ts.map +1 -0
- package/dist/components/media/SkeletonMediaTile.js +67 -0
- package/dist/components/media/SkeletonMediaTile.js.map +1 -0
- package/dist/components/media/index.d.ts +7 -0
- package/dist/components/media/index.d.ts.map +1 -0
- package/dist/components/media/index.js +8 -0
- package/dist/components/media/index.js.map +1 -0
- package/dist/components/navigation/AppbarWeb.d.ts +18 -0
- package/dist/components/navigation/AppbarWeb.d.ts.map +1 -0
- package/dist/components/navigation/AppbarWeb.js +70 -0
- package/dist/components/navigation/AppbarWeb.js.map +1 -0
- package/dist/components/navigation/IconButtonGroup.d.ts +7 -0
- package/dist/components/navigation/IconButtonGroup.d.ts.map +1 -0
- package/dist/components/navigation/IconButtonGroup.js +33 -0
- package/dist/components/navigation/IconButtonGroup.js.map +1 -0
- package/dist/components/navigation/Logo.d.ts +16 -0
- package/dist/components/navigation/Logo.d.ts.map +1 -0
- package/dist/components/navigation/Logo.js +64 -0
- package/dist/components/navigation/Logo.js.map +1 -0
- package/dist/components/navigation/MobileMenuDrawer.d.ts +13 -0
- package/dist/components/navigation/MobileMenuDrawer.d.ts.map +1 -0
- package/dist/components/navigation/MobileMenuDrawer.js +184 -0
- package/dist/components/navigation/MobileMenuDrawer.js.map +1 -0
- package/dist/components/navigation/ScreenHeader.d.ts +30 -0
- package/dist/components/navigation/ScreenHeader.d.ts.map +1 -0
- package/dist/components/navigation/ScreenHeader.js +127 -0
- package/dist/components/navigation/ScreenHeader.js.map +1 -0
- package/dist/components/navigation/iconUtils.d.ts +24 -0
- package/dist/components/navigation/iconUtils.d.ts.map +1 -0
- package/dist/components/navigation/iconUtils.js +53 -0
- package/dist/components/navigation/iconUtils.js.map +1 -0
- package/dist/components/navigation/index.d.ts +6 -0
- package/dist/components/navigation/index.d.ts.map +1 -0
- package/dist/components/navigation/index.js +7 -0
- package/dist/components/navigation/index.js.map +1 -0
- package/dist/components/tile/Tile.d.ts +18 -0
- package/dist/components/tile/Tile.d.ts.map +1 -0
- package/dist/components/tile/Tile.js +41 -0
- package/dist/components/tile/Tile.js.map +1 -0
- package/dist/components/tile/index.d.ts +2 -0
- package/dist/components/tile/index.d.ts.map +1 -0
- package/dist/components/tile/index.js +2 -0
- package/dist/components/tile/index.js.map +1 -0
- package/dist/components/ui/ArrowButton.d.ts +8 -0
- package/dist/components/ui/ArrowButton.d.ts.map +1 -0
- package/dist/components/ui/ArrowButton.js +30 -0
- package/dist/components/ui/ArrowButton.js.map +1 -0
- package/dist/components/ui/BlurButton.d.ts +16 -0
- package/dist/components/ui/BlurButton.d.ts.map +1 -0
- package/dist/components/ui/BlurButton.js +26 -0
- package/dist/components/ui/BlurButton.js.map +1 -0
- package/dist/components/ui/Button.d.ts +24 -0
- package/dist/components/ui/Button.d.ts.map +1 -0
- package/dist/components/ui/Button.js +60 -0
- package/dist/components/ui/Button.js.map +1 -0
- package/dist/components/ui/ErrorBoundary.d.ts +18 -0
- package/dist/components/ui/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ui/ErrorBoundary.js +37 -0
- package/dist/components/ui/ErrorBoundary.js.map +1 -0
- package/dist/components/ui/IconButton.d.ts +13 -0
- package/dist/components/ui/IconButton.d.ts.map +1 -0
- package/dist/components/ui/IconButton.js +27 -0
- package/dist/components/ui/IconButton.js.map +1 -0
- package/dist/components/ui/LoadingIndicator.d.ts +6 -0
- package/dist/components/ui/LoadingIndicator.d.ts.map +1 -0
- package/dist/components/ui/LoadingIndicator.js +15 -0
- package/dist/components/ui/LoadingIndicator.js.map +1 -0
- package/dist/components/ui/NotificationBadge.d.ts +8 -0
- package/dist/components/ui/NotificationBadge.d.ts.map +1 -0
- package/dist/components/ui/NotificationBadge.js +24 -0
- package/dist/components/ui/NotificationBadge.js.map +1 -0
- package/dist/components/ui/SkeletonCard.d.ts +14 -0
- package/dist/components/ui/SkeletonCard.d.ts.map +1 -0
- package/dist/components/ui/SkeletonCard.js +50 -0
- package/dist/components/ui/SkeletonCard.js.map +1 -0
- package/dist/components/ui/StyledText.d.ts +17 -0
- package/dist/components/ui/StyledText.d.ts.map +1 -0
- package/dist/components/ui/StyledText.js +27 -0
- package/dist/components/ui/StyledText.js.map +1 -0
- package/dist/components/ui/StyledTextInput.d.ts +10 -0
- package/dist/components/ui/StyledTextInput.d.ts.map +1 -0
- package/dist/components/ui/StyledTextInput.js +62 -0
- package/dist/components/ui/StyledTextInput.js.map +1 -0
- package/dist/components/ui/TextLink.d.ts +14 -0
- package/dist/components/ui/TextLink.d.ts.map +1 -0
- package/dist/components/ui/TextLink.js +25 -0
- package/dist/components/ui/TextLink.js.map +1 -0
- package/dist/components/ui/ToggleIconButton.d.ts +14 -0
- package/dist/components/ui/ToggleIconButton.d.ts.map +1 -0
- package/dist/components/ui/ToggleIconButton.js +19 -0
- package/dist/components/ui/ToggleIconButton.js.map +1 -0
- package/dist/components/ui/index.d.ts +13 -0
- package/dist/components/ui/index.d.ts.map +1 -0
- package/dist/components/ui/index.js +14 -0
- package/dist/components/ui/index.js.map +1 -0
- package/dist/context/scrollContext.d.ts +8 -0
- package/dist/context/scrollContext.d.ts.map +1 -0
- package/dist/context/scrollContext.js +16 -0
- package/dist/context/scrollContext.js.map +1 -0
- package/dist/hooks/index.d.ts +4 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +5 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useDimensions.d.ts +31 -0
- package/dist/hooks/useDimensions.d.ts.map +1 -0
- package/dist/hooks/useDimensions.js +44 -0
- package/dist/hooks/useDimensions.js.map +1 -0
- package/dist/hooks/useWindowHeight.d.ts +7 -0
- package/dist/hooks/useWindowHeight.d.ts.map +1 -0
- package/dist/hooks/useWindowHeight.js +10 -0
- package/dist/hooks/useWindowHeight.js.map +1 -0
- package/dist/hooks/useWindowWidth.d.ts +20 -0
- package/dist/hooks/useWindowWidth.d.ts.map +1 -0
- package/dist/hooks/useWindowWidth.js +27 -0
- package/dist/hooks/useWindowWidth.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/theme/index.d.ts +3 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +4 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/theme.d.ts +15 -0
- package/dist/theme/theme.d.ts.map +1 -0
- package/dist/theme/theme.js +38 -0
- package/dist/theme/theme.js.map +1 -0
- package/dist/theme/themeConfig.d.ts +19 -0
- package/dist/theme/themeConfig.d.ts.map +1 -0
- package/dist/theme/themeConfig.js +43 -0
- package/dist/theme/themeConfig.js.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|