-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtypes.tsx
56 lines (47 loc) · 1.52 KB
/
types.tsx
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
54
55
56
/**
* Learn more about using TypeScript with React Navigation:
* https://reactnavigation.org/docs/typescript/
*/
import { BottomTabScreenProps } from "@react-navigation/bottom-tabs";
import {
CompositeScreenProps,
NavigationProp,
NavigatorScreenParams,
} from "@react-navigation/native";
import { NativeStackScreenProps } from "@react-navigation/native-stack";
declare global {
namespace ReactNavigation {
interface RootParamList extends RootStackParamList {}
}
}
export type RootStackParamList = {
Root: NavigatorScreenParams<RootTabParamList> | undefined;
NotFound: undefined;
Tournament: { name: string } | undefined;
BracketList: { name: string } | undefined;
Login: undefined;
Register: { fromGoogleFlow: boolean };
Home: undefined;
SearchAndJoinStack: undefined;
TournamentDetails: undefined;
// Modal views:
CreateTournament: undefined;
SearchTournament: undefined;
TournamentDetailsSearch: undefined;
};
export type RootStackScreenProps<Screen extends keyof RootStackParamList> =
NativeStackScreenProps<RootStackParamList, Screen>;
export type RootTabParamList = {
HomeTab: undefined;
Brackets: undefined;
Account: undefined;
};
// For those many cases where you have a screen that only needs a navigation prop
export type ScreenWithNavigation = {
navigation: NavigationProp<any>;
};
export type RootTabScreenProps<Screen extends keyof RootTabParamList> =
CompositeScreenProps<
BottomTabScreenProps<RootTabParamList, Screen>,
NativeStackScreenProps<RootStackParamList>
>;