Files
Munawwirul Jamal 61a3e8597b dev: hotfix, improvements
+ components/pub/my-ui/data-table
+ components/pub/ui/badge
+ lib/date
2025-10-17 02:18:25 +07:00

39 lines
1.4 KiB
TypeScript

import type { VariantProps } from 'class-variance-authority'
import { cva } from 'class-variance-authority'
export { default as Badge } from './Badge.vue'
export type Variants = | 'default' | 'secondary' | 'fresh' | 'positive' | 'negative' | 'warning' | 'destructive' | 'outline'
const variants: Record<Variants, string> = {
default:
'border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80',
secondary:
'border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80',
fresh:
'border-transparent bg-teal-400 text-primary-foreground shadow hover:bg-teal-400/80',
positive:
'border-transparent bg-sky-400 text-primary-foreground shadow hover:bg-sky-400/80',
negative:
'border-transparent bg-neutral-400 text-destructive-foreground shadow hover:bg-neutral-400/80',
warning:
'border-transparent bg-orange-400 text-destructive-foreground shadow hover:bg-orange-400/80',
destructive:
'border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80',
outline: 'text-foreground',
}
export const badgeVariants = cva(
'inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2',
{
variants: {
variant: variants,
},
defaultVariants: {
variant: 'default',
},
},
)
export type BadgeVariants = VariantProps<typeof badgeVariants>