create-expo-stack 2.7.0-next.8c0b833 → 2.7.0-next.997d3bf

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 (22) hide show
  1. package/README.md +7 -7
  2. package/build/templates/base/package.json.ejs +1 -0
  3. package/build/templates/base/tsconfig.json.ejs +1 -1
  4. package/build/templates/packages/nativewindui/app/+not-found.tsx.ejs +1 -1
  5. package/build/templates/packages/nativewindui/app/_layout.tsx.ejs +5 -5
  6. package/build/templates/packages/nativewindui/app/bottom-tabs/_layout.tsx.ejs +1 -1
  7. package/build/templates/packages/nativewindui/app/drawer/_layout.tsx.ejs +2 -2
  8. package/build/templates/packages/nativewindui/app/index.tsx.ejs +60 -132
  9. package/build/templates/packages/nativewindui/app/modal.tsx.ejs +1 -1
  10. package/build/templates/packages/nativewindui/app/top-tabs/_layout.tsx.ejs +3 -3
  11. package/build/templates/packages/nativewindui/app/top-tabs/following.tsx.ejs +1 -1
  12. package/build/templates/packages/nativewindui/app/top-tabs/index.tsx.ejs +1 -1
  13. package/build/templates/packages/nativewindui/app/top-tabs/my-group.tsx.ejs +1 -1
  14. package/build/templates/packages/nativewindui/components/ThemeToggle.tsx.ejs +3 -3
  15. package/build/templates/packages/nativewindui/components/nativewind-ui/Text.tsx.ejs +1 -1
  16. package/build/templates/packages/nativewindui/lib/useColorScheme.tsx.ejs +1 -1
  17. package/build/templates/packages/nativewindui/lib/useHeaderSearchBar.tsx.ejs +2 -2
  18. package/build/templates/packages/nativewindui/theme/colors.ts.ejs +8 -8
  19. package/build/templates/packages/nativewindui/theme/index.ts.ejs +4 -4
  20. package/build/utilities/configureProjectFiles.js +1 -2
  21. package/package.json +1 -1
  22. package/build/templates/packages/nativewindui/components/nativewind-ui/Toggle.tsx.ejs +0 -17
package/README.md CHANGED
@@ -179,6 +179,13 @@ Thanks go to these wonderful people:
179
179
  </a>
180
180
  </td></tr>
181
181
  <tr>
182
+ <td align="center">
183
+ <a href="https://github.com/mrzachnugent">
184
+ <img src="https://avatars.githubusercontent.com/u/63797719?v=4" width="100;" alt="mrzachnugent"/>
185
+ <br />
186
+ <sub><b>Zach Nugent</b></sub>
187
+ </a>
188
+ </td>
182
189
  <td align="center">
183
190
  <a href="https://github.com/alitnk">
184
191
  <img src="https://avatars.githubusercontent.com/u/35243344?v=4" width="100;" alt="alitnk"/>
@@ -200,13 +207,6 @@ Thanks go to these wonderful people:
200
207
  <sub><b>Null</b></sub>
201
208
  </a>
202
209
  </td>
203
- <td align="center">
204
- <a href="https://github.com/mrzachnugent">
205
- <img src="https://avatars.githubusercontent.com/u/63797719?v=4" width="100;" alt="mrzachnugent"/>
206
- <br />
207
- <sub><b>Zach Nugent</b></sub>
208
- </a>
209
- </td>
210
210
  <td align="center">
211
211
  <a href="https://github.com/coyksdev">
212
212
  <img src="https://avatars.githubusercontent.com/u/19565694?v=4" width="100;" alt="coyksdev"/>
@@ -22,6 +22,7 @@
22
22
  <% if (props.stylingPackage?.name === "nativewindui") { %>
23
23
  "@react-navigation/material-top-tabs": "^6.6.13",
24
24
  "@roninoss/icons": "^0.0.3",
25
+ "@shopify/flash-list": "1.6.3",
25
26
  "class-variance-authority": "^0.7.0",
26
27
  "clsx": "^2.1.0",
27
28
  "expo-dev-client": "~3.3.8",
@@ -7,7 +7,7 @@
7
7
  "baseUrl": ".",
8
8
  "paths": {
9
9
  <% if (props.stylingPackage?.name === 'nativewindui') { %>
10
- "@/*": [ "./*" ]
10
+ "~/*": [ "./*" ]
11
11
  <% } else { %>
12
12
  <% if (props.navigationPackage?.name === "expo-router" && props.flags.importAlias === true) { %>
13
13
  "~/*": ["*"]
@@ -1,6 +1,6 @@
1
1
  import { Link, Stack } from 'expo-router';
2
2
  import { View } from 'react-native';
3
- import { Text } from '@/components/nativewind-ui/Text';
3
+ import { Text } from '~/components/nativewind-ui/Text';
4
4
 
5
5
  export default function NotFoundScreen() {
6
6
  return (
@@ -1,4 +1,4 @@
1
- import '@/global.css';
1
+ import '~/global.css';
2
2
  import 'expo-dev-client';
3
3
  import { ThemeProvider as NavThemeProvider } from '@react-navigation/native';
4
4
  import { Icon } from '@roninoss/icons';
@@ -7,10 +7,10 @@ import { StatusBar } from 'expo-status-bar';
7
7
  import { Pressable, View } from 'react-native';
8
8
  import { GestureHandlerRootView } from 'react-native-gesture-handler';
9
9
 
10
- import { ThemeToggle } from '@/components/ThemeToggle';
11
- import { cn } from '@/lib/cn';
12
- import { useColorScheme } from '@/lib/useColorScheme';
13
- import { NAV_THEME } from '@/theme';
10
+ import { ThemeToggle } from '~/components/ThemeToggle';
11
+ import { cn } from '~/lib/cn';
12
+ import { useColorScheme } from '~/lib/useColorScheme';
13
+ import { NAV_THEME } from '~/theme';
14
14
 
15
15
  export {
16
16
  // Catch any errors thrown by the Layout component.
@@ -1,4 +1,4 @@
1
- import { ThemeToggle } from '@/components/ThemeToggle';
1
+ import { ThemeToggle } from '~/components/ThemeToggle';
2
2
  import { Icon } from '@roninoss/icons';
3
3
  import { Tabs } from 'expo-router';
4
4
  import { View } from 'react-native';
@@ -1,5 +1,5 @@
1
- import { ThemeToggle } from '@/components/ThemeToggle';
2
- import { useColorScheme } from '@/lib/useColorScheme';
1
+ import { ThemeToggle } from '~/components/ThemeToggle';
2
+ import { useColorScheme } from '~/lib/useColorScheme';
3
3
  import { Drawer } from 'expo-router/drawer';
4
4
  import { View } from 'react-native';
5
5
 
@@ -1,86 +1,83 @@
1
- import { Icon } from '@roninoss/icons';
2
- import { Link } from 'expo-router';
1
+ import { FlashList } from '@shopify/flash-list';
2
+ import { cssInterop } from 'nativewind';
3
3
  import * as React from 'react';
4
- import { FlatList, Pressable, View } from 'react-native';
4
+ import { Button as RNButton, ButtonProps, Linking, View } from 'react-native';
5
5
 
6
- import { Text } from '@/components/nativewind-ui/Text';
7
- import { Toggle } from '@/components/nativewind-ui/Toggle';
8
- import { cn } from '@/lib/cn';
9
- import { useColorScheme } from '@/lib/useColorScheme';
10
- import { useHeaderSearchBar } from '@/lib/useHeaderSearchBar';
6
+ import { Text } from '~/components/nativewind-ui/Text';
7
+ import { useColorScheme } from '~/lib/useColorScheme';
8
+ import { useHeaderSearchBar } from '~/lib/useHeaderSearchBar';
11
9
 
12
- export default function Screen() {
10
+ cssInterop(FlashList, {
11
+ className: 'style',
12
+ contentContainerClassName: 'contentContainerStyle',
13
+ });
14
+
15
+ function DefaultButton({ color, ...props }: ButtonProps) {
13
16
  const { colors } = useColorScheme();
17
+ return <RNButton color={color ?? colors.primary} {...props} />;
18
+ }
19
+
20
+ export default function Screen() {
14
21
  const searchValue = useHeaderSearchBar();
15
22
 
16
23
  const data = searchValue
17
24
  ? COMPONENTS.filter((c) => c.name.toLowerCase().includes(searchValue.toLowerCase()))
18
25
  : COMPONENTS;
19
26
 
20
- const screens = searchValue
21
- ? FULL_SCREEN_COMPONENTS.filter((c) => c.name.toLowerCase().includes(searchValue.toLowerCase()))
22
- : FULL_SCREEN_COMPONENTS;
27
+ if (data.length === 0) {
28
+ return (
29
+ <View className='flex-1 justify-center items-center px-4'>
30
+ <Text variant='title3' className='text-center font-bold pb-1'>
31
+ {searchValue.length === 0
32
+ ? 'No Components Installed'
33
+ : 'No Components Found'}
34
+ </Text>
35
+ <Text color='tertiary' variant='body' className='text-center pb-4'>
36
+ You can install any of the free components from the NativeWindUI
37
+ website.
38
+ </Text>
39
+ <DefaultButton
40
+ title='Open NativeWindUI'
41
+ onPress={() => Linking.openURL('https://nativewindui.com')}
42
+ />
43
+ </View>
44
+ );
45
+ }
23
46
 
24
47
  return (
25
- <FlatList
48
+ <FlashList
26
49
  contentInsetAdjustmentBehavior="automatic"
50
+ keyboardShouldPersistTaps="handled"
27
51
  data={data}
52
+ estimatedItemSize={200}
28
53
  contentContainerClassName="py-4"
29
54
  extraData={searchValue}
30
55
  removeClippedSubviews={false} // used for selecting text on android
31
- keyExtractor={(item) => item.name}
32
- ItemSeparatorComponent={() => <View className="p-2" />}
33
- renderItem={({ item }) => {
34
- return (
35
- <Card title={item.name}>
36
- <item.component />
37
- </Card>
38
- );
39
- }}
40
- ListFooterComponent={() => {
41
- return (
42
- <FlatList
43
- ListHeaderComponent={() => (
44
- <View className={cn('px-4 pb-2 pt-6', screens.length === 0 && 'hidden')}>
45
- <Text className="text-xs font-semibold opacity-50 ">NAVIGATORS</Text>
46
- </View>
47
- )}
48
- scrollToOverflowEnabled
49
- scrollEnabled={false}
50
- contentInsetAdjustmentBehavior="automatic"
51
- data={screens}
52
- className="ios:px-4"
53
- extraData={searchValue}
54
- keyExtractor={(item) => item.name}
55
- renderItem={({ index, item }) => {
56
- const isLast = index === screens.length - 1;
57
- return (
58
- <Link href={item.href} asChild>
59
- <Pressable
60
- className={cn(
61
- index === 0 && 'ios:rounded-t-xl border-t',
62
- isLast && 'ios:rounded-b-xl border-b',
63
- 'bg-card ios:border-l ios:border-r border-border flex-row active:opacity-80'
64
- )}>
65
- <View
66
- className={cn(
67
- !isLast && 'border-border border-b',
68
- 'flex-1 flex-row items-center justify-between px-4 py-3'
69
- )}>
70
- <Text>{item.name}</Text>
71
- <Icon name="chevron-right" size={18} color={colors.grey} />
72
- </View>
73
- </Pressable>
74
- </Link>
75
- );
76
- }}
77
- />
78
- );
79
- }}
56
+ keyExtractor={keyExtractor}
57
+ ItemSeparatorComponent={renderItemSeparator}
58
+ renderItem={renderItem}
80
59
  />
81
60
  );
82
61
  }
83
62
 
63
+ type ComponentItem = { name: string; component: () => React.JSX.Element };
64
+
65
+ function keyExtractor(item: ComponentItem) {
66
+ return item.name;
67
+ }
68
+
69
+ function renderItemSeparator() {
70
+ return <View className='p-2' />;
71
+ }
72
+
73
+ function renderItem({ item }: { item: ComponentItem }) {
74
+ return (
75
+ <Card title={item.name}>
76
+ <item.component />
77
+ </Card>
78
+ );
79
+ }
80
+
84
81
  function Card({ children, title }: { children: React.ReactNode; title: string }) {
85
82
  return (
86
83
  <View className="px-4">
@@ -92,74 +89,5 @@ function Card({ children, title }: { children: React.ReactNode; title: string })
92
89
  );
93
90
  }
94
91
 
95
- function ToggleExample() {
96
- const [switchValue, setSwitchValue] = React.useState(true);
97
- return (
98
- <View className="items-center">
99
- <Toggle value={switchValue} onValueChange={setSwitchValue} />
100
- </View>
101
- );
102
- }
103
-
104
- const COMPONENTS = [
105
- {
106
- name: 'Toggle',
107
- component: ToggleExample,
108
- },
109
-
110
- {
111
- name: 'Text',
112
- component: () => (
113
- <View className="gap-2">
114
- <Text variant="largeTitle" className="text-center">
115
- Large Title
116
- </Text>
117
- <Text variant="title1" className="text-center">
118
- Title 1
119
- </Text>
120
- <Text variant="title2" className="text-center">
121
- Title 2
122
- </Text>
123
- <Text variant="title3" className="text-center">
124
- Title 3
125
- </Text>
126
- <Text variant="heading" className="text-center">
127
- Heading
128
- </Text>
129
- <Text variant="body" className="text-center">
130
- Body
131
- </Text>
132
- <Text variant="callout" className="text-center">
133
- Callout
134
- </Text>
135
- <Text variant="subhead" className="text-center">
136
- Subhead
137
- </Text>
138
- <Text variant="footnote" className="text-center">
139
- Footnote
140
- </Text>
141
- <Text variant="caption1" className="text-center">
142
- Caption 1
143
- </Text>
144
- <Text variant="caption2" className="text-center">
145
- Caption 2
146
- </Text>
147
- </View>
148
- ),
149
- },
150
- ] as const;
92
+ const COMPONENTS: ComponentItem[] = [];
151
93
 
152
- const FULL_SCREEN_COMPONENTS = [
153
- {
154
- name: 'Drawer Navigation',
155
- href: '/drawer/',
156
- },
157
- {
158
- name: 'Bottom Tabs Navigation',
159
- href: '/bottom-tabs/',
160
- },
161
- {
162
- name: 'Top Tabs Navigation',
163
- href: '/top-tabs/',
164
- },
165
- ] as const;
@@ -1,4 +1,4 @@
1
- import { Text } from '@/components/nativewind-ui/Text';
1
+ import { Text } from '~/components/nativewind-ui/Text';
2
2
  import { Link } from 'expo-router';
3
3
  import { StatusBar } from 'expo-status-bar';
4
4
  import { useColorScheme } from 'nativewind';
@@ -1,4 +1,4 @@
1
- import { useColorScheme } from '@/lib/useColorScheme';
1
+ import { useColorScheme } from '~/lib/useColorScheme';
2
2
  import type {
3
3
  MaterialTopTabNavigationEventMap,
4
4
  MaterialTopTabNavigationOptions,
@@ -43,7 +43,7 @@ export default function TopTabsLayout() {
43
43
  <TopTabs
44
44
  initialRouteName='index'
45
45
  screenOptions={{
46
- tabBarActiveTintColor: colors.blue,
46
+ tabBarActiveTintColor: colors.primary,
47
47
  tabBarInactiveTintColor: 'grey',
48
48
  tabBarLabelStyle: {
49
49
  fontSize: 14,
@@ -51,7 +51,7 @@ export default function TopTabsLayout() {
51
51
  fontWeight: 'bold',
52
52
  },
53
53
  tabBarIndicatorStyle: {
54
- backgroundColor: colors.blue,
54
+ backgroundColor: colors.primary,
55
55
  },
56
56
  tabBarScrollEnabled: true,
57
57
  tabBarItemStyle: { width: width / SCREENS.length },
@@ -1,4 +1,4 @@
1
- import { Text } from '@/components/nativewind-ui/Text';
1
+ import { Text } from '~/components/nativewind-ui/Text';
2
2
  import { View } from 'react-native';
3
3
 
4
4
  export default function FollowingScreen() {
@@ -1,4 +1,4 @@
1
- import { Text } from '@/components/nativewind-ui/Text';
1
+ import { Text } from '~/components/nativewind-ui/Text';
2
2
  import { View } from 'react-native';
3
3
 
4
4
  export default function ForYouScreen() {
@@ -1,5 +1,5 @@
1
1
  import { View } from 'react-native';
2
- import { Text } from '@/components/nativewind-ui/Text';
2
+ import { Text } from '~/components/nativewind-ui/Text';
3
3
 
4
4
  export default function MyGroupScreen() {
5
5
  return (
@@ -2,9 +2,9 @@ import { Icon } from '@roninoss/icons';
2
2
  import { Appearance, Pressable, View } from 'react-native';
3
3
  import Animated, { LayoutAnimationConfig, ZoomInRotate } from 'react-native-reanimated';
4
4
 
5
- import { cn } from '@/lib/cn';
6
- import { useColorScheme } from '@/lib/useColorScheme';
7
- import { COLORS } from '@/theme/colors';
5
+ import { cn } from '~/lib/cn';
6
+ import { useColorScheme } from '~/lib/useColorScheme';
7
+ import { COLORS } from '~/theme/colors';
8
8
 
9
9
  export function ThemeToggle() {
10
10
  const { colorScheme, toggleColorScheme } = useColorScheme();
@@ -3,7 +3,7 @@ import { cssInterop } from 'nativewind';
3
3
  import * as React from 'react';
4
4
  import { UITextView } from 'react-native-uitextview';
5
5
 
6
- import { cn } from '@/lib/cn';
6
+ import { cn } from '~/lib/cn';
7
7
 
8
8
  cssInterop(UITextView, { className: 'style' });
9
9
 
@@ -1,6 +1,6 @@
1
1
  import { useColorScheme as useNativewindColorScheme } from 'nativewind';
2
2
 
3
- import { COLORS } from '@/theme/colors';
3
+ import { COLORS } from '~/theme/colors';
4
4
 
5
5
  export function useColorScheme() {
6
6
  const { colorScheme, setColorScheme, toggleColorScheme } = useNativewindColorScheme();
@@ -1,4 +1,4 @@
1
- import { COLORS } from '@/theme/colors';
1
+ import { COLORS } from '~/theme/colors';
2
2
  import { useNavigation } from 'expo-router';
3
3
  import * as React from 'react';
4
4
  import { SearchBarProps } from 'react-native-screens';
@@ -15,7 +15,7 @@ export function useHeaderSearchBar(props: SearchBarProps = {}) {
15
15
  placeholder: 'Search...',
16
16
  barTintColor: colorScheme === 'dark' ? COLORS.black : COLORS.white,
17
17
  textColor: colors.foreground,
18
- tintColor: colors.blue,
18
+ tintColor: colors.primary,
19
19
  headerIconColor: colors.foreground,
20
20
  hintTextColor: colors.grey,
21
21
  hideWhenScrolling: false,
@@ -14,8 +14,8 @@ const IOS_SYSTEM_COLORS = {
14
14
  foreground: 'rgb(0, 0, 0)',
15
15
  root: 'rgb(255, 255, 255)',
16
16
  card: 'rgb(255, 255, 255)',
17
- red: 'rgb(255, 56, 43)',
18
- blue: 'rgb(0, 123, 254)',
17
+ destructive: 'rgb(255, 56, 43)',
18
+ primary: 'rgb(0, 123, 254)',
19
19
  },
20
20
  dark: {
21
21
  grey6: 'rgb(21, 21, 24)',
@@ -28,8 +28,8 @@ const IOS_SYSTEM_COLORS = {
28
28
  foreground: 'rgb(255, 255, 255)',
29
29
  root: 'rgb(0, 0, 0)',
30
30
  card: 'rgb(28, 28, 30)',
31
- red: 'rgb(254, 67, 54)',
32
- blue: 'rgb(3, 133, 255)',
31
+ destructive: 'rgb(254, 67, 54)',
32
+ primary: 'rgb(3, 133, 255)',
33
33
  },
34
34
  } as const;
35
35
 
@@ -47,8 +47,8 @@ const ANDROID_COLORS = {
47
47
  foreground: 'rgb(0, 0, 0)',
48
48
  root: 'rgb(255, 255, 255)',
49
49
  card: 'rgb(255, 255, 255)',
50
- red: 'rgb(186, 26, 26)',
51
- blue: 'rgb(0, 112, 233)',
50
+ destructive: 'rgb(186, 26, 26)',
51
+ primary: 'rgb(0, 112, 233)',
52
52
  },
53
53
  dark: {
54
54
  grey6: 'rgb(16, 19, 27)',
@@ -61,8 +61,8 @@ const ANDROID_COLORS = {
61
61
  foreground: 'rgb(255, 255, 255)',
62
62
  root: 'rgb(0, 0, 0)',
63
63
  card: 'rgb(16, 19, 27)',
64
- red: 'rgb(147, 0, 10)',
65
- blue: 'rgb(3, 133, 255)',
64
+ destructive: 'rgb(147, 0, 10)',
65
+ primary: 'rgb(3, 133, 255)',
66
66
  },
67
67
  } as const;
68
68
 
@@ -8,8 +8,8 @@ const NAV_THEME: { light: Theme; dark: Theme } = {
8
8
  background: COLORS.light.background,
9
9
  border: COLORS.light.grey5,
10
10
  card: COLORS.light.card,
11
- notification: COLORS.light.red,
12
- primary: COLORS.light.blue, // BRAND COLOR
11
+ notification: COLORS.light.destructive,
12
+ primary: COLORS.light.primary,
13
13
  text: COLORS.black,
14
14
  },
15
15
  },
@@ -19,8 +19,8 @@ const NAV_THEME: { light: Theme; dark: Theme } = {
19
19
  background: COLORS.dark.background,
20
20
  border: COLORS.dark.grey5,
21
21
  card: COLORS.dark.grey6,
22
- notification: COLORS.dark.red,
23
- primary: COLORS.dark.blue, // BRAND COLOR
22
+ notification: COLORS.dark.destructive,
23
+ primary: COLORS.dark.primary,
24
24
  text: COLORS.white,
25
25
  },
26
26
  },
@@ -57,7 +57,6 @@ function configureProjectFiles(authenticationPackage, files, navigationPackage,
57
57
  'packages/nativewindui/app/modal.tsx.ejs',
58
58
  'packages/nativewindui/components/nativewind-ui/Text.tsx.ejs',
59
59
  'packages/nativewindui/components/ThemeToggle.tsx.ejs',
60
- 'packages/nativewindui/components/nativewind-ui/Toggle.tsx.ejs',
61
60
  'packages/nativewindui/lib/useColorScheme.tsx.ejs',
62
61
  'packages/nativewindui/lib/useHeaderSearchBar.tsx.ejs',
63
62
  'packages/nativewindui/lib/cn.ts.ejs',
@@ -288,4 +287,4 @@ function configureProjectFiles(authenticationPackage, files, navigationPackage,
288
287
  return files;
289
288
  }
290
289
  exports.configureProjectFiles = configureProjectFiles;
291
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJlUHJvamVjdEZpbGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxpdGllcy9jb25maWd1cmVQcm9qZWN0RmlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBRUEseURBQXdEO0FBRXhELFNBQWdCLHFCQUFxQixDQUNuQyxxQkFBb0QsRUFDcEQsS0FBZSxFQUNmLGlCQUFnRCxFQUNoRCxjQUE2QyxFQUM3QyxPQUFnQixFQUNoQixVQUFzQixFQUN0QixzQkFBcUQ7O0lBRXJELDJEQUEyRDtJQUMzRCxJQUFJLFNBQVMsR0FBRztRQUNkLHdCQUF3QjtRQUN4QixtQkFBbUI7UUFDbkIsa0JBQWtCO1FBQ2xCLDBCQUEwQjtRQUMxQix1QkFBdUI7UUFDdkIscUJBQXFCO1FBQ3JCLDZCQUE2QjtLQUM5QixDQUFDO0lBRUYsSUFBSSxDQUFBLGNBQWMsYUFBZCxjQUFjLHVCQUFkLGNBQWMsQ0FBRSxJQUFJLE1BQUssWUFBWSxFQUFFLENBQUM7UUFDMUMsU0FBUyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7WUFDM0IsbUNBQW1DO1lBQ25DLHVDQUF1QztZQUN2Qyx3Q0FBd0M7U0FDekMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQU0sY0FBYyxHQUFHLElBQUEscUNBQWlCLEVBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzlELHVEQUF1RDtJQUN2RCxJQUFJLGNBQWMsS0FBSyxNQUFNLElBQUksQ0FBQSxpQkFBaUIsYUFBakIsaUJBQWlCLHVCQUFqQixpQkFBaUIsQ0FBRSxJQUFJLE1BQUssYUFBYSxFQUFFLENBQUM7UUFDM0UsU0FBUyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFNLGlCQUFpQixHQUFHO1FBQ3hCLHdCQUF3QjtRQUN4QixtQkFBbUI7UUFDbkIsMEJBQTBCO1FBQzFCLHVCQUF1QjtRQUN2QixxQkFBcUI7UUFD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
290
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJlUHJvamVjdEZpbGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxpdGllcy9jb25maWd1cmVQcm9qZWN0RmlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBRUEseURBQXdEO0FBRXhELFNBQWdCLHFCQUFxQixDQUNuQyxxQkFBb0QsRUFDcEQsS0FBZSxFQUNmLGlCQUFnRCxFQUNoRCxjQUE2QyxFQUM3QyxPQUFnQixFQUNoQixVQUFzQixFQUN0QixzQkFBcUQ7O0lBRXJELDJEQUEyRDtJQUMzRCxJQUFJLFNBQVMsR0FBRztRQUNkLHdCQUF3QjtRQUN4QixtQkFBbUI7UUFDbkIsa0JBQWtCO1FBQ2xCLDBCQUEwQjtRQUMxQix1QkFBdUI7UUFDdkIscUJBQXFCO1FBQ3JCLDZCQUE2QjtLQUM5QixDQUFDO0lBRUYsSUFBSSxDQUFBLGNBQWMsYUFBZCxjQUFjLHVCQUFkLGNBQWMsQ0FBRSxJQUFJLE1BQUssWUFBWSxFQUFFLENBQUM7UUFDMUMsU0FBUyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7WUFDM0IsbUNBQW1DO1lBQ25DLHVDQUF1QztZQUN2Qyx3Q0FBd0M7U0FDekMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQU0sY0FBYyxHQUFHLElBQUEscUNBQWlCLEVBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzlELHVEQUF1RDtJQUN2RCxJQUFJLGNBQWMsS0FBSyxNQUFNLElBQUksQ0FBQSxpQkFBaUIsYUFBakIsaUJBQWlCLHVCQUFqQixpQkFBaUIsQ0FBRSxJQUFJLE1BQUssYUFBYSxFQUFFLENBQUM7UUFDM0UsU0FBUyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFNLGlCQUFpQixHQUFHO1FBQ3hCLHdCQUF3QjtRQUN4QixtQkFBbUI7UUFDbkIsMEJBQTBCO1FBQzFCLHVCQUF1QjtRQUN2QixxQkFBcUI7UUFD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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-expo-stack",
3
- "version": "2.7.0-next.8c0b833",
3
+ "version": "2.7.0-next.997d3bf",
4
4
  "description": "CLI tool to initialize a React Native application with Expo",
5
5
  "repository": {
6
6
  "type": "git",
@@ -1,17 +0,0 @@
1
- import { useColorScheme } from '@/lib/useColorScheme';
2
- import { COLORS } from '@/theme/colors';
3
- import { Switch } from 'react-native';
4
-
5
- export function Toggle(props: React.ComponentPropsWithoutRef<typeof Switch>) {
6
- const { colors } = useColorScheme();
7
- return (
8
- <Switch
9
- trackColor={{
10
- true: colors.blue,
11
- false: colors.grey,
12
- }}
13
- thumbColor={COLORS.white}
14
- {...props}
15
- />
16
- );
17
- }