portfolio_site/tailwind.config.ts

98 lines
3.1 KiB
TypeScript
Raw Normal View History

2025-01-21 15:22:19 +02:00
import { fontFamily } from 'tailwindcss/defaultTheme';
import type { Config } from 'tailwindcss';
import tailwindcssAnimate from 'tailwindcss-animate';
2025-01-18 23:06:09 +02:00
2025-01-18 23:17:25 +02:00
const config: Config = {
2025-01-31 19:37:17 +02:00
darkMode: ['class', 'dark'],
2025-01-21 15:22:19 +02:00
content: ['./src/**/*.{html,js,svelte,ts}'],
2025-01-18 23:06:09 +02:00
theme: {
2025-01-18 23:17:25 +02:00
extend: {
colors: {
2025-01-21 15:22:19 +02:00
border: 'hsl(var(--border) / <alpha-value>)',
input: 'hsl(var(--input) / <alpha-value>)',
ring: 'hsl(var(--ring) / <alpha-value>)',
background: 'hsl(var(--background) / <alpha-value>)',
foreground: 'hsl(var(--foreground) / <alpha-value>)',
2025-01-18 23:17:25 +02:00
primary: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--primary) / <alpha-value>)',
foreground: 'hsl(var(--primary-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
secondary: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--secondary) / <alpha-value>)',
foreground: 'hsl(var(--secondary-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
destructive: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--destructive) / <alpha-value>)',
foreground: 'hsl(var(--destructive-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
muted: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--muted) / <alpha-value>)',
foreground: 'hsl(var(--muted-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
accent: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--accent) / <alpha-value>)',
foreground: 'hsl(var(--accent-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
popover: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--popover) / <alpha-value>)',
foreground: 'hsl(var(--popover-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
card: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--card) / <alpha-value>)',
foreground: 'hsl(var(--card-foreground) / <alpha-value>)'
2025-01-18 23:17:25 +02:00
},
sidebar: {
2025-01-21 15:22:19 +02:00
DEFAULT: 'hsl(var(--sidebar-background))',
foreground: 'hsl(var(--sidebar-foreground))',
primary: 'hsl(var(--sidebar-primary))',
'primary-foreground': 'hsl(var(--sidebar-primary-foreground))',
accent: 'hsl(var(--sidebar-accent))',
'accent-foreground': 'hsl(var(--sidebar-accent-foreground))',
border: 'hsl(var(--sidebar-border))',
ring: 'hsl(var(--sidebar-ring))'
}
2025-01-18 23:17:25 +02:00
},
borderRadius: {
2025-01-21 15:22:19 +02:00
xl: 'calc(var(--radius) + 4px)',
lg: 'var(--radius)',
md: 'calc(var(--radius) - 2px)',
sm: 'calc(var(--radius) - 4px)'
2025-01-18 23:17:25 +02:00
},
fontFamily: {
2025-01-21 15:22:19 +02:00
sans: [...fontFamily.sans],
title: ['Smooch Sans Variable', ...fontFamily.sans],
mono: ['Kode Mono Variable', ...fontFamily.mono]
2025-01-18 23:17:25 +02:00
},
keyframes: {
2025-01-21 15:22:19 +02:00
'accordion-down': {
from: { height: '0' },
to: { height: 'var(--bits-accordion-content-height)' }
2025-01-18 23:17:25 +02:00
},
2025-01-21 15:22:19 +02:00
'accordion-up': {
from: { height: 'var(--bits-accordion-content-height)' },
to: { height: '0' }
2025-01-18 23:17:25 +02:00
},
2025-01-21 15:22:19 +02:00
'caret-blink': {
'0%,70%,100%': { opacity: '1' },
'20%,50%': { opacity: '0' }
}
2025-01-18 23:17:25 +02:00
},
animation: {
2025-01-21 15:22:19 +02:00
'accordion-down': 'accordion-down 0.2s ease-out',
'accordion-up': 'accordion-up 0.2s ease-out',
'caret-blink': 'caret-blink 1.25s ease-out infinite'
},
transitionTimingFunction: {
2025-01-31 19:37:17 +02:00
default: 'cubic-bezier(0.16, 1, 0.3, 1)',
in: 'cubic-bezier(0.7, 0, 0.84, 0)',
out: 'cubic-bezier(0.16, 1, 0.3, 1)',
'in-out': 'cubic-bezier(0.87, 0, 0.13, 1)',
bouncy: 'cubic-bezier(.65,.01,.04,.97)'
2025-01-21 15:22:19 +02:00
}
}
2025-01-18 23:06:09 +02:00
},
2025-01-21 15:22:19 +02:00
plugins: [tailwindcssAnimate]
2025-01-18 23:17:25 +02:00
};
2025-01-18 23:06:09 +02:00
2025-01-18 23:17:25 +02:00
export default config;