'use client'; import type { VariantProps } from 'class-variance-authority'; import { useMemo } from 'react'; import { cva } from 'class-variance-authority'; import { cn, Label, Separator } from '@gib/ui'; export function FieldSet({ className, ...props }: React.ComponentProps<'fieldset'>) { return (
[data-slot=checkbox-group]]:gap-3 has-[>[data-slot=radio-group]]:gap-3', className, )} {...props} /> ); } export function FieldLegend({ className, variant = 'legend', ...props }: React.ComponentProps<'legend'> & { variant?: 'legend' | 'label' }) { return ( ); } export function FieldGroup({ className, ...props }: React.ComponentProps<'div'>) { return (
[data-slot=field-group]]:gap-4', className, )} {...props} /> ); } const fieldVariants = cva( 'group/field data-[invalid=true]:text-destructive flex w-full gap-3', { variants: { orientation: { vertical: ['flex-col [&>*]:w-full [&>.sr-only]:w-auto'], horizontal: [ 'flex-row items-center', '[&>[data-slot=field-label]]:flex-auto', 'has-[>[data-slot=field-content]]:items-start has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px', ], responsive: [ 'flex-col @md/field-group:flex-row @md/field-group:items-center [&>*]:w-full @md/field-group:[&>*]:w-auto [&>.sr-only]:w-auto', '@md/field-group:[&>[data-slot=field-label]]:flex-auto', '@md/field-group:has-[>[data-slot=field-content]]:items-start @md/field-group:has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px', ], }, }, defaultVariants: { orientation: 'vertical', }, }, ); export function Field({ className, orientation = 'vertical', ...props }: React.ComponentProps<'div'> & VariantProps) { return (
); } export function FieldContent({ className, ...props }: React.ComponentProps<'div'>) { return (
); } export function FieldLabel({ className, ...props }: React.ComponentProps) { return (