mirror of
https://github.com/documenso/documenso.git
synced 2025-11-10 04:22:32 +10:00
28 lines
893 B
TypeScript
28 lines
893 B
TypeScript
'use client';
|
|
|
|
import * as React from 'react';
|
|
|
|
import * as LabelPrimitive from '@radix-ui/react-label';
|
|
import { VariantProps, cva } from 'class-variance-authority';
|
|
|
|
import { cn } from '../lib/utils';
|
|
|
|
const labelVariants = cva(
|
|
'text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70',
|
|
);
|
|
|
|
const Label = React.forwardRef<
|
|
React.ElementRef<typeof LabelPrimitive.Root>,
|
|
React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &
|
|
VariantProps<typeof labelVariants> & { required?: boolean }
|
|
>(({ className, children, required, ...props }, ref) => (
|
|
<LabelPrimitive.Root ref={ref} className={cn(labelVariants(), className)} {...props}>
|
|
{children}
|
|
{required && <span className="text-destructive ml-1 inline-block font-medium">*</span>}
|
|
</LabelPrimitive.Root>
|
|
));
|
|
|
|
Label.displayName = LabelPrimitive.Root.displayName;
|
|
|
|
export { Label };
|