103 lines
2.9 KiB
TypeScript
103 lines
2.9 KiB
TypeScript
import { type Config } from 'tailwindcss'
|
|
import typography from '@tailwindcss/typography'
|
|
import animate from 'tailwindcss-animate'
|
|
|
|
export default {
|
|
darkMode: ['class'],
|
|
content: ['./src/**/*.{ts,tsx,css,html}'],
|
|
theme: {
|
|
container: {
|
|
center: true,
|
|
padding: '2rem'
|
|
},
|
|
extend: {
|
|
zIndex: {
|
|
infinity: 'calc(infinity)'
|
|
},
|
|
colors: {
|
|
border: 'hsl(var(--border))',
|
|
input: 'hsl(var(--input))',
|
|
ring: 'hsl(var(--ring))',
|
|
background: 'hsl(var(--background))',
|
|
foreground: 'hsl(var(--foreground))',
|
|
primary: {
|
|
DEFAULT: 'hsl(var(--primary))',
|
|
foreground: 'hsl(var(--primary-foreground))'
|
|
},
|
|
secondary: {
|
|
DEFAULT: 'hsl(var(--secondary))',
|
|
foreground: 'hsl(var(--secondary-foreground))'
|
|
},
|
|
destructive: {
|
|
DEFAULT: 'hsl(var(--destructive))',
|
|
foreground: 'hsl(var(--destructive-foreground))'
|
|
},
|
|
muted: {
|
|
DEFAULT: 'hsl(var(--muted))',
|
|
foreground: 'hsl(var(--muted-foreground))'
|
|
},
|
|
accent: {
|
|
DEFAULT: 'hsl(var(--accent))',
|
|
foreground: 'hsl(var(--accent-foreground))'
|
|
},
|
|
popover: {
|
|
DEFAULT: 'hsl(var(--popover))',
|
|
foreground: 'hsl(var(--popover-foreground))'
|
|
},
|
|
card: {
|
|
DEFAULT: 'hsl(var(--card))',
|
|
foreground: 'hsl(var(--card-foreground))'
|
|
}
|
|
},
|
|
minWidth: {
|
|
screen: '100vw'
|
|
},
|
|
backdropBlur: {
|
|
xs: '2px'
|
|
},
|
|
borderRadius: {
|
|
lg: 'var(--radius)',
|
|
md: 'calc(var(--radius) - 2px)',
|
|
sm: 'calc(var(--radius) - 4px)'
|
|
},
|
|
|
|
keyframes: {
|
|
'accordion-down': {
|
|
from: { height: '0' },
|
|
to: { height: 'var(--radix-accordion-content-height)' }
|
|
},
|
|
'accordion-up': {
|
|
from: { height: 'var(--radix-accordion-content-height)' },
|
|
to: { height: '0' }
|
|
},
|
|
pulse: {
|
|
'0%, 100%': { boxShadow: '0 0 0 0 var(--pulse-color)' },
|
|
'50%': { boxShadow: '0 0 0 8px var(--pulse-color)' }
|
|
},
|
|
meteor: {
|
|
'0%': { transform: 'rotate(215deg) translateX(0)', opacity: '1' },
|
|
'70%': { opacity: '1' },
|
|
'100%': {
|
|
transform: 'rotate(215deg) translateX(-500px)',
|
|
opacity: '0'
|
|
}
|
|
},
|
|
shimmer: {
|
|
'0%': {
|
|
'--shimmer-angle': '0deg'
|
|
},
|
|
'100%': {
|
|
'--shimmer-angle': '360deg'
|
|
}
|
|
}
|
|
},
|
|
animation: {
|
|
'accordion-down': 'accordion-down 0.2s ease-out',
|
|
'accordion-up': 'accordion-up 0.2s ease-out',
|
|
pulse: 'pulse var(--duration) ease-out infinite',
|
|
meteor: 'meteor 5s linear infinite'
|
|
}
|
|
}
|
|
},
|
|
plugins: [animate, typography()]
|
|
} satisfies Config
|