-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathApp.tsx
More file actions
53 lines (48 loc) · 1.91 KB
/
App.tsx
File metadata and controls
53 lines (48 loc) · 1.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
import { ModalProvider } from '@contexts/ModalProvider';
import { ThemeProvider } from '@emotion/react';
import RootNavigator from '@src/navigation/RootNavigator';
import theme from '@styles/theme';
import { useFonts } from 'expo-font';
import React from 'react';
import { View, ActivityIndicator } from 'react-native';
import { SafeAreaProvider } from 'react-native-safe-area-context';
import Toast from 'react-native-toast-message';
const SHOW_SB = process.env.EXPO_PUBLIC_STORYBOOK === '1';
const StorybookUIRoot = SHOW_SB ? require('./.storybook').default : null;
export default function App() {
// 여기에 실제 파일 경로/이름 맞춰주세요
const [fontsLoaded] = useFonts({
'Pretendard-Black': require('./src/assets/fonts/Pretendard-Black.ttf'),
'Pretendard-Bold': require('./src/assets/fonts/Pretendard-Bold.ttf'),
'Pretendard-ExtraBold': require('./src/assets/fonts/Pretendard-ExtraBold.ttf'),
'Pretendard-ExtraLight': require('./src/assets/fonts/Pretendard-ExtraLight.ttf'),
'Pretendard-Light': require('./src/assets/fonts/Pretendard-Light.ttf'),
'Pretendard-Medium': require('./src/assets/fonts/Pretendard-Medium.ttf'),
'Pretendard-Regular': require('./src/assets/fonts/Pretendard-Regular.ttf'),
'Pretendard-SemiBold': require('./src/assets/fonts/Pretendard-SemiBold.ttf'),
'Pretendard-Thin': require('./src/assets/fonts/Pretendard-Thin.ttf'),
});
// 폰트 아직이면 간단 로더
if (!fontsLoaded) {
return (
<View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}>
<ActivityIndicator />
</View>
);
}
// 스토리북 켰을 때
if (SHOW_SB && StorybookUIRoot) {
return <StorybookUIRoot />;
}
// 앱 UI
return (
<ThemeProvider theme={theme}>
<ModalProvider>
<SafeAreaProvider>
<RootNavigator />
<Toast />
</SafeAreaProvider>
</ModalProvider>
</ThemeProvider>
);
}