-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtamagui.config.ts
70 lines (64 loc) · 1.72 KB
/
tamagui.config.ts
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
import {createInterFont} from "@tamagui/font-inter";
import {createMedia} from "@tamagui/react-native-media-driver";
import {shorthands} from "@tamagui/shorthands";
import {themes, tokens} from "@tamagui/themes";
import {createTamagui} from "tamagui";
import {createAnimations} from "@tamagui/animations-react-native";
const animations = createAnimations({
bouncy: {
type: "spring",
damping: 10,
mass: 0.9,
stiffness: 100,
},
lazy: {
type: "spring",
damping: 20,
stiffness: 60,
},
quick: {
type: "spring",
damping: 20,
mass: 1.2,
stiffness: 250,
},
});
const headingFont = createInterFont();
const bodyFont = createInterFont();
const config = createTamagui({
animations,
defaultTheme: "dark",
shouldAddPrefersColorThemes: false,
themeClassNameOnRoot: false,
shorthands,
fonts: {
heading: headingFont,
body: bodyFont,
},
themes,
tokens,
media: createMedia({
xs: {maxWidth: 660},
sm: {maxWidth: 800},
md: {maxWidth: 1020},
lg: {maxWidth: 1280},
xl: {maxWidth: 1420},
xxl: {maxWidth: 1600},
gtXs: {minWidth: 660 + 1},
gtSm: {minWidth: 800 + 1},
gtMd: {minWidth: 1020 + 1},
gtLg: {minWidth: 1280 + 1},
short: {maxHeight: 820},
tall: {minHeight: 820},
hoverNone: {hover: "none"},
pointerCoarse: {pointer: "coarse"},
}),
});
export type AppConfig = typeof config;
declare module "tamagui" {
// overrides TamaguiCustomConfig so your custom types
// work everywhere you import `tamagui`
interface TamaguiCustomConfig extends AppConfig {
}
}
export default config;