-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtailwind.config.ts
96 lines (92 loc) · 2.6 KB
/
tailwind.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import type { Config } from 'tailwindcss'
const defaultTheme = require('tailwindcss/defaultTheme')
const mainColor = "var(--primary-color)";
const getTintedColor = (color: string, intensity: number, mixColor: string = 'white') => {
return `color-mix(in srgb, ${color}, ${mixColor} ${intensity * 100}%)`
}
const generateTintedColors = (color: string, variants: Record<number, number>, mixColor: string = 'white') => {
return Object.fromEntries(
Object.entries(variants).map(([key, value]) => [key, getTintedColor(color, value, mixColor)])
);
};
export default {
content: ["./src/**/*.{html,ts}"],
darkMode: "class",
theme: {
extend: {
fontFamily: {
'sans': ['"Inter"', ...defaultTheme.fontFamily.sans],
},
colors: {
primary: {
DEFAULT: mainColor,
...generateTintedColors(mainColor, {
50: 0.95,
100: 0.9,
200: 0.7,
300: 0.5,
400: 0.3
}),
500: mainColor,
...generateTintedColors(mainColor, {
600: 0.1,
700: 0.3,
800: 0.5,
900: 0.7
}, 'black'),
},
},
keyframes: {
wave: {
'from, 50%, to': { transform: 'rotate(0deg)' },
'10%, 30%': { transform: 'rotate(-10deg)' },
'20%': { transform: 'rotate(12deg)' },
'40%': { transform: 'rotate(9deg)' },
},
skeleton: {
'0%': { backgroundColor: 'hsl(200, 20%, 80%)'},
'100%': { backgroundColor: 'hsl(200, 20%, 95%)'}
},
'music-bars': {
'10%': {
transform: 'scaleY(0.3)',
},
'30%': {
transform: 'scaleY(1)',
},
'60%': {
transform: 'scaleY(0.5)',
},
'80%': {
transform: 'scaleY(0.75)',
},
'100%': {
transform: 'scaleY(0.6)',
},
},
},
animation: {
'waving-hand': 'wave 2s linear infinite',
'skeleton-loading': 'skeleton 1s linear infinite alternate',
'music-bars': 'music-bars 2.2s ease infinite alternate',
},
},
},
plugins: [
require('@tailwindcss/typography')
],
safelist: [
{
pattern: /(bg|text)-(sky|green|slate)-(400)/,
variants: ['hover', 'dark', 'dark:hover']
},
'hover:fill-[#1469C7]',
'hover:fill-[#e74c3c]',
'hover:fill-[#c3c3c3]',
'hover:fill-[#E52765]',
'dark:hover:fill-[#1469C7]',
'dark:hover:fill-[#e74c3c]',
'dark:hover:fill-[#c3c3c3]',
'dark:hover:fill-[#E52765]'
]
} satisfies Config