-
Notifications
You must be signed in to change notification settings - Fork 1
/
types.tsx
84 lines (73 loc) · 1.87 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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/**
* Learn more about using TypeScript with React Navigation:
* https://reactnavigation.org/docs/typescript/
*/
import { BottomTabScreenProps } from "@react-navigation/bottom-tabs";
import {
CompositeScreenProps,
NavigatorScreenParams,
} from "@react-navigation/native";
import { NativeStackScreenProps } from "@react-navigation/native-stack";
declare global {
namespace ReactNavigation {
interface RootParamList extends RootStackParamList {}
}
}
export type EventProps = {
title: string;
location?: string;
time: string;
Icon?: any;
color: string;
lat?: string;
lng?: string;
};
export type AuthStackParamList = {
Welcome: undefined;
};
export type RootStackParamList = {
Root: NavigatorScreenParams<RootTabParamList> | undefined;
Welcome: undefined;
Notifications: undefined;
Event: EventProps | undefined;
NotFound: undefined;
Sponsors: undefined;
};
export type RootStackScreenProps<Screen extends keyof RootStackParamList> =
NativeStackScreenProps<RootStackParamList, Screen>;
export type RootTabParamList = {
Timeline: undefined;
Contact: undefined;
Profile: undefined;
};
export type RootTabScreenProps<Screen extends keyof RootTabParamList> =
CompositeScreenProps<
BottomTabScreenProps<RootTabParamList, Screen>,
NativeStackScreenProps<RootStackParamList>
>;
export interface User {
email: string;
IEEEID: string;
NotificationToken?: string;
Notifications?: Notification[];
FirstName?: string;
LastName?: string;
Gender?: string;
DateofBirth?: string;
PassportNumber?: string;
CountryOfResidence?: string;
}
export interface Notification {
title: string;
message: string;
}
export interface EventTimeline {
title: string;
from: string[];
to: string[];
day: number;
Icon: ({ fill, ...props }: { [x: string]: any; fill: any }) => JSX.Element;
lat?: string;
lng?: string;
location?: string;
}