create-expo-stack 2.4.0-next.f483b52 → 2.4.1-next.9242c21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/README.md +1 -0
  2. package/build/commands/create-expo-stack.js +39 -17
  3. package/build/templates/base/App.tsx.ejs +25 -0
  4. package/build/templates/base/babel.config.js.ejs +10 -11
  5. package/build/templates/base/package.json.ejs +29 -21
  6. package/build/templates/packages/expo-router/drawer/app/(drawer)/(tabs)/_layout.tsx.ejs +41 -0
  7. package/build/templates/packages/expo-router/drawer/app/(drawer)/(tabs)/index.tsx.ejs +88 -0
  8. package/build/templates/packages/expo-router/drawer/app/(drawer)/(tabs)/two.tsx.ejs +88 -0
  9. package/build/templates/packages/expo-router/drawer/app/(drawer)/_layout.tsx.ejs +43 -19
  10. package/build/templates/packages/expo-router/drawer/app/(drawer)/index.tsx.ejs +20 -1
  11. package/build/templates/packages/expo-router/drawer/app/[...unmatched].tsx.ejs +26 -0
  12. package/build/templates/packages/expo-router/drawer/app/_layout.tsx.ejs +39 -30
  13. package/build/templates/packages/expo-router/drawer/app/modal.tsx.ejs +96 -0
  14. package/build/templates/packages/expo-router/drawer/components/edit-screen-info.tsx.ejs +153 -0
  15. package/build/templates/packages/expo-router/metro.config.js.ejs +16 -0
  16. package/build/templates/packages/expo-router/stack/app/[...unmatched].tsx.ejs +28 -0
  17. package/build/templates/packages/expo-router/stack/app/_layout.tsx.ejs +7 -0
  18. package/build/templates/packages/expo-router/stack/app/details.tsx.ejs +43 -1
  19. package/build/templates/packages/expo-router/stack/app/index.tsx.ejs +36 -0
  20. package/build/templates/packages/expo-router/tabs/app/(tabs)/_layout.tsx.ejs +30 -8
  21. package/build/templates/packages/expo-router/tabs/app/(tabs)/index.tsx.ejs +16 -2
  22. package/build/templates/packages/expo-router/tabs/app/(tabs)/two.tsx.ejs +15 -2
  23. package/build/templates/packages/expo-router/tabs/app/[...unmatched].tsx.ejs +28 -0
  24. package/build/templates/packages/expo-router/tabs/app/_layout.tsx.ejs +7 -0
  25. package/build/templates/packages/expo-router/tabs/app/modal.tsx.ejs +15 -1
  26. package/build/templates/packages/expo-router/tabs/components/edit-screen-info.tsx.ejs +36 -0
  27. package/build/templates/packages/firebase/metro.config.js.ejs +9 -10
  28. package/build/templates/packages/nativewind/global.css +3 -0
  29. package/build/templates/packages/nativewind/metro.config.js +7 -0
  30. package/build/templates/packages/nativewind/tailwind.config.js.ejs +1 -0
  31. package/build/templates/packages/react-navigation/App.tsx.ejs +6 -0
  32. package/build/templates/packages/react-navigation/components/edit-screen-info.tsx.ejs +59 -0
  33. package/build/templates/packages/react-navigation/navigation/drawer-navigator.tsx.ejs +41 -6
  34. package/build/templates/packages/react-navigation/navigation/index.tsx.ejs +31 -2
  35. package/build/templates/packages/react-navigation/navigation/tab-navigator.tsx.ejs +47 -17
  36. package/build/templates/packages/react-navigation/screens/details.tsx.ejs +25 -0
  37. package/build/templates/packages/react-navigation/screens/home.tsx.ejs +83 -0
  38. package/build/templates/packages/react-navigation/screens/modal.tsx.ejs +13 -0
  39. package/build/templates/packages/react-navigation/screens/one.tsx.ejs +12 -0
  40. package/build/templates/packages/react-navigation/screens/overview.tsx.ejs +33 -2
  41. package/build/templates/packages/react-navigation/screens/two.tsx.ejs +12 -0
  42. package/build/templates/packages/unistyles/breakpoints.ts.ejs +9 -0
  43. package/build/templates/packages/unistyles/theme.ts.ejs +76 -0
  44. package/build/templates/packages/unistyles/unistyles.ts.ejs +27 -0
  45. package/build/types/types.d.ts +2 -2
  46. package/build/types/utilities/printOutput.d.ts +2 -2
  47. package/build/types.js +3 -2
  48. package/build/utilities/configureProjectFiles.js +29 -8
  49. package/build/utilities/generateProjectFiles.js +5 -2
  50. package/build/utilities/printOutput.js +14 -2
  51. package/build/utilities/runCLI.js +7 -3
  52. package/build/utilities/showHelp.js +3 -1
  53. package/package.json +2 -2
  54. package/build/templates/packages/expo-router/drawer/app/(drawer)/news.tsx.ejs +0 -71
  55. package/build/templates/packages/expo-router/metro.config.js +0 -11
@@ -1,25 +1,49 @@
1
+ import { FontAwesome, Ionicons, MaterialIcons } from '@expo/vector-icons';
2
+ import { Link } from 'expo-router';
1
3
  import { Drawer } from 'expo-router/drawer';
2
- import { Ionicons } from '@expo/vector-icons';
4
+ import { Pressable, StyleSheet } from 'react-native';
3
5
 
4
6
  const DrawerLayout = () => (
5
- <Drawer>
6
- <Drawer.Screen
7
- name="index"
8
- options={{
9
- headerTitle: 'Home',
10
- drawerLabel: 'Home',
11
- drawerIcon: ({ size, color }) => <Ionicons name="home-outline" size={size} color={color} />
12
- }}
13
- />
14
- <Drawer.Screen
15
- name="news"
16
- options={{
17
- headerTitle: 'Newsfeed',
18
- drawerLabel: 'News',
19
- drawerIcon: ({ size, color }) => <Ionicons name="newspaper-outline" size={size} color={color} />
20
- }}
21
- />
22
- </Drawer>
7
+ <Drawer>
8
+ <Drawer.Screen
9
+ name="index"
10
+ options={{
11
+ headerTitle: 'Home',
12
+ drawerLabel: 'Home',
13
+ drawerIcon: ({ size, color }) => <Ionicons name="home-outline" size={size} color={color} />,
14
+ }}
15
+ />
16
+ <Drawer.Screen
17
+ name="(tabs)"
18
+ options={{
19
+ headerTitle: 'Tabs',
20
+ drawerLabel: 'Tabs',
21
+ drawerIcon: ({ size, color }) => (
22
+ <MaterialIcons name="border-bottom" size={size} color={color} />
23
+ ),
24
+ headerRight: () => (
25
+ <Link href="/modal" asChild>
26
+ <Pressable>
27
+ {({ pressed }) => (
28
+ <FontAwesome
29
+ name="info-circle"
30
+ size={25}
31
+ color="gray"
32
+ style={[styles.headerRight, { opacity: pressed ? 0.5 : 1 }]}
33
+ />
34
+ )}
35
+ </Pressable>
36
+ </Link>
37
+ ),
38
+ }}
39
+ />
40
+ </Drawer>
23
41
  );
24
42
 
43
+ const styles = StyleSheet.create({
44
+ headerRight: {
45
+ marginRight: 15,
46
+ },
47
+ });
48
+
25
49
  export default DrawerLayout;
@@ -4,12 +4,27 @@
4
4
  import { YStack, H2, Separator, Theme } from "tamagui";
5
5
  <% } else if (props.stylingPackage?.name === "restyle") { %>
6
6
  import { Box, Text } from 'theme';
7
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
8
+ import { useStyles } from 'react-native-unistyles'
9
+ import { Text, View } from 'react-native';
7
10
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
8
11
  import { StyleSheet, Text, View } from "react-native";
9
12
  <% } %>
10
13
 
14
+ import EditScreenInfo from "../../components/edit-screen-info";
15
+
11
16
  const Page = () => {
12
- <% if (props.stylingPackage?.name === "nativewind") { %>
17
+ <% if (props.stylingPackage?.name === "unistyles") { %>
18
+ const { theme } = useStyles()
19
+
20
+ return (
21
+ <View style={theme.components.container}>
22
+ <Text style={theme.components.title}>Home</Text>
23
+ <View style={theme.components.separator} />
24
+ <EditScreenInfo path="app/(tabs)/index.tsx" />
25
+ </View>
26
+ );
27
+ <% } else if (props.stylingPackage?.name === "nativewind") { %>
13
28
  return (
14
29
  <View className={styles.container}>
15
30
  <Text className={styles.title}>Home</Text>
@@ -23,6 +38,7 @@ const Page = () => {
23
38
  <YStack flex={1} alignItems="center" justifyContent="center">
24
39
  <H2>Home</H2>
25
40
  <Separator />
41
+ <EditScreenInfo path="app/(tabs)/index.tsx" />
26
42
  </YStack>
27
43
  </Theme>
28
44
  );
@@ -31,6 +47,7 @@ const Page = () => {
31
47
  <Box flex={1} alignItems="center" justifyContent="center">
32
48
  <Text variant="title">Home</Text>
33
49
  <Box height={1} marginVertical="l_32" width="80%" />
50
+ <EditScreenInfo path="app/(tabs)/index.tsx" />
34
51
  </Box>
35
52
  );
36
53
  <% } else { %>
@@ -38,6 +55,7 @@ const Page = () => {
38
55
  <View style={styles.container}>
39
56
  <Text style={styles.title}>Home</Text>
40
57
  <View style={styles.separator} />
58
+ <EditScreenInfo path="app/(tabs)/index.tsx" />
41
59
  </View>
42
60
  );
43
61
  <% } %>
@@ -59,6 +77,7 @@ export default Page;
59
77
  justifyContent: "center",
60
78
  },
61
79
  separator: {
80
+ backgroundColor: '#d1d5db',
62
81
  height: 1,
63
82
  marginVertical: 30,
64
83
  width: "80%",
@@ -1,6 +1,9 @@
1
1
  import { Link, Stack } from 'expo-router';
2
2
  <% if (props.stylingPackage?.name === "nativewind") {%>
3
3
  import { Text, View } from 'react-native';
4
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
5
+ import { createStyleSheet, useStyles } from 'react-native-unistyles'
6
+ import { Text, View } from 'react-native';
4
7
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
5
8
  import { StyleSheet, Text, View } from 'react-native';
6
9
  <% } else if (props.stylingPackage?.name === "tamagui") { %>
@@ -13,6 +16,8 @@ import { Link, Stack } from 'expo-router';
13
16
  export default function NotFoundScreen() {
14
17
  <% if (props.stylingPackage?.name === "restyle") { %>
15
18
  const styles = useStyles();
19
+ <% } else if (props.stylingPackage?.name === "unistyles") {%>
20
+ const { styles } = useStyles(stylesheet);
16
21
  <% } %>
17
22
 
18
23
  return (
@@ -71,6 +76,27 @@ export default function NotFoundScreen() {
71
76
  link: `mt-4 pt-4`,
72
77
  linkText: `text-base text-[#2e78b7]`,
73
78
  };
79
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
80
+ const stylesheet = createStyleSheet((theme) => ({
81
+ container: {
82
+ flex: 1,
83
+ alignItems: 'center',
84
+ justifyContent: 'center',
85
+ padding: 20,
86
+ },
87
+ title: {
88
+ fontSize: 20,
89
+ fontWeight: 'bold',
90
+ },
91
+ link: {
92
+ marginTop: 16,
93
+ paddingVertical: 16,
94
+ },
95
+ linkText: {
96
+ fontSize: 14,
97
+ color: theme.colors.astral,
98
+ },
99
+ }));
74
100
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
75
101
  const styles = StyleSheet.create({
76
102
  container: {
@@ -1,13 +1,19 @@
1
+ <% if (props.stylingPackage?.name === "nativewind") { %>
2
+ import '../global.css';
3
+ <% } %>
4
+ <% if (props.stylingPackage?.name === "unistyles") { %>
5
+ import '../unistyles';
6
+ <% } %>
7
+
1
8
  import 'react-native-gesture-handler';
2
9
  import { GestureHandlerRootView } from 'react-native-gesture-handler';
3
- import { Slot } from 'expo-router';
4
- <% if (props.stylingPackage?.name === "tamagui") { %>
5
- import React, { useEffect } from "react";
6
- import { TamaguiProvider } from 'tamagui'
7
- import { SplashScreen } from "expo-router";
8
- import { useFonts } from "expo-font";
10
+ import { Stack } from 'expo-router';
9
11
 
10
- import config from '../tamagui.config'
12
+ <% if (props.stylingPackage?.name==="tamagui" ) { %>
13
+ import React, { useEffect } from "react";
14
+ import { TamaguiProvider } from 'tamagui'
15
+ import { SplashScreen } from "expo-router";
16
+ import { useFonts } from "expo-font";
11
17
 
12
18
  SplashScreen.preventAutoHideAsync();
13
19
  <% } else if (props.stylingPackage?.name === "restyle") { %>
@@ -17,25 +23,25 @@ import { Slot } from 'expo-router';
17
23
  <% } %>
18
24
 
19
25
  export const unstable_settings = {
20
- // Ensure that reloading on `/modal` keeps a back button present.
21
- initialRouteName: "(drawer)",
26
+ // Ensure that reloading on `/modal` keeps a back button present.
27
+ initialRouteName: "(drawer)",
22
28
  };
23
29
 
24
30
  export default function RootLayout() {
25
- <% if (props.stylingPackage?.name === "tamagui") { %>
26
- const [loaded] = useFonts({
27
- Inter: require("@tamagui/font-inter/otf/Inter-Medium.otf"),
28
- InterBold: require("@tamagui/font-inter/otf/Inter-Bold.otf")
29
- });
31
+ <% if (props.stylingPackage?.name==="tamagui" ) { %>
32
+ const [loaded] = useFonts({
33
+ Inter: require("@tamagui/font-inter/otf/Inter-Medium.otf"),
34
+ InterBold: require("@tamagui/font-inter/otf/Inter-Bold.otf")
35
+ });
30
36
 
31
- useEffect(() => {
32
- if (loaded) {
33
- SplashScreen.hideAsync();
34
- }
35
- }, [loaded]);
37
+ useEffect(() => {
38
+ if (loaded) {
39
+ SplashScreen.hideAsync();
40
+ }
41
+ }, [loaded]);
36
42
 
37
- if (!loaded) return null;
38
- <% } %>
43
+ if (!loaded) return null;
44
+ <% } %>
39
45
 
40
46
  return (
41
47
  <% if (props.stylingPackage?.name === "tamagui") { %>
@@ -43,13 +49,16 @@ export default function RootLayout() {
43
49
  <% } else if (props.stylingPackage?.name === "restyle") { %>
44
50
  <ThemeProvider theme={theme}>
45
51
  <% } %>
46
- <GestureHandlerRootView style={{ flex: 1 }}>
47
- <Slot />
48
- </GestureHandlerRootView>
49
- <% if (props.stylingPackage?.name === "tamagui") { %>
50
- </TamaguiProvider>
51
- <% } else if (props.stylingPackage?.name === "restyle") { %>
52
- </ThemeProvider>
53
- <% } %>
54
- );
52
+ <GestureHandlerRootView style={{ flex: 1 }}>
53
+ <Stack>
54
+ <Stack.Screen name="(drawer)" options={{ headerShown: false }} />
55
+ <Stack.Screen name="modal" options={{ title: 'Modal', presentation: 'modal' }} />
56
+ </Stack>
57
+ </GestureHandlerRootView>
58
+ <% if (props.stylingPackage?.name === "tamagui") { %>
59
+ </TamaguiProvider>
60
+ <% } else if (props.stylingPackage?.name === "restyle") { %>
61
+ </ThemeProvider>
62
+ <% } %>
63
+ );
55
64
  }
@@ -0,0 +1,96 @@
1
+ <% if (props.stylingPackage?.name === 'nativewind') { %>
2
+ import { Platform, Text, View } from 'react-native';
3
+ <% } else if (props.stylingPackage?.name === 'tamagui') { %>
4
+ import { YStack, Paragraph, Separator, Theme } from 'tamagui';
5
+ import { Platform } from 'react-native'
6
+ <% } else if (props.stylingPackage?.name === 'restyle') { %>
7
+ import { Platform } from 'react-native';
8
+ import { Box, Text } from 'theme';
9
+ <% } else if (props.stylingPackage?.name === 'unistyles') { %>
10
+ import { useStyles } from 'react-native-unistyles'
11
+ import { Platform, Text, View } from 'react-native';
12
+ <% } else { %>
13
+ import { Platform, StyleSheet, Text, View } from 'react-native';
14
+ <% } %>
15
+ import { StatusBar } from 'expo-status-bar';
16
+
17
+ import EditScreenInfo from '../components/edit-screen-info';
18
+
19
+ export default function ModalScreen() {
20
+ <% if (props.stylingPackage?.name === 'unistyles') { %>
21
+ const { theme } = useStyles()
22
+
23
+ return (
24
+ <View style={theme.components.container}>
25
+ <StatusBar style={Platform.OS === 'ios' ? 'light' : 'auto'} />
26
+ <Text style={theme.components.title}>Modal</Text>
27
+ <View style={theme.components.separator} />
28
+ <EditScreenInfo path='app/modal.tsx' />
29
+ </View>
30
+ );
31
+ <% } else if (props.stylingPackage?.name === 'nativewind') { %>
32
+ return (
33
+ <View className={styles.container}>
34
+ <StatusBar style={Platform.OS === 'ios' ? 'light' : 'auto'} />
35
+ <Text className={styles.title}>Modal</Text>
36
+ <View className={styles.separator} />
37
+ <EditScreenInfo path='app/modal.tsx' />
38
+ </View>
39
+ );
40
+ <% } else if (props.stylingPackage?.name === 'tamagui') { %>
41
+ return (
42
+ <Theme name='light'>
43
+ <YStack flex={1} alignItems='center' justifyContent='center'>
44
+ <StatusBar style={Platform.OS === 'ios' ? 'light' : 'auto'} />
45
+ <Paragraph>Modal</Paragraph>
46
+ <Separator />
47
+ <EditScreenInfo path='app/modal.tsx' />
48
+ </YStack>
49
+ </Theme>
50
+ );
51
+ <% } else if (props.stylingPackage?.name === 'restyle') { %>
52
+ return (
53
+ <Box flex={1} alignItems='center' justifyContent='center'>
54
+ <StatusBar style={Platform.OS === 'ios' ? 'light' : 'auto'} />
55
+ <Text variant='title'>Modal</Text>
56
+ <Box height={1} marginVertical='l_32' width='80%' />
57
+ <EditScreenInfo path='app/modal.tsx' />
58
+ </Box>
59
+ );
60
+ <% } else { %>
61
+ return (
62
+ <View style={styles.container}>
63
+ <StatusBar style={Platform.OS === 'ios' ? 'light' : 'auto'} />
64
+ <Text style={styles.title}>Modal</Text>
65
+ <View style={styles.separator} />
66
+ <EditScreenInfo path='app/modal.tsx' />
67
+ </View>
68
+ );
69
+ <% } %>
70
+ }
71
+
72
+ <% if (props.stylingPackage?.name === 'nativewind') { %>
73
+ const styles = {
74
+ container: `items-center flex-1 justify-center`,
75
+ separator: `h-[1px] my-7 w-4/5 bg-gray-200`,
76
+ title: `text-xl font-bold`
77
+ };
78
+ <% } else if (props.stylingPackage?.name === 'stylesheet') { %>
79
+ const styles = StyleSheet.create({
80
+ container: {
81
+ alignItems: 'center',
82
+ flex: 1,
83
+ justifyContent: 'center'
84
+ },
85
+ separator: {
86
+ backgroundColor: '#d1d5db',
87
+ height: 1,
88
+ marginVertical: 30,
89
+ width: '80%'
90
+ },
91
+ title: {
92
+ fontSize: 20,
93
+ fontWeight: 'bold'
94
+ }
95
+ });
96
+ <% } %>
@@ -0,0 +1,153 @@
1
+ <% if (props.stylingPackage?.name === 'nativewind') { %>
2
+ import { Text, View } from 'react-native';
3
+ <% } else if (props.stylingPackage?.name === 'tamagui') { %>
4
+ import { YStack, H4, Paragraph } from 'tamagui'
5
+ <% } else if (props.stylingPackage?.name === 'restyle') { %>
6
+ import { Box, Text } from 'theme';
7
+ <% } else if (props.stylingPackage?.name === 'unistyles') { %>
8
+ import { createStyleSheet, useStyles } from 'react-native-unistyles'
9
+ import { Text, View } from 'react-native';
10
+ <% } else { %>
11
+ import { StyleSheet, Text, View } from 'react-native';
12
+ <% } %>
13
+
14
+ export default function EditScreenInfo({ path }: { path: string }) {
15
+ <% if (props.stylingPackage?.name === 'unistyles') { %>
16
+ const { styles } = useStyles(stylesheet);
17
+ <% } %>
18
+ <% if (props.stylingPackage?.name === 'nativewind') { %>
19
+ return (
20
+ <View>
21
+ <View className={styles.getStartedContainer}>
22
+ <Text className={styles.getStartedText}>
23
+ Open up the code for this screen:
24
+ </Text>
25
+ <View className={styles.codeHighlightContainer + styles.homeScreenFilename}>
26
+ <Text>{path}</Text>
27
+ </View>
28
+ <Text className={styles.getStartedText}>
29
+ Change any of the text, save the file, and your app will automatically update.
30
+ </Text>
31
+ </View>
32
+ </View>
33
+ );
34
+ <% } else if (props.stylingPackage?.name === 'tamagui') { %>
35
+ return (
36
+ <YStack>
37
+ <YStack alignItems='center' marginHorizontal='$6'>
38
+ <H4>
39
+ Open up the code for this screen:
40
+ </H4>
41
+ <YStack borderRadius='$3' marginVertical='$1'>
42
+ <Paragraph>{path}</Paragraph>
43
+ </YStack>
44
+ <Paragraph>
45
+ Change any of the text, save the file, and your app will automatically update.
46
+ </Paragraph>
47
+ </YStack>
48
+ </YStack>
49
+ );
50
+ <% } else if (props.stylingPackage?.name === 'restyle') { %>
51
+ return (
52
+ <Box alignItems='center' marginHorizontal='xl_64'>
53
+ <Text variant='body' lineHeight={24} textAlign='center'>
54
+ Open up the code for this screen:
55
+ </Text>
56
+ <Box borderRadius='s_3' paddingHorizontal='xs_4' marginVertical='s_8'>
57
+ <Text>{path}</Text>
58
+ </Box>
59
+ <Text variant='body' lineHeight={24} textAlign='center'>
60
+ Change any of the text, save the file, and your app will automatically update.
61
+ </Text>
62
+ </Box>
63
+ );
64
+ <% } else { %>
65
+ return (
66
+ <View>
67
+ <View style={styles.getStartedContainer}>
68
+ <Text style={styles.getStartedText}>
69
+ Open up the code for this screen:
70
+ </Text>
71
+ <View style={[styles.codeHighlightContainer, styles.homeScreenFilename]}>
72
+ <Text>{path}</Text>
73
+ </View>
74
+ <Text style={styles.getStartedText}>
75
+ Change any of the text, save the file, and your app will automatically update.
76
+ </Text>
77
+ </View>
78
+ </View>
79
+ );
80
+ <% } %>
81
+ }
82
+
83
+ <% if (props.stylingPackage?.name === 'nativewind') { %>
84
+ const styles = {
85
+ codeHighlightContainer: `rounded-md px-1`,
86
+ getStartedContainer: `items-center mx-12`,
87
+ getStartedText: `text-lg leading-6 text-center`,
88
+ helpContainer: `items-center mx-5 mt-4`,
89
+ helpLink: `py-4`,
90
+ helpLinkText: `text-center`,
91
+ homeScreenFilename: `my-2`,
92
+ };
93
+ <% } else if (props.stylingPackage?.name === 'unistyles') { %>
94
+ const stylesheet = createStyleSheet({
95
+ codeHighlightContainer: {
96
+ borderRadius: 3,
97
+ paddingHorizontal: 4
98
+ },
99
+ getStartedContainer: {
100
+ alignItems: 'center',
101
+ marginHorizontal: 50
102
+ },
103
+ getStartedText: {
104
+ fontSize: 17,
105
+ lineHeight: 24,
106
+ textAlign: 'center'
107
+ },
108
+ helpContainer: {
109
+ alignItems: 'center',
110
+ marginHorizontal: 20,
111
+ marginTop: 15
112
+ },
113
+ helpLink: {
114
+ paddingVertical: 15
115
+ },
116
+ helpLinkText: {
117
+ textAlign: 'center'
118
+ },
119
+ homeScreenFilename: {
120
+ marginVertical: 7
121
+ }
122
+ });
123
+ <% } else if (props.stylingPackage?.name === 'stylesheet') { %>
124
+ const styles = StyleSheet.create({
125
+ codeHighlightContainer: {
126
+ borderRadius: 3,
127
+ paddingHorizontal: 4
128
+ },
129
+ getStartedContainer: {
130
+ alignItems: 'center',
131
+ marginHorizontal: 50
132
+ },
133
+ getStartedText: {
134
+ fontSize: 17,
135
+ lineHeight: 24,
136
+ textAlign: 'center'
137
+ },
138
+ helpContainer: {
139
+ alignItems: 'center',
140
+ marginHorizontal: 20,
141
+ marginTop: 15
142
+ },
143
+ helpLink: {
144
+ paddingVertical: 15
145
+ },
146
+ helpLinkText: {
147
+ textAlign: 'center'
148
+ },
149
+ homeScreenFilename: {
150
+ marginVertical: 7
151
+ }
152
+ });
153
+ <% } %>
@@ -0,0 +1,16 @@
1
+ // Learn more https://docs.expo.io/guides/customizing-metro
2
+ const { getDefaultConfig } = require('expo/metro-config');
3
+ <% if (props.stylingPackage?.name === "nativewind") { %>
4
+ const { withNativeWind } = require("nativewind/metro");
5
+ <% } %>
6
+
7
+ /** @type {import('expo/metro-config').MetroConfig} */
8
+ // eslint-disable-next-line no-undef
9
+ const config = getDefaultConfig(__dirname);
10
+
11
+ <% if (props.stylingPackage?.name === "nativewind") { %>
12
+ module.exports = withNativeWind(config, { input: "./global.css" });
13
+ <% } else { %>
14
+ module.exports = config;
15
+ <% } %>
16
+
@@ -1,6 +1,9 @@
1
1
  import { Link, Stack } from 'expo-router';
2
2
  <% if (props.stylingPackage?.name === "nativewind") {%>
3
3
  import { Text, View } from 'react-native';
4
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
5
+ import { createStyleSheet, useStyles } from 'react-native-unistyles'
6
+ import { Text, View } from 'react-native';
4
7
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
5
8
  import { StyleSheet, Text, View } from 'react-native';
6
9
  <% } else if (props.stylingPackage?.name === "tamagui") { %>
@@ -15,6 +18,10 @@ export default function NotFoundScreen() {
15
18
  const styles = useStyles();
16
19
  <% } %>
17
20
 
21
+ <% if (props.stylingPackage?.name === "unistyles") {%>
22
+ const { styles } = useStyles(stylesheet)
23
+ <% } %>
24
+
18
25
  return (
19
26
  <% if (props.stylingPackage?.name === "nativewind") {%>
20
27
  <>
@@ -71,6 +78,27 @@ export default function NotFoundScreen() {
71
78
  link: `mt-4 pt-4`,
72
79
  linkText: `text-base text-[#2e78b7]`,
73
80
  };
81
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
82
+ const stylesheet = createStyleSheet({
83
+ container: {
84
+ flex: 1,
85
+ alignItems: 'center',
86
+ justifyContent: 'center',
87
+ padding: 20,
88
+ },
89
+ title: {
90
+ fontSize: 20,
91
+ fontWeight: 'bold',
92
+ },
93
+ link: {
94
+ marginTop: 16,
95
+ paddingVertical: 16,
96
+ },
97
+ linkText: {
98
+ fontSize: 14,
99
+ color: '#2e78b7',
100
+ },
101
+ });
74
102
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
75
103
  const styles = StyleSheet.create({
76
104
  container: {
@@ -1,3 +1,10 @@
1
+ <% if (props.stylingPackage?.name === "nativewind") { %>
2
+ import '../global.css';
3
+ <% } %>
4
+ <% if (props.stylingPackage?.name === "unistyles") { %>
5
+ import '../unistyles';
6
+ <% } %>
7
+
1
8
  <% if (props.stylingPackage?.name === "tamagui") { %>
2
9
  import { useFonts } from 'expo-font';
3
10
  import { SplashScreen, Stack } from 'expo-router';
@@ -8,6 +8,9 @@
8
8
  <% } else if (props.stylingPackage?.name === "restyle") { %>
9
9
  import { Box, Text } from 'theme';
10
10
  import { TouchableOpacity } from 'react-native';
11
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
12
+ import { createStyleSheet, useStyles } from 'react-native-unistyles';
13
+ import { Text, TouchableOpacity, View } from "react-native";
11
14
  <% } else { %>
12
15
  import { StyleSheet, Text, TouchableOpacity, View } from "react-native";
13
16
  <% } %>
@@ -17,7 +20,19 @@ import { Stack, useLocalSearchParams, useRouter } from "expo-router";
17
20
  export default function Details() {
18
21
  const { name } = useLocalSearchParams();
19
22
  const router = useRouter();
20
- <% if (props.stylingPackage?.name === "nativewind") { %>
23
+
24
+ <% if (props.stylingPackage?.name === "unistyles") { %>
25
+ const { styles, theme } = useStyles(stylesheet);
26
+
27
+ const BackButton = () => (
28
+ <TouchableOpacity onPress={router.back}>
29
+ <View style={styles.backButton}>
30
+ <Feather name='chevron-left' size={16} color={theme.colors.azureRadiance} />
31
+ <Text style={styles.backButtonText}>Back</Text>
32
+ </View>
33
+ </TouchableOpacity>
34
+ );
35
+ <% } else if (props.stylingPackage?.name === "nativewind") { %>
21
36
  const BackButton = () => (
22
37
  <TouchableOpacity onPress={router.back}>
23
38
  <View className={styles.backButton}>
@@ -84,6 +99,14 @@ export default function Details() {
84
99
  </Box>
85
100
  </Box>
86
101
  </>
102
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
103
+ <View style={styles.container}>
104
+ <Stack.Screen options={{ title: "Details", headerLeft: () => <BackButton /> }} />
105
+ <View style={styles.main}>
106
+ <Text style={theme.components.title}>Details</Text>
107
+ <Text style={theme.components.subtitle}>Showing details for user {name}.</Text>
108
+ </View>
109
+ </View>
87
110
  <% } else { %>
88
111
  <View style={styles.container}>
89
112
  <Stack.Screen options={{ title: "Details", headerLeft: () => <BackButton /> }} />
@@ -105,6 +128,25 @@ export default function Details() {
105
128
  title: "text-[64px] font-bold",
106
129
  subtitle: "text-4xl text-gray-700",
107
130
  };
131
+ <% } else if (props.stylingPackage?.name === "unistyles") { %>
132
+ const stylesheet = createStyleSheet((theme) => ({
133
+ backButton: {
134
+ flexDirection: 'row',
135
+ },
136
+ backButtonText: {
137
+ color: theme.colors.azureRadiance,
138
+ marginLeft: 4,
139
+ },
140
+ container: {
141
+ flex: 1,
142
+ padding: 24,
143
+ },
144
+ main: {
145
+ flex: 1,
146
+ maxWidth: 960,
147
+ marginHorizontal: 'auto',
148
+ },
149
+ }));
108
150
  <% } else if (props.stylingPackage?.name === "stylesheet") { %>
109
151
  const styles = StyleSheet.create({
110
152
  backButton: {