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,30 @@
|
|
|
1
|
+
import { ImageSourcePropType, ViewStyle, ImageStyle } from 'react-native';
|
|
2
|
+
export interface MediaTileProps {
|
|
3
|
+
image: ImageSourcePropType | {
|
|
4
|
+
uri: string;
|
|
5
|
+
};
|
|
6
|
+
fallbackImage?: ImageSourcePropType | {
|
|
7
|
+
uri: string;
|
|
8
|
+
};
|
|
9
|
+
title: string;
|
|
10
|
+
subtitle?: string;
|
|
11
|
+
metadata?: string[];
|
|
12
|
+
onPress?: () => void;
|
|
13
|
+
loading?: boolean;
|
|
14
|
+
width?: number | {
|
|
15
|
+
mobile: number;
|
|
16
|
+
desktop: number;
|
|
17
|
+
};
|
|
18
|
+
height?: number | {
|
|
19
|
+
mobile: number;
|
|
20
|
+
desktop: number;
|
|
21
|
+
};
|
|
22
|
+
imageStyle?: ImageStyle;
|
|
23
|
+
contentStyle?: ViewStyle;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* A general-purpose media tile component that displays an image with title, subtitle, and metadata.
|
|
27
|
+
* Responsive sizing and integrates with the design system theme/brand.
|
|
28
|
+
*/
|
|
29
|
+
export declare const MediaTile: ({ image, fallbackImage, title, subtitle, metadata, onPress, loading, width, height, imageStyle, contentStyle, }: MediaTileProps) => import("react/jsx-runtime").JSX.Element;
|
|
30
|
+
//# sourceMappingURL=MediaTile.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaTile.d.ts","sourceRoot":"","sources":["../../../components/media/MediaTile.tsx"],"names":[],"mappings":"AACA,OAAO,EAAsC,mBAAmB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAK9G,MAAM,WAAW,cAAc;IAE7B,KAAK,EAAE,mBAAmB,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IAC7C,aAAa,CAAC,EAAE,mBAAmB,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IAGtD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAGpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAGlB,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACrD,MAAM,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAGtD,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,YAAY,CAAC,EAAE,SAAS,CAAC;CAC1B;AAED;;;GAGG;AACH,eAAO,MAAM,SAAS,GAAI,iHAYvB,cAAc,4CAgFhB,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useMemo } from 'react';
|
|
3
|
+
import { View, Image, Pressable, StyleSheet } from 'react-native';
|
|
4
|
+
import { StyledText } from '../ui';
|
|
5
|
+
import { useBrand } from '../../brand';
|
|
6
|
+
import { useBreakpoints } from '../../hooks/useWindowWidth';
|
|
7
|
+
/**
|
|
8
|
+
* A general-purpose media tile component that displays an image with title, subtitle, and metadata.
|
|
9
|
+
* Responsive sizing and integrates with the design system theme/brand.
|
|
10
|
+
*/
|
|
11
|
+
export const MediaTile = ({ image, fallbackImage, title, subtitle, metadata, onPress, loading, width, height, imageStyle, contentStyle, }) => {
|
|
12
|
+
const { isMediumOrLarger } = useBreakpoints();
|
|
13
|
+
const brand = useBrand();
|
|
14
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
15
|
+
image: {
|
|
16
|
+
width: '100%',
|
|
17
|
+
borderRadius: brand.borderRadius,
|
|
18
|
+
},
|
|
19
|
+
infoContainer: {
|
|
20
|
+
marginTop: 10,
|
|
21
|
+
gap: 5,
|
|
22
|
+
},
|
|
23
|
+
}), [brand]);
|
|
24
|
+
// Handle responsive sizing
|
|
25
|
+
const getWidth = () => {
|
|
26
|
+
if (typeof width === 'object') {
|
|
27
|
+
return isMediumOrLarger ? width.desktop : width.mobile;
|
|
28
|
+
}
|
|
29
|
+
return width;
|
|
30
|
+
};
|
|
31
|
+
const getHeight = () => {
|
|
32
|
+
if (typeof height === 'object') {
|
|
33
|
+
return isMediumOrLarger ? height.desktop : height.mobile;
|
|
34
|
+
}
|
|
35
|
+
return height;
|
|
36
|
+
};
|
|
37
|
+
// Default responsive sizes if not provided
|
|
38
|
+
const tileWidth = getWidth() ?? (isMediumOrLarger ? 250 : 150);
|
|
39
|
+
const imageHeight = getHeight() ?? (isMediumOrLarger ? 150 : 200);
|
|
40
|
+
// Determine image source
|
|
41
|
+
const imageSource = image || fallbackImage;
|
|
42
|
+
const content = (_jsxs(_Fragment, { children: [_jsx(Image, { source: imageSource, style: [styles.image, { height: imageHeight }, imageStyle], resizeMode: 'cover' }), _jsxs(View, { style: [styles.infoContainer, contentStyle], children: [_jsx(StyledText, { fontSize: "md", numberOfLines: 1, align: "left", children: title }), subtitle && (_jsx(StyledText, { fontSize: 'sm', numberOfLines: 1, align: "left", muted: true, children: subtitle })), metadata && metadata.length > 0 && metadata.map((item, index) => (_jsx(StyledText, { fontSize: 'sm', numberOfLines: 1, align: "left", muted: true, children: item }, index)))] })] }));
|
|
43
|
+
if (onPress) {
|
|
44
|
+
return (_jsx(Pressable, { style: [
|
|
45
|
+
{ marginRight: 10 },
|
|
46
|
+
{ width: tileWidth },
|
|
47
|
+
], onPress: onPress, children: content }));
|
|
48
|
+
}
|
|
49
|
+
return (_jsx(View, { style: [{ marginRight: 10, width: tileWidth }], children: content }));
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=MediaTile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaTile.js","sourceRoot":"","sources":["../../../components/media/MediaTile.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface SkeletonMediaTileProps {
|
|
2
|
+
width?: number | {
|
|
3
|
+
mobile: number;
|
|
4
|
+
desktop: number;
|
|
5
|
+
};
|
|
6
|
+
height?: number | {
|
|
7
|
+
mobile: number;
|
|
8
|
+
desktop: number;
|
|
9
|
+
};
|
|
10
|
+
metadataCount?: number;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Skeleton loading state for MediaTile component.
|
|
14
|
+
* Provides consistent loading states with responsive sizing.
|
|
15
|
+
*/
|
|
16
|
+
export declare const SkeletonMediaTile: ({ width, height, metadataCount, }: SkeletonMediaTileProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
//# sourceMappingURL=SkeletonMediaTile.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SkeletonMediaTile.d.ts","sourceRoot":"","sources":["../../../components/media/SkeletonMediaTile.tsx"],"names":[],"mappings":"AAMA,MAAM,WAAW,sBAAsB;IACrC,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACrD,MAAM,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACtD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAAI,mCAI/B,sBAAsB,4CA+ExB,CAAC"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { View, StyleSheet } from 'react-native';
|
|
4
|
+
import { ThemeContext } from '../../theme';
|
|
5
|
+
import { useBrand } from '../../brand';
|
|
6
|
+
import { useBreakpoints } from '../../hooks/useWindowWidth';
|
|
7
|
+
/**
|
|
8
|
+
* Skeleton loading state for MediaTile component.
|
|
9
|
+
* Provides consistent loading states with responsive sizing.
|
|
10
|
+
*/
|
|
11
|
+
export const SkeletonMediaTile = ({ width, height, metadataCount = 2, }) => {
|
|
12
|
+
const theme = useContext(ThemeContext);
|
|
13
|
+
const { isMediumOrLarger } = useBreakpoints();
|
|
14
|
+
const brand = useBrand();
|
|
15
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
16
|
+
skeletonImage: {
|
|
17
|
+
width: '100%',
|
|
18
|
+
borderRadius: brand.borderRadius,
|
|
19
|
+
},
|
|
20
|
+
infoContainer: {
|
|
21
|
+
marginTop: 10,
|
|
22
|
+
gap: 5,
|
|
23
|
+
},
|
|
24
|
+
skeletonText: {
|
|
25
|
+
height: 10,
|
|
26
|
+
borderRadius: 4,
|
|
27
|
+
marginTop: 5,
|
|
28
|
+
},
|
|
29
|
+
}), [brand]);
|
|
30
|
+
// Handle responsive sizing
|
|
31
|
+
const getWidth = () => {
|
|
32
|
+
if (typeof width === 'object') {
|
|
33
|
+
return isMediumOrLarger ? width.desktop : width.mobile;
|
|
34
|
+
}
|
|
35
|
+
return width;
|
|
36
|
+
};
|
|
37
|
+
const getHeight = () => {
|
|
38
|
+
if (typeof height === 'object') {
|
|
39
|
+
return isMediumOrLarger ? height.desktop : height.mobile;
|
|
40
|
+
}
|
|
41
|
+
return height;
|
|
42
|
+
};
|
|
43
|
+
// Default responsive sizes if not provided
|
|
44
|
+
const tileWidth = getWidth() ?? (isMediumOrLarger ? 250 : 150);
|
|
45
|
+
const imageHeight = getHeight() ?? (isMediumOrLarger ? 150 : 200);
|
|
46
|
+
const skeletonColor = theme.values.isDark ? '#333333' : '#e0e0e0';
|
|
47
|
+
const skeletonWidths = ['70%', '40%', '30%'];
|
|
48
|
+
return (_jsxs(View, { style: [
|
|
49
|
+
{ width: tileWidth, marginRight: 10 },
|
|
50
|
+
], children: [_jsx(View, { style: [
|
|
51
|
+
styles.skeletonImage,
|
|
52
|
+
{ backgroundColor: skeletonColor, height: imageHeight },
|
|
53
|
+
] }), _jsxs(View, { style: styles.infoContainer, children: [_jsx(View, { style: [
|
|
54
|
+
styles.skeletonText,
|
|
55
|
+
{
|
|
56
|
+
width: (skeletonWidths[0] || '70%'),
|
|
57
|
+
backgroundColor: skeletonColor,
|
|
58
|
+
},
|
|
59
|
+
] }), Array.from({ length: metadataCount }).map((_, index) => (_jsx(View, { style: [
|
|
60
|
+
styles.skeletonText,
|
|
61
|
+
{
|
|
62
|
+
width: (skeletonWidths[index + 1] || '40%'),
|
|
63
|
+
backgroundColor: skeletonColor,
|
|
64
|
+
},
|
|
65
|
+
] }, index)))] })] }));
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=SkeletonMediaTile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SkeletonMediaTile.js","sourceRoot":"","sources":["../../../components/media/SkeletonMediaTile.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { ImageCarousel } from './ImageCarousel';
|
|
2
|
+
export { default as FeatureCard } from './FeatureCard';
|
|
3
|
+
export { HorizontalCarousel } from './HorizontalCarousel';
|
|
4
|
+
export { Carousel } from './Carousel';
|
|
5
|
+
export { MediaTile } from './MediaTile';
|
|
6
|
+
export { SkeletonMediaTile } from './SkeletonMediaTile';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/media/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// Media components
|
|
2
|
+
export { ImageCarousel } from './ImageCarousel';
|
|
3
|
+
export { default as FeatureCard } from './FeatureCard';
|
|
4
|
+
export { HorizontalCarousel } from './HorizontalCarousel';
|
|
5
|
+
export { Carousel } from './Carousel';
|
|
6
|
+
export { MediaTile } from './MediaTile';
|
|
7
|
+
export { SkeletonMediaTile } from './SkeletonMediaTile';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/media/index.ts"],"names":[],"mappings":"AAAA,mBAAmB;AACnB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type AppbarProps = {
|
|
3
|
+
title?: string;
|
|
4
|
+
logoUri?: string;
|
|
5
|
+
tabs?: React.ReactElement | React.ReactElement[];
|
|
6
|
+
currentRoute?: string;
|
|
7
|
+
onNavigate?: (route: string) => void;
|
|
8
|
+
hideTabs?: boolean;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* A responsive appbar that displays at the top of the page.
|
|
12
|
+
* Dynamically adapts its styling when the viewport is less than medium
|
|
13
|
+
* On mobile web: Logo + Hamburger menu
|
|
14
|
+
* On desktop/tablet: Logo + Top tabs + Theme toggle
|
|
15
|
+
*/
|
|
16
|
+
declare const AppbarWeb: ({ title, logoUri, tabs, currentRoute, onNavigate, hideTabs }: AppbarProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export default AppbarWeb;
|
|
18
|
+
//# sourceMappingURL=AppbarWeb.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AppbarWeb.d.ts","sourceRoot":"","sources":["../../../components/navigation/AppbarWeb.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAUnD,KAAK,WAAW,GAAG;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;IACjD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF;;;;;GAKG;AAEH,QAAA,MAAM,SAAS,GAAI,8DAAsE,WAAW,4CAwEnG,CAAC;AACF,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { StyleSheet, View } from 'react-native';
|
|
4
|
+
import { useDimensions } from '../../hooks';
|
|
5
|
+
import { useBrand } from '../../brand';
|
|
6
|
+
import { ThemeContext } from '../../theme';
|
|
7
|
+
import { Platform } from 'react-native';
|
|
8
|
+
import IconButtonGroup from './IconButtonGroup';
|
|
9
|
+
import AppbarBranding from './Logo';
|
|
10
|
+
import MobileMenuDrawer from './MobileMenuDrawer';
|
|
11
|
+
/**
|
|
12
|
+
* A responsive appbar that displays at the top of the page.
|
|
13
|
+
* Dynamically adapts its styling when the viewport is less than medium
|
|
14
|
+
* On mobile web: Logo + Hamburger menu
|
|
15
|
+
* On desktop/tablet: Logo + Top tabs + Theme toggle
|
|
16
|
+
*/
|
|
17
|
+
const AppbarWeb = ({ title, logoUri, tabs, currentRoute, onNavigate, hideTabs = false }) => {
|
|
18
|
+
//Initialize theme
|
|
19
|
+
const theme = useContext(ThemeContext);
|
|
20
|
+
//Use dimensions hook
|
|
21
|
+
const dimensions = useDimensions();
|
|
22
|
+
const brand = useBrand();
|
|
23
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
24
|
+
appbar: {
|
|
25
|
+
flexDirection: 'row',
|
|
26
|
+
alignItems: 'center',
|
|
27
|
+
justifyContent: 'space-between',
|
|
28
|
+
height: 80,
|
|
29
|
+
paddingHorizontal: '5%',
|
|
30
|
+
},
|
|
31
|
+
appbarWebSmall: {
|
|
32
|
+
flexDirection: 'row',
|
|
33
|
+
alignItems: 'center',
|
|
34
|
+
justifyContent: 'space-between',
|
|
35
|
+
height: 80,
|
|
36
|
+
width: '100%',
|
|
37
|
+
paddingHorizontal: brand.spacing.xl,
|
|
38
|
+
},
|
|
39
|
+
iconContainer: {
|
|
40
|
+
flexDirection: 'row',
|
|
41
|
+
gap: brand.spacing.sm + 2,
|
|
42
|
+
},
|
|
43
|
+
logo: {
|
|
44
|
+
width: 40,
|
|
45
|
+
height: 40,
|
|
46
|
+
},
|
|
47
|
+
title: {
|
|
48
|
+
fontSize: brand.fontSizes.large,
|
|
49
|
+
fontWeight: 'bold',
|
|
50
|
+
marginLeft: brand.spacing.sm + 2,
|
|
51
|
+
},
|
|
52
|
+
webContainer: {}, // WebContainer property for additional styling
|
|
53
|
+
}), [brand]);
|
|
54
|
+
return (_jsx(View, { style: {
|
|
55
|
+
//Configure a background with a theme background
|
|
56
|
+
backgroundColor: theme.values.appbarBackgroundColor,
|
|
57
|
+
// Ensure appbar appears above content
|
|
58
|
+
zIndex: 10,
|
|
59
|
+
position: 'relative',
|
|
60
|
+
}, children: _jsx(View, { style: {
|
|
61
|
+
...styles.webContainer, //Configure appbar with theme appbar background color
|
|
62
|
+
backgroundColor: theme.values.appbarBackgroundColor,
|
|
63
|
+
...(!theme.values.isDark && { borderBottomWidth: 1, borderBottomColor: theme.values.borderColor }),
|
|
64
|
+
}, children: _jsxs(View, { style: {
|
|
65
|
+
...styles.appbar,
|
|
66
|
+
height: Platform.OS === 'web' && dimensions.breakpoint === 'small' ? 60 : 80,
|
|
67
|
+
}, children: [_jsx(AppbarBranding, { logoUri: logoUri }), Platform.OS === 'web' && dimensions.breakpoint === 'small' ? (_jsx(MobileMenuDrawer, { currentRoute: currentRoute, onNavigate: onNavigate, logoUri: logoUri })) : (_jsxs(_Fragment, { children: [!hideTabs && tabs, _jsx(IconButtonGroup, {})] }))] }) }) }));
|
|
68
|
+
};
|
|
69
|
+
export default AppbarWeb;
|
|
70
|
+
//# sourceMappingURL=AppbarWeb.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AppbarWeb.js","sourceRoot":"","sources":["../../../components/navigation/AppbarWeb.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Icons to be rendered inside appbar on both web and mobile
|
|
3
|
+
* @returns Rendered IconButtonGroup
|
|
4
|
+
*/
|
|
5
|
+
declare const IconButtonGroup: () => import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export default IconButtonGroup;
|
|
7
|
+
//# sourceMappingURL=IconButtonGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IconButtonGroup.d.ts","sourceRoot":"","sources":["../../../components/navigation/IconButtonGroup.tsx"],"names":[],"mappings":"AAMA;;;GAGG;AACH,QAAA,MAAM,eAAe,+CAiBpB,CAAC;AACF,eAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext } from 'react';
|
|
3
|
+
import { StyleSheet, View } from 'react-native';
|
|
4
|
+
import { ToggleIconButton } from '../ui';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
import { useDimensions } from '../../hooks';
|
|
7
|
+
/**
|
|
8
|
+
* Icons to be rendered inside appbar on both web and mobile
|
|
9
|
+
* @returns Rendered IconButtonGroup
|
|
10
|
+
*/
|
|
11
|
+
const IconButtonGroup = () => {
|
|
12
|
+
//Initialize theme toggle
|
|
13
|
+
const { toggleTheme } = useContext(ThemeContext);
|
|
14
|
+
const dimensions = useDimensions();
|
|
15
|
+
return (_jsx(View, { style: {
|
|
16
|
+
...styles.buttonGroup,
|
|
17
|
+
width: dimensions.breakpoint !== 'small' ? 150 : 'auto',
|
|
18
|
+
justifyContent: 'flex-end',
|
|
19
|
+
}, children: _jsx(View, { style: styles.iconContainer, children: _jsx(ToggleIconButton, { iconName: "sun", alternateIconName: "moon", onPress: toggleTheme }) }) }));
|
|
20
|
+
};
|
|
21
|
+
export default IconButtonGroup;
|
|
22
|
+
const styles = StyleSheet.create({
|
|
23
|
+
buttonGroup: {
|
|
24
|
+
width: 150,
|
|
25
|
+
flexDirection: 'row',
|
|
26
|
+
alignItems: 'center',
|
|
27
|
+
},
|
|
28
|
+
iconContainer: {
|
|
29
|
+
flexDirection: 'row',
|
|
30
|
+
gap: 10,
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=IconButtonGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IconButtonGroup.js","sourceRoot":"","sources":["../../../components/navigation/IconButtonGroup.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C;;;GAGG;AACH,MAAM,eAAe,GAAG,GAAG,EAAE;IAC3B,yBAAyB;IACzB,MAAM,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACjD,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,OAAO,CACL,KAAC,IAAI,IACH,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,WAAW;YACrB,KAAK,EAAE,UAAU,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;YACvD,cAAc,EAAE,UAAU;SAC3B,YACD,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,aAAa,YAC/B,KAAC,gBAAgB,IAAC,QAAQ,EAAC,KAAK,EAAC,iBAAiB,EAAC,MAAM,EAAC,OAAO,EAAE,WAAW,GAAI,GAC7E,GACF,CACR,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,eAAe,CAAC;AAE/B,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,WAAW,EAAE;QACX,KAAK,EAAE,GAAG;QACV,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;KACrB;IACD,aAAa,EAAE;QACb,aAAa,EAAE,KAAK;QACpB,GAAG,EAAE,EAAE;KACR;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ImageSourcePropType } from 'react-native';
|
|
2
|
+
type AppBarBrandingProps = {
|
|
3
|
+
/**
|
|
4
|
+
* Optional logo image source. Can be a string URI or ImageSourcePropType (require).
|
|
5
|
+
* If provided, this takes precedence over brand config logos.
|
|
6
|
+
*/
|
|
7
|
+
logoUri?: string | ImageSourcePropType;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Appbar with optional Logo for the business
|
|
11
|
+
* Supports URI strings, ImageSourcePropType, or brand config logos
|
|
12
|
+
* Priority: logoUri > brand config > fallback
|
|
13
|
+
*/
|
|
14
|
+
declare const Logo: ({ logoUri }: AppBarBrandingProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
15
|
+
export default Logo;
|
|
16
|
+
//# sourceMappingURL=Logo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logo.d.ts","sourceRoot":"","sources":["../../../components/navigation/Logo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAe,mBAAmB,EAAc,MAAM,cAAc,CAAC;AAO5E,KAAK,mBAAmB,GAAG;IACzB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,GAAG,mBAAmB,CAAC;CACxC,CAAC;AAEF;;;;GAIG;AAEH,QAAA,MAAM,IAAI,GAAI,aAAa,mBAAmB,mDA8C7C,CAAC;AAEF,eAAe,IAAI,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { View, Image, StyleSheet } from 'react-native';
|
|
4
|
+
import { Link } from 'expo-router';
|
|
5
|
+
import { useBrand } from '../../brand';
|
|
6
|
+
import { useDimensions } from '../../hooks';
|
|
7
|
+
import { ThemeContext } from '../../theme';
|
|
8
|
+
import { Platform } from 'react-native';
|
|
9
|
+
/**
|
|
10
|
+
* Appbar with optional Logo for the business
|
|
11
|
+
* Supports URI strings, ImageSourcePropType, or brand config logos
|
|
12
|
+
* Priority: logoUri > brand config > fallback
|
|
13
|
+
*/
|
|
14
|
+
const Logo = ({ logoUri }) => {
|
|
15
|
+
const dimensions = useDimensions();
|
|
16
|
+
const theme = React.useContext(ThemeContext);
|
|
17
|
+
const brand = useBrand();
|
|
18
|
+
// Determine image source with priority: logoUri > brand config > undefined
|
|
19
|
+
const getImageSource = () => {
|
|
20
|
+
if (logoUri) {
|
|
21
|
+
// If logoUri is provided, use it (supports both string URIs and ImageSourcePropType)
|
|
22
|
+
return typeof logoUri === 'string' ? { uri: logoUri } : logoUri;
|
|
23
|
+
}
|
|
24
|
+
// Fall back to brand config logos
|
|
25
|
+
const brandLogo = theme.values.isDark ? brand.logo.dark : brand.logo.light;
|
|
26
|
+
if (brandLogo) {
|
|
27
|
+
return typeof brandLogo === 'string' ? { uri: brandLogo } : brandLogo;
|
|
28
|
+
}
|
|
29
|
+
// No logo available
|
|
30
|
+
return undefined;
|
|
31
|
+
};
|
|
32
|
+
const imageSource = getImageSource();
|
|
33
|
+
// Don't render if no image source is available
|
|
34
|
+
if (!imageSource) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return (_jsx(Link, { href: "/", children: _jsx(View, { style: {
|
|
38
|
+
...styles.container,
|
|
39
|
+
width: dimensions.breakpoint !== 'small' ? 150 : 'auto',
|
|
40
|
+
}, children: _jsx(Image, { source: imageSource, style: [
|
|
41
|
+
styles.logo,
|
|
42
|
+
Platform.OS === 'web' && dimensions.breakpoint === 'small' && styles.logoMobile,
|
|
43
|
+
] }) }) }));
|
|
44
|
+
};
|
|
45
|
+
export default Logo;
|
|
46
|
+
const styles = StyleSheet.create({
|
|
47
|
+
container: {
|
|
48
|
+
width: 150,
|
|
49
|
+
flexDirection: 'row',
|
|
50
|
+
alignItems: 'center',
|
|
51
|
+
justifyContent: 'flex-start',
|
|
52
|
+
gap: 5,
|
|
53
|
+
},
|
|
54
|
+
logo: {
|
|
55
|
+
marginTop: 12,
|
|
56
|
+
width: 200,
|
|
57
|
+
height: 50,
|
|
58
|
+
},
|
|
59
|
+
logoMobile: {
|
|
60
|
+
width: 150,
|
|
61
|
+
height: 38,
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
//# sourceMappingURL=Logo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../../components/navigation/Logo.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,KAAK,EAAuB,UAAU,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAUxC;;;;GAIG;AAEH,MAAM,IAAI,GAAG,CAAC,EAAE,OAAO,EAAuB,EAAE,EAAE;IAChD,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IAC7C,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,2EAA2E;IAC3E,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,OAAO,EAAE,CAAC;YACZ,qFAAqF;YACrF,OAAO,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;QAClE,CAAC;QAED,kCAAkC;QAClC,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;QAC3E,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;QACxE,CAAC;QAED,oBAAoB;QACpB,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,+CAA+C;IAC/C,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,KAAC,IAAI,IAAC,IAAI,EAAC,GAAG,YACZ,KAAC,IAAI,IACH,KAAK,EAAE;gBACL,GAAG,MAAM,CAAC,SAAS;gBACnB,KAAK,EAAE,UAAU,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;aACxD,YACD,KAAC,KAAK,IACJ,MAAM,EAAE,WAAW,EACnB,KAAK,EAAE;oBACL,MAAM,CAAC,IAAI;oBACX,QAAQ,CAAC,EAAE,KAAK,KAAK,IAAI,UAAU,CAAC,UAAU,KAAK,OAAO,IAAI,MAAM,CAAC,UAAU;iBAChF,GACD,GACG,GACF,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,SAAS,EAAE;QACT,KAAK,EAAE,GAAG;QACV,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,YAAY;QAC5B,GAAG,EAAE,CAAC;KACP;IACD,IAAI,EAAE;QACJ,SAAS,EAAE,EAAE;QACb,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;KACX;IACD,UAAU,EAAE;QACV,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;KACX;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
type MobileMenuDrawerProps = {
|
|
2
|
+
currentRoute?: string;
|
|
3
|
+
onNavigate?: (route: string) => void;
|
|
4
|
+
logoUri?: string;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* Hamburger menu drawer for mobile web that opens a side drawer
|
|
8
|
+
* Contains navigation links and theme toggle
|
|
9
|
+
* Enhanced with keyboard support, accessibility, and improved animations
|
|
10
|
+
*/
|
|
11
|
+
declare const MobileMenuDrawer: ({ currentRoute, onNavigate, logoUri }: MobileMenuDrawerProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
12
|
+
export default MobileMenuDrawer;
|
|
13
|
+
//# sourceMappingURL=MobileMenuDrawer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MobileMenuDrawer.d.ts","sourceRoot":"","sources":["../../../components/navigation/MobileMenuDrawer.tsx"],"names":[],"mappings":"AAWA,KAAK,qBAAqB,GAAG;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,gBAAgB,GAAI,uCAAuC,qBAAqB,mDAmRrF,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|