diff --git a/apps/mobile/app.json b/apps/mobile/app.json index 868366f..5c59f8e 100644 --- a/apps/mobile/app.json +++ b/apps/mobile/app.json @@ -6,6 +6,7 @@ "orientation": "portrait", "icon": "./assets/icon.png", "scheme": "kittygram", + "userInterfaceStyle": "automatic", "splash": { "image": "./assets/splash.png", "resizeMode": "contain", diff --git a/apps/mobile/src/app/_layout.tsx b/apps/mobile/src/app/_layout.tsx index 5bc5c8c..78bb290 100644 --- a/apps/mobile/src/app/_layout.tsx +++ b/apps/mobile/src/app/_layout.tsx @@ -1,6 +1,7 @@ import { Stack } from 'expo-router/stack'; import { GestureHandlerRootView } from 'react-native-gesture-handler'; import Toast from 'react-native-toast-message'; +import { createStyleSheet, useStyles } from 'react-native-unistyles'; import { Provider } from 'react-redux'; import { CustomToast } from '../components/CustomToast'; import { store } from '../store/store'; @@ -11,20 +12,27 @@ const toastConfig = { }; const NavigationLayout = () => { + const { styles } = useStyles(stylesheet); return ( - + ); }; +const stylesheet = createStyleSheet((theme) => ({ + header: { backgroundColor: theme.colors.background.$3 }, +})); + const ProviderLayout = () => { return ( - {/**/} ); diff --git a/apps/mobile/src/app/index.tsx b/apps/mobile/src/app/index.tsx index 82dcc0f..dd25e34 100644 --- a/apps/mobile/src/app/index.tsx +++ b/apps/mobile/src/app/index.tsx @@ -56,7 +56,8 @@ const Home = () => { const stylesheet = createStyleSheet((theme, runtime) => ({ container: { flex: 1, - padding: 16, + padding: theme.space.$2, + backgroundColor: theme.colors.background.$5, }, overlay: { position: 'absolute', diff --git a/apps/mobile/src/components/BottomSheet.tsx b/apps/mobile/src/components/BottomSheet.tsx index 0ab806c..6c56102 100644 --- a/apps/mobile/src/components/BottomSheet.tsx +++ b/apps/mobile/src/components/BottomSheet.tsx @@ -21,6 +21,8 @@ export const BottomSheet = ({ return ( ({ root: { - flex: 1, + backgroundColor: theme.colors.background.$3, }, content: { flex: 1, diff --git a/apps/mobile/src/components/CustomToast.tsx b/apps/mobile/src/components/CustomToast.tsx index 8f2a6cb..658506e 100644 --- a/apps/mobile/src/components/CustomToast.tsx +++ b/apps/mobile/src/components/CustomToast.tsx @@ -1,15 +1,18 @@ import { ComponentProps } from 'react'; import { BaseToast } from 'react-native-toast-message'; +import { useStyles } from 'react-native-unistyles'; export const CustomToast = (props: ComponentProps) => { + const { theme } = useStyles(); + return ( ); diff --git a/apps/mobile/src/components/ImageSource.tsx b/apps/mobile/src/components/ImageSource.tsx index 2504aa7..15ab30e 100644 --- a/apps/mobile/src/components/ImageSource.tsx +++ b/apps/mobile/src/components/ImageSource.tsx @@ -1,8 +1,10 @@ import { FontAwesome5 } from '@expo/vector-icons'; import { ComponentProps } from 'react'; -import { Pressable, StyleProp, Text, ViewStyle } from 'react-native'; +import { Pressable, StyleProp, ViewStyle } from 'react-native'; import { createStyleSheet, useStyles } from 'react-native-unistyles'; +import { Text } from './Text'; + export type ImageSourceProps = ComponentProps & { icon: string; label?: string; @@ -28,9 +30,10 @@ const stylesheet = createStyleSheet((theme) => ({ flex: 1, justifyContent: 'center', alignItems: 'center', + backgroundColor: theme.colors.background.$5, borderStyle: 'dashed', - borderWidth: 1, - borderRadius: 10, - rowGap: 8, + borderWidth: theme.borderWidths.$1, + borderRadius: theme.radii.$2, + rowGap: theme.space.$2, }, })); diff --git a/apps/mobile/src/components/Text.tsx b/apps/mobile/src/components/Text.tsx new file mode 100644 index 0000000..383002f --- /dev/null +++ b/apps/mobile/src/components/Text.tsx @@ -0,0 +1,16 @@ +import { ComponentProps } from 'react'; +import { Text as RNText } from 'react-native'; +import { createStyleSheet, useStyles } from 'react-native-unistyles'; + +export type TextProps = ComponentProps; + +export const Text = ({ style, ...props }: TextProps) => { + const { styles } = useStyles(stylesheet); + return ; +}; + +const stylesheet = createStyleSheet((theme) => ({ + root: { + color: theme.colors.typography.$5, + }, +})); diff --git a/apps/mobile/src/features/CatCard/CardActions.tsx b/apps/mobile/src/features/CatCard/CardActions.tsx index fbddd52..80a25b8 100644 --- a/apps/mobile/src/features/CatCard/CardActions.tsx +++ b/apps/mobile/src/features/CatCard/CardActions.tsx @@ -1,7 +1,9 @@ import { useCallback, useMemo } from 'react'; -import { Text, View } from 'react-native'; +import { View } from 'react-native'; import { createStyleSheet, useStyles } from 'react-native-unistyles'; import { match, P } from 'ts-pattern'; + +import { Text } from '../../components/Text'; import { useDownvoteImageMutation, useUpvoteImageMutation, @@ -65,17 +67,17 @@ export const CardActions = ({ item }: CardProps) => { ); }; -const stylesheet = createStyleSheet({ +const stylesheet = createStyleSheet((theme) => ({ root: {}, inner: { - backgroundColor: 'rgba(255, 255, 255, 0.8)', + backgroundColor: theme.colors.background.translucent, flexDirection: 'row', justifyContent: 'space-around', - borderBottomLeftRadius: 15, - borderBottomRightRadius: 15, + borderBottomLeftRadius: theme.radii.$3, + borderBottomRightRadius: theme.radii.$3, }, voteCount: { alignSelf: 'center', - fontSize: 20, + fontSize: theme.fontSizes.$3, }, -}); +})); diff --git a/apps/mobile/src/features/CatCard/CatCard.tsx b/apps/mobile/src/features/CatCard/CatCard.tsx index 19a4b92..f7ba604 100644 --- a/apps/mobile/src/features/CatCard/CatCard.tsx +++ b/apps/mobile/src/features/CatCard/CatCard.tsx @@ -18,15 +18,18 @@ export const CatCard = ({ item }: CardProps) => { ); }; -const stylesheet = createStyleSheet({ +const stylesheet = createStyleSheet((theme) => ({ root: { - width: '100%', + borderColor: theme.colors.background.$6, + borderRadius: theme.radii.$3, + borderWidth: theme.borderWidths.$1, + width: theme.space.full, }, image: { - borderTopLeftRadius: 15, - borderTopRightRadius: 15, - width: '100%', + borderTopLeftRadius: theme.radii.$3, + borderTopRightRadius: theme.radii.$3, + width: theme.space.full, height: 200, - backgroundColor: 'white', + backgroundColor: theme.colors.background.$5, }, -}); +})); diff --git a/apps/mobile/src/features/CatCard/ImageOverlay.tsx b/apps/mobile/src/features/CatCard/ImageOverlay.tsx index b839334..6028661 100644 --- a/apps/mobile/src/features/CatCard/ImageOverlay.tsx +++ b/apps/mobile/src/features/CatCard/ImageOverlay.tsx @@ -54,18 +54,18 @@ export const ImageOverlay = ({ item }: CardProps) => { ); }; -const stylesheet = createStyleSheet({ +const stylesheet = createStyleSheet((theme) => ({ root: { position: 'absolute', right: 0, }, favorite: { + flex: 1, justifyContent: 'center', alignItems: 'center', - backgroundColor: 'rgba(255, 255, 255, 0.8)', - borderRadius: 100, - margin: 8, - padding: 16, - flex: 1, + backgroundColor: theme.colors.background.translucent, + borderRadius: theme.radii.circle, + margin: theme.space.$1, + padding: theme.space.$2, }, -}); +})); diff --git a/apps/mobile/src/features/CatCard/VoteButton.tsx b/apps/mobile/src/features/CatCard/VoteButton.tsx index 7bd696d..d9597a5 100644 --- a/apps/mobile/src/features/CatCard/VoteButton.tsx +++ b/apps/mobile/src/features/CatCard/VoteButton.tsx @@ -18,10 +18,10 @@ export const VoteButton = ({ style, iconProps, ...props }: VoteButtonProps) => { ); }; -const stylesheet = createStyleSheet({ +const stylesheet = createStyleSheet((theme) => ({ root: { - marginVertical: 8, + marginVertical: theme.space.$2, flexDirection: 'row', - columnGap: 8, + columnGap: theme.space.$2, }, -}); +})); diff --git a/apps/mobile/src/features/HomePage/ImageList.tsx b/apps/mobile/src/features/HomePage/ImageList.tsx index fcd889e..7ad1358 100644 --- a/apps/mobile/src/features/HomePage/ImageList.tsx +++ b/apps/mobile/src/features/HomePage/ImageList.tsx @@ -24,10 +24,10 @@ export const ImageList = () => { const stylesheet = createStyleSheet((theme) => ({ root: { - width: '100%', - height: '100%', + width: theme.space.full, + height: theme.space.full, }, list: { - rowGap: 16, + rowGap: theme.space.$2, }, })); diff --git a/apps/mobile/src/features/HomePage/NoImagesFound.tsx b/apps/mobile/src/features/HomePage/NoImagesFound.tsx index 5d41699..b547494 100644 --- a/apps/mobile/src/features/HomePage/NoImagesFound.tsx +++ b/apps/mobile/src/features/HomePage/NoImagesFound.tsx @@ -22,12 +22,12 @@ const stylesheet = createStyleSheet((theme) => ({ alignItems: 'center', }, message: { - borderRadius: 15, - padding: 16, - backgroundColor: 'lightgrey', + flexDirection: 'row', justifyContent: 'center', alignItems: 'center', - columnGap: 16, - flexDirection: 'row', + padding: theme.space.$2, + borderRadius: theme.radii.$3, + backgroundColor: theme.colors.background.$6, + columnGap: theme.space.$2, }, })); diff --git a/apps/mobile/src/features/UploadImageModal/UploadImageSheet.tsx b/apps/mobile/src/features/UploadImageModal/UploadImageSheet.tsx index da6f8da..09748bc 100644 --- a/apps/mobile/src/features/UploadImageModal/UploadImageSheet.tsx +++ b/apps/mobile/src/features/UploadImageModal/UploadImageSheet.tsx @@ -10,8 +10,8 @@ export type UploadImageSheetProps = ComponentProps; export const UploadImageSheet = ({ open, onClose }: UploadImageSheetProps) => { const { styles } = useStyles(stylesheet); return ( - - + + @@ -21,9 +21,12 @@ export const UploadImageSheet = ({ open, onClose }: UploadImageSheetProps) => { const stylesheet = createStyleSheet((theme) => ({ root: { + // backgroundColor: theme.colors.background.$3 + }, + inner: { flex: 1, flexDirection: 'row', - padding: 16, - columnGap: 16, + padding: theme.space.$2, + columnGap: theme.space.$2, }, })); diff --git a/apps/mobile/src/theme/themes.ts b/apps/mobile/src/theme/themes.ts index d24c105..4e4abc4 100644 --- a/apps/mobile/src/theme/themes.ts +++ b/apps/mobile/src/theme/themes.ts @@ -1,25 +1,159 @@ +const sharedColors = { + primary: { + $1: '#e8d3f9', + $2: '#d0a8f1', + $3: '#b67de9', + $4: '#9950e0', + $5: '#7819d7', + $6: '#601aa8', + $7: '#49197b', + $8: '#331551', + $9: '#1e102b', + }, + secondary: { + $1: '#faf7d7', + $2: '#f3efae', + $3: '#ebe785', + $4: '#e2df59', + $5: '#d7d719', + $6: '#a8a81d', + $7: '#7c7b1d', + $8: '#525119', + $9: '#2b2a12', + }, + accent: { + $1: '#def8d6', + $2: '#bbf1ad', + $3: '#95e983', + $4: '#68e057', + $5: '#19d719', + $6: '#23a81c', + $7: '#237b1c', + $8: '#1f5118', + $9: '#162b11', + }, +} as const; + +const shared = { + space: { + $1: 8, + $2: 16, + $3: 24, + $4: 28, + $5: 36, + $6: 48, + $7: 64, + $8: 72, + $9: 128, + + none: 0, + auto: 'auto', + full: '100%', + }, + + fontSizes: { + $1: 14, + $2: 16, + $3: 20, + $4: 24, + $5: 28, + $6: 36, + $7: 48, + $8: 64, + $9: 72, + }, + + fontWeights: { + bold: '500', + }, + + radii: { + $1: 5, + $2: 10, + $3: 15, + $4: 20, + $5: 25, + $6: 50, + $7: 75, + + none: 0, + circle: 100, + }, + + borderWidths: { + $1: 1, + $2: 2, + $3: 3, + $4: 4, + $5: 5, + $6: 6, + $7: 7, + $8: 8, + + none: 0, + }, +} as const; + export const lightTheme = { + ...shared, colors: { - typography: '#000000', - background: '#ffffff', - }, - margins: { - sm: 2, - md: 4, - lg: 8, - xl: 12, + ...sharedColors, + typography: { + $1: '#d6d6d6', + $2: '#aeaeae', + $3: '#888888', + $4: '#646464', + $5: '#424242', + $6: '#353535', + $7: '#292929', + $8: '#1e1e1e', + $9: '#121212', + }, + background: { + $1: '#ffffff', + $2: '#ffffff', + $3: '#ffffff', + $4: '#ffffff', + $5: '#ffffff', + $6: '#c6c6c6', + $7: '#919191', + $8: '#5e5e5e', + $9: '#303030', + + transparent: 'transparent', + translucent: 'rgba(255, 255, 255, 0.8)', + }, }, } as const; export const darkTheme = { + ...shared, colors: { - typography: '#ffffff', - background: '#000000', - }, - margins: { - sm: 2, - md: 4, - lg: 8, - xl: 12, + ...sharedColors, + typography: { + $1: '#ffffff', + $2: '#ffffff', + $3: '#ffffff', + $4: '#ffffff', + $5: '#ffffff', + $6: '#c6c6c6', + $7: '#919191', + $8: '#5e5e5e', + $9: '#303030', + }, + background: { + $1: '#d6d6d6', + $2: '#aeaeae', + $3: '#888888', + $4: '#646464', + $5: '#424242', + $6: '#353535', + $7: '#292929', + $8: '#1e1e1e', + $9: '#121212', + + transparent: 'transparent', + translucent: 'rgba(0, 0, 0, 0.8)', + }, }, } as const; diff --git a/bun.lockb b/bun.lockb index 8c6a42c..a2a4647 100755 Binary files a/bun.lockb and b/bun.lockb differ