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,16 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Animated } from 'react-native';
|
|
3
|
+
interface BlurButtonProps {
|
|
4
|
+
onPress: () => void;
|
|
5
|
+
children: React.ReactNode;
|
|
6
|
+
intensity?: number;
|
|
7
|
+
tint?: 'light' | 'dark' | 'default';
|
|
8
|
+
style?: any;
|
|
9
|
+
scaleValue?: Animated.Value;
|
|
10
|
+
onPressIn?: () => void;
|
|
11
|
+
onPressOut?: () => void;
|
|
12
|
+
activeOpacity?: number;
|
|
13
|
+
}
|
|
14
|
+
declare const BlurButton: React.FC<BlurButtonProps>;
|
|
15
|
+
export { BlurButton };
|
|
16
|
+
//# sourceMappingURL=BlurButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlurButton.d.ts","sourceRoot":"","sources":["../../../components/ui/BlurButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAsC,QAAQ,EAAE,MAAM,cAAc,CAAC;AAK5E,UAAU,eAAe;IACvB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;IACpC,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,UAAU,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA2BzC,CAAC;AAkBF,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext } from 'react';
|
|
3
|
+
import { StyleSheet, TouchableOpacity, Animated } from 'react-native';
|
|
4
|
+
import { BlurView } from 'expo-blur';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
const BlurButton = ({ onPress, children, intensity = 80, tint = 'dark', style, scaleValue, onPressIn, onPressOut, activeOpacity = 0.9, }) => {
|
|
7
|
+
const theme = useContext(ThemeContext);
|
|
8
|
+
return (_jsx(Animated.View, { style: scaleValue ? { transform: [{ scale: scaleValue }] } : undefined, children: _jsx(BlurView, { intensity: intensity, tint: tint, style: [styles.blurButton, { borderColor: theme.values.borderColor }, style], children: _jsx(TouchableOpacity, { style: styles.touchable, onPress: onPress, onPressIn: onPressIn, onPressOut: onPressOut, activeOpacity: activeOpacity, children: children }) }) }));
|
|
9
|
+
};
|
|
10
|
+
const styles = StyleSheet.create({
|
|
11
|
+
blurButton: {
|
|
12
|
+
borderRadius: 100,
|
|
13
|
+
justifyContent: 'center',
|
|
14
|
+
alignItems: 'center',
|
|
15
|
+
paddingHorizontal: 10,
|
|
16
|
+
paddingVertical: 10,
|
|
17
|
+
borderWidth: 0.5,
|
|
18
|
+
overflow: 'hidden',
|
|
19
|
+
},
|
|
20
|
+
touchable: {
|
|
21
|
+
paddingHorizontal: 20,
|
|
22
|
+
paddingVertical: 8,
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
export { BlurButton };
|
|
26
|
+
//# sourceMappingURL=BlurButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlurButton.js","sourceRoot":"","sources":["../../../components/ui/BlurButton.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAQ,UAAU,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAc3C,MAAM,UAAU,GAA8B,CAAC,EAC7C,OAAO,EACP,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,IAAI,GAAG,MAAM,EACb,KAAK,EACL,UAAU,EACV,SAAS,EACT,UAAU,EACV,aAAa,GAAG,GAAG,GACpB,EAAE,EAAE;IACH,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,OAAO,CACL,KAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,YACnF,KAAC,QAAQ,IAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,YACtH,KAAC,gBAAgB,IACf,KAAK,EAAE,MAAM,CAAC,SAAS,EACvB,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,YAE3B,QAAQ,GACQ,GACV,GACG,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,UAAU,EAAE;QACV,YAAY,EAAE,GAAG;QACjB,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,iBAAiB,EAAE,EAAE;QACrB,eAAe,EAAE,EAAE;QACnB,WAAW,EAAE,GAAG;QAChB,QAAQ,EAAE,QAAQ;KACnB;IACD,SAAS,EAAE;QACT,iBAAiB,EAAE,EAAE;QACrB,eAAe,EAAE,CAAC;KACnB;CACF,CAAC,CAAC;AAEH,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { GestureResponderEvent } from 'react-native';
|
|
2
|
+
import * as Icons from '@expo/vector-icons';
|
|
3
|
+
type IconLibrary = keyof typeof Icons;
|
|
4
|
+
type ButtonProps = {
|
|
5
|
+
title: string;
|
|
6
|
+
onPress: (event: GestureResponderEvent) => void;
|
|
7
|
+
secondary?: boolean;
|
|
8
|
+
loading?: boolean;
|
|
9
|
+
icon?: {
|
|
10
|
+
library: IconLibrary;
|
|
11
|
+
name: string;
|
|
12
|
+
size?: number;
|
|
13
|
+
color?: string;
|
|
14
|
+
};
|
|
15
|
+
iconPosition?: 'left' | 'right';
|
|
16
|
+
style?: any;
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* A reusable button component that can be customized with different styles,
|
|
20
|
+
* loading states, and behavior based on props. It can also display an optional icon.
|
|
21
|
+
*/
|
|
22
|
+
declare const Button: ({ title, secondary, loading, icon, onPress, iconPosition, style, }: ButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
export { Button };
|
|
24
|
+
//# sourceMappingURL=Button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../components/ui/Button.tsx"],"names":[],"mappings":"AACA,OAAO,EAEL,qBAAqB,EAItB,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,KAAK,MAAM,oBAAoB,CAAC;AAK5C,KAAK,WAAW,GAAG,MAAM,OAAO,KAAK,CAAC;AAEtC,KAAK,WAAW,GAAG;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,CAAC,KAAK,EAAE,qBAAqB,KAAK,IAAI,CAAC;IAChD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE;QACL,OAAO,EAAE,WAAW,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAChC,KAAK,CAAC,EAAE,GAAG,CAAC;CACb,CAAC;AAEF;;;GAGG;AAEH,QAAA,MAAM,MAAM,GAAI,oEAQb,WAAW,4CA8Eb,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React, { useContext, useMemo } from 'react';
|
|
3
|
+
import { ActivityIndicator, Pressable, StyleSheet, View, } from 'react-native';
|
|
4
|
+
import * as Icons from '@expo/vector-icons';
|
|
5
|
+
import { useBrand } from '../../brand';
|
|
6
|
+
import { StyledText } from './StyledText';
|
|
7
|
+
import { ThemeContext } from '../../theme';
|
|
8
|
+
/**
|
|
9
|
+
* A reusable button component that can be customized with different styles,
|
|
10
|
+
* loading states, and behavior based on props. It can also display an optional icon.
|
|
11
|
+
*/
|
|
12
|
+
const Button = ({ title, secondary, loading, icon, onPress, iconPosition = 'right', style, }) => {
|
|
13
|
+
const theme = useContext(ThemeContext);
|
|
14
|
+
const brand = useBrand();
|
|
15
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
16
|
+
primary: {
|
|
17
|
+
maxHeight: 100,
|
|
18
|
+
minWidth: 200,
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
justifyContent: 'center',
|
|
21
|
+
padding: 15,
|
|
22
|
+
borderRadius: brand.borderRadius,
|
|
23
|
+
backgroundColor: brand.colors.primary,
|
|
24
|
+
},
|
|
25
|
+
secondary: {
|
|
26
|
+
maxHeight: 100,
|
|
27
|
+
minWidth: 200,
|
|
28
|
+
alignItems: 'center',
|
|
29
|
+
justifyContent: 'center',
|
|
30
|
+
padding: 15,
|
|
31
|
+
borderRadius: brand.borderRadius,
|
|
32
|
+
backgroundColor: 'transparent',
|
|
33
|
+
borderWidth: 2,
|
|
34
|
+
borderColor: brand.colors.secondary,
|
|
35
|
+
},
|
|
36
|
+
contentContainer: {
|
|
37
|
+
flexDirection: 'row', // Ensures icon and text are in a row
|
|
38
|
+
alignItems: 'center', // Vertically centers icon and text
|
|
39
|
+
justifyContent: 'center', // Horizontally centers icon and text
|
|
40
|
+
},
|
|
41
|
+
icon: {
|
|
42
|
+
marginLeft: 8, // Adds spacing between icon and text
|
|
43
|
+
},
|
|
44
|
+
}), [brand]);
|
|
45
|
+
return loading ? (_jsx(View, { children: _jsx(ActivityIndicator, { size: "small", color: secondary ? brand.colors.secondary : brand.colors.primary }) })) : (_jsx(Pressable, { onPress: onPress, style: [secondary ? styles.secondary : styles.primary, style], children: _jsxs(View, { style: styles.contentContainer, children: [icon && iconPosition === 'left' && (_jsx(View, { style: { marginRight: 8 }, children: icon.library && Icons[icon.library]
|
|
46
|
+
? React.createElement(Icons[icon.library], {
|
|
47
|
+
name: icon.name,
|
|
48
|
+
size: icon.size || 20,
|
|
49
|
+
color: icon.color || (!secondary ? '#fff' : theme.values.color),
|
|
50
|
+
})
|
|
51
|
+
: null })), _jsx(StyledText, { fontSize: 'sm', color: !secondary ? '#FFFFFF' : theme.values.color, fontWeight: 500, numberOfLines: 1, align: "center", children: title }), icon && iconPosition === 'right' && (_jsx(View, { style: { marginLeft: 8 }, children: icon.library && Icons[icon.library]
|
|
52
|
+
? React.createElement(Icons[icon.library], {
|
|
53
|
+
name: icon.name,
|
|
54
|
+
size: icon.size || 20,
|
|
55
|
+
color: icon.color || (!secondary ? '#fff' : theme.values.color),
|
|
56
|
+
})
|
|
57
|
+
: null }))] }) }));
|
|
58
|
+
};
|
|
59
|
+
export { Button };
|
|
60
|
+
//# sourceMappingURL=Button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../components/ui/Button.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface ErrorBoundaryState {
|
|
3
|
+
hasError: boolean;
|
|
4
|
+
error?: Error;
|
|
5
|
+
}
|
|
6
|
+
interface ErrorBoundaryProps {
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
fallback?: React.ReactNode;
|
|
9
|
+
onError?: (error: Error, errorInfo: React.ErrorInfo) => void;
|
|
10
|
+
}
|
|
11
|
+
declare class ErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundaryState> {
|
|
12
|
+
constructor(props: ErrorBoundaryProps);
|
|
13
|
+
static getDerivedStateFromError(error: Error): ErrorBoundaryState;
|
|
14
|
+
componentDidCatch(error: Error, errorInfo: React.ErrorInfo): void;
|
|
15
|
+
render(): string | number | bigint | boolean | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | import("react/jsx-runtime").JSX.Element | null | undefined;
|
|
16
|
+
}
|
|
17
|
+
export { ErrorBoundary };
|
|
18
|
+
//# sourceMappingURL=ErrorBoundary.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorBoundary.d.ts","sourceRoot":"","sources":["../../../components/ui/ErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,CAAC;CACf;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC;CAC9D;AAED,cAAM,aAAc,SAAQ,KAAK,CAAC,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;gBACrE,KAAK,EAAE,kBAAkB;IAKrC,MAAM,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,GAAG,kBAAkB;IAIjE,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS;IAK1D,MAAM;CAiBP;AAYD,OAAO,EAAE,aAAa,EAAE,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { View, StyleSheet } from 'react-native';
|
|
4
|
+
import { StyledText } from './StyledText';
|
|
5
|
+
class ErrorBoundary extends React.Component {
|
|
6
|
+
constructor(props) {
|
|
7
|
+
super(props);
|
|
8
|
+
this.state = { hasError: false };
|
|
9
|
+
}
|
|
10
|
+
static getDerivedStateFromError(error) {
|
|
11
|
+
return { hasError: true, error };
|
|
12
|
+
}
|
|
13
|
+
componentDidCatch(error, errorInfo) {
|
|
14
|
+
console.error('ErrorBoundary caught an error:', error, errorInfo);
|
|
15
|
+
this.props.onError?.(error, errorInfo);
|
|
16
|
+
}
|
|
17
|
+
render() {
|
|
18
|
+
if (this.state.hasError) {
|
|
19
|
+
if (this.props.fallback) {
|
|
20
|
+
return this.props.fallback;
|
|
21
|
+
}
|
|
22
|
+
return (_jsx(View, { style: styles.errorContainer, children: _jsx(StyledText, { fontSize: "sm", color: "#666", align: "center", children: "Content temporarily unavailable" }) }));
|
|
23
|
+
}
|
|
24
|
+
return this.props.children;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const styles = StyleSheet.create({
|
|
28
|
+
errorContainer: {
|
|
29
|
+
padding: 20,
|
|
30
|
+
justifyContent: 'center',
|
|
31
|
+
alignItems: 'center',
|
|
32
|
+
backgroundColor: '#f5f5f5',
|
|
33
|
+
borderRadius: 8,
|
|
34
|
+
},
|
|
35
|
+
});
|
|
36
|
+
export { ErrorBoundary };
|
|
37
|
+
//# sourceMappingURL=ErrorBoundary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorBoundary.js","sourceRoot":"","sources":["../../../components/ui/ErrorBoundary.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAa1C,MAAM,aAAc,SAAQ,KAAK,CAAC,SAAiD;IACjF,YAAY,KAAyB;QACnC,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,MAAM,CAAC,wBAAwB,CAAC,KAAY;QAC1C,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,KAAY,EAAE,SAA0B;QACxD,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YACxB,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACxB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YAC7B,CAAC;YAED,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,cAAc,YAChC,KAAC,UAAU,IAAC,QAAQ,EAAC,IAAI,EAAC,KAAK,EAAC,MAAM,EAAC,KAAK,EAAC,QAAQ,gDAExC,GACR,CACR,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;CACF;AAED,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,cAAc,EAAE;QACd,OAAO,EAAE,EAAE;QACX,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,eAAe,EAAE,SAAS;QAC1B,YAAY,EAAE,CAAC;KAChB;CACF,CAAC,CAAC;AAEH,OAAO,EAAE,aAAa,EAAE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import Feather from '@expo/vector-icons/Feather';
|
|
2
|
+
type IconButtonProps = {
|
|
3
|
+
iconName: keyof typeof Feather.glyphMap;
|
|
4
|
+
onPress: () => void;
|
|
5
|
+
color?: string;
|
|
6
|
+
backgroundColor?: string;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Renders rounded icon button with icon from expo-vector icons.
|
|
10
|
+
*/
|
|
11
|
+
declare const IconButton: ({ iconName, onPress, color, backgroundColor }: IconButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export { IconButton };
|
|
13
|
+
//# sourceMappingURL=IconButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IconButton.d.ts","sourceRoot":"","sources":["../../../components/ui/IconButton.tsx"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,4BAA4B,CAAC;AAGjD,KAAK,eAAe,GAAG;IACrB,QAAQ,EAAE,MAAM,OAAO,OAAO,CAAC,QAAQ,CAAC;IACxC,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF;;GAEG;AAEH,QAAA,MAAM,UAAU,GAAI,+CAA+C,eAAe,4CAcjF,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext } from 'react';
|
|
3
|
+
import { StyleSheet, Pressable } from 'react-native';
|
|
4
|
+
import Feather from '@expo/vector-icons/Feather';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
/**
|
|
7
|
+
* Renders rounded icon button with icon from expo-vector icons.
|
|
8
|
+
*/
|
|
9
|
+
const IconButton = ({ iconName, onPress, color, backgroundColor }) => {
|
|
10
|
+
//Initialize theme
|
|
11
|
+
const theme = useContext(ThemeContext);
|
|
12
|
+
return (_jsx(Pressable, { onPress: onPress, style: {
|
|
13
|
+
...styles.container,
|
|
14
|
+
backgroundColor: backgroundColor ?? 'transparent',
|
|
15
|
+
}, children: _jsx(Feather, { name: iconName, size: 20, color: color ? theme.values.iconButtonIconColor : theme.values.color }) }));
|
|
16
|
+
};
|
|
17
|
+
export { IconButton };
|
|
18
|
+
const styles = StyleSheet.create({
|
|
19
|
+
container: {
|
|
20
|
+
justifyContent: 'center',
|
|
21
|
+
alignItems: 'center',
|
|
22
|
+
width: 40,
|
|
23
|
+
height: 40,
|
|
24
|
+
borderRadius: 25,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=IconButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IconButton.js","sourceRoot":"","sources":["../../../components/ui/IconButton.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,OAAO,MAAM,4BAA4B,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAS3C;;GAEG;AAEH,MAAM,UAAU,GAAG,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,eAAe,EAAmB,EAAE,EAAE;IACpF,kBAAkB;IAClB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,OAAO,CACL,KAAC,SAAS,IACR,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,SAAS;YACnB,eAAe,EAAE,eAAe,IAAI,aAAa;SAClD,YACD,KAAC,OAAO,IAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,GAAI,GACjG,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC;AAEtB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,SAAS,EAAE;QACT,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,EAAE;QACV,YAAY,EAAE,EAAE;KACjB;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingIndicator.d.ts","sourceRoot":"","sources":["../../../components/ui/LoadingIndicator.tsx"],"names":[],"mappings":"AAMA;;GAEG;AAEH,QAAA,MAAM,gBAAgB,+CAKrB,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
//A spinner component that uses theme values to style the spinner.
|
|
3
|
+
import { useContext } from 'react';
|
|
4
|
+
import { ActivityIndicator } from 'react-native';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
/**
|
|
7
|
+
* Loading indicator
|
|
8
|
+
*/
|
|
9
|
+
const LoadingIndicator = () => {
|
|
10
|
+
// Initialize theme
|
|
11
|
+
const theme = useContext(ThemeContext);
|
|
12
|
+
return _jsx(ActivityIndicator, { size: "large", color: theme.values.highlightColor });
|
|
13
|
+
};
|
|
14
|
+
export { LoadingIndicator };
|
|
15
|
+
//# sourceMappingURL=LoadingIndicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingIndicator.js","sourceRoot":"","sources":["../../../components/ui/LoadingIndicator.tsx"],"names":[],"mappings":";AAAA,kEAAkE;AAElE,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C;;GAEG;AAEH,MAAM,gBAAgB,GAAG,GAAG,EAAE;IAC5B,mBAAmB;IACnB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,OAAO,KAAC,iBAAiB,IAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,cAAc,GAAI,CAAC;AAChF,CAAC,CAAC;AAEF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationBadge.d.ts","sourceRoot":"","sources":["../../../components/ui/NotificationBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,sBAAsB;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAoB9D,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { View, StyleSheet } from 'react-native';
|
|
3
|
+
import { StyledText } from './StyledText';
|
|
4
|
+
export const NotificationBadge = ({ count, maxCount = 99 }) => {
|
|
5
|
+
if (count <= 0)
|
|
6
|
+
return null;
|
|
7
|
+
const displayCount = count > maxCount ? `${maxCount}+` : count.toString();
|
|
8
|
+
return (_jsx(View, { style: styles.badge, children: _jsx(StyledText, { color: "white", fontSize: "sm", fontWeight: 600, align: "center", children: displayCount }) }));
|
|
9
|
+
};
|
|
10
|
+
const styles = StyleSheet.create({
|
|
11
|
+
badge: {
|
|
12
|
+
position: 'absolute',
|
|
13
|
+
top: -4,
|
|
14
|
+
right: -4,
|
|
15
|
+
backgroundColor: '#CC3366', // Using brand primary color
|
|
16
|
+
borderRadius: 8,
|
|
17
|
+
minWidth: 16,
|
|
18
|
+
height: 16,
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
justifyContent: 'center',
|
|
21
|
+
paddingHorizontal: 4,
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=NotificationBadge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationBadge.js","sourceRoot":"","sources":["../../../components/ui/NotificationBadge.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAO1C,MAAM,CAAC,MAAM,iBAAiB,GAAqC,CAAC,EAClE,KAAK,EACL,QAAQ,GAAG,EAAE,EACd,EAAE,EAAE;IACH,IAAI,KAAK,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAE5B,MAAM,YAAY,GAAG,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IAE1E,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,KAAK,YACvB,KAAC,UAAU,IACT,KAAK,EAAC,OAAO,EACb,QAAQ,EAAC,IAAI,EACb,UAAU,EAAE,GAAG,EACf,KAAK,EAAC,QAAQ,YAEb,YAAY,GACF,GACR,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,KAAK,EAAE;QACL,QAAQ,EAAE,UAAU;QACpB,GAAG,EAAE,CAAC,CAAC;QACP,KAAK,EAAE,CAAC,CAAC;QACT,eAAe,EAAE,SAAS,EAAE,4BAA4B;QACxD,YAAY,EAAE,CAAC;QACf,QAAQ,EAAE,EAAE;QACZ,MAAM,EAAE,EAAE;QACV,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,iBAAiB,EAAE,CAAC;KACrB;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
interface SkeletonCardProps {
|
|
2
|
+
width?: number | {
|
|
3
|
+
mobile: number;
|
|
4
|
+
web: number;
|
|
5
|
+
};
|
|
6
|
+
imageHeight?: number | {
|
|
7
|
+
mobile: number;
|
|
8
|
+
web: number;
|
|
9
|
+
};
|
|
10
|
+
textLines?: number[];
|
|
11
|
+
}
|
|
12
|
+
declare function SkeletonCard({ width, imageHeight, textLines, }: SkeletonCardProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export { SkeletonCard };
|
|
14
|
+
//# sourceMappingURL=SkeletonCard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SkeletonCard.d.ts","sourceRoot":"","sources":["../../../components/ui/SkeletonCard.tsx"],"names":[],"mappings":"AAMA,UAAU,iBAAiB;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IACjD,WAAW,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IACvD,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;CACtB;AAED,iBAAS,YAAY,CAAC,EACpB,KAAK,EACL,WAAW,EACX,SAAwB,GACzB,EAAE,iBAAiB,2CA4DnB;AAED,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { View, StyleSheet } from 'react-native';
|
|
4
|
+
import { useBrand } from '../../brand';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
import { useDimensions, breakpoints } from '../../hooks';
|
|
7
|
+
function SkeletonCard({ width, imageHeight, textLines = [70, 40, 30], // Default: 3 lines with different widths
|
|
8
|
+
}) {
|
|
9
|
+
const theme = useContext(ThemeContext);
|
|
10
|
+
const dimensions = useDimensions();
|
|
11
|
+
const brand = useBrand();
|
|
12
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
13
|
+
skeletonImage: {
|
|
14
|
+
width: '100%',
|
|
15
|
+
borderRadius: brand.borderRadius,
|
|
16
|
+
},
|
|
17
|
+
infoContainer: {
|
|
18
|
+
marginTop: 10,
|
|
19
|
+
gap: 5,
|
|
20
|
+
},
|
|
21
|
+
skeletonText: {
|
|
22
|
+
height: 10,
|
|
23
|
+
borderRadius: 4,
|
|
24
|
+
marginTop: 5,
|
|
25
|
+
},
|
|
26
|
+
}), [brand]);
|
|
27
|
+
// Determine responsive dimensions
|
|
28
|
+
const cardWidth = typeof width === 'object'
|
|
29
|
+
? dimensions.width > breakpoints.medium
|
|
30
|
+
? width.web
|
|
31
|
+
: width.mobile
|
|
32
|
+
: width || (dimensions.width > breakpoints.medium ? 250 : 150);
|
|
33
|
+
const height = typeof imageHeight === 'object'
|
|
34
|
+
? dimensions.width > breakpoints.medium
|
|
35
|
+
? imageHeight.web
|
|
36
|
+
: imageHeight.mobile
|
|
37
|
+
: imageHeight || (dimensions.width > breakpoints.medium ? 150 : 200);
|
|
38
|
+
return (_jsxs(View, { style: [{ marginRight: 10 }, { width: cardWidth }], children: [_jsx(View, { style: [
|
|
39
|
+
styles.skeletonImage,
|
|
40
|
+
{ backgroundColor: theme.values.isDark ? '#333333' : '#e0e0e0', height },
|
|
41
|
+
] }), _jsx(View, { style: styles.infoContainer, children: textLines.map((widthPercent, index) => (_jsx(View, { style: [
|
|
42
|
+
styles.skeletonText,
|
|
43
|
+
{
|
|
44
|
+
width: `${widthPercent}%`,
|
|
45
|
+
backgroundColor: theme.values.isDark ? '#333333' : '#e0e0e0',
|
|
46
|
+
},
|
|
47
|
+
] }, index))) })] }));
|
|
48
|
+
}
|
|
49
|
+
export { SkeletonCard };
|
|
50
|
+
//# sourceMappingURL=SkeletonCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SkeletonCard.js","sourceRoot":"","sources":["../../../components/ui/SkeletonCard.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAQzD,SAAS,YAAY,CAAC,EACpB,KAAK,EACL,WAAW,EACX,SAAS,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,yCAAyC;EACjD;IAClB,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,aAAa,EAAE;YACb,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,KAAK,CAAC,YAAY;SACjC;QACD,aAAa,EAAE;YACb,SAAS,EAAE,EAAE;YACb,GAAG,EAAE,CAAC;SACP;QACD,YAAY,EAAE;YACZ,MAAM,EAAE,EAAE;YACV,YAAY,EAAE,CAAC;YACf,SAAS,EAAE,CAAC;SACb;KACF,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,kCAAkC;IAClC,MAAM,SAAS,GACb,OAAO,KAAK,KAAK,QAAQ;QACvB,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;YACrC,CAAC,CAAC,KAAK,CAAC,GAAG;YACX,CAAC,CAAC,KAAK,CAAC,MAAM;QAChB,CAAC,CAAC,KAAK,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAEnE,MAAM,MAAM,GACV,OAAO,WAAW,KAAK,QAAQ;QAC7B,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;YACrC,CAAC,CAAC,WAAW,CAAC,GAAG;YACjB,CAAC,CAAC,WAAW,CAAC,MAAM;QACtB,CAAC,CAAC,WAAW,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAEzE,OAAO,CACL,MAAC,IAAI,IAAC,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,aACtD,KAAC,IAAI,IACH,KAAK,EAAE;oBACL,MAAM,CAAC,aAAa;oBACpB,EAAE,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE,MAAM,EAAE;iBACzE,GACD,EACF,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,aAAa,YAC9B,SAAS,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE,CAAC,CACtC,KAAC,IAAI,IAEH,KAAK,EAAE;wBACL,MAAM,CAAC,YAAY;wBACnB;4BACE,KAAK,EAAE,GAAG,YAAY,GAAG;4BACzB,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;yBAC7D;qBACF,IAPI,KAAK,CAQV,CACH,CAAC,GACG,IACF,CACR,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TextStyle } from 'react-native';
|
|
3
|
+
type StyledTextProps = {
|
|
4
|
+
children: React.ReactNode;
|
|
5
|
+
fontSize?: 'sm' | 'md' | 'lg' | 'xl' | number;
|
|
6
|
+
align?: 'left' | 'center' | 'right';
|
|
7
|
+
color?: string;
|
|
8
|
+
bold?: boolean;
|
|
9
|
+
uppercase?: boolean;
|
|
10
|
+
numberOfLines?: number;
|
|
11
|
+
muted?: boolean;
|
|
12
|
+
fontWeight?: number;
|
|
13
|
+
style?: TextStyle;
|
|
14
|
+
};
|
|
15
|
+
export declare const StyledText: ({ children, fontSize, align, color, bold, numberOfLines, uppercase, muted, fontWeight, style, }: StyledTextProps) => React.ReactNode;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=StyledText.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StyledText.d.ts","sourceRoot":"","sources":["../../../components/ui/StyledText.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,EAAoB,SAAS,EAAE,MAAM,cAAc,CAAC;AAI3D,KAAK,eAAe,GAAG;IACrB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;IAC9C,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,iGAWxB,eAAe,KAAG,KAAK,CAAC,SA2B1B,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { StyleSheet, Text } from 'react-native';
|
|
4
|
+
import { useBrand } from '../../brand';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
export const StyledText = ({ children, fontSize = 'md', align = 'left', color, bold = false, numberOfLines, uppercase = false, muted = false, fontWeight, style, }) => {
|
|
7
|
+
const theme = useContext(ThemeContext);
|
|
8
|
+
const brand = useBrand();
|
|
9
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
10
|
+
sm: { fontSize: brand.fontSizes.small },
|
|
11
|
+
md: { fontSize: brand.fontSizes.medium },
|
|
12
|
+
lg: { fontSize: brand.fontSizes.large },
|
|
13
|
+
xl: { fontSize: brand.fontSizes.xlarge },
|
|
14
|
+
}), [brand]);
|
|
15
|
+
const textStyle = {
|
|
16
|
+
fontSize: typeof fontSize === 'number'
|
|
17
|
+
? fontSize
|
|
18
|
+
: styles[fontSize]?.fontSize || brand.fontSizes.medium,
|
|
19
|
+
textAlign: align,
|
|
20
|
+
color: muted ? 'gray' : color || theme.values.color,
|
|
21
|
+
fontWeight: fontWeight ? fontWeight : bold ? '700' : 'normal',
|
|
22
|
+
letterSpacing: 1,
|
|
23
|
+
...style, // Merge custom style if provided
|
|
24
|
+
};
|
|
25
|
+
return (_jsx(Text, { style: textStyle, numberOfLines: numberOfLines, children: uppercase ? children?.toString().toUpperCase() : children }));
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=StyledText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StyledText.js","sourceRoot":"","sources":["../../../components/ui/StyledText.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,IAAI,EAAa,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAe3C,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,QAAQ,EACR,QAAQ,GAAG,IAAI,EACf,KAAK,GAAG,MAAM,EACd,KAAK,EACL,IAAI,GAAG,KAAK,EACZ,aAAa,EACb,SAAS,GAAG,KAAK,EACjB,KAAK,GAAG,KAAK,EACb,UAAU,EACV,KAAK,GACW,EAAmB,EAAE;IACrC,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QAC7C,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE;QACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE;QACxC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE;QACvC,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE;KACzC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEb,MAAM,SAAS,GAAc;QAC3B,QAAQ,EACN,OAAO,QAAQ,KAAK,QAAQ;YAC1B,CAAC,CAAC,QAAQ;YACV,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,QAAQ,IAAI,KAAK,CAAC,SAAS,CAAC,MAAM;QAC1D,SAAS,EAAE,KAAK;QAChB,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK;QACnD,UAAU,EAAE,UAAU,CAAC,CAAC,CAAE,UAAsC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;QAC1F,aAAa,EAAE,CAAC;QAChB,GAAG,KAAK,EAAE,iCAAiC;KAC5C,CAAC;IACF,OAAO,CACL,KAAC,IAAI,IAAC,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,aAAa,YACjD,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,QAAQ,GACrD,CACR,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TextInputProps } from 'react-native';
|
|
3
|
+
interface CustomTextInputProps extends TextInputProps {
|
|
4
|
+
value: string;
|
|
5
|
+
inputHeight?: number;
|
|
6
|
+
onKeyDown?: (e: any) => void;
|
|
7
|
+
}
|
|
8
|
+
declare const StyledTextInput: (props: CustomTextInputProps) => React.JSX.Element;
|
|
9
|
+
export { StyledTextInput };
|
|
10
|
+
//# sourceMappingURL=StyledTextInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StyledTextInput.d.ts","sourceRoot":"","sources":["../../../components/ui/StyledTextInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,EAIL,cAAc,EAEf,MAAM,cAAc,CAAC;AAKtB,UAAU,oBAAqB,SAAQ,cAAc;IACnD,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;CAC9B;AAED,QAAA,MAAM,eAAe,GAAI,OAAO,oBAAoB,KAAG,KAAK,CAAC,GAAG,CAAC,OAmEhE,CAAC;AAEF,OAAO,EAAE,eAAe,EAAE,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { StyleSheet, View, TextInput as RNTextInput, Platform, } from 'react-native';
|
|
4
|
+
import { useBrand } from '../../brand';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
const StyledTextInput = (props) => {
|
|
7
|
+
const { value, inputHeight, ...textInputProps } = props;
|
|
8
|
+
const theme = useContext(ThemeContext);
|
|
9
|
+
const brand = useBrand();
|
|
10
|
+
const currentHeight = inputHeight || MIN_HEIGHT;
|
|
11
|
+
const isSingleLine = currentHeight <= MIN_HEIGHT;
|
|
12
|
+
const styles = useMemo(() => StyleSheet.create({
|
|
13
|
+
container: {
|
|
14
|
+
width: '100%',
|
|
15
|
+
maxHeight: 200,
|
|
16
|
+
padding: 5,
|
|
17
|
+
alignSelf: 'center',
|
|
18
|
+
borderRadius: brand.borderRadius,
|
|
19
|
+
},
|
|
20
|
+
textInput: {
|
|
21
|
+
width: '100%',
|
|
22
|
+
fontSize: brand.fontSizes.medium,
|
|
23
|
+
borderWidth: 0, // Remove any internal border from the StyledTextInput
|
|
24
|
+
paddingHorizontal: 10,
|
|
25
|
+
paddingVertical: 10,
|
|
26
|
+
minHeight: MIN_HEIGHT,
|
|
27
|
+
},
|
|
28
|
+
webInput: {
|
|
29
|
+
// @ts-ignore - Web-specific styles
|
|
30
|
+
outlineStyle: 'none',
|
|
31
|
+
WebkitAppearance: 'none',
|
|
32
|
+
MozAppearance: 'none',
|
|
33
|
+
appearance: 'none',
|
|
34
|
+
},
|
|
35
|
+
}), [brand]);
|
|
36
|
+
return (_jsx(View, { style: [
|
|
37
|
+
styles.container,
|
|
38
|
+
{
|
|
39
|
+
borderColor: theme.values.borderColor,
|
|
40
|
+
borderWidth: theme.values.isDark ? 0 : 1,
|
|
41
|
+
backgroundColor: theme.values.isDark
|
|
42
|
+
? theme.values.borderColor
|
|
43
|
+
: theme.values.backgroundColor,
|
|
44
|
+
},
|
|
45
|
+
], children: _jsx(RNTextInput, { ...textInputProps, onKeyPress: props.onKeyPress, onContentSizeChange: props.onContentSizeChange, value: value, multiline: true, style: [
|
|
46
|
+
styles.textInput,
|
|
47
|
+
{
|
|
48
|
+
color: theme.values.color,
|
|
49
|
+
height: inputHeight ? currentHeight : undefined, // Only set height if provided
|
|
50
|
+
minHeight: MIN_HEIGHT,
|
|
51
|
+
maxHeight: MAX_HEIGHT,
|
|
52
|
+
textAlignVertical: isSingleLine ? 'center' : 'top',
|
|
53
|
+
},
|
|
54
|
+
Platform.OS === 'web' && styles.webInput,
|
|
55
|
+
], placeholderTextColor: theme.values.color,
|
|
56
|
+
// @ts-ignore - onKeyDown is web-specific and not in React Native types
|
|
57
|
+
onKeyDown: props.onKeyDown }) }));
|
|
58
|
+
};
|
|
59
|
+
export { StyledTextInput };
|
|
60
|
+
const MIN_HEIGHT = 40;
|
|
61
|
+
const MAX_HEIGHT = 120;
|
|
62
|
+
//# sourceMappingURL=StyledTextInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StyledTextInput.js","sourceRoot":"","sources":["../../../components/ui/StyledTextInput.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
type TextLinkProps = {
|
|
2
|
+
text: string;
|
|
3
|
+
onPress?: () => void;
|
|
4
|
+
href?: string;
|
|
5
|
+
align?: 'left' | 'center' | 'right';
|
|
6
|
+
color?: string;
|
|
7
|
+
fontSize?: 'sm' | 'md' | 'lg' | 'xl' | number;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* A pressable text component that can navigate to a URL or trigger an action.
|
|
11
|
+
*/
|
|
12
|
+
declare const TextLink: ({ text, onPress, href, align, color, fontSize }: TextLinkProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export { TextLink };
|
|
14
|
+
//# sourceMappingURL=TextLink.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextLink.d.ts","sourceRoot":"","sources":["../../../components/ui/TextLink.tsx"],"names":[],"mappings":"AAKA,KAAK,aAAa,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;CAC/C,CAAC;AAEF;;GAEG;AACH,QAAA,MAAM,QAAQ,GAAI,iDAAmE,aAAa,4CA4BjG,CAAC;AAEF,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useContext } from 'react';
|
|
3
|
+
import { Linking, Pressable, Platform } from 'react-native';
|
|
4
|
+
import { StyledText } from './StyledText';
|
|
5
|
+
import { ThemeContext } from '../../theme';
|
|
6
|
+
/**
|
|
7
|
+
* A pressable text component that can navigate to a URL or trigger an action.
|
|
8
|
+
*/
|
|
9
|
+
const TextLink = ({ text, onPress, href, align = 'center', color, fontSize = 'sm' }) => {
|
|
10
|
+
const [isHovered, setIsHovered] = useState(false);
|
|
11
|
+
const theme = useContext(ThemeContext);
|
|
12
|
+
const handlePress = () => {
|
|
13
|
+
if (href) {
|
|
14
|
+
Linking.openURL(href);
|
|
15
|
+
}
|
|
16
|
+
else if (onPress) {
|
|
17
|
+
onPress();
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
// On web, use primary color (highlightColor) when hovered, otherwise use provided color
|
|
21
|
+
const textColor = Platform.OS === 'web' && isHovered ? theme.values.highlightColor : color;
|
|
22
|
+
return (_jsx(Pressable, { onPress: handlePress, onHoverIn: () => setIsHovered(true), onHoverOut: () => setIsHovered(false), children: _jsx(StyledText, { align: align, color: textColor, fontSize: fontSize, children: text }) }));
|
|
23
|
+
};
|
|
24
|
+
export { TextLink };
|
|
25
|
+
//# sourceMappingURL=TextLink.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextLink.js","sourceRoot":"","sources":["../../../components/ui/TextLink.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAW3C;;GAEG;AACH,MAAM,QAAQ,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,GAAG,QAAQ,EAAE,KAAK,EAAE,QAAQ,GAAG,IAAI,EAAiB,EAAE,EAAE;IACpG,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IAEvC,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;aAAM,IAAI,OAAO,EAAE,CAAC;YACnB,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,CAAC;IAEF,wFAAwF;IACxF,MAAM,SAAS,GAAG,QAAQ,CAAC,EAAE,KAAK,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC;IAE3F,OAAO,CACL,KAAC,SAAS,IACR,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EACnC,UAAU,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,YACrC,KAAC,UAAU,IACT,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,QAAQ,YACjB,IAAI,GACM,GACH,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|