Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 | 18x 18x 240x 240x 18x | import type { HTMLAttributes } from 'react';
import { forwardRef } from 'react';
import { cva, type VariantProps } from 'class-variance-authority';
import { cn } from '@/lib/utils';
const headingVariants = cva(
[
// Typography
'font-semibold tracking-tight',
].join(' '),
{
variants: {
variant: {
default: 'text-foreground',
muted: 'text-muted-foreground',
accent: 'text-accent-foreground',
destructive: 'text-destructive',
},
size: {
h1: 'text-4xl lg:text-5xl',
h2: 'text-3xl lg:text-4xl',
h3: 'text-2xl lg:text-3xl',
h4: 'text-xl lg:text-2xl',
h5: 'text-lg lg:text-xl',
h6: 'text-base lg:text-lg',
},
},
defaultVariants: {
variant: 'default',
size: 'h2',
},
}
);
export interface HeadingProps
extends HTMLAttributes<HTMLHeadingElement>,
VariantProps<typeof headingVariants> {
as?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
}
const Heading = forwardRef<HTMLHeadingElement, HeadingProps>(
({ className, variant, size, as = 'h2', ...props }, ref) => {
const Comp = as;
return (
<Comp
className={cn(headingVariants({ variant, size, className }))}
ref={ref}
{...props}
/>
);
}
);
Heading.displayName = 'Heading';
export { Heading, headingVariants };
|