shadcn-zod-formkit 1.28.0 → 1.29.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +91 -64
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.mts +14 -2
- package/dist/index.d.ts +14 -2
- package/dist/index.mjs +91 -65
- package/dist/index.mjs.map +1 -1
- package/dist/shadcn-zod-formkit-1.29.0.tgz +0 -0
- package/package.json +1 -1
- package/dist/shadcn-zod-formkit-1.28.0.tgz +0 -0
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../node_modules/clsx/dist/clsx.mjs","../src/lib/utils.ts","../src/components/ui/alert.tsx","../src/components/custom/custom-alert.tsx","../src/components/custom/form/input-errors.ts","../src/components/custom/form/inputs/base/base-input.ts","../src/components/custom/form/inputs/base/definitions.ts","../src/components/custom/form/inputs/base/input-types.ts","../src/components/ui/accordion.tsx","../src/components/ui/badge.tsx","../src/components/ui/button.tsx","../src/components/ui/calendar.tsx","../src/components/ui/card.tsx","../src/components/ui/checkbox.tsx","../src/components/ui/popover.tsx","../src/components/ui/color-input.tsx","../src/components/ui/dialog.tsx","../src/components/ui/label.tsx","../src/components/ui/separator.tsx","../src/components/ui/field.tsx","../src/components/ui/form.tsx","../src/components/ui/input.tsx","../src/components/ui/textarea.tsx","../src/components/ui/input-group.tsx","../src/components/ui/input-otp.tsx","../src/components/ui/radio-group.tsx","../src/components/ui/resizable.tsx","../src/components/ui/scroll-area.tsx","../src/components/ui/select.tsx","../src/components/ui/sonner.tsx","../src/components/ui/switch.tsx","../src/components/ui/tooltip.tsx","../src/components/custom/form/inputs/types/grouped-switches-input.tsx","../src/components/custom/form/inputs/types/accordion-grouped-switches.tsx","../src/components/ui/button-group.tsx","../src/components/custom/form/inputs/types/button-group-input.tsx","../src/components/custom/form/inputs/types/check-list-input.tsx","../src/components/custom/form/inputs/types/checkbox-input.tsx","../src/components/custom/form/inputs/types/color-input.tsx","../src/components/ui/command.tsx","../src/components/custom/form/inputs/types/combo-box-input.tsx","../src/components/custom/form/inputs/types/currency-input.tsx","../node_modules/date-fns/constants.js","../node_modules/date-fns/constructFrom.js","../node_modules/date-fns/toDate.js","../node_modules/date-fns/_lib/defaultOptions.js","../node_modules/date-fns/startOfWeek.js","../node_modules/date-fns/startOfISOWeek.js","../node_modules/date-fns/getISOWeekYear.js","../node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js","../node_modules/date-fns/_lib/normalizeDates.js","../node_modules/date-fns/startOfDay.js","../node_modules/date-fns/differenceInCalendarDays.js","../node_modules/date-fns/startOfISOWeekYear.js","../node_modules/date-fns/isDate.js","../node_modules/date-fns/isValid.js","../node_modules/date-fns/startOfYear.js","../node_modules/date-fns/locale/en-US/_lib/formatDistance.js","../node_modules/date-fns/locale/_lib/buildFormatLongFn.js","../node_modules/date-fns/locale/en-US/_lib/formatLong.js","../node_modules/date-fns/locale/en-US/_lib/formatRelative.js","../node_modules/date-fns/locale/_lib/buildLocalizeFn.js","../node_modules/date-fns/locale/en-US/_lib/localize.js","../node_modules/date-fns/locale/_lib/buildMatchFn.js","../node_modules/date-fns/locale/_lib/buildMatchPatternFn.js","../node_modules/date-fns/locale/en-US/_lib/match.js","../node_modules/date-fns/locale/en-US.js","../node_modules/date-fns/getDayOfYear.js","../node_modules/date-fns/getISOWeek.js","../node_modules/date-fns/getWeekYear.js","../node_modules/date-fns/startOfWeekYear.js","../node_modules/date-fns/getWeek.js","../node_modules/date-fns/_lib/addLeadingZeros.js","../node_modules/date-fns/_lib/format/lightFormatters.js","../node_modules/date-fns/_lib/format/formatters.js","../node_modules/date-fns/_lib/format/longFormatters.js","../node_modules/date-fns/_lib/protectedTokens.js","../node_modules/date-fns/format.js","../src/components/custom/form/inputs/types/date-input.tsx","../src/components/custom/form/inputs/types/date-time-input.tsx","../src/components/custom/form/inputs/types/file-input.tsx","../src/components/custom/form/inputs/types/file-multi-input.tsx","../src/components/custom/form/inputs/types/key-value-input.tsx","../src/components/custom/form/inputs/types/multi-select-input.tsx","../src/components/custom/form/inputs/types/text-input-group.tsx","../src/components/custom/form/inputs/types/number-input.tsx","../src/components/custom/form/inputs/types/otp-input.tsx","../src/components/custom/form/inputs/types/radio-group-input.tsx","../src/components/custom/form/inputs/types/repeater-input.tsx","../src/components/ui/tabs.tsx","../src/components/custom/form/inputs/types/repeater-tabs-input.tsx","../src/components/custom/form/inputs/types/select-input.tsx","../src/components/custom/form/inputs/types/simple-check-list-input.tsx","../src/components/ui/slider.tsx","../src/components/custom/form/inputs/types/slide-input.tsx","../src/components/custom/form/inputs/types/sortable-list-input.tsx","../src/components/custom/form/inputs/types/string-value-input.tsx","../src/components/custom/form/inputs/types/switch-input.tsx","../src/components/custom/form/inputs/types/tags-input.tsx","../src/components/custom/form/inputs/types/text-area-input.tsx","../src/components/custom/form/inputs/types/text-input.tsx","../src/components/custom/form/inputs/types/time-input.tsx","../src/components/custom/form/inputs/input-factory.tsx","../src/components/custom/form/inputs/base/form-errors.tsx","../src/components/custom/form/inputs/FormFieldsGrid.tsx","../src/components/custom/form/inputs/DynamicForm.tsx","../src/components/custom/form/inputs/DynamicFormExample.tsx","../src/components/custom/input-list.tsx","../src/components/custom/others/GenericFilter.tsx"],"names":["jsx","TextInputType","InputTypes","jsxs","cva","Slot","formatters","className","props","ChevronDownIcon","React","React2","React4","CheckIcon","Sonner","useState","input","useEffect","useColor","ColorPicker","CommandPrimitive","React6","value","isValid","useMemo","defaultOptions","format","localize","formatLong","CircleCheck","CircleX","Loader2","React7","Fragment","useRef","Label","ChevronsUpDown","Check","EyeOff","Eye","OTPInput","Trash2","Plus","useFieldArray","React8","FieldTimeInput","flattenFields","z"],"mappings":"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","file":"index.mjs","sourcesContent":["function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","import { clsx, type ClassValue } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n","import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst alertVariants = cva(\n \"relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current\",\n {\n variants: {\n variant: {\n default: \"bg-card text-card-foreground\",\n destructive:\n \"text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Alert({\n className,\n variant,\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof alertVariants>) {\n return (\n <div\n data-slot=\"alert\"\n role=\"alert\"\n className={cn(alertVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nfunction AlertTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"alert-title\"\n className={cn(\n \"col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction AlertDescription({\n className,\n ...props\n}: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"alert-description\"\n className={cn(\n \"text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Alert, AlertTitle, AlertDescription }\n","'use client'\n\nimport { ReactNode } from \"react\";\nimport { MessageCircleWarning } from \"lucide-react\";\nimport { InfoCircledIcon } from '@radix-ui/react-icons';\nimport { Alert, AlertDescription, AlertTitle } from \"@/src/components/ui/alert\";\nimport { cn } from \"@/src/lib/utils\";\n\ninterface Props {\n title: string;\n description: string | ReactNode;\n className?: string;\n variant?: \"info\" | \"warning\" | \"error\" | \"success\";\n}\n\nexport const CustomAlert = ({\n title,\n description,\n className = \"\",\n variant = \"info\",\n}: Props) => {\n const variantClasses = {\n info: \"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200\",\n warning: \"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200\",\n error: \"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200\",\n success: \"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200\",\n };\n\n const variantIcons = {\n info: <MessageCircleWarning size={32} className=\"text-blue-500 dark:text-blue-300\" />,\n warning: <MessageCircleWarning size={32} className=\"text-yellow-500 dark:text-yellow-300\" />,\n error: <MessageCircleWarning size={32} className=\"text-red-500 dark:text-red-300\" />,\n success: <InfoCircledIcon className=\"w-8 h-8 text-green-500 dark:text-green-300\" />,\n };\n\n return (\n <Alert\n className={cn(\n \"mb-4 flex items-start gap-3 border-l-4 p-4 rounded-lg\",\n variantClasses[variant],\n className\n )}\n >\n {/* Icono a la izquierda */}\n <div className=\"flex flex-col shrink-0\">{variantIcons[variant]}</div>\n\n {/* Texto a la derecha */}\n <div className=\"flex flex-col\">\n <AlertTitle className=\"font-semibold text-lg\">{title}</AlertTitle>\n <AlertDescription className=\"text-sm text-muted-foreground dark:text-gray-300\">\n {description}\n </AlertDescription>\n </div>\n </Alert>\n );\n};\n","export const validationMessages = {\n required: \"Este campo es obligatorio\",\n email: \"El correo electrónico no es válido\",\n invalidFormat: \"Formato inválido\",\n onlyPositive: \"Solo números positivos\",\n minLength: (length: number) => `Debe tener al menos ${length} caracteres`,\n maxLength: (length: number) => `No puede tener más de ${length} caracteres`,\n passwordMismatch: \"Las contraseñas no coinciden\",\n invalidPhone: \"El número de teléfono no es válido\",\n};\n\nexport default validationMessages;","import { JSX, ReactNode } from \"react\";\n\nimport { ControllerRenderProps, FieldValues, UseFormReturn } from \"react-hook-form\";\nimport { FieldProps, GroupedOption, InputOption } from \"./definitions\";\n// import { FieldProps } from \"./field-props\";\n\n\nexport abstract class BaseInput {\n constructor(\n protected readonly input: FieldProps,\n protected readonly form: UseFormReturn,\n protected readonly isSubmitting?: boolean,\n ) {}\n\n abstract render(): JSX.Element;\n}\n\n\nexport const entityToInputOption = (entitiy:any, name:string = 'name', description:string = 'description', groupedLabel?:string): InputOption => ({\n id: entitiy['id'],\n name: entitiy[name],\n description: entitiy[description],\n groupedLabel\n})\n\nexport const entitiesToInputOption = (data:any[], optionValue:string = 'name', groupedLabel?:string): InputOption[] => {\n const entities: InputOption[] = [];\n for (const key of data) {\n const entidad = entityToInputOption(key, optionValue, undefined, groupedLabel);\n if(entidad) entities.push(entidad);\n }\n return entities;\n}\nexport const entityToGroupedOption = (entitiy:any, name:string = 'name'): GroupedOption => ({\n id: entitiy['id'],\n label: entitiy[name] || entitiy['label'],\n options: entitiy['options'] || [],\n selectedOptions: [],\n})\n\n\nexport const entitiesToGroupedOption = (data:any[], optionValue:string = 'name' ): GroupedOption[] => {\n const entities: GroupedOption[] = [];\n for (const key of data) {\n const entidad = entityToGroupedOption(key, optionValue);\n if(entidad) entities.push(entidad);\n }\n return entities;\n}\n\nexport const handleOnChage = (\n event: any[] | any,\n input: FieldProps,\n field?: ControllerRenderProps<FieldValues, string>\n): void => {\n let value: any = event;\n\n // 🔹 Detecta si el valor viene de un input DOM normal\n if (event && typeof event === \"object\" && \"target\" in event) {\n value = (event.target as HTMLInputElement).value;\n }\n\n // 🔹 React Hook Form: actualiza el valor del campo\n field?.onChange(value);\n\n // 🔹 Obtiene los valores actuales del formulario\n const data = input.form?.getValues();\n\n // 🔹 Llama al callback específico del input (si existe)\n input.onChange?.(value, data);\n\n // 🔹 Callback global (si existe)\n input.onAnyFieldChange?.(data);\n};\n\nexport const isValidField = (input: FieldProps, form: UseFormReturn, defaultValue?: any): boolean => {\n const value = defaultValue ?? form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n \n // Si el campo tiene un esquema zod, validamos con él\n if (input.zodType) {\n const result = input.zodType.safeParse(value);\n return result.success;\n }\n // Si no tiene zodType, usamos la validación estándar de react-hook-form\n return !fieldState.error && value !== undefined && value !== \"\";\n }\n","import { z, ZodTypeAny } from \"zod\";\nimport { InputTypes } from \"./input-types\"\nimport { LucideProps } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\nexport const flattenFields = <T extends Record<string, any>>(\n fields: FieldConfig<T>[],\n onAnyFieldChange?: (data:any) => void\n): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n result.push(...flattenFields((field as any).fields));\n } else {\n if (onAnyFieldChange) field.onAnyFieldChange = (data:any) => onAnyFieldChange(data)\n result.push(field);\n }\n }\n\n return result;\n};\n\n\nexport type FieldConfig<T, RT = Record<string,any>> = FieldProps<T,RT> | FieldConfig<T,RT>[];\n\nexport interface FieldProps<T = Record<string,any>, RT = Record<string,any>> {\n name: keyof T // Campo debe coincidir con la definición en el esquema\n label: string\n \n withAddBtn?: boolean;\n form?: UseFormReturn<any>;\n isRemovebleOption?:boolean\n withDuplicatTag?: boolean\n onChange?: (event: any[], formValues?: Record<string,any>) => void\n tabLabelField?:string\n childrenPosition?: 'up' | 'down'\n children?: ReactNode | ((item: any, index: number) => ReactNode);\n defaultValue?: any;\n direction?: 'row' | 'col';\n \n repeaterFields?: Array<FieldProps<RT> | FieldProps<RT>[]>;\n minItems?: number;\n maxItems?: number;\n\n\n currencyFormat?: Intl.NumberFormatOptions\n mask?: string | RegExp;\n\n onAnyFieldChange?: (data:Record<string,any>) => void\n wrapInCard?: boolean\n placeHolder?: string\n description?: string\n className?: string\n inputType?: InputTypes\n keyboardType?: TextInputType\n disabled?: boolean\n required?: boolean\n value?: any\n min?: number,\n max?: number,\n zodType?: ZodTypeAny;\n\n infoTooltip?: string\n \n // list?: any[]\n dependsOn?: string // Nombre del campo del que depende este campo\n loadOptions?: (dependencyValue: any) => Promise<any[]> // Función para cargar opciones dinámicamente\n optionLabel?: string // Propiedad a mostrar como etiqueta en el select\n optionValue?: string // Propiedad a usar como valor en el select\n optionDescription?: string // Propiedad a usar como valor en el select\n hidden?:boolean\n onListOptionChange?: (item: any) => void\n\n\n listConfig?: ListConfig\n\n fileConfig?: {\n previewSize?: number\n showPreview?: boolean\n accept: string // tipos de archivo permitidos\n multiple: boolean // múltiples archivos\n maxSize: number\n }\n\n inputGroupConfig?: inputGroudConfig\n}\n\ninterface inputGroudConfig {\n\n autoValidIcons?: boolean \n\n iconsLeft?: React.ForwardRefExoticComponent<Omit<LucideProps, \"ref\"> & React.RefAttributes<SVGSVGElement>>[];\n iconsRight?: React.ForwardRefExoticComponent<Omit<LucideProps, \"ref\"> & React.RefAttributes<SVGSVGElement>>[];\n\n textLeft?: string;\n textRight?: string;\n}\n\n\ninterface ListConfig {\n children?: ReactNode | ((item: any, index: number) => ReactNode);\n list: InputOption[] | GroupedOption[]\n optionLabel?: string\n optionValue?: InputOption| string | number | object\n onOptionChange: (item?: InputOption | InputOption[] | GroupedOption ) => void\n optionDescription?: string\n selectedList?: InputOption[]\n sortable?: boolean;\n}\nexport interface BtnConfig {\n label: string;\n btnType: 'submit' | 'button';\n onClick: () => void\n variant?: \"default\" | \"link\" | \"destructive\" | \"outline\" | \"secondary\" | \"ghost\" | null | undefined;\n disabled?: boolean;\n}\n\nexport interface InputOption {\n id: number | string\n name: string\n label?: string\n description?: string\n disabled?: boolean\n checked?: boolean\n groupedLabel?: string\n value?:any\n}\nexport interface GroupedOption {\n id?: number\n label: string\n options: InputOption[]\n selectedOptions: InputOption[]\n totalSelected?: number\n disabled?: boolean\n value?:any\n}\n\nexport interface InputSetup {\n required: boolean;\n disabled: boolean;\n minLegth?: number;\n maxLength?: number;\n pattern?: RegExp;\n min?:number;\n max?:number;\n isObscure?:boolean;\n isEmail?:boolean;\n isUrl?:boolean;\n zopType?: z.ZodType\n}\n\n\nexport enum TextInputType {\n DEFAULT = \"default\",\n NUMBER = \"number\",\n EMAIL = \"email\",\n PHONE = \"phone\",\n PASSWORD = \"password\",\n}","export enum InputTypes {\n HIDDEN = \"hidden\",\n TEXT = \"text\",\n TEXT_GROUP = \"text_group\",\n NUMBER = \"number\",\n SWITCH = \"switch\",\n CHECKBOX = \"checkbox\",\n SELECT = \"select\",\n SIMPLE_CHECK_LIST = \"siple_checklist\",\n CHECK_LIST = \"checklist\",\n // SWITCH_LIST = \"switchlist\",\n GROUPED_SWITCH_LIST = \"grouped_switchlist\",\n ACCORDION_GROUPED_SWITCH_LIST = \"accordion_grouped_switchlist\",\n DATE = \"date\",\n TEXTAREA = \"textarea\",\n FILE = \"file\",\n OTP = \"otp\",\n FORM = \"form\",\n COLOR = \"color\",\n RADIO_GROUP = \"radio_group\",\n TAGS = \"tags\",\n DATE_TIME = \"date_time\",\n TIME = \"time\",\n FILE_MULTI_UPLOAD = \"file_multi_upload\",\n SLIDER = \"slider\",\n BUTTON_GROUP = \"button_group\",\n CURRENCY = \"currency\",\n KEY_VALUE = \"key_value\",\n REPEATER = \"repeater\",\n MULTI_SELECT = \"multi_select\",\n COMBOBOX = \"COMBO_BOX\",\n SORTABLE_LIST = \"sortable_list\",\n REPEATER_TABS = \"repeater_tabs\",\n STRING_LIST = \"string_list\",\n}\n\nexport const inputFieldComp = [\n InputTypes.STRING_LIST,\n InputTypes.REPEATER_TABS,\n InputTypes.SORTABLE_LIST,\n InputTypes.COMBOBOX,\n InputTypes.MULTI_SELECT,\n InputTypes.REPEATER,\n InputTypes.KEY_VALUE,\n InputTypes.CURRENCY,\n InputTypes.BUTTON_GROUP,\n InputTypes.SLIDER,\n InputTypes.FILE_MULTI_UPLOAD,\n InputTypes.TIME,\n InputTypes.DATE_TIME,\n InputTypes.TAGS,\n InputTypes.RADIO_GROUP,\n InputTypes.TEXT_GROUP,\n InputTypes.ACCORDION_GROUPED_SWITCH_LIST,\n InputTypes.GROUPED_SWITCH_LIST,\n InputTypes.TEXT,\n InputTypes.SWITCH,\n InputTypes.SIMPLE_CHECK_LIST,\n InputTypes.CHECKBOX,\n InputTypes.COLOR,\n InputTypes.OTP,\n InputTypes.SELECT,\n InputTypes.DATE,\n InputTypes.FILE,\n InputTypes.FORM,\n InputTypes.NUMBER,\n InputTypes.TEXTAREA,\n // InputTypes.SWITCH_LIST,\n InputTypes.HIDDEN,\n]","\"use client\"\n\nimport * as React from \"react\"\nimport * as AccordionPrimitive from \"@radix-ui/react-accordion\"\nimport { ChevronDownIcon } from \"lucide-react\"\nimport { cn } from \"@/src/lib/utils\"\n\n\nfunction Accordion({\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Root>) {\n return <AccordionPrimitive.Root data-slot=\"accordion\" {...props} />\n}\n\nfunction AccordionItem({\n className,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Item>) {\n return (\n <AccordionPrimitive.Item\n data-slot=\"accordion-item\"\n className={cn(\"border-b last:border-b-0\", className)}\n {...props}\n />\n )\n}\n\nfunction AccordionTrigger({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Trigger>) {\n return (\n <AccordionPrimitive.Header className=\"flex\">\n <AccordionPrimitive.Trigger\n data-slot=\"accordion-trigger\"\n className={cn(\n \"focus-visible:border-ring focus-visible:ring-ring/50 flex flex-1 items-start justify-between gap-4 rounded-md py-4 text-left text-sm font-medium transition-all outline-none hover:underline focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 [&[data-state=open]>svg]:rotate-180\",\n className\n )}\n {...props}\n >\n {children}\n <ChevronDownIcon className=\"text-muted-foreground pointer-events-none size-4 shrink-0 translate-y-0.5 transition-transform duration-200\" />\n </AccordionPrimitive.Trigger>\n </AccordionPrimitive.Header>\n )\n}\n\nfunction AccordionContent({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Content>) {\n return (\n <AccordionPrimitive.Content\n data-slot=\"accordion-content\"\n className=\"data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down overflow-hidden text-sm\"\n {...props}\n >\n <div className={cn(\"pt-0 pb-4\", className)}>{children}</div>\n </AccordionPrimitive.Content>\n )\n}\n\nexport { Accordion, AccordionItem, AccordionTrigger, AccordionContent }\n","import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst badgeVariants = cva(\n \"inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden\",\n {\n variants: {\n variant: {\n default:\n \"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90\",\n secondary:\n \"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90\",\n destructive:\n \"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Badge({\n className,\n variant,\n asChild = false,\n ...props\n}: React.ComponentProps<\"span\"> &\n VariantProps<typeof badgeVariants> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"span\"\n\n return (\n <Comp\n data-slot=\"badge\"\n className={cn(badgeVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nexport { Badge, badgeVariants }\n","import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n {\n variants: {\n variant: {\n default: \"bg-primary text-primary-foreground hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50\",\n secondary:\n \"bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n ghost:\n \"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-9 px-4 py-2 has-[>svg]:px-3\",\n sm: \"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5\",\n lg: \"h-10 rounded-md px-6 has-[>svg]:px-4\",\n icon: \"size-9\",\n \"icon-sm\": \"size-8\",\n \"icon-lg\": \"size-10\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nfunction Button({\n className,\n variant,\n size,\n asChild = false,\n ...props\n}: React.ComponentProps<\"button\"> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean\n }) {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n data-slot=\"button\"\n className={cn(buttonVariants({ variant, size, className }))}\n {...props}\n />\n )\n}\n\nexport { Button, buttonVariants }\n","\"use client\"\n\nimport * as React from \"react\"\nimport {\n ChevronDownIcon,\n ChevronLeftIcon,\n ChevronRightIcon,\n} from \"lucide-react\"\nimport { DayButton, DayPicker, getDefaultClassNames } from \"react-day-picker\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Button, buttonVariants } from \"./button\"\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = \"label\",\n buttonVariant = \"ghost\",\n formatters,\n components,\n ...props\n}: React.ComponentProps<typeof DayPicker> & {\n buttonVariant?: React.ComponentProps<typeof Button>[\"variant\"]\n}) {\n const defaultClassNames = getDefaultClassNames()\n\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n \"bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent\",\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n className\n )}\n captionLayout={captionLayout}\n formatters={{\n formatMonthDropdown: (date) =>\n date.toLocaleString(\"default\", { month: \"short\" }),\n ...formatters,\n }}\n classNames={{\n root: cn(\"w-fit\", defaultClassNames.root),\n months: cn(\n \"flex gap-4 flex-col md:flex-row relative\",\n defaultClassNames.months\n ),\n month: cn(\"flex flex-col w-full gap-4\", defaultClassNames.month),\n nav: cn(\n \"flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between\",\n defaultClassNames.nav\n ),\n button_previous: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_previous\n ),\n button_next: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_next\n ),\n month_caption: cn(\n \"flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)\",\n defaultClassNames.month_caption\n ),\n dropdowns: cn(\n \"w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5\",\n defaultClassNames.dropdowns\n ),\n dropdown_root: cn(\n \"relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md\",\n defaultClassNames.dropdown_root\n ),\n dropdown: cn(\n \"absolute bg-popover inset-0 opacity-0\",\n defaultClassNames.dropdown\n ),\n caption_label: cn(\n \"select-none font-medium\",\n captionLayout === \"label\"\n ? \"text-sm\"\n : \"rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5\",\n defaultClassNames.caption_label\n ),\n table: \"w-full border-collapse\",\n weekdays: cn(\"flex\", defaultClassNames.weekdays),\n weekday: cn(\n \"text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none\",\n defaultClassNames.weekday\n ),\n week: cn(\"flex w-full mt-2\", defaultClassNames.week),\n week_number_header: cn(\n \"select-none w-(--cell-size)\",\n defaultClassNames.week_number_header\n ),\n week_number: cn(\n \"text-[0.8rem] select-none text-muted-foreground\",\n defaultClassNames.week_number\n ),\n day: cn(\n \"relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none\",\n defaultClassNames.day\n ),\n range_start: cn(\n \"rounded-l-md bg-accent\",\n defaultClassNames.range_start\n ),\n range_middle: cn(\"rounded-none\", defaultClassNames.range_middle),\n range_end: cn(\"rounded-r-md bg-accent\", defaultClassNames.range_end),\n today: cn(\n \"bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none\",\n defaultClassNames.today\n ),\n outside: cn(\n \"text-muted-foreground aria-selected:text-muted-foreground\",\n defaultClassNames.outside\n ),\n disabled: cn(\n \"text-muted-foreground opacity-50\",\n defaultClassNames.disabled\n ),\n hidden: cn(\"invisible\", defaultClassNames.hidden),\n ...classNames,\n }}\n components={{\n Root: ({ className, rootRef, ...props }) => {\n return (\n <div\n data-slot=\"calendar\"\n ref={rootRef}\n className={cn(className)}\n {...props}\n />\n )\n },\n Chevron: ({ className, orientation, ...props }) => {\n if (orientation === \"left\") {\n return (\n <ChevronLeftIcon className={cn(\"size-4\", className)} {...props} />\n )\n }\n\n if (orientation === \"right\") {\n return (\n <ChevronRightIcon\n className={cn(\"size-4\", className)}\n {...props}\n />\n )\n }\n\n return (\n <ChevronDownIcon className={cn(\"size-4\", className)} {...props} />\n )\n },\n DayButton: CalendarDayButton,\n WeekNumber: ({ children, ...props }) => {\n return (\n <td {...props}>\n <div className=\"flex size-(--cell-size) items-center justify-center text-center\">\n {children}\n </div>\n </td>\n )\n },\n ...components,\n }}\n {...props}\n />\n )\n}\n\nfunction CalendarDayButton({\n className,\n day,\n modifiers,\n ...props\n}: React.ComponentProps<typeof DayButton>) {\n const defaultClassNames = getDefaultClassNames()\n\n const ref = React.useRef<HTMLButtonElement>(null)\n React.useEffect(() => {\n if (modifiers.focused) ref.current?.focus()\n }, [modifiers.focused])\n\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n data-day={day.date.toLocaleDateString()}\n data-selected-single={\n modifiers.selected &&\n !modifiers.range_start &&\n !modifiers.range_end &&\n !modifiers.range_middle\n }\n data-range-start={modifiers.range_start}\n data-range-end={modifiers.range_end}\n data-range-middle={modifiers.range_middle}\n className={cn(\n \"data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70\",\n defaultClassNames.day,\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Calendar, CalendarDayButton }\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Card({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card\"\n className={cn(\n \"bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-header\"\n className={cn(\n \"@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-title\"\n className={cn(\"leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-action\"\n className={cn(\n \"col-start-2 row-span-2 row-start-1 self-start justify-self-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-content\"\n className={cn(\"px-6\", className)}\n {...props}\n />\n )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-footer\"\n className={cn(\"flex items-center px-6 [.border-t]:pt-6\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Card,\n CardHeader,\n CardFooter,\n CardTitle,\n CardAction,\n CardDescription,\n CardContent,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as CheckboxPrimitive from \"@radix-ui/react-checkbox\"\nimport { CheckIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Checkbox({\n className,\n ...props\n}: React.ComponentProps<typeof CheckboxPrimitive.Root>) {\n return (\n <CheckboxPrimitive.Root\n data-slot=\"checkbox\"\n className={cn(\n \"peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator\n data-slot=\"checkbox-indicator\"\n className=\"flex items-center justify-center text-current transition-none\"\n >\n <CheckIcon className=\"size-3.5\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n )\n}\n\nexport { Checkbox }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Popover({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Root>) {\n return <PopoverPrimitive.Root data-slot=\"popover\" {...props} />\n}\n\nfunction PopoverTrigger({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Trigger>) {\n return <PopoverPrimitive.Trigger data-slot=\"popover-trigger\" {...props} />\n}\n\nfunction PopoverContent({\n className,\n align = \"center\",\n sideOffset = 4,\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Content>) {\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n data-slot=\"popover-content\"\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden\",\n className\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n )\n}\n\nfunction PopoverAnchor({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Anchor>) {\n return <PopoverPrimitive.Anchor data-slot=\"popover-anchor\" {...props} />\n}\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n","\"use client\"\n\nimport * as React from \"react\"\nimport { ColorPicker, IColor, useColor } from \"react-color-palette\"\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/src/components/ui/popover\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { cn } from \"@/src/lib/utils\"\nimport \"react-color-palette/css\"\n\nexport interface Props {\n value?: string\n onChange?: (color: string) => void\n onBlur?: () => void\n disabled?: boolean\n className?: string\n placeholder?: string\n}\n\nconst ColorCnInput = React.forwardRef<HTMLButtonElement, Props>(\n ({ value = \"#000000\", onChange, onBlur, disabled, className }, ref) => {\n const [color, setColor] = useColor(value)\n const [open, setOpen] = React.useState(false)\n\n React.useEffect(() => {\n if (value !== color.hex) {\n setColor({ ...color, hex: value })\n }\n }, [color, setColor, value])\n\n const handleColorChange = (newColor: IColor) => {\n setColor(newColor)\n onChange?.(newColor.hex)\n }\n\n const handleOpenChange = (newOpen: boolean) => {\n setOpen(newOpen)\n if (!newOpen) {\n onBlur?.()\n }\n }\n\n return (\n <Popover open={open} onOpenChange={handleOpenChange}>\n <PopoverTrigger asChild>\n <Button\n ref={ref}\n variant=\"outline\"\n disabled={disabled}\n className={cn(\"w-full justify-start text-left font-normal\", !value && \"text-muted-foreground\", className)}\n >\n <div className=\"flex items-center gap-2\">\n <div className=\"h-4 w-4 rounded border border-border\" style={{ backgroundColor: color.hex }} />\n <span>{color.hex}</span>\n </div>\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-3\" align=\"start\">\n <ColorPicker color={color} onChange={handleColorChange} hideInput={[\"rgb\", \"hsv\"]} />\n </PopoverContent>\n </Popover>\n )\n },\n)\n\nColorCnInput.displayName = \"ColorCnInput\"\n\nexport { ColorCnInput }\n","import * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { XIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Dialog({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Root>) {\n return <DialogPrimitive.Root data-slot=\"dialog\" {...props} />\n}\n\nfunction DialogTrigger({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Trigger>) {\n return <DialogPrimitive.Trigger data-slot=\"dialog-trigger\" {...props} />\n}\n\nfunction DialogPortal({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Portal>) {\n return <DialogPrimitive.Portal data-slot=\"dialog-portal\" {...props} />\n}\n\nfunction DialogClose({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Close>) {\n return <DialogPrimitive.Close data-slot=\"dialog-close\" {...props} />\n}\n\nfunction DialogOverlay({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Overlay>) {\n return (\n <DialogPrimitive.Overlay\n data-slot=\"dialog-overlay\"\n className={cn(\n \"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction DialogContent({\n className,\n children,\n showCloseButton = true,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Content> & {\n showCloseButton?: boolean\n}) {\n return (\n <DialogPortal data-slot=\"dialog-portal\">\n <DialogOverlay />\n <DialogPrimitive.Content\n data-slot=\"dialog-content\"\n className={cn(\n \"bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg\",\n className\n )}\n {...props}\n >\n {children}\n {showCloseButton && (\n <DialogPrimitive.Close\n data-slot=\"dialog-close\"\n className=\"ring-offset-background focus:ring-ring data-[state=open]:bg-accent data-[state=open]:text-muted-foreground absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\"\n >\n <XIcon />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n )}\n </DialogPrimitive.Content>\n </DialogPortal>\n )\n}\n\nfunction DialogHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-header\"\n className={cn(\"flex flex-col gap-2 text-center sm:text-left\", className)}\n {...props}\n />\n )\n}\n\nfunction DialogFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-footer\"\n className={cn(\n \"flex flex-col-reverse gap-2 sm:flex-row sm:justify-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction DialogTitle({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Title>) {\n return (\n <DialogPrimitive.Title\n data-slot=\"dialog-title\"\n className={cn(\"text-lg leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction DialogDescription({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Description>) {\n return (\n <DialogPrimitive.Description\n data-slot=\"dialog-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n}\n","import * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Label({\n className,\n ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n return (\n <LabelPrimitive.Root\n data-slot=\"label\"\n className={cn(\n \"flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Label }\n","import * as React from \"react\"\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Separator({\n className,\n orientation = \"horizontal\",\n decorative = true,\n ...props\n}: React.ComponentProps<typeof SeparatorPrimitive.Root>) {\n return (\n <SeparatorPrimitive.Root\n data-slot=\"separator\"\n decorative={decorative}\n orientation={orientation}\n className={cn(\n \"bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Separator }\n","import { useMemo } from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Label } from \"@/src/components/ui/label\"\nimport { Separator } from \"@/src/components/ui/separator\"\n\nfunction FieldSet({ className, ...props }: React.ComponentProps<\"fieldset\">) {\n return (\n <fieldset\n data-slot=\"field-set\"\n className={cn(\n \"flex flex-col gap-6\",\n \"has-[>[data-slot=checkbox-group]]:gap-3 has-[>[data-slot=radio-group]]:gap-3\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldLegend({\n className,\n variant = \"legend\",\n ...props\n}: React.ComponentProps<\"legend\"> & { variant?: \"legend\" | \"label\" }) {\n return (\n <legend\n data-slot=\"field-legend\"\n data-variant={variant}\n className={cn(\n \"mb-3 font-medium\",\n \"data-[variant=legend]:text-base\",\n \"data-[variant=label]:text-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-group\"\n className={cn(\n \"group/field-group @container/field-group flex w-full flex-col gap-7 data-[slot=checkbox-group]:gap-3 [&>[data-slot=field-group]]:gap-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nconst fieldVariants = cva(\n \"group/field flex w-full gap-3 data-[invalid=true]:text-destructive\",\n {\n variants: {\n orientation: {\n vertical: [\"flex-col [&>*]:w-full [&>.sr-only]:w-auto\"],\n horizontal: [\n \"flex-row items-center\",\n \"[&>[data-slot=field-label]]:flex-auto\",\n \"has-[>[data-slot=field-content]]:items-start has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px\",\n ],\n responsive: [\n \"flex-col [&>*]:w-full [&>.sr-only]:w-auto @md/field-group:flex-row @md/field-group:items-center @md/field-group:[&>*]:w-auto\",\n \"@md/field-group:[&>[data-slot=field-label]]:flex-auto\",\n \"@md/field-group:has-[>[data-slot=field-content]]:items-start @md/field-group:has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px\",\n ],\n },\n },\n defaultVariants: {\n orientation: \"vertical\",\n },\n }\n)\n\nfunction Field({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof fieldVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"field\"\n data-orientation={orientation}\n className={cn(fieldVariants({ orientation }), className)}\n {...props}\n />\n )\n}\n\nfunction FieldContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-content\"\n className={cn(\n \"group/field-content flex flex-1 flex-col gap-1.5 leading-snug\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldLabel({\n className,\n ...props\n}: React.ComponentProps<typeof Label>) {\n return (\n <Label\n data-slot=\"field-label\"\n className={cn(\n \"group/field-label peer/field-label flex w-fit gap-2 leading-snug group-data-[disabled=true]/field:opacity-50\",\n \"has-[>[data-slot=field]]:w-full has-[>[data-slot=field]]:flex-col has-[>[data-slot=field]]:rounded-md has-[>[data-slot=field]]:border [&>*]:data-[slot=field]:p-4\",\n \"has-data-[state=checked]:bg-primary/5 has-data-[state=checked]:border-primary dark:has-data-[state=checked]:bg-primary/10\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-label\"\n className={cn(\n \"flex w-fit items-center gap-2 text-sm leading-snug font-medium group-data-[disabled=true]/field:opacity-50\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldDescription({ className, ...props }: React.ComponentProps<\"p\">) {\n return (\n <p\n data-slot=\"field-description\"\n className={cn(\n \"text-muted-foreground text-sm leading-normal font-normal group-has-[[data-orientation=horizontal]]/field:text-balance\",\n \"last:mt-0 nth-last-2:-mt-1 [[data-variant=legend]+&]:-mt-1.5\",\n \"[&>a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldSeparator({\n children,\n className,\n ...props\n}: React.ComponentProps<\"div\"> & {\n children?: React.ReactNode\n}) {\n return (\n <div\n data-slot=\"field-separator\"\n data-content={!!children}\n className={cn(\n \"relative -my-2 h-5 text-sm group-data-[variant=outline]/field-group:-mb-2\",\n className\n )}\n {...props}\n >\n <Separator className=\"absolute inset-0 top-1/2\" />\n {children && (\n <span\n className=\"bg-background text-muted-foreground relative mx-auto block w-fit px-2\"\n data-slot=\"field-separator-content\"\n >\n {children}\n </span>\n )}\n </div>\n )\n}\n\nfunction FieldError({\n className,\n children,\n errors,\n ...props\n}: React.ComponentProps<\"div\"> & {\n errors?: Array<{ message?: string } | undefined>\n}) {\n const content = useMemo(() => {\n if (children) {\n return children\n }\n\n if (!errors?.length) {\n return null\n }\n\n const uniqueErrors = [\n ...new Map(errors.map((error) => [error?.message, error])).values(),\n ]\n\n if (uniqueErrors?.length == 1) {\n return uniqueErrors[0]?.message\n }\n\n return (\n <ul className=\"ml-4 flex list-disc flex-col gap-1\">\n {uniqueErrors.map(\n (error, index) =>\n error?.message && <li key={index}>{error.message}</li>\n )}\n </ul>\n )\n }, [children, errors])\n\n if (!content) {\n return null\n }\n\n return (\n <div\n role=\"alert\"\n data-slot=\"field-error\"\n className={cn(\"text-destructive text-sm font-normal\", className)}\n {...props}\n >\n {content}\n </div>\n )\n}\n\nexport {\n Field,\n FieldLabel,\n FieldDescription,\n FieldError,\n FieldGroup,\n FieldLegend,\n FieldSeparator,\n FieldSet,\n FieldContent,\n FieldTitle,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport {\n Controller,\n FormProvider,\n useFormContext,\n useFormState,\n type ControllerProps,\n type FieldPath,\n type FieldValues,\n} from \"react-hook-form\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Label } from \"@/src/components/ui/label\"\n\nconst Form = FormProvider\n\ntype FormFieldContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n> = {\n name: TName\n}\n\nconst FormFieldContext = React.createContext<FormFieldContextValue>(\n {} as FormFieldContextValue\n)\n\nconst FormField = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n>({\n ...props\n}: ControllerProps<TFieldValues, TName>) => {\n return (\n <FormFieldContext.Provider value={{ name: props.name }}>\n <Controller {...props} />\n </FormFieldContext.Provider>\n )\n}\n\nconst useFormField = () => {\n const fieldContext = React.useContext(FormFieldContext)\n const itemContext = React.useContext(FormItemContext)\n const { getFieldState } = useFormContext()\n const formState = useFormState({ name: fieldContext.name })\n const fieldState = getFieldState(fieldContext.name, formState)\n\n if (!fieldContext) {\n throw new Error(\"useFormField should be used within <FormField>\")\n }\n\n const { id } = itemContext\n\n return {\n id,\n name: fieldContext.name,\n formItemId: `${id}-form-item`,\n formDescriptionId: `${id}-form-item-description`,\n formMessageId: `${id}-form-item-message`,\n ...fieldState,\n }\n}\n\ntype FormItemContextValue = {\n id: string\n}\n\nconst FormItemContext = React.createContext<FormItemContextValue>(\n {} as FormItemContextValue\n)\n\nfunction FormItem({ className, ...props }: React.ComponentProps<\"div\">) {\n const id = React.useId()\n\n return (\n <FormItemContext.Provider value={{ id }}>\n <div\n data-slot=\"form-item\"\n className={cn(\"grid gap-2\", className)}\n {...props}\n />\n </FormItemContext.Provider>\n )\n}\n\nfunction FormLabel({\n className,\n ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n const { error, formItemId } = useFormField()\n\n return (\n <Label\n data-slot=\"form-label\"\n data-error={!!error}\n className={cn(\"data-[error=true]:text-destructive\", className)}\n htmlFor={formItemId}\n {...props}\n />\n )\n}\n\nfunction FormControl({ ...props }: React.ComponentProps<typeof Slot>) {\n const { error, formItemId, formDescriptionId, formMessageId } = useFormField()\n\n return (\n <Slot\n data-slot=\"form-control\"\n id={formItemId}\n aria-describedby={\n !error\n ? `${formDescriptionId}`\n : `${formDescriptionId} ${formMessageId}`\n }\n aria-invalid={!!error}\n {...props}\n />\n )\n}\n\nfunction FormDescription({ className, ...props }: React.ComponentProps<\"p\">) {\n const { formDescriptionId } = useFormField()\n\n return (\n <p\n data-slot=\"form-description\"\n id={formDescriptionId}\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction FormMessage({ className, ...props }: React.ComponentProps<\"p\">) {\n const { error, formMessageId } = useFormField()\n const body = error ? String(error?.message ?? \"\") : props.children\n\n if (!body) {\n return null\n }\n\n return (\n <p\n data-slot=\"form-message\"\n id={formMessageId}\n className={cn(\"text-destructive text-sm\", className)}\n {...props}\n >\n {body}\n </p>\n )\n}\n\nexport {\n useFormField,\n Form,\n FormItem,\n FormLabel,\n FormControl,\n FormDescription,\n FormMessage,\n FormField,\n}\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Input({ className, type, ...props }: React.ComponentProps<\"input\">) {\n return (\n <input\n type={type}\n data-slot=\"input\"\n className={cn(\n \"file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n \"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]\",\n \"aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Input }\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Textarea({ className, ...props }: React.ComponentProps<\"textarea\">) {\n return (\n <textarea\n data-slot=\"textarea\"\n className={cn(\n \"border-input placeholder:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 flex field-sizing-content min-h-16 w-full rounded-md border bg-transparent px-3 py-2 text-base shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Textarea }\n","import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { Input } from \"@/src/components/ui/input\"\nimport { Textarea } from \"@/src/components/ui/textarea\"\n\nfunction InputGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"input-group\"\n role=\"group\"\n className={cn(\n \"group/input-group border-input dark:bg-input/30 relative flex w-full items-center rounded-md border shadow-xs transition-[color,box-shadow] outline-none\",\n \"h-9 min-w-0 has-[>textarea]:h-auto\",\n\n // Variants based on alignment.\n \"has-[>[data-align=inline-start]]:[&>input]:pl-2\",\n \"has-[>[data-align=inline-end]]:[&>input]:pr-2\",\n \"has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3\",\n \"has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3\",\n\n // Focus state.\n \"has-[[data-slot=input-group-control]:focus-visible]:border-ring has-[[data-slot=input-group-control]:focus-visible]:ring-ring/50 has-[[data-slot=input-group-control]:focus-visible]:ring-[3px]\",\n\n // Error state.\n \"has-[[data-slot][aria-invalid=true]]:ring-destructive/20 has-[[data-slot][aria-invalid=true]]:border-destructive dark:has-[[data-slot][aria-invalid=true]]:ring-destructive/40\",\n\n className\n )}\n {...props}\n />\n )\n}\n\nconst inputGroupAddonVariants = cva(\n \"text-muted-foreground flex h-auto cursor-text items-center justify-center gap-2 py-1.5 text-sm font-medium select-none [&>svg:not([class*='size-'])]:size-4 [&>kbd]:rounded-[calc(var(--radius)-5px)] group-data-[disabled=true]/input-group:opacity-50\",\n {\n variants: {\n align: {\n \"inline-start\":\n \"order-first pl-3 has-[>button]:ml-[-0.45rem] has-[>kbd]:ml-[-0.35rem]\",\n \"inline-end\":\n \"order-last pr-3 has-[>button]:mr-[-0.45rem] has-[>kbd]:mr-[-0.35rem]\",\n \"block-start\":\n \"order-first w-full justify-start px-3 pt-3 [.border-b]:pb-3 group-has-[>input]/input-group:pt-2.5\",\n \"block-end\":\n \"order-last w-full justify-start px-3 pb-3 [.border-t]:pt-3 group-has-[>input]/input-group:pb-2.5\",\n },\n },\n defaultVariants: {\n align: \"inline-start\",\n },\n }\n)\n\nfunction InputGroupAddon({\n className,\n align = \"inline-start\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof inputGroupAddonVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"input-group-addon\"\n data-align={align}\n className={cn(inputGroupAddonVariants({ align }), className)}\n onClick={(e) => {\n if ((e.target as HTMLElement).closest(\"button\")) {\n return\n }\n e.currentTarget.parentElement?.querySelector(\"input\")?.focus()\n }}\n {...props}\n />\n )\n}\n\nconst inputGroupButtonVariants = cva(\n \"text-sm shadow-none flex gap-2 items-center\",\n {\n variants: {\n size: {\n xs: \"h-6 gap-1 px-2 rounded-[calc(var(--radius)-5px)] [&>svg:not([class*='size-'])]:size-3.5 has-[>svg]:px-2\",\n sm: \"h-8 px-2.5 gap-1.5 rounded-md has-[>svg]:px-2.5\",\n \"icon-xs\":\n \"size-6 rounded-[calc(var(--radius)-5px)] p-0 has-[>svg]:p-0\",\n \"icon-sm\": \"size-8 p-0 has-[>svg]:p-0\",\n },\n },\n defaultVariants: {\n size: \"xs\",\n },\n }\n)\n\nfunction InputGroupButton({\n className,\n type = \"button\",\n variant = \"ghost\",\n size = \"xs\",\n ...props\n}: Omit<React.ComponentProps<typeof Button>, \"size\"> &\n VariantProps<typeof inputGroupButtonVariants>) {\n return (\n <Button\n type={type}\n data-size={size}\n variant={variant}\n className={cn(inputGroupButtonVariants({ size }), className)}\n {...props}\n />\n )\n}\n\nfunction InputGroupText({ className, ...props }: React.ComponentProps<\"span\">) {\n return (\n <span\n className={cn(\n \"text-muted-foreground flex items-center gap-2 text-sm [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupInput({\n className,\n ...props\n}: React.ComponentProps<\"input\">) {\n return (\n <Input\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 rounded-none border-0 bg-transparent shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupTextarea({\n className,\n ...props\n}: React.ComponentProps<\"textarea\">) {\n return (\n <Textarea\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 resize-none rounded-none border-0 bg-transparent py-3 shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n InputGroup,\n InputGroupAddon,\n InputGroupButton,\n InputGroupText,\n InputGroupInput,\n InputGroupTextarea,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport { OTPInput, OTPInputContext } from \"input-otp\"\nimport { MinusIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction InputOTP({\n className,\n containerClassName,\n ...props\n}: React.ComponentProps<typeof OTPInput> & {\n containerClassName?: string\n}) {\n return (\n <OTPInput\n data-slot=\"input-otp\"\n containerClassName={cn(\n \"flex items-center gap-2 has-disabled:opacity-50\",\n containerClassName\n )}\n className={cn(\"disabled:cursor-not-allowed\", className)}\n {...props}\n />\n )\n}\n\nfunction InputOTPGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"input-otp-group\"\n className={cn(\"flex items-center\", className)}\n {...props}\n />\n )\n}\n\nfunction InputOTPSlot({\n index,\n className,\n ...props\n}: React.ComponentProps<\"div\"> & {\n index: number\n}) {\n const inputOTPContext = React.useContext(OTPInputContext)\n const { char, hasFakeCaret, isActive } = inputOTPContext?.slots[index] ?? {}\n\n return (\n <div\n data-slot=\"input-otp-slot\"\n data-active={isActive}\n className={cn(\n \"data-[active=true]:border-ring data-[active=true]:ring-ring/50 data-[active=true]:aria-invalid:ring-destructive/20 dark:data-[active=true]:aria-invalid:ring-destructive/40 aria-invalid:border-destructive data-[active=true]:aria-invalid:border-destructive dark:bg-input/30 border-input relative flex h-9 w-9 items-center justify-center border-y border-r text-sm shadow-xs transition-all outline-none first:rounded-l-md first:border-l last:rounded-r-md data-[active=true]:z-10 data-[active=true]:ring-[3px]\",\n className\n )}\n {...props}\n >\n {char}\n {hasFakeCaret && (\n <div className=\"pointer-events-none absolute inset-0 flex items-center justify-center\">\n <div className=\"animate-caret-blink bg-foreground h-4 w-px duration-1000\" />\n </div>\n )}\n </div>\n )\n}\n\nfunction InputOTPSeparator({ ...props }: React.ComponentProps<\"div\">) {\n return (\n <div data-slot=\"input-otp-separator\" role=\"separator\" {...props}>\n <MinusIcon />\n </div>\n )\n}\n\nexport { InputOTP, InputOTPGroup, InputOTPSlot, InputOTPSeparator }\n","import * as React from \"react\"\nimport * as RadioGroupPrimitive from \"@radix-ui/react-radio-group\"\nimport { CircleIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction RadioGroup({\n className,\n ...props\n}: React.ComponentProps<typeof RadioGroupPrimitive.Root>) {\n return (\n <RadioGroupPrimitive.Root\n data-slot=\"radio-group\"\n className={cn(\"grid gap-3\", className)}\n {...props}\n />\n )\n}\n\nfunction RadioGroupItem({\n className,\n ...props\n}: React.ComponentProps<typeof RadioGroupPrimitive.Item>) {\n return (\n <RadioGroupPrimitive.Item\n data-slot=\"radio-group-item\"\n className={cn(\n \"border-input text-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 aspect-square size-4 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <RadioGroupPrimitive.Indicator\n data-slot=\"radio-group-indicator\"\n className=\"relative flex items-center justify-center\"\n >\n <CircleIcon className=\"fill-primary absolute top-1/2 left-1/2 size-2 -translate-x-1/2 -translate-y-1/2\" />\n </RadioGroupPrimitive.Indicator>\n </RadioGroupPrimitive.Item>\n )\n}\n\nexport { RadioGroup, RadioGroupItem }\n","\"use client\"\n\nimport * as React from \"react\"\nimport { GripVerticalIcon } from \"lucide-react\"\nimport * as ResizablePrimitive from \"react-resizable-panels\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction ResizablePanelGroup({\n className,\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) {\n return (\n <ResizablePrimitive.PanelGroup\n data-slot=\"resizable-panel-group\"\n className={cn(\n \"flex h-full w-full data-[panel-group-direction=vertical]:flex-col\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ResizablePanel({\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.Panel>) {\n return <ResizablePrimitive.Panel data-slot=\"resizable-panel\" {...props} />\n}\n\nfunction ResizableHandle({\n withHandle,\n className,\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelResizeHandle> & {\n withHandle?: boolean\n}) {\n return (\n <ResizablePrimitive.PanelResizeHandle\n data-slot=\"resizable-handle\"\n className={cn(\n \"bg-border focus-visible:ring-ring relative flex w-px items-center justify-center after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:ring-1 focus-visible:ring-offset-1 focus-visible:outline-hidden data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:translate-x-0 data-[panel-group-direction=vertical]:after:-translate-y-1/2 [&[data-panel-group-direction=vertical]>div]:rotate-90\",\n className\n )}\n {...props}\n >\n {withHandle && (\n <div className=\"bg-border z-10 flex h-4 w-3 items-center justify-center rounded-xs border\">\n <GripVerticalIcon className=\"size-2.5\" />\n </div>\n )}\n </ResizablePrimitive.PanelResizeHandle>\n )\n}\n\nexport { ResizablePanelGroup, ResizablePanel, ResizableHandle }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction ScrollArea({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.Root>) {\n return (\n <ScrollAreaPrimitive.Root\n data-slot=\"scroll-area\"\n className={cn(\"relative\", className)}\n {...props}\n >\n <ScrollAreaPrimitive.Viewport\n data-slot=\"scroll-area-viewport\"\n className=\"focus-visible:ring-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:outline-1\"\n >\n {children}\n </ScrollAreaPrimitive.Viewport>\n <ScrollBar />\n <ScrollAreaPrimitive.Corner />\n </ScrollAreaPrimitive.Root>\n )\n}\n\nfunction ScrollBar({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>) {\n return (\n <ScrollAreaPrimitive.ScrollAreaScrollbar\n data-slot=\"scroll-area-scrollbar\"\n orientation={orientation}\n className={cn(\n \"flex touch-none p-px transition-colors select-none\",\n orientation === \"vertical\" &&\n \"h-full w-2.5 border-l border-l-transparent\",\n orientation === \"horizontal\" &&\n \"h-2.5 flex-col border-t border-t-transparent\",\n className\n )}\n {...props}\n >\n <ScrollAreaPrimitive.ScrollAreaThumb\n data-slot=\"scroll-area-thumb\"\n className=\"bg-border relative flex-1 rounded-full\"\n />\n </ScrollAreaPrimitive.ScrollAreaScrollbar>\n )\n}\n\nexport { ScrollArea, ScrollBar }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as SelectPrimitive from \"@radix-ui/react-select\"\nimport { CheckIcon, ChevronDownIcon, ChevronUpIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Select({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Root>) {\n return <SelectPrimitive.Root data-slot=\"select\" {...props} />\n}\n\nfunction SelectGroup({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Group>) {\n return <SelectPrimitive.Group data-slot=\"select-group\" {...props} />\n}\n\nfunction SelectValue({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Value>) {\n return <SelectPrimitive.Value data-slot=\"select-value\" {...props} />\n}\n\nfunction SelectTrigger({\n className,\n size = \"default\",\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Trigger> & {\n size?: \"sm\" | \"default\"\n}) {\n return (\n <SelectPrimitive.Trigger\n data-slot=\"select-trigger\"\n data-size={size}\n className={cn(\n \"border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDownIcon className=\"size-4 opacity-50\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n )\n}\n\nfunction SelectContent({\n className,\n children,\n position = \"popper\",\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Content>) {\n return (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n data-slot=\"select-content\"\n className={cn(\n \"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md\",\n position === \"popper\" &&\n \"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\",\n className\n )}\n position={position}\n {...props}\n >\n <SelectScrollUpButton />\n <SelectPrimitive.Viewport\n className={cn(\n \"p-1\",\n position === \"popper\" &&\n \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectScrollDownButton />\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n )\n}\n\nfunction SelectLabel({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Label>) {\n return (\n <SelectPrimitive.Label\n data-slot=\"select-label\"\n className={cn(\"text-muted-foreground px-2 py-1.5 text-xs\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectItem({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Item>) {\n return (\n <SelectPrimitive.Item\n data-slot=\"select-item\"\n className={cn(\n \"focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2\",\n className\n )}\n {...props}\n >\n <span className=\"absolute right-2 flex size-3.5 items-center justify-center\">\n <SelectPrimitive.ItemIndicator>\n <CheckIcon className=\"size-4\" />\n </SelectPrimitive.ItemIndicator>\n </span>\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n </SelectPrimitive.Item>\n )\n}\n\nfunction SelectSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Separator>) {\n return (\n <SelectPrimitive.Separator\n data-slot=\"select-separator\"\n className={cn(\"bg-border pointer-events-none -mx-1 my-1 h-px\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectScrollUpButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollUpButton>) {\n return (\n <SelectPrimitive.ScrollUpButton\n data-slot=\"select-scroll-up-button\"\n className={cn(\n \"flex cursor-default items-center justify-center py-1\",\n className\n )}\n {...props}\n >\n <ChevronUpIcon className=\"size-4\" />\n </SelectPrimitive.ScrollUpButton>\n )\n}\n\nfunction SelectScrollDownButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollDownButton>) {\n return (\n <SelectPrimitive.ScrollDownButton\n data-slot=\"select-scroll-down-button\"\n className={cn(\n \"flex cursor-default items-center justify-center py-1\",\n className\n )}\n {...props}\n >\n <ChevronDownIcon className=\"size-4\" />\n </SelectPrimitive.ScrollDownButton>\n )\n}\n\nexport {\n Select,\n SelectContent,\n SelectGroup,\n SelectItem,\n SelectLabel,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n}\n","\"use client\"\n\nimport { useTheme } from \"next-themes\"\nimport { Toaster as Sonner, ToasterProps } from \"sonner\"\n\nconst Toaster = ({ ...props }: ToasterProps) => {\n const { theme = \"system\" } = useTheme()\n\n return (\n <Sonner\n theme={theme as ToasterProps[\"theme\"]}\n className=\"toaster group\"\n style={\n {\n \"--normal-bg\": \"var(--popover)\",\n \"--normal-text\": \"var(--popover-foreground)\",\n \"--normal-border\": \"var(--border)\",\n } as React.CSSProperties\n }\n {...props}\n />\n )\n}\n\nexport { Toaster }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as SwitchPrimitive from \"@radix-ui/react-switch\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Switch({\n className,\n ...props\n}: React.ComponentProps<typeof SwitchPrimitive.Root>) {\n return (\n <SwitchPrimitive.Root\n data-slot=\"switch\"\n className={cn(\n \"peer data-[state=checked]:bg-primary data-[state=unchecked]:bg-input focus-visible:border-ring focus-visible:ring-ring/50 dark:data-[state=unchecked]:bg-input/80 inline-flex h-[1.15rem] w-8 shrink-0 items-center rounded-full border border-transparent shadow-xs transition-all outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <SwitchPrimitive.Thumb\n data-slot=\"switch-thumb\"\n className={cn(\n \"bg-background dark:data-[state=unchecked]:bg-foreground dark:data-[state=checked]:bg-primary-foreground pointer-events-none block size-4 rounded-full ring-0 transition-transform data-[state=checked]:translate-x-[calc(100%-2px)] data-[state=unchecked]:translate-x-0\"\n )}\n />\n </SwitchPrimitive.Root>\n )\n}\n\nexport { Switch }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction TooltipProvider({\n delayDuration = 0,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Provider>) {\n return (\n <TooltipPrimitive.Provider\n data-slot=\"tooltip-provider\"\n delayDuration={delayDuration}\n {...props}\n />\n )\n}\n\nfunction Tooltip({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Root>) {\n return (\n <TooltipProvider>\n <TooltipPrimitive.Root data-slot=\"tooltip\" {...props} />\n </TooltipProvider>\n )\n}\n\nfunction TooltipTrigger({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {\n return <TooltipPrimitive.Trigger data-slot=\"tooltip-trigger\" {...props} />\n}\n\nfunction TooltipContent({\n className,\n sideOffset = 0,\n children,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Content>) {\n return (\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n data-slot=\"tooltip-content\"\n sideOffset={sideOffset}\n className={cn(\n \"bg-foreground text-background animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance\",\n className\n )}\n {...props}\n >\n {children}\n <TooltipPrimitive.Arrow className=\"bg-foreground fill-foreground z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]\" />\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n )\n}\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }\n","\"use client\"\n\nimport { JSX, useState } from \"react\"\nimport { Switch, Label, Card } from \"@/src/components/ui\"\nimport { BaseInput, handleOnChage } from \"../base\"\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { cn } from \"@/src/lib/utils\";\n\n\n// interface Props {\n// options: InputOption[]\n// onChange?: (optionsUpdated: InputOption[]) => void\n// }\n\n// export const GroupedSwitches = ({ options, onChange, }: Props) => {\nexport class GroupedSwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, isSubmitting } = this;\n return (\n <GroupedSwitches options={[]} input={input} isSubmitting={isSubmitting} />\n )\n }\n}\n\ninterface Props {\n input: FieldProps;\n options?: InputOption[];\n isSubmitting?: boolean;\n onChange?: (optionsUpdated: InputOption[]) => void\n}\n\nexport const GroupedSwitches = ({ options, onChange, input, isSubmitting}: Props) => {\n\n const mockInputOptions:InputOption[] = [\n { id: 1, name: 'MOCK OPTION - CREATE', checked: false },\n { id: 2, name: 'MOCK OPTION - READ', checked: true },\n { id: 3, name: 'MOCK OPTION - UPDATE', checked: false },\n { id: 4, name: 'MOCK OPTION - DELETE ', checked: false },\n ]\n \n const initialSwitches: InputOption[] = options ? (options.length > 0 ? options : ((input.listConfig?.list as InputOption[]) ?? []) ) : mockInputOptions \n const [switches, setSwitches] = useState<InputOption[]>(initialSwitches)\n const [allChecked, setAllChecked] = useState<boolean>(initialSwitches.every((opt) => opt.checked))\n \n const [bgColor, setBgColor] = useState<string>('bg-green-500/5 border-green-400/10')\n\n const handleMainToggle = (checked: boolean) => {\n const updated = switches.map((opt) => ({ ...opt, checked }));\n setSwitches(updated);\n setAllChecked(checked);\n onChange?.(updated.filter((opt) => opt.checked));\n }\n\n const handleChildToggle = (option: InputOption, checked: boolean, input: FieldProps) => {\n const updated = switches.map((opt) =>\n opt.id === option.id ? { ...opt, checked } : opt\n );\n setSwitches(updated);\n setAllChecked(updated.every((opt) => opt.checked));\n onChange?.(updated.filter((opt) => opt.checked));\n handleOnChage(updated.filter((opt) => opt.checked),input)\n }\n\n return (\n <Card >\n <div className={cn(`w-full h-full space-y-4 p-4 border-2 rounded-xl bg-green-500 ${allChecked ? 'bg-green-500/5 border-green-400/10' : 'bg-black/5'}`)}>\n {/* Switch principal */}\n <div className=\"flex items-center justify-between border-b p-2\">\n <div>{input.name}</div>\n <div className=\"flex flex-row gap-2\">\n <Label htmlFor=\"main\">Seleccionar todo</Label>\n <Switch id=\"main\" checked={allChecked} onCheckedChange={handleMainToggle} />\n </div>\n </div>\n\n {/* Switches hijos */}\n {switches.map((opt, index) => (\n <div key={opt.id} className={`p-2 rounded-lg flex flex-row w-full items-center justify-between ${!(index % 2 )? 'bg-black/5' : 'bg-white/5'}`}>\n <Label htmlFor={String(opt.id)}>{opt.label || opt.name}</Label>\n <Switch\n disabled={input.disabled || isSubmitting}\n id={String(opt.id)}\n checked={opt?.checked || false}\n onCheckedChange={checked => handleChildToggle(opt, checked, input) }\n />\n </div>\n ))}\n </div>\n </Card>\n )\n}\n\n","'use client'\n\n\nimport { UseFormReturn } from 'react-hook-form'\nimport { JSX, useEffect, useState } from 'react'\nimport { BaseInput, FieldProps, GroupedOption, handleOnChage, InputOption } from '../base'\nimport { GroupedSwitches } from './grouped-switches-input'\nimport { \n Accordion,\n AccordionContent,\n AccordionItem,\n AccordionTrigger,\n Badge,\n Card,\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormMessage \n} from '@/src/components/ui'\n\n/* ========= INPUT PRINCIPAL ========= */\n\nexport class AccordionGroupedSwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this\n return (\n <AccordionGroupedSwitches\n form={form}\n input={input}\n isSubmitting={isSubmitting}\n groups={(input?.listConfig?.list as GroupedOption[]) ?? []}\n onChange={input?.listConfig?.onOptionChange ?? (() => {})}\n />\n )\n }\n}\n\n/* ========= COMPONENTE ========= */\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n groups?: GroupedOption[];\n isSubmitting?: boolean;\n onChange?: (optionsUpdated: InputOption[]) => void\n}\n\nexport const AccordionGroupedSwitches = ({ form, input, groups = [], onChange, isSubmitting }: Props) => {\n const [groupsState, setGroupsState] = useState<GroupedOption[]>([])\n const [selectedOptions, setSelectedOptions] = useState<InputOption[]>([])\n\n // 🔹 Cargar los grupos y sincronizar seleccionados\n useEffect(() => {\n const selected = input.listConfig?.selectedList ?? []\n const updatedGroups = groups.map((group) => ({\n ...group,\n options: group.options.map((opt) => ({\n ...opt,\n checked: selected.some((sel) => sel.id === opt.id),\n groupedLabel: group.label,\n })),\n }))\n setGroupsState(updatedGroups)\n setSelectedOptions(selected)\n }, [groups, input])\n\n // 🔹 Calcular cuántos están seleccionados por grupo\n const countCheckedByGroup = (group: GroupedOption): number => {\n return group.options.filter((opt) => opt.checked).length\n }\n\n // 🔹 Manejar cambio en switches individuales\n const handleOptionChange = (field: any, updatedGroupLabel: string, updatedOptions: InputOption[], input: FieldProps) => {\n const newGroups = groupsState.map((group) =>\n group.label === updatedGroupLabel ? { ...group, options: updatedOptions } : group\n )\n\n setGroupsState(newGroups)\n\n const allChecked = newGroups.flatMap((g) => g.options).filter((o) => o.checked)\n setSelectedOptions(allChecked)\n field.onChange(allChecked)\n onChange?.(allChecked)\n handleOnChage(allChecked, input, field)\n }\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className=\"shadow-lg\">\n <FormControl>\n <Card className=\"p-4 space-y-4\">\n <h2 className=\"text-2xl font-bold\">{input.label}</h2>\n <Accordion type=\"multiple\">\n {groupsState.map((group, indx) => (\n <AccordionItem\n key={indx}\n value={group.label}\n className={`px-1 ${indx % 2 ? `bg-black/10` : 'bg-black/5'}`}\n >\n <AccordionTrigger>\n <div className=\"grid grid-cols-2 w-full\">\n {group.label}{' '}\n <Badge>\n {countCheckedByGroup(group)} / {group.options.length}\n </Badge>\n </div>\n </AccordionTrigger>\n <AccordionContent>\n <GroupedSwitches\n isSubmitting={isSubmitting}\n input={input}\n options={group.options}\n onChange={(updated: InputOption[]) =>\n handleOptionChange(field, group.label, updated, input)\n }\n />\n </AccordionContent>\n </AccordionItem>\n ))}\n </Accordion>\n </Card>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n\n {/* Debug visual opcional */}\n {/* <pre className=\"text-xs font-bold mt-2 bg-black/5 p-2 rounded-lg\">\n <code>{JSON.stringify(selectedOptions, null, 2)}</code>\n </pre> */}\n </FormItem>\n )}\n />\n )\n}\n","import { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Separator } from \"@/src/components/ui/separator\"\n\nconst buttonGroupVariants = cva(\n \"flex w-fit items-stretch [&>*]:focus-visible:z-10 [&>*]:focus-visible:relative [&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1 has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-md has-[>[data-slot=button-group]]:gap-2\",\n {\n variants: {\n orientation: {\n horizontal:\n \"[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none\",\n vertical:\n \"flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none\",\n },\n },\n defaultVariants: {\n orientation: \"horizontal\",\n },\n }\n)\n\nfunction ButtonGroup({\n className,\n orientation,\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof buttonGroupVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"button-group\"\n data-orientation={orientation}\n className={cn(buttonGroupVariants({ orientation }), className)}\n {...props}\n />\n )\n}\n\nfunction ButtonGroupText({\n className,\n asChild = false,\n ...props\n}: React.ComponentProps<\"div\"> & {\n asChild?: boolean\n}) {\n const Comp = asChild ? Slot : \"div\"\n\n return (\n <Comp\n className={cn(\n \"bg-muted flex items-center gap-2 rounded-md border px-4 text-sm font-medium shadow-xs [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ButtonGroupSeparator({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<typeof Separator>) {\n return (\n <Separator\n data-slot=\"button-group-separator\"\n orientation={orientation}\n className={cn(\n \"bg-input relative !m-0 self-stretch data-[orientation=vertical]:h-auto\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n ButtonGroup,\n ButtonGroupSeparator,\n ButtonGroupText,\n buttonGroupVariants,\n}\n","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput, FieldProps, handleOnChage, InputOption } from \"../base\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { ButtonGroup } from \"@/src/components/ui/button-group\";\n\ninterface Option {\n label: string;\n value: string | number;\n}\n\nexport class ButtonGroupInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n const className = input.className\n return <FieldButtonGroup input={input} form={form} isSubmitting={isSubmitting} className={className}/>;\n }\n}\n\ninterface Props {\n input: FieldProps;\n form: UseFormReturn;\n isSubmitting?: boolean;\n className?: string;\n}\n\nexport const FieldButtonGroup = ({ input, form, isSubmitting, className = \"w-full flex-1\" }: Props) => {\n const options: InputOption[] = (input.listConfig?.list ?? []).filter((option): option is InputOption => 'name' in option);\n\n const handleSelect = (value: any) => {\n form.setValue(input.name, value, { shouldValidate: true });\n if (input.listConfig?.onOptionChange) input.listConfig.onOptionChange(value);\n };\n\n\n\n const selectedValue = form.watch(input.name);\n\n return (\n <ButtonGroup className=\"flex flex-row w-full\">\n {options.map((option, key) => (\n <Button\n type=\"button\"\n className={className}\n key={`${input.name}-${key}-btn-g`}\n variant={selectedValue === option.value ? \"default\" : \"outline\"}\n onClick={() => {\n handleSelect(option.value)\n handleOnChage(option.value, input)\n }}\n disabled={isSubmitting}\n >\n {option.label ?? option.name }\n </Button>\n ))}\n </ButtonGroup>\n );\n};\n","'use client'\nimport { JSX } from 'react';\nimport { BaseInput, handleOnChage } from '../base'\nimport { Card, CardContent, CardHeader, CardTitle, Checkbox, Label } from '@/src/components/ui';\n\n\n\n// interface Props {\n// title?: string,\n// input: FieldProps,\n// onCheckedChange: (value : InputOption) => void\n// }\n\nexport class CheckListInput extends BaseInput {\n render(): JSX.Element {\n const { input, isSubmitting } = this;\n const listConfig = input?.listConfig\n // export const InputCheckList = ({input, onCheckedChange, title}:Props) => {\n let lista = listConfig?.list ?? []\n if (lista == undefined) lista = []\n const title = 'title' //listConfig?.title\n\n const value: string[] = input.value\n const label = (listConfig?.optionLabel ?? \"name\") as string;\n const optionValue = (listConfig?.optionValue ?? \"id\") as string;\n const description = (listConfig?.optionDescription ?? \"description\") as string;\n return (\n <Card key={title}>\n <CardHeader className=\"pb-3\">\n <CardTitle className=\"text-base\">{title ?? input.label}</CardTitle>\n </CardHeader>\n <CardContent className=\"space-y-3\">\n {lista.map((item) => ( \n <div key={item[optionValue as keyof typeof item] as React.Key} className=\"flex items-center space-x-2\">\n <Checkbox\n onChange={(e) => handleOnChage(e, input)}\n disabled={input.disabled || isSubmitting}\n id={String(item[optionValue as keyof typeof item])}\n checked={value.includes(item[optionValue as keyof typeof item] as string)}\n onCheckedChange={() => {/* onCheckedChange(item[optionValue as keyof typeof item]) */}}\n />\n <div className=\"grid gap-1.5 leading-none\">\n <Label\n htmlFor={String(item[optionValue as keyof typeof item])}\n className=\"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\"\n >\n {item[label as keyof typeof item]}\n </Label>\n <p className=\"text-xs text-muted-foreground\">{item[description as keyof typeof item]}</p>\n </div>\n </div>\n )\n )}\n </CardContent>\n </Card>\n )\n }\n}\n","'use client'\n\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { JSX } from \"react\";\nimport { Checkbox } from \"@/src/components/ui/checkbox\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n} from \"@/src/components/ui/form\";\nimport { UseFormReturn } from \"react-hook-form\";\n\nexport class CheckboxInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n\n return (\n <FieldCheckbox form={form} input={input} isSubmitting={isSubmitting} />\n );\n }\n}\n\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldCheckbox = ({ input, form, isSubmitting }: Props) => {\n const className = input.className;\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem\n className={`hover:bg-accent/50 flex items-start gap-3 rounded-lg border p-3 transition \n has-[[aria-checked=true]]:border-blue-600 \n has-[[aria-checked=true]]:bg-blue-50 \n dark:has-[[aria-checked=true]]:border-blue-900 \n dark:has-[[aria-checked=true]]:bg-blue-950\n ${className ?? \"\"}`}\n >\n <FormControl>\n <Checkbox\n id={input.name}\n checked={field.value}\n onCheckedChange={(e) => handleOnChage(e, input, field)}\n disabled={input.disabled || isSubmitting}\n className=\"data-[state=checked]:border-blue-600 data-[state=checked]:bg-blue-600 data-[state=checked]:text-white \n dark:data-[state=checked]:border-blue-700 dark:data-[state=checked]:bg-blue-700\"\n />\n </FormControl>\n\n <div className=\"grid gap-1.5 font-normal\">\n <FormLabel htmlFor={input.name} className=\"text-sm leading-none font-medium\">\n {input.label ?? \"Enable notifications\"}\n </FormLabel>\n {(input.description || input.placeHolder) && (\n <FormDescription className=\"text-muted-foreground text-sm\">\n {input.description ?? input.placeHolder}\n </FormDescription>\n )}\n <FormMessage />\n </div>\n </FormItem>\n )}\n />\n )\n}","\"use client\"\nimport React, { JSX, useEffect, useState } from \"react\"\nimport { ColorPicker, useColor } from 'react-color-palette';\nimport { UseFormReturn } from \"react-hook-form\"\nimport \"react-color-palette/css\"\nimport { cn } from \"@/src/lib/utils\"\nimport { \n Button,\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Popover, \n PopoverContent, \n PopoverTrigger,\n} from \"@/src/components/ui\"\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\"\n// ...existing code...\n\nexport class ColorInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldColor input={input} form={form} isSubmitting={isSubmitting} />\n )\n }\n}\n\ntype HideInputOption = \"rgb\" | \"hsv\" | \"hex\";\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst PRESET_COLORS = [\n \"#ef4444\", // red\n \"#f97316\", // orange\n \"#eab308\", // yellow\n \"#22c55e\", // green\n \"#06b6d4\", // cyan\n \"#3b82f6\", // blue\n \"#8b5cf6\", // purple\n \"#ec4899\", // pink\n \"#64748b\", // slate\n \"#000000\", // black\n]\n\n\nconst FieldColor = ({ form, input, isSubmitting }: Props) => {\n const [ColorCmp, _setColorCmp] = useState<any>(ColorComp)\n\n \n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n {ColorCmp ? (\n <ColorCmp\n value={field.value || \"#000000\"}\n onChange={(event: any[])=> {\n handleOnChage(event, input, field)\n }}\n onBlur={field.onBlur}\n disabled={input.disabled || isSubmitting}\n placeholder={input.placeHolder}\n />\n ) : (\n 'N/A'\n // <input\n // type=\"color\"\n // value={field.value || \"#000000\"}\n // onChange={(e) => {\n // field.onChange(e.target.value);\n // input.onChange?.(e)\n // }}\n // onBlur={() => field.onBlur()}\n // disabled={input.disabled || isSubmitting}\n // placeholder={input.placeHolder}\n // style={{ width: 48, height: 28 }}\n // />\n )}\n </FormControl>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )}\n />\n )\n}\n// ...existing code...\n\n\nexport interface ColorCompProps {\n value?: string;\n onChange?: (color: string) => void;\n onBlur?: () => void;\n disabled?: boolean;\n className?: string;\n placeholder?: string;\n hideInput?: HideInputOption[];\n}\n\nconst ColorComp = React.forwardRef<HTMLButtonElement, ColorCompProps>(\n ({ value = \"#000000\", onChange, onBlur, disabled, className, hideInput =[\"hsv\"] }, ref) => {\n // const [color, setColor] = useColor(value)\n // const [open, setOpen] = React.useState(false)\n\n // React.useEffect(() => {\n // if (value !== color.hex) {\n // setColor({ ...color, hex: value })\n // }\n // }, [color, setColor, value])\n\n // const handleColorChange = (newColor: IColor) => {\n // setColor(newColor)\n // onChange?.(newColor.hex)\n // }\n\n // const handleOpenChange = (newOpen: boolean) => {\n // setOpen(newOpen)\n // if (!newOpen) {\n // onBlur?.()\n // }\n // }\n\n const [color, setColor] = useColor(value)\n const [open, setOpen] = useState(false)\n\n React.useEffect(() => {\n if (value !== color.hex) {\n setColor({ ...color, hex: value })\n }\n }, [value])\n\n const handleColorChange = (newColor: string) => {\n setColor({ ...color, hex: newColor })\n onChange?.(newColor)\n }\n\n const handlePickerChange = (newColor: any) => {\n setColor(newColor)\n onChange?.(newColor.hex)\n }\n\n const handleOpenChange = (newOpen: boolean) => {\n setOpen(newOpen)\n if (!newOpen) {\n onBlur?.()\n }\n }\n\n return (\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex flex-wrap gap-2 p-2\">\n {PRESET_COLORS.map((presetColor) => (\n <button\n key={presetColor}\n type=\"button\"\n disabled={disabled}\n className={cn(\n \"size-6 rounded-md border-2 transition-all hover:scale-110 disabled:opacity-50 disabled:cursor-not-allowed\",\n color.hex === presetColor\n ? \"border-foreground ring-2 ring-foreground/20\"\n : \"border-border hover:border-foreground/50\",\n )}\n style={{ backgroundColor: presetColor }}\n onClick={() => handleColorChange(presetColor)}\n aria-label={`Select color ${presetColor}`}\n />\n ))}\n </div>\n \n <Popover open={open} onOpenChange={handleOpenChange}>\n <PopoverTrigger asChild>\n <Button\n ref={ref}\n variant=\"outline\"\n disabled={disabled}\n className={cn(\"w-full justify-start text-left font-normal\", !value && \"text-muted-foreground\", className)}\n >\n <div className=\"flex items-center gap-2\">\n <div className=\"h-4 w-4 border border-border rounded-sm\" style={{ backgroundColor: color.hex, width: 20, height:20 }} />\n <span>{color.hex}</span>\n </div>\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-3\" align=\"start\">\n <ColorPicker color={color} onChange={handlePickerChange} hideInput={hideInput} />\n </PopoverContent>\n </Popover>\n </div>\n )\n },\n)","\"use client\"\n\nimport * as React from \"react\"\nimport { Command as CommandPrimitive } from \"cmdk\"\nimport { SearchIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n} from \"@/src/components/ui/dialog\"\n\nfunction Command({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive>) {\n return (\n <CommandPrimitive\n data-slot=\"command\"\n className={cn(\n \"bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandDialog({\n title = \"Command Palette\",\n description = \"Search for a command to run...\",\n children,\n className,\n showCloseButton = true,\n ...props\n}: React.ComponentProps<typeof Dialog> & {\n title?: string\n description?: string\n className?: string\n showCloseButton?: boolean\n}) {\n return (\n <Dialog {...props}>\n <DialogHeader className=\"sr-only\">\n <DialogTitle>{title}</DialogTitle>\n <DialogDescription>{description}</DialogDescription>\n </DialogHeader>\n <DialogContent\n className={cn(\"overflow-hidden p-0\", className)}\n showCloseButton={showCloseButton}\n >\n <Command className=\"[&_[cmdk-group-heading]]:text-muted-foreground **:data-[slot=command-input-wrapper]:h-12 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group]]:px-2 [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n )\n}\n\nfunction CommandInput({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Input>) {\n return (\n <div\n data-slot=\"command-input-wrapper\"\n className=\"flex h-9 items-center gap-2 border-b px-3\"\n >\n <SearchIcon className=\"size-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n data-slot=\"command-input\"\n className={cn(\n \"placeholder:text-muted-foreground flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n />\n </div>\n )\n}\n\nfunction CommandList({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.List>) {\n return (\n <CommandPrimitive.List\n data-slot=\"command-list\"\n className={cn(\n \"max-h-[300px] scroll-py-1 overflow-x-hidden overflow-y-auto\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandEmpty({\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Empty>) {\n return (\n <CommandPrimitive.Empty\n data-slot=\"command-empty\"\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n )\n}\n\nfunction CommandGroup({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Group>) {\n return (\n <CommandPrimitive.Group\n data-slot=\"command-group\"\n className={cn(\n \"text-foreground [&_[cmdk-group-heading]]:text-muted-foreground overflow-hidden p-1 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Separator>) {\n return (\n <CommandPrimitive.Separator\n data-slot=\"command-separator\"\n className={cn(\"bg-border -mx-1 h-px\", className)}\n {...props}\n />\n )\n}\n\nfunction CommandItem({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Item>) {\n return (\n <CommandPrimitive.Item\n data-slot=\"command-item\"\n className={cn(\n \"data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandShortcut({\n className,\n ...props\n}: React.ComponentProps<\"span\">) {\n return (\n <span\n data-slot=\"command-shortcut\"\n className={cn(\n \"text-muted-foreground ml-auto text-xs tracking-widest\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Check, ChevronsUpDown } from \"lucide-react\";\nimport { cn } from \"@/src/lib/utils\";\nimport { Button } from \"@/src/components/ui/button\";\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"@/src/components/ui/command\";\nimport {\n Popover,\n PopoverContent,\n PopoverTrigger,\n} from \"@/src/components/ui/popover\";\n\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\n\nexport class ComboboxInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldCombobox input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldCombobox = ({ form, input, isSubmitting }: Props) => {\n const [open, setOpen] = React.useState(false);\n const [options, setOptions] = React.useState<InputOption[]>(\n () =>\n input.listConfig?.list?.length\n ? (input.listConfig.list as InputOption[])\n : []\n );\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n const [value, setValue] = React.useState<string>(input.value?.toString() ?? \"\");\n\n // 🔁 Si depende de otro campo\n React.useEffect(() => {\n const dependsOn = input.dependsOn;\n if (!dependsOn || !input.loadOptions) return;\n\n const subscription = form.watch(async (values) => {\n const parentValue = values[dependsOn];\n if (parentValue) {\n const loader = input.loadOptions!;\n const newOptions = await loader(parentValue);\n setOptions(newOptions as InputOption[]);\n form.setValue(input.name, \"\");\n setValue(\"\");\n } else {\n setOptions([]);\n }\n });\n\n return () => subscription.unsubscribe?.();\n }, [form, input.loadOptions, input.dependsOn]);\n\n // Sincronizar valor inicial\n React.useEffect(() => {\n const currentValue = form.getValues(input.name);\n if (!currentValue && input.value) {\n form.setValue(input.name, input.value);\n setValue(input.value.toString());\n }\n }, [form, input.name, input.value]);\n\n const getValue = (item: InputOption): string =>\n (optionValue === \"name\"\n ? item.name\n : item.value?.toString() ?? item.id?.toString()) ?? \"\";\n\n const selectedOption = options.find((o) => getValue(o) === value);\n\n return (\n <div className=\"flex flex-col gap-2\">\n {input.label && (\n <label className=\"font-medium text-sm\">{input.label}</label>\n )}\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n <Button\n disabled={input.disabled || isSubmitting}\n variant=\"outline\"\n role=\"combobox\"\n aria-expanded={open}\n className=\"w-[60%] justify-between bg-black/10 dark:bg-white/25\"\n >\n {selectedOption ? selectedOption.name : input.placeHolder ?? \"Seleccionar...\"}\n <ChevronsUpDown className=\"opacity-50\" />\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-[60%] p-0\">\n <Command\n filter={(value, search) => {\n const option = options.find((o) => getValue(o) === value);\n return option?.name?.toLowerCase().includes(search.toLowerCase())\n ? 1\n : 0;\n }}\n >\n <CommandInput placeholder={`Buscar ${input.label?.toLowerCase()}...`} className=\"h-9\" />\n <CommandList>\n <CommandEmpty>No se encontraron resultados.</CommandEmpty>\n <CommandGroup>\n {options.map((item) => (\n <CommandItem\n key={item.id}\n value={getValue(item)}\n onSelect={(currentValue) => {\n const newValue = currentValue === value ? \"\" : currentValue;\n setValue(newValue);\n form.setValue(input.name, newValue);\n handleOnChage(options.find((o) => getValue(o) === newValue), input)\n input.listConfig?.onOptionChange?.(\n options.find((o) => getValue(o) === newValue)\n );\n setOpen(false);\n }}\n >\n {item.name}\n <Check\n className={cn(\n \"ml-auto\",\n value === getValue(item) ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n </div>\n );\n};\n","'use client'\n\nimport { JSX, useState, useMemo } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { \n FormField, \n FormItem, \n FormLabel, \n FormControl, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { \n InputGroup, \n InputGroupAddon, \n InputGroupInput, \n InputGroupText \n} from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class CurrencyInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldCurrency input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\n/**\n * Campo numérico con formato monetario.\n * Acepta solo números y el punto mientras se edita.\n */\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldCurrency = ({ form, input, isSubmitting }: Props): JSX.Element => {\n const groupConfig = input.inputGroupConfig;\n const infoTooltip = input?.infoTooltip;\n const autoValidate = groupConfig?.autoValidIcons;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n // Estado local para manejar validez desde el primer render\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n const defaultCurrencyFormat: Intl.NumberFormatOptions = {\n style: 'currency',\n currency: 'USD',\n minimumFractionDigits: 2,\n maximumFractionDigits: 2,\n };\n\n const mask = input?.mask;\n const currencyFormat = input?.currencyFormat ?? defaultCurrencyFormat;\n\n const [rawValue, setRawValue] = useState<string>(form.getValues(input.name) ?? \"\");\n\n // Formateador monetario (por defecto: español - República Dominicana)\n const formatter = useMemo(() => {\n return new Intl.NumberFormat('es-DO', currencyFormat);\n }, [currencyFormat]);\n\n // 🔢 Limpia y convierte el texto a número\n const parseValue = (formatted: string): number | null => {\n const numeric = parseFloat(formatted.replace(/[^0-9.-]/g, \"\"));\n return isNaN(numeric) ? null : numeric;\n };\n\n // 🎨 Aplica formato visual\n const formatValue = (value: string): string => {\n if (!value) return \"\";\n const numeric = parseFloat(value.replace(/[^0-9.-]/g, \"\"));\n if (isNaN(numeric)) return \"\";\n\n if (typeof mask === \"string\") {\n return mask.replace(/0+(?:[.,]0+)?/, formatter.format(numeric).replace(/[^\\d.,]/g, \"\"));\n }\n\n if (mask instanceof RegExp) {\n const valid = mask.test(value);\n return valid ? value : rawValue;\n }\n\n return formatter.format(numeric);\n };\n\n // 🚫 Permite solo números y punto\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n const allowedKeys = [\n \"Backspace\",\n \"Delete\",\n \"Tab\",\n \"ArrowLeft\",\n \"ArrowRight\",\n \"Home\",\n \"End\",\n ];\n\n // Permitir navegación y borrado\n if (allowedKeys.includes(e.key)) return;\n\n // Permitir solo dígitos y un único punto decimal\n if (!/^[0-9.]$/.test(e.key)) {\n e.preventDefault();\n return;\n }\n\n // Impedir más de un punto\n if (e.key === \".\" && rawValue.includes(\".\")) {\n e.preventDefault();\n }\n };\n\n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <InputGroup>\n {/* Prefijo */}\n <InputGroupAddon>\n <InputGroupText>$</InputGroupText>\n {input.inputGroupConfig?.textLeft && (\n <InputGroupText>{input.inputGroupConfig.textLeft}</InputGroupText>\n )}\n </InputGroupAddon>\n\n {/* Input principal */}\n <InputGroupInput\n {...field}\n disabled={input.disabled || isSubmitting}\n placeholder={input.placeHolder ?? \"0.00\"}\n inputMode=\"decimal\"\n value={rawValue}\n onKeyDown={handleKeyDown}\n onChange={(e) => {\n const newVal = e.target.value;\n setRawValue(newVal);\n const parsed = parseValue(newVal);\n if (parsed !== null) field.onChange(parsed);\n handleOnChage(parsed, input, field)\n }}\n onBlur={(e) => {\n const formatted = formatValue(e.target.value);\n setRawValue(formatted);\n }}\n onFocus={(e) => {\n const numeric = e.target.value.replace(/[^0-9.-]/g, \"\");\n setRawValue(numeric);\n }}\n />\n\n {/* Sufijo */}\n <InputGroupAddon align=\"inline-end\">\n <InputGroupText>{currencyFormat.currency}</InputGroupText>\n {input.inputGroupConfig?.textRight && (\n <InputGroupText>{input.inputGroupConfig.textRight}</InputGroupText>\n )}\n {/* Icono de validación / loading */}\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n </InputGroup>\n </FormControl>\n <FormMessage />\n </FormItem>\n )}}\n />\n );\n};\n","/**\n * @module constants\n * @summary Useful constants\n * @description\n * Collection of useful date constants.\n *\n * The constants could be imported from `date-fns/constants`:\n *\n * ```ts\n * import { maxTime, minTime } from \"./constants/date-fns/constants\";\n *\n * function isAllowedTime(time) {\n * return time <= maxTime && time >= minTime;\n * }\n * ```\n */\n\n/**\n * @constant\n * @name daysInWeek\n * @summary Days in 1 week.\n */\nexport const daysInWeek = 7;\n\n/**\n * @constant\n * @name daysInYear\n * @summary Days in 1 year.\n *\n * @description\n * How many days in a year.\n *\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate<DateType extends Date>(date: DateType): DateType {\n * return constructFrom(\n * date, // Use constructor from the given date\n * date.getTime() // Use the date value to create a new date\n * );\n * }\n */\nexport function constructFrom(date, value) {\n if (typeof date === \"function\") return date(value);\n\n if (date && typeof date === \"object\" && constructFromSymbol in date)\n return date[constructFromSymbol](value);\n\n if (date instanceof Date) return new date.constructor(value);\n\n return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n // [TODO] Get rid of `toDate` or `constructFrom`?\n return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n","let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\n}\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfWeek} function options.\n */\n\n/**\n * @name startOfWeek\n * @category Week Helpers\n * @summary Return the start of a week for the given date.\n *\n * @description\n * Return the start of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week\n *\n * @example\n * // The start of a week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date, options?.in);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n\n _date.setDate(_date.getDate() - diff);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeek;\n","import { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfISOWeek} function options.\n */\n\n/**\n * @name startOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the start of an ISO week for the given date.\n *\n * @description\n * Return the start of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * const result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfISOWeek(date, options) {\n return startOfWeek(date, { ...options, weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeekYear} function options.\n */\n\n/**\n * @name getISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Get the ISO week-numbering year of the given date.\n *\n * @description\n * Get the ISO week-numbering year of the given date,\n * which always starts 3 days before the year's first Thursday.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n *\n * @returns The ISO week-numbering year\n *\n * @example\n * // Which ISO-week numbering year is 2 January 2005?\n * const result = getISOWeekYear(new Date(2005, 0, 2))\n * //=> 2004\n */\nexport function getISOWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const fourthOfJanuaryOfNextYear = constructFrom(_date, 0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n\n const fourthOfJanuaryOfThisYear = constructFrom(_date, 0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getISOWeekYear;\n","import { toDate } from \"../toDate.js\";\n\n/**\n * Google Chrome as of 67.0.3396.87 introduced timezones with offset that includes seconds.\n * They usually appear for dates that denote time before the timezones were introduced\n * (e.g. for 'Europe/Prague' timezone the offset is GMT+00:57:44 before 1 October 1891\n * and GMT+01:00:00 after that date)\n *\n * Date#getTimezoneOffset returns the offset in minutes and would return 57 for the example above,\n * which would lead to incorrect calculations.\n *\n * This function returns the timezone offset in milliseconds that takes seconds in account.\n */\nexport function getTimezoneOffsetInMilliseconds(date) {\n const _date = toDate(date);\n const utcDate = new Date(\n Date.UTC(\n _date.getFullYear(),\n _date.getMonth(),\n _date.getDate(),\n _date.getHours(),\n _date.getMinutes(),\n _date.getSeconds(),\n _date.getMilliseconds(),\n ),\n );\n utcDate.setUTCFullYear(_date.getFullYear());\n return +date - +utcDate;\n}\n","import { constructFrom } from \"../constructFrom.js\";\n\nexport function normalizeDates(context, ...dates) {\n const normalize = constructFrom.bind(\n null,\n context || dates.find((date) => typeof date === \"object\"),\n );\n return dates.map(normalize);\n}\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfDay} function options.\n */\n\n/**\n * @name startOfDay\n * @category Day Helpers\n * @summary Return the start of a day for the given date.\n *\n * @description\n * Return the start of a day for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a day\n *\n * @example\n * // The start of a day for 2 September 2014 11:55:00:\n * const result = startOfDay(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 02 2014 00:00:00\n */\nexport function startOfDay(date, options) {\n const _date = toDate(date, options?.in);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfDay;\n","import { getTimezoneOffsetInMilliseconds } from \"./_lib/getTimezoneOffsetInMilliseconds.js\";\nimport { normalizeDates } from \"./_lib/normalizeDates.js\";\nimport { millisecondsInDay } from \"./constants.js\";\nimport { startOfDay } from \"./startOfDay.js\";\n\n/**\n * The {@link differenceInCalendarDays} function options.\n */\n\n/**\n * @name differenceInCalendarDays\n * @category Day Helpers\n * @summary Get the number of calendar days between the given dates.\n *\n * @description\n * Get the number of calendar days between the given dates. This means that the times are removed\n * from the dates and then the difference in days is calculated.\n *\n * @param laterDate - The later date\n * @param earlierDate - The earlier date\n * @param options - The options object\n *\n * @returns The number of calendar days\n *\n * @example\n * // How many calendar days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInCalendarDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 366\n * // How many calendar days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInCalendarDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 1\n */\nexport function differenceInCalendarDays(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n\n const laterStartOfDay = startOfDay(laterDate_);\n const earlierStartOfDay = startOfDay(earlierDate_);\n\n const laterTimestamp =\n +laterStartOfDay - getTimezoneOffsetInMilliseconds(laterStartOfDay);\n const earlierTimestamp =\n +earlierStartOfDay - getTimezoneOffsetInMilliseconds(earlierStartOfDay);\n\n // Round the number of days to the nearest integer because the number of\n // milliseconds in a day is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay);\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarDays;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { getISOWeekYear } from \"./getISOWeekYear.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\n\n/**\n * The {@link startOfISOWeekYear} function options.\n */\n\n/**\n * @name startOfISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Return the start of an ISO week-numbering year for the given date.\n *\n * @description\n * Return the start of an ISO week-numbering year,\n * which always starts 3 days before the year's first Thursday.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week-numbering year\n *\n * @example\n * // The start of an ISO week-numbering year for 2 July 2005:\n * const result = startOfISOWeekYear(new Date(2005, 6, 2))\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfISOWeekYear(date, options) {\n const year = getISOWeekYear(date, options);\n const fourthOfJanuary = constructFrom(options?.in || date, 0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n return startOfISOWeek(fourthOfJanuary);\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeekYear;\n","/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param value - The value to check\n *\n * @returns True if the given value is a date\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport function isDate(value) {\n return (\n value instanceof Date ||\n (typeof value === \"object\" &&\n Object.prototype.toString.call(value) === \"[object Date]\")\n );\n}\n\n// Fallback for modularized imports:\nexport default isDate;\n","import { isDate } from \"./isDate.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate](https://date-fns.org/docs/toDate)\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @param date - The date to check\n *\n * @returns The date is valid\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertible into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport function isValid(date) {\n return !((!isDate(date) && typeof date !== \"number\") || isNaN(+toDate(date)));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfYear} function options.\n */\n\n/**\n * @name startOfYear\n * @category Year Helpers\n * @summary Return the start of a year for the given date.\n *\n * @description\n * Return the start of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a year\n *\n * @example\n * // The start of a year for 2 September 2014 11:55:00:\n * const result = startOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Jan 01 2014 00:00:00\n */\nexport function startOfYear(date, options) {\n const date_ = toDate(date, options?.in);\n date_.setFullYear(date_.getFullYear(), 0, 1);\n date_.setHours(0, 0, 0, 0);\n return date_;\n}\n\n// Fallback for modularized imports:\nexport default startOfYear;\n","const formatDistanceLocale = {\n lessThanXSeconds: {\n one: \"less than a second\",\n other: \"less than {{count}} seconds\",\n },\n\n xSeconds: {\n one: \"1 second\",\n other: \"{{count}} seconds\",\n },\n\n halfAMinute: \"half a minute\",\n\n lessThanXMinutes: {\n one: \"less than a minute\",\n other: \"less than {{count}} minutes\",\n },\n\n xMinutes: {\n one: \"1 minute\",\n other: \"{{count}} minutes\",\n },\n\n aboutXHours: {\n one: \"about 1 hour\",\n other: \"about {{count}} hours\",\n },\n\n xHours: {\n one: \"1 hour\",\n other: \"{{count}} hours\",\n },\n\n xDays: {\n one: \"1 day\",\n other: \"{{count}} days\",\n },\n\n aboutXWeeks: {\n one: \"about 1 week\",\n other: \"about {{count}} weeks\",\n },\n\n xWeeks: {\n one: \"1 week\",\n other: \"{{count}} weeks\",\n },\n\n aboutXMonths: {\n one: \"about 1 month\",\n other: \"about {{count}} months\",\n },\n\n xMonths: {\n one: \"1 month\",\n other: \"{{count}} months\",\n },\n\n aboutXYears: {\n one: \"about 1 year\",\n other: \"about {{count}} years\",\n },\n\n xYears: {\n one: \"1 year\",\n other: \"{{count}} years\",\n },\n\n overXYears: {\n one: \"over 1 year\",\n other: \"over {{count}} years\",\n },\n\n almostXYears: {\n one: \"almost 1 year\",\n other: \"almost {{count}} years\",\n },\n};\n\nexport const formatDistance = (token, count, options) => {\n let result;\n\n const tokenValue = formatDistanceLocale[token];\n if (typeof tokenValue === \"string\") {\n result = tokenValue;\n } else if (count === 1) {\n result = tokenValue.one;\n } else {\n result = tokenValue.other.replace(\"{{count}}\", count.toString());\n }\n\n if (options?.addSuffix) {\n if (options.comparison && options.comparison > 0) {\n return \"in \" + result;\n } else {\n return result + \" ago\";\n }\n }\n\n return result;\n};\n","export function buildFormatLongFn(args) {\n return (options = {}) => {\n // TODO: Remove String()\n const width = options.width ? String(options.width) : args.defaultWidth;\n const format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}\n","import { buildFormatLongFn } from \"../../_lib/buildFormatLongFn.js\";\n\nconst dateFormats = {\n full: \"EEEE, MMMM do, y\",\n long: \"MMMM do, y\",\n medium: \"MMM d, y\",\n short: \"MM/dd/yyyy\",\n};\n\nconst timeFormats = {\n full: \"h:mm:ss a zzzz\",\n long: \"h:mm:ss a z\",\n medium: \"h:mm:ss a\",\n short: \"h:mm a\",\n};\n\nconst dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: \"{{date}}, {{time}}\",\n short: \"{{date}}, {{time}}\",\n};\n\nexport const formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: \"full\",\n }),\n\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: \"full\",\n }),\n\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: \"full\",\n }),\n};\n","const formatRelativeLocale = {\n lastWeek: \"'last' eeee 'at' p\",\n yesterday: \"'yesterday at' p\",\n today: \"'today at' p\",\n tomorrow: \"'tomorrow at' p\",\n nextWeek: \"eeee 'at' p\",\n other: \"P\",\n};\n\nexport const formatRelative = (token, _date, _baseDate, _options) =>\n formatRelativeLocale[token];\n","/**\n * The localize function argument callback which allows to convert raw value to\n * the actual type.\n *\n * @param value - The value to convert\n *\n * @returns The converted value\n */\n\n/**\n * The map of localized values for each width.\n */\n\n/**\n * The index type of the locale unit value. It types conversion of units of\n * values that don't start at 0 (i.e. quarters).\n */\n\n/**\n * Converts the unit value to the tuple of values.\n */\n\n/**\n * The tuple of localized era values. The first element represents BC,\n * the second element represents AD.\n */\n\n/**\n * The tuple of localized quarter values. The first element represents Q1.\n */\n\n/**\n * The tuple of localized day values. The first element represents Sunday.\n */\n\n/**\n * The tuple of localized month values. The first element represents January.\n */\n\nexport function buildLocalizeFn(args) {\n return (value, options) => {\n const context = options?.context ? String(options.context) : \"standalone\";\n\n let valuesArray;\n if (context === \"formatting\" && args.formattingValues) {\n const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n const width = options?.width ? String(options.width) : defaultWidth;\n\n valuesArray =\n args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n const defaultWidth = args.defaultWidth;\n const width = options?.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[width] || args.values[defaultWidth];\n }\n const index = args.argumentCallback ? args.argumentCallback(value) : value;\n\n // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n return valuesArray[index];\n };\n}\n","import { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.js\";\n\nconst eraValues = {\n narrow: [\"B\", \"A\"],\n abbreviated: [\"BC\", \"AD\"],\n wide: [\"Before Christ\", \"Anno Domini\"],\n};\n\nconst quarterValues = {\n narrow: [\"1\", \"2\", \"3\", \"4\"],\n abbreviated: [\"Q1\", \"Q2\", \"Q3\", \"Q4\"],\n wide: [\"1st quarter\", \"2nd quarter\", \"3rd quarter\", \"4th quarter\"],\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nconst monthValues = {\n narrow: [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"],\n abbreviated: [\n \"Jan\",\n \"Feb\",\n \"Mar\",\n \"Apr\",\n \"May\",\n \"Jun\",\n \"Jul\",\n \"Aug\",\n \"Sep\",\n \"Oct\",\n \"Nov\",\n \"Dec\",\n ],\n\n wide: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n};\n\nconst dayValues = {\n narrow: [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"],\n short: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n abbreviated: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n wide: [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n ],\n};\n\nconst dayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n};\n\nconst formattingDayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n};\n\nconst ordinalNumber = (dirtyNumber, _options) => {\n const number = Number(dirtyNumber);\n\n // If ordinal numbers depend on context, for example,\n // if they are different for different grammatical genders,\n // use `options.unit`.\n //\n // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n // 'day', 'hour', 'minute', 'second'.\n\n const rem100 = number % 100;\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + \"st\";\n case 2:\n return number + \"nd\";\n case 3:\n return number + \"rd\";\n }\n }\n return number + \"th\";\n};\n\nexport const localize = {\n ordinalNumber,\n\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: \"wide\",\n }),\n\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: \"wide\",\n argumentCallback: (quarter) => quarter - 1,\n }),\n\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: \"wide\",\n }),\n\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: \"wide\",\n }),\n\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: \"wide\",\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: \"wide\",\n }),\n};\n","export function buildMatchFn(args) {\n return (string, options = {}) => {\n const width = options.width;\n\n const matchPattern =\n (width && args.matchPatterns[width]) ||\n args.matchPatterns[args.defaultMatchWidth];\n const matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n const matchedString = matchResult[0];\n\n const parsePatterns =\n (width && args.parsePatterns[width]) ||\n args.parsePatterns[args.defaultParseWidth];\n\n const key = Array.isArray(parsePatterns)\n ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))\n : // [TODO] -- I challenge you to fix the type\n findKey(parsePatterns, (pattern) => pattern.test(matchedString));\n\n let value;\n\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback\n ? // [TODO] -- I challenge you to fix the type\n options.valueCallback(value)\n : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n\nfunction findKey(object, predicate) {\n for (const key in object) {\n if (\n Object.prototype.hasOwnProperty.call(object, key) &&\n predicate(object[key])\n ) {\n return key;\n }\n }\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (let key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n return undefined;\n}\n","export function buildMatchPatternFn(args) {\n return (string, options = {}) => {\n const matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n const matchedString = matchResult[0];\n\n const parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n let value = args.valueCallback\n ? args.valueCallback(parseResult[0])\n : parseResult[0];\n\n // [TODO] I challenge you to fix the type\n value = options.valueCallback ? options.valueCallback(value) : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n","import { buildMatchFn } from \"../../_lib/buildMatchFn.js\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.js\";\n\nconst matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nconst parseOrdinalNumberPattern = /\\d+/i;\n\nconst matchEraPatterns = {\n narrow: /^(b|a)/i,\n abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n wide: /^(before christ|before common era|anno domini|common era)/i,\n};\nconst parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i],\n};\n\nconst matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i,\n};\nconst parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i],\n};\n\nconst matchMonthPatterns = {\n narrow: /^[jfmasond]/i,\n abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i,\n};\nconst parseMonthPatterns = {\n narrow: [\n /^j/i,\n /^f/i,\n /^m/i,\n /^a/i,\n /^m/i,\n /^j/i,\n /^j/i,\n /^a/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n\n any: [\n /^ja/i,\n /^f/i,\n /^mar/i,\n /^ap/i,\n /^may/i,\n /^jun/i,\n /^jul/i,\n /^au/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n};\n\nconst matchDayPatterns = {\n narrow: /^[smtwf]/i,\n short: /^(su|mo|tu|we|th|fr|sa)/i,\n abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i,\n};\nconst parseDayPatterns = {\n narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i],\n};\n\nconst matchDayPeriodPatterns = {\n narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i,\n};\nconst parseDayPeriodPatterns = {\n any: {\n am: /^a/i,\n pm: /^p/i,\n midnight: /^mi/i,\n noon: /^no/i,\n morning: /morning/i,\n afternoon: /afternoon/i,\n evening: /evening/i,\n night: /night/i,\n },\n};\n\nexport const match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: (value) => parseInt(value, 10),\n }),\n\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseEraPatterns,\n defaultParseWidth: \"any\",\n }),\n\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: \"any\",\n valueCallback: (index) => index + 1,\n }),\n\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: \"any\",\n }),\n\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseDayPatterns,\n defaultParseWidth: \"any\",\n }),\n\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: \"any\",\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: \"any\",\n }),\n};\n","import { formatDistance } from \"./en-US/_lib/formatDistance.js\";\nimport { formatLong } from \"./en-US/_lib/formatLong.js\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.js\";\nimport { localize } from \"./en-US/_lib/localize.js\";\nimport { match } from \"./en-US/_lib/match.js\";\n\n/**\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp](https://github.com/kossnocorp)\n * @author Lesha Koss [@leshakoss](https://github.com/leshakoss)\n */\nexport const enUS = {\n code: \"en-US\",\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0 /* Sunday */,\n firstWeekContainsDate: 1,\n },\n};\n\n// Fallback for modularized imports:\nexport default enUS;\n","import { differenceInCalendarDays } from \"./differenceInCalendarDays.js\";\nimport { startOfYear } from \"./startOfYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getDayOfYear} function options.\n */\n\n/**\n * @name getDayOfYear\n * @category Day Helpers\n * @summary Get the day of the year of the given date.\n *\n * @description\n * Get the day of the year of the given date.\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The day of year\n *\n * @example\n * // Which day of the year is 2 July 2014?\n * const result = getDayOfYear(new Date(2014, 6, 2))\n * //=> 183\n */\nexport function getDayOfYear(date, options) {\n const _date = toDate(date, options?.in);\n const diff = differenceInCalendarDays(_date, startOfYear(_date));\n const dayOfYear = diff + 1;\n return dayOfYear;\n}\n\n// Fallback for modularized imports:\nexport default getDayOfYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeek} function options.\n */\n\n/**\n * @name getISOWeek\n * @category ISO Week Helpers\n * @summary Get the ISO week of the given date.\n *\n * @description\n * Get the ISO week of the given date.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The ISO week\n *\n * @example\n * // Which week of the ISO-week numbering year is 2 January 2005?\n * const result = getISOWeek(new Date(2005, 0, 2))\n * //=> 53\n */\nexport function getISOWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getISOWeek;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeekYear} function options.\n */\n\n/**\n * @name getWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Get the local week-numbering year of the given date.\n *\n * @description\n * Get the local week-numbering year of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options.\n *\n * @returns The local week-numbering year\n *\n * @example\n * // Which week numbering year is 26 December 2004 with the default settings?\n * const result = getWeekYear(new Date(2004, 11, 26))\n * //=> 2005\n *\n * @example\n * // Which week numbering year is 26 December 2004 if week starts on Saturday?\n * const result = getWeekYear(new Date(2004, 11, 26), { weekStartsOn: 6 })\n * //=> 2004\n *\n * @example\n * // Which week numbering year is 26 December 2004 if the first week contains 4 January?\n * const result = getWeekYear(new Date(2004, 11, 26), { firstWeekContainsDate: 4 })\n * //=> 2004\n */\nexport function getWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const firstWeekOfNextYear = constructFrom(options?.in || date, 0);\n firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);\n\n const firstWeekOfThisYear = constructFrom(options?.in || date, 0);\n firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);\n\n if (+_date >= +startOfNextYear) {\n return year + 1;\n } else if (+_date >= +startOfThisYear) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getWeekYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { getWeekYear } from \"./getWeekYear.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfWeekYear} function options.\n */\n\n/**\n * @name startOfWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Return the start of a local week-numbering year for the given date.\n *\n * @description\n * Return the start of a local week-numbering year.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week-numbering year\n *\n * @example\n * // The start of an a week-numbering year for 2 July 2005 with default settings:\n * const result = startOfWeekYear(new Date(2005, 6, 2))\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // The start of a week-numbering year for 2 July 2005\n * // if Monday is the first day of week\n * // and 4 January is always in the first week of the year:\n * const result = startOfWeekYear(new Date(2005, 6, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfWeekYear(date, options) {\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const year = getWeekYear(date, options);\n const firstWeek = constructFrom(options?.in || date, 0);\n firstWeek.setFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setHours(0, 0, 0, 0);\n const _date = startOfWeek(firstWeek, options);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeekYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { startOfWeekYear } from \"./startOfWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeek} function options.\n */\n\n/**\n * @name getWeek\n * @category Week Helpers\n * @summary Get the local week index of the given date.\n *\n * @description\n * Get the local week index of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The week\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005 with default options?\n * const result = getWeek(new Date(2005, 0, 2))\n * //=> 2\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January?\n * const result = getWeek(new Date(2005, 0, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> 53\n */\nexport function getWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getWeek;\n","export function addLeadingZeros(number, targetLength) {\n const sign = number < 0 ? \"-\" : \"\";\n const output = Math.abs(number).toString().padStart(targetLength, \"0\");\n return sign + output;\n}\n","import { addLeadingZeros } from \"../addLeadingZeros.js\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | |\n * | d | Day of month | D | |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | m | Minute | M | Month |\n * | s | Second | S | Fraction of second |\n * | y | Year (abs) | Y | |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\n\nexport const lightFormatters = {\n // Year\n y(date, token) {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === \"yy\" ? year % 100 : year, token.length);\n },\n\n // Month\n M(date, token) {\n const month = date.getMonth();\n return token === \"M\" ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n\n // Day of the month\n d(date, token) {\n return addLeadingZeros(date.getDate(), token.length);\n },\n\n // AM or PM\n a(date, token) {\n const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return dayPeriodEnumValue.toUpperCase();\n case \"aaa\":\n return dayPeriodEnumValue;\n case \"aaaaa\":\n return dayPeriodEnumValue[0];\n case \"aaaa\":\n default:\n return dayPeriodEnumValue === \"am\" ? \"a.m.\" : \"p.m.\";\n }\n },\n\n // Hour [1-12]\n h(date, token) {\n return addLeadingZeros(date.getHours() % 12 || 12, token.length);\n },\n\n // Hour [0-23]\n H(date, token) {\n return addLeadingZeros(date.getHours(), token.length);\n },\n\n // Minute\n m(date, token) {\n return addLeadingZeros(date.getMinutes(), token.length);\n },\n\n // Second\n s(date, token) {\n return addLeadingZeros(date.getSeconds(), token.length);\n },\n\n // Fraction of second\n S(date, token) {\n const numberOfDigits = token.length;\n const milliseconds = date.getMilliseconds();\n const fractionalSeconds = Math.trunc(\n milliseconds * Math.pow(10, numberOfDigits - 3),\n );\n return addLeadingZeros(fractionalSeconds, token.length);\n },\n};\n","import { getDayOfYear } from \"../../getDayOfYear.js\";\nimport { getISOWeek } from \"../../getISOWeek.js\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.js\";\nimport { getWeek } from \"../../getWeek.js\";\nimport { getWeekYear } from \"../../getWeekYear.js\";\n\nimport { addLeadingZeros } from \"../addLeadingZeros.js\";\nimport { lightFormatters } from \"./lightFormatters.js\";\n\nconst dayPeriodEnum = {\n am: \"am\",\n pm: \"pm\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n};\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O | Timezone (GMT) |\n * | p! | Long localized time | P! | Long localized date |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nexport const formatters = {\n // Era\n G: function (date, token, localize) {\n const era = date.getFullYear() > 0 ? 1 : 0;\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return localize.era(era, { width: \"abbreviated\" });\n // A, B\n case \"GGGGG\":\n return localize.era(era, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return localize.era(era, { width: \"wide\" });\n }\n },\n\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === \"yo\") {\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, { unit: \"year\" });\n }\n\n return lightFormatters.y(date, token);\n },\n\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n const signedWeekYear = getWeekYear(date, options);\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n // Two digit year\n if (token === \"YY\") {\n const twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n }\n\n // Ordinal number\n if (token === \"Yo\") {\n return localize.ordinalNumber(weekYear, { unit: \"year\" });\n }\n\n // Padding\n return addLeadingZeros(weekYear, token.length);\n },\n\n // ISO week-numbering year\n R: function (date, token) {\n const isoWeekYear = getISOWeekYear(date);\n\n // Padding\n return addLeadingZeros(isoWeekYear, token.length);\n },\n\n // Extended year. This is a single number designating the year of this calendar system.\n // The main difference between `y` and `u` localizers are B.C. years:\n // | Year | `y` | `u` |\n // |------|-----|-----|\n // | AC 1 | 1 | 1 |\n // | BC 1 | 1 | 0 |\n // | BC 2 | 2 | -1 |\n // Also `yy` always returns the last two digits of a year,\n // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n u: function (date, token) {\n const year = date.getFullYear();\n return addLeadingZeros(year, token.length);\n },\n\n // Quarter\n Q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"QQ\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone quarter\n q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"qq\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // Month\n M: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n case \"M\":\n case \"MM\":\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // J, F, ..., D\n case \"MMMMM\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return localize.month(month, { width: \"wide\", context: \"formatting\" });\n }\n },\n\n // Stand-alone month\n L: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return String(month + 1);\n // 01, 02, ..., 12\n case \"LL\":\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // J, F, ..., D\n case \"LLLLL\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return localize.month(month, { width: \"wide\", context: \"standalone\" });\n }\n },\n\n // Local week of year\n w: function (date, token, localize, options) {\n const week = getWeek(date, options);\n\n if (token === \"wo\") {\n return localize.ordinalNumber(week, { unit: \"week\" });\n }\n\n return addLeadingZeros(week, token.length);\n },\n\n // ISO week of year\n I: function (date, token, localize) {\n const isoWeek = getISOWeek(date);\n\n if (token === \"Io\") {\n return localize.ordinalNumber(isoWeek, { unit: \"week\" });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n\n // Day of the month\n d: function (date, token, localize) {\n if (token === \"do\") {\n return localize.ordinalNumber(date.getDate(), { unit: \"date\" });\n }\n\n return lightFormatters.d(date, token);\n },\n\n // Day of year\n D: function (date, token, localize) {\n const dayOfYear = getDayOfYear(date);\n\n if (token === \"Do\") {\n return localize.ordinalNumber(dayOfYear, { unit: \"dayOfYear\" });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n\n // Day of week\n E: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"EEEEE\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"EEEE\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Local day of week\n e: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (Nth day of week with current locale or weekStartsOn)\n case \"e\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"ee\":\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n case \"eo\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"eee\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"eeeee\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"eeee\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (same as in `e`)\n case \"c\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"cc\":\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n case \"co\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"ccc\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // T\n case \"ccccc\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"standalone\",\n });\n // Tuesday\n case \"cccc\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // ISO day of week\n i: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n switch (token) {\n // 2\n case \"i\":\n return String(isoDayOfWeek);\n // 02\n case \"ii\":\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n case \"io\":\n return localize.ordinalNumber(isoDayOfWeek, { unit: \"day\" });\n // Tue\n case \"iii\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"iiiii\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"iiiiii\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"iiii\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM or PM\n a: function (date, token, localize) {\n const hours = date.getHours();\n const dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"aaa\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"aaaaa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours === 12) {\n dayPeriodEnumValue = dayPeriodEnum.noon;\n } else if (hours === 0) {\n dayPeriodEnumValue = dayPeriodEnum.midnight;\n } else {\n dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n }\n\n switch (token) {\n case \"b\":\n case \"bb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"bbb\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"bbbbb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours >= 17) {\n dayPeriodEnumValue = dayPeriodEnum.evening;\n } else if (hours >= 12) {\n dayPeriodEnumValue = dayPeriodEnum.afternoon;\n } else if (hours >= 4) {\n dayPeriodEnumValue = dayPeriodEnum.morning;\n } else {\n dayPeriodEnumValue = dayPeriodEnum.night;\n }\n\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"BBBBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === \"ho\") {\n let hours = date.getHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return lightFormatters.h(date, token);\n },\n\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === \"Ho\") {\n return localize.ordinalNumber(date.getHours(), { unit: \"hour\" });\n }\n\n return lightFormatters.H(date, token);\n },\n\n // Hour [0-11]\n K: function (date, token, localize) {\n const hours = date.getHours() % 12;\n\n if (token === \"Ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Hour [1-24]\n k: function (date, token, localize) {\n let hours = date.getHours();\n if (hours === 0) hours = 24;\n\n if (token === \"ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Minute\n m: function (date, token, localize) {\n if (token === \"mo\") {\n return localize.ordinalNumber(date.getMinutes(), { unit: \"minute\" });\n }\n\n return lightFormatters.m(date, token);\n },\n\n // Second\n s: function (date, token, localize) {\n if (token === \"so\") {\n return localize.ordinalNumber(date.getSeconds(), { unit: \"second\" });\n }\n\n return lightFormatters.s(date, token);\n },\n\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n if (timezoneOffset === 0) {\n return \"Z\";\n }\n\n switch (token) {\n // Hours and optional minutes\n case \"X\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XX`\n case \"XXXX\":\n case \"XX\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XXX`\n case \"XXXXX\":\n case \"XXX\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case \"x\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xx`\n case \"xxxx\":\n case \"xx\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xxx`\n case \"xxxxx\":\n case \"xxx\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (GMT)\n O: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"O\":\n case \"OO\":\n case \"OOO\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"OOOO\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (specific non-location)\n z: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"z\":\n case \"zz\":\n case \"zzz\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"zzzz\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Seconds timestamp\n t: function (date, token, _localize) {\n const timestamp = Math.trunc(+date / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n return addLeadingZeros(+date, token.length);\n },\n};\n\nfunction formatTimezoneShort(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = Math.trunc(absOffset / 60);\n const minutes = absOffset % 60;\n if (minutes === 0) {\n return sign + String(hours);\n }\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, delimiter) {\n if (offset % 60 === 0) {\n const sign = offset > 0 ? \"-\" : \"+\";\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n return formatTimezone(offset, delimiter);\n}\n\nfunction formatTimezone(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);\n const minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n","const dateLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"P\":\n return formatLong.date({ width: \"short\" });\n case \"PP\":\n return formatLong.date({ width: \"medium\" });\n case \"PPP\":\n return formatLong.date({ width: \"long\" });\n case \"PPPP\":\n default:\n return formatLong.date({ width: \"full\" });\n }\n};\n\nconst timeLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"p\":\n return formatLong.time({ width: \"short\" });\n case \"pp\":\n return formatLong.time({ width: \"medium\" });\n case \"ppp\":\n return formatLong.time({ width: \"long\" });\n case \"pppp\":\n default:\n return formatLong.time({ width: \"full\" });\n }\n};\n\nconst dateTimeLongFormatter = (pattern, formatLong) => {\n const matchResult = pattern.match(/(P+)(p+)?/) || [];\n const datePattern = matchResult[1];\n const timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n let dateTimeFormat;\n\n switch (datePattern) {\n case \"P\":\n dateTimeFormat = formatLong.dateTime({ width: \"short\" });\n break;\n case \"PP\":\n dateTimeFormat = formatLong.dateTime({ width: \"medium\" });\n break;\n case \"PPP\":\n dateTimeFormat = formatLong.dateTime({ width: \"long\" });\n break;\n case \"PPPP\":\n default:\n dateTimeFormat = formatLong.dateTime({ width: \"full\" });\n break;\n }\n\n return dateTimeFormat\n .replace(\"{{date}}\", dateLongFormatter(datePattern, formatLong))\n .replace(\"{{time}}\", timeLongFormatter(timePattern, formatLong));\n};\n\nexport const longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter,\n};\n","const dayOfYearTokenRE = /^D+$/;\nconst weekYearTokenRE = /^Y+$/;\n\nconst throwTokens = [\"D\", \"DD\", \"YY\", \"YYYY\"];\n\nexport function isProtectedDayOfYearToken(token) {\n return dayOfYearTokenRE.test(token);\n}\n\nexport function isProtectedWeekYearToken(token) {\n return weekYearTokenRE.test(token);\n}\n\nexport function warnOrThrowProtectedError(token, format, input) {\n const _message = message(token, format, input);\n console.warn(_message);\n if (throwTokens.includes(token)) throw new RangeError(_message);\n}\n\nfunction message(token, format, input) {\n const subject = token[0] === \"Y\" ? \"years\" : \"days of the month\";\n return `Use \\`${token.toLowerCase()}\\` instead of \\`${token}\\` (in \\`${format}\\`) for formatting ${subject} to the input \\`${input}\\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;\n}\n","import { defaultLocale } from \"./_lib/defaultLocale.js\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { formatters } from \"./_lib/format/formatters.js\";\nimport { longFormatters } from \"./_lib/format/longFormatters.js\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.js\";\nimport { isValid } from \"./isValid.js\";\nimport { toDate } from \"./toDate.js\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { formatters, longFormatters };\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\nexport { format as formatDate };\n\n/**\n * The {@link format} function options.\n */\n\n/**\n * @name format\n * @alias formatDate\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit | Pattern | Result examples | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era | G..GGG | AD, BC | |\n * | | GGGG | Anno Domini, Before Christ | 2 |\n * | | GGGGG | A, B | |\n * | Calendar year | y | 44, 1, 1900, 2017 | 5 |\n * | | yo | 44th, 1st, 0th, 17th | 5,7 |\n * | | yy | 44, 01, 00, 17 | 5 |\n * | | yyy | 044, 001, 1900, 2017 | 5 |\n * | | yyyy | 0044, 0001, 1900, 2017 | 5 |\n * | | yyyyy | ... | 3,5 |\n * | Local week-numbering year | Y | 44, 1, 1900, 2017 | 5 |\n * | | Yo | 44th, 1st, 1900th, 2017th | 5,7 |\n * | | YY | 44, 01, 00, 17 | 5,8 |\n * | | YYY | 044, 001, 1900, 2017 | 5 |\n * | | YYYY | 0044, 0001, 1900, 2017 | 5,8 |\n * | | YYYYY | ... | 3,5 |\n * | ISO week-numbering year | R | -43, 0, 1, 1900, 2017 | 5,7 |\n * | | RR | -43, 00, 01, 1900, 2017 | 5,7 |\n * | | RRR | -043, 000, 001, 1900, 2017 | 5,7 |\n * | | RRRR | -0043, 0000, 0001, 1900, 2017 | 5,7 |\n * | | RRRRR | ... | 3,5,7 |\n * | Extended year | u | -43, 0, 1, 1900, 2017 | 5 |\n * | | uu | -43, 01, 1900, 2017 | 5 |\n * | | uuu | -043, 001, 1900, 2017 | 5 |\n * | | uuuu | -0043, 0001, 1900, 2017 | 5 |\n * | | uuuuu | ... | 3,5 |\n * | Quarter (formatting) | Q | 1, 2, 3, 4 | |\n * | | Qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | QQ | 01, 02, 03, 04 | |\n * | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | q | 1, 2, 3, 4 | |\n * | | qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | qq | 01, 02, 03, 04 | |\n * | | qqq | Q1, Q2, Q3, Q4 | |\n * | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | qqqqq | 1, 2, 3, 4 | 4 |\n * | Month (formatting) | M | 1, 2, ..., 12 | |\n * | | Mo | 1st, 2nd, ..., 12th | 7 |\n * | | MM | 01, 02, ..., 12 | |\n * | | MMM | Jan, Feb, ..., Dec | |\n * | | MMMM | January, February, ..., December | 2 |\n * | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | L | 1, 2, ..., 12 | |\n * | | Lo | 1st, 2nd, ..., 12th | 7 |\n * | | LL | 01, 02, ..., 12 | |\n * | | LLL | Jan, Feb, ..., Dec | |\n * | | LLLL | January, February, ..., December | 2 |\n * | | LLLLL | J, F, ..., D | |\n * | Local week of year | w | 1, 2, ..., 53 | |\n * | | wo | 1st, 2nd, ..., 53th | 7 |\n * | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | I | 1, 2, ..., 53 | 7 |\n * | | Io | 1st, 2nd, ..., 53th | 7 |\n * | | II | 01, 02, ..., 53 | 7 |\n * | Day of month | d | 1, 2, ..., 31 | |\n * | | do | 1st, 2nd, ..., 31st | 7 |\n * | | dd | 01, 02, ..., 31 | |\n * | Day of year | D | 1, 2, ..., 365, 366 | 9 |\n * | | Do | 1st, 2nd, ..., 365th, 366th | 7 |\n * | | DD | 01, 02, ..., 365, 366 | 9 |\n * | | DDD | 001, 002, ..., 365, 366 | |\n * | | DDDD | ... | 3 |\n * | Day of week (formatting) | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | EEEEE | M, T, W, T, F, S, S | |\n * | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | i | 1, 2, 3, ..., 7 | 7 |\n * | | io | 1st, 2nd, ..., 7th | 7 |\n * | | ii | 01, 02, ..., 07 | 7 |\n * | | iii | Mon, Tue, Wed, ..., Sun | 7 |\n * | | iiii | Monday, Tuesday, ..., Sunday | 2,7 |\n * | | iiiii | M, T, W, T, F, S, S | 7 |\n * | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 7 |\n * | Local day of week (formatting) | e | 2, 3, 4, ..., 1 | |\n * | | eo | 2nd, 3rd, ..., 1st | 7 |\n * | | ee | 02, 03, ..., 01 | |\n * | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | eeeee | M, T, W, T, F, S, S | |\n * | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | c | 2, 3, 4, ..., 1 | |\n * | | co | 2nd, 3rd, ..., 1st | 7 |\n * | | cc | 02, 03, ..., 01 | |\n * | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | ccccc | M, T, W, T, F, S, S | |\n * | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | a..aa | AM, PM | |\n * | | aaa | am, pm | |\n * | | aaaa | a.m., p.m. | 2 |\n * | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | b..bb | AM, PM, noon, midnight | |\n * | | bbb | am, pm, noon, midnight | |\n * | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | bbbbb | a, p, n, mi | |\n * | Flexible day period | B..BBB | at night, in the morning, ... | |\n * | | BBBB | at night, in the morning, ... | 2 |\n * | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | h | 1, 2, ..., 11, 12 | |\n * | | ho | 1st, 2nd, ..., 11th, 12th | 7 |\n * | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | H | 0, 1, 2, ..., 23 | |\n * | | Ho | 0th, 1st, 2nd, ..., 23rd | 7 |\n * | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | K | 1, 2, ..., 11, 0 | |\n * | | Ko | 1st, 2nd, ..., 11th, 0th | 7 |\n * | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | k | 24, 1, 2, ..., 23 | |\n * | | ko | 24th, 1st, 2nd, ..., 23rd | 7 |\n * | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | m | 0, 1, ..., 59 | |\n * | | mo | 0th, 1st, ..., 59th | 7 |\n * | | mm | 00, 01, ..., 59 | |\n * | Second | s | 0, 1, ..., 59 | |\n * | | so | 0th, 1st, ..., 59th | 7 |\n * | | ss | 00, 01, ..., 59 | |\n * | Fraction of second | S | 0, 1, ..., 9 | |\n * | | SS | 00, 01, ..., 99 | |\n * | | SSS | 000, 001, ..., 999 | |\n * | | SSSS | ... | 3 |\n * | Timezone (ISO-8601 w/ Z) | X | -08, +0530, Z | |\n * | | XX | -0800, +0530, Z | |\n * | | XXX | -08:00, +05:30, Z | |\n * | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | x | -08, +0530, +00 | |\n * | | xx | -0800, +0530, +0000 | |\n * | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Timezone (GMT) | O...OOO | GMT-8, GMT+5:30, GMT+0 | |\n * | | OOOO | GMT-08:00, GMT+05:30, GMT+00:00 | 2 |\n * | Timezone (specific non-locat.) | z...zzz | GMT-8, GMT+5:30, GMT+0 | 6 |\n * | | zzzz | GMT-08:00, GMT+05:30, GMT+00:00 | 2,6 |\n * | Seconds timestamp | t | 512969520 | 7 |\n * | | tt | ... | 3,7 |\n * | Milliseconds timestamp | T | 512969520900 | 7 |\n * | | TT | ... | 3,7 |\n * | Long localized date | P | 04/29/1453 | 7 |\n * | | PP | Apr 29, 1453 | 7 |\n * | | PPP | April 29th, 1453 | 7 |\n * | | PPPP | Friday, April 29th, 1453 | 2,7 |\n * | Long localized time | p | 12:00 AM | 7 |\n * | | pp | 12:00:00 AM | 7 |\n * | | ppp | 12:00:00 AM GMT+2 | 7 |\n * | | pppp | 12:00:00 AM GMT+02:00 | 2,7 |\n * | Combination of date and time | Pp | 04/29/1453, 12:00 AM | 7 |\n * | | PPpp | Apr 29, 1453, 12:00:00 AM | 7 |\n * | | PPPppp | April 29th, 1453 at ... | 7 |\n * | | PPPPpppp| Friday, April 29th, 1453 at ... | 2,7 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n * the output will be the same as default pattern for this unit, usually\n * the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n * are marked with \"2\" in the last column of the table.\n *\n * `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n * `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n * The output will be padded with zeros to match the length of the pattern.\n *\n * `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` always returns the last two digits of a year,\n * while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n * | Year | `yy` | `uu` |\n * |------|------|------|\n * | 1 | 01 | 01 |\n * | 14 | 14 | 14 |\n * | 376 | 76 | 376 |\n * | 1453 | 53 | 1453 |\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [getISOWeekYear](https://date-fns.org/docs/getISOWeekYear)\n * and [getWeekYear](https://date-fns.org/docs/getWeekYear)).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n * so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `t`: seconds timestamp\n * - `T`: milliseconds timestamp\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @param date - The original date\n * @param format - The string of tokens\n * @param options - An object with options\n *\n * @returns The formatted date string\n *\n * @throws `date` must not be Invalid Date\n * @throws `options.locale` must contain `localize` property\n * @throws `options.locale` must contain `formatLong` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n * locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\nexport function format(date, formatStr, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const originalDate = toDate(date, options?.in);\n\n if (!isValid(originalDate)) {\n throw new RangeError(\"Invalid time value\");\n }\n\n let parts = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter === \"p\" || firstCharacter === \"P\") {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp)\n .map((substring) => {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return { isToken: false, value: \"'\" };\n }\n\n const firstCharacter = substring[0];\n if (firstCharacter === \"'\") {\n return { isToken: false, value: cleanEscapedString(substring) };\n }\n\n if (formatters[firstCharacter]) {\n return { isToken: true, value: substring };\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n return { isToken: false, value: substring };\n });\n\n // invoke localize preprocessor (only for french locales at the moment)\n if (locale.localize.preprocessor) {\n parts = locale.localize.preprocessor(originalDate, parts);\n }\n\n const formatterOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n return parts\n .map((part) => {\n if (!part.isToken) return part.value;\n\n const token = part.value;\n\n if (\n (!options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)) ||\n (!options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token))\n ) {\n warnOrThrowProtectedError(token, formatStr, String(date));\n }\n\n const formatter = formatters[token[0]];\n return formatter(originalDate, token, locale.localize, formatterOptions);\n })\n .join(\"\");\n}\n\nfunction cleanEscapedString(input) {\n const matched = input.match(escapedStringRegExp);\n\n if (!matched) {\n return input;\n }\n\n return matched[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default format;\n","\"use client\"\n\nimport * as React from \"react\"\nimport { format } from \"date-fns\"\nimport { CalendarIcon, CircleCheck, CircleX, Loader2 } from \"lucide-react\"\n\nimport { Button } from \"@/src/components/ui/button\"\nimport { Calendar } from \"@/src/components/ui/calendar\"\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/src/components/ui/popover\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\"\nimport { BaseInput, FieldProps, handleOnChage, isValidField } from \"../base\"\nimport { JSX, useState } from \"react\"\nimport { cn } from '@/src/lib/utils';\nimport { UseFormReturn } from \"react-hook-form\"\nimport { InputGroup, InputGroupAddon, InputGroupButton, InputGroupText } from \"@/src/components/ui/input-group\"\n\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\nexport class DateInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\nconst FieldTimeInput = ({ form, input, isSubmitting }: Props) => {\n\n const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n \n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n setIsValid(isValidField(input, form));\n // 🔑 Inicializa el estado con el valor actual del formulario (si existe)\n const [date, setDate] = React.useState<Date | undefined>(\n field.value ? new Date(field.value) : undefined\n )\n\n // 🔑 Sincroniza el estado con el form cuando cambie\n React.useEffect(() => {\n if (field.value && !date) {\n setDate(new Date(field.value))\n setIsValid(isValidField(input, form));\n }\n }, [field.value])\n\n const handleSelect = (selectedDate?: Date) => {\n // setIsValid(isValidField(input, form));\n setDate(selectedDate)\n // field.onChange(selectedDate) // <-- Actualiza el form\n handleOnChage(selectedDate, input, field)\n }\n\n return (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <Popover>\n <PopoverTrigger asChild>\n {/* <div className=\"flex flex-col justify-start gap-2 \"> */}\n <FormControl>\n <InputGroup className=\"flex flex-row gap-1\">\n\n <Button\n variant=\"outline\"\n className={cn(\n \"w-full justify-start text-left py-0.5 \",\n !date && \"text-muted-foreground\"\n )}\n >\n <div className=\"flex flex-1 items-center gap-1 justify-start text-left \">\n <CalendarIcon />\n {date ? format(date, \"PPP\") : <span>{input.placeHolder ?? 'Fecha'}</span>}\n </div>\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <>\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={24} className=\"w-6! h-6!\" />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </>\n )}\n \n </Button>\n\n\n </InputGroup>\n </FormControl>\n {/* </div> */}\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-0\">\n <Calendar\n mode=\"single\"\n selected={date}\n onSelect={handleSelect}\n initialFocus />\n </PopoverContent>\n </Popover>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )\n } } />\n return <>{formField}</>;\n}\n\n\n","'use client'\n\nimport { JSX, useState, useEffect } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { InputGroup, InputGroupAddon, InputGroupInput, InputGroupText } from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class DateTimeInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldDateTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldDateTimeInput = ({ form, input, isSubmitting }: Props) => {\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n // Estado local para la fecha y hora\n const [dateTime, setDateTime] = useState<string>(() => form.getValues(input.name) ?? \"\");\n\n useEffect(() => {\n const fieldValue = form.getValues(input.name) ?? \"\";\n if (fieldValue !== dateTime) setDateTime(fieldValue);\n }, [form.getValues(input.name)]);\n\n const handleChange = (val: string) => {\n setDateTime(val);\n form.setValue(input.name, val);\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n <InputGroup>\n\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input de tipo datetime-local */}\n <InputGroupInput\n type=\"datetime-local\"\n value={dateTime}\n disabled={input.disabled || isSubmitting}\n onChange={(e) =>{ \n handleOnChage(e.target.value, input, field);\n handleChange(e.target.value);\n }}\n />\n\n {/* Iconos derecha */}\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <InputGroupAddon align=\"inline-end\">\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={24} />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n\n </InputGroup>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport type { UseFormReturn } from \"react-hook-form\"\nimport { useEffect, useState } from \"react\";\nimport { Eye, EyeOff } from \"lucide-react\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { Card } from \"@/src/components/ui/card\"\nimport { FieldProps, BaseInput, handleOnChage } from \"../base\";\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Input } from \"@/src/components/ui\";\nimport { JSX } from \"react\"\n\nexport class FileInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return ( <FieldFile input={input} form={form} isSubmitting={isSubmitting} /> )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldFile = ({ form, input, isSubmitting }: Props) => {\n const [preview, setPreview] = useState<string | null>(form.getValues(input.name) ?? null)\n const [showPreview, setShowPreview] = useState<boolean>(input.fileConfig?.showPreview ?? false)\n \n const accept = input.fileConfig?.accept || \"*/*\";\n const multiple = input.fileConfig?.multiple || false;\n // const maxSize = input.fileConfig?.maxSize || 25;\n // const previewSize = input.fileConfig?.previewSize || 60;\n\n useEffect(() => {\n setPreview(form.getValues(input.name) || null)\n }, [input])\n\n\n const handleFileChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const file = e.target.files?.[0]\n if (file) {\n const objectUrl = URL.createObjectURL(file)\n setPreview(objectUrl)\n } else {\n setPreview(null)\n }\n }\n\n return (\n <>\n \n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <div className=\"flex gap-1\">\n <FormControl>\n <Input \n type=\"file\"\n accept={accept}\n multiple={multiple}\n placeholder={input.placeHolder}\n name={field.name}\n disabled={input.disabled || isSubmitting}\n onChange={(e) => {\n field.onChange(e.target.files?.[0]); handleFileChange(e)\n handleOnChage(e.target.files?.[0], input, field)\n }} \n />\n </FormControl>\n { preview && (<Button type=\"button\" onClick={() => { setShowPreview(!showPreview); }}>\n {showPreview ? <EyeOff /> : <Eye />}\n </Button>) }\n <FormDescription>{input.description}</FormDescription>\n </div>\n {/* <pre> <b>{JSON.stringify(field, null, 2) } </b> </pre> */}\n <FormMessage />\n {\n (preview && showPreview) && (\n <Card>\n {/* <Image\n src={preview}\n alt=\"Preview\"\n width={previewSize}\n height={previewSize}\n /> */}\n </Card> ) \n }\n </FormItem>\n )}\n />\n </>\n )\n}\n\n","'use client'\n\nimport { JSX, useRef, useState } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2, Upload } from \"lucide-react\";\nimport { cn } from \"@/src/lib/utils\";\n\nexport class FileMultiUploadInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldFileMultiUpload input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldFileMultiUpload = ({ input, form, isSubmitting }: Props) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const [files, setFiles] = useState<File[]>(form.getValues(input.name) || []);\n const [dragOver, setDragOver] = useState(false);\n\n const autoValidate = input.inputGroupConfig?.autoValidIcons;\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const handleFileSelect = (event: React.ChangeEvent<HTMLInputElement>) => {\n const selectedFiles = event.target.files ? Array.from(event.target.files) : [];\n setFiles(selectedFiles);\n form.setValue(input.name, selectedFiles);\n };\n\n const handleDrop = (event: React.DragEvent<HTMLDivElement>) => {\n event.preventDefault();\n const droppedFiles = event.dataTransfer.files ? Array.from(event.dataTransfer.files) : [];\n const updatedFiles = [...files, ...droppedFiles];\n setFiles(updatedFiles);\n form.setValue(input.name, updatedFiles);\n setDragOver(false);\n };\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const isValid = !fieldState.error && files.length > 0;\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <div\n ref={inputRef}\n onClick={() => inputRef.current?.click()}\n onDragOver={(e) => { e.preventDefault(); setDragOver(true); } }\n onDragLeave={() => setDragOver(false)}\n onDrop={handleDrop}\n className={cn(\n \"w-full h-40 border-2 border-dashed rounded-lg flex flex-col items-center justify-center cursor-pointer transition-all duration-200\",\n dragOver ? \"border-blue-500 bg-blue-50\" : \"border-gray-400 bg-gray-50\",\n isSubmitting && \"opacity-50 cursor-not-allowed\"\n )}\n >\n <Upload className=\"w-10 h-10 text-gray-500 mb-2\" />\n <span className=\"text-gray-600 text-sm text-center px-2\">\n {files.length === 0\n ? \"Arrastra tus archivos aquí o haz click para seleccionar\"\n : `${files.length} archivo(s) seleccionados`}\n </span>\n <input\n ref={inputRef}\n type=\"file\"\n multiple\n className=\"hidden\"\n disabled={input.disabled || isSubmitting}\n onChange={handleFileSelect} />\n </div>\n </FormControl>\n\n {/* Lista de archivos seleccionados */}\n {files.length > 0 && (\n <ul className=\"mt-2 max-h-40 overflow-y-auto border rounded-md p-2 bg-white\">\n {files.map((f, idx) => (\n <li key={idx} className=\"flex justify-between items-center py-1 px-2 rounded hover:bg-gray-100\">\n <span className=\"truncate\">{f.name}</span>\n <button\n type=\"button\"\n onClick={() => {\n const filtered = files.filter((_, i) => i !== idx);\n setFiles(filtered);\n form.setValue(input.name, filtered);\n } }\n className=\"text-red-500 hover:text-red-700 text-sm\"\n >\n Eliminar\n </button>\n </li>\n ))}\n </ul>\n )}\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n\n {autoValidate && (\n <div className=\"mt-1\">\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n\n <FormMessage />\n </FormItem>\n );\n } } />;\n\n return <>{formField}</>;\n \n};\n","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Link2Icon, Plus, Trash2 } from \"lucide-react\";\nimport { useEffect } from \"react\";\nimport { FieldTextGroup } from \"./text-input-group\";\nimport { InputGroup, InputGroupAddon, InputGroupInput } from \"@/src/components/ui/input-group\";\nimport { ButtonGroup, ButtonGroupText } from \"@/src/components/ui/button-group\";\nimport { Label } from \"@radix-ui/react-label\";\n\nexport class KeyValueListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldKeyValueList\n input={input}\n form={form}\n isSubmitting={isSubmitting}\n />\n );\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 🧠 Lista editable de pares clave-valor\n */\nexport const FieldKeyValueList = ({ form, input, isSubmitting }: Props) => {\n const fieldName = input.name;\n\n // Inicializamos el valor como array vacío si no existe\n useEffect(() => {\n const current = form.getValues(fieldName);\n if (!Array.isArray(current)) {\n form.setValue(fieldName, []);\n }\n }, [form, fieldName]);\n\n const handleAddPair = () => {\n const current = form.getValues(fieldName) || [];\n form.setValue(fieldName, [...current, { key: \"\", value: \"\" }]);\n };\n\n const handleRemovePair = (index: number) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.filter((_: any, i: number) => i !== index);\n form.setValue(fieldName, updated);\n };\n\n const handleChange = (index: number, fieldType: \"key\" | \"value\", newValue: string) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.map((item: any, i: number) =>\n i === index ? { ...item, [fieldType]: newValue } : item\n );\n form.setValue(fieldName, updated);\n };\n\n return (\n <FormField\n control={form.control}\n name={fieldName}\n render={() => {\n const pairs = form.watch(fieldName) || [];\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormMessage />\n <FormControl>\n <div className=\"flex flex-col gap-3 rounded-xl \">\n {pairs.length === 0 && (\n <p className=\"text-sm text-muted-foreground\">\n No pairs have been added yet.\n </p>\n )}\n\n {pairs.map((pair: { key: string; value: string }, index: number) => (\n <div\n key={index}\n className=\"flex flex-row w-full gap-2 items-center py-0.5\"\n > \n\n <ButtonGroup className=\"w-full\">\n <ButtonGroupText asChild>\n <Label htmlFor=\"key\">Key</Label>\n </ButtonGroupText>\n <InputGroup>\n <InputGroupInput\n placeholder=\"Key\"\n value={pair.key}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"key\", e.target.value)}\n className=\"flex-1\"\n />\n </InputGroup>\n </ButtonGroup>\n\n <ButtonGroup className=\"w-full\">\n <ButtonGroupText asChild>\n <Label htmlFor=\"value\">Value</Label>\n </ButtonGroupText>\n <InputGroup>\n <InputGroupInput\n placeholder=\"Value\"\n value={pair.value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"value\", e.target.value)}\n className=\"flex-1\"\n />\n </InputGroup>\n </ButtonGroup>\n\n {/* <Input\n placeholder=\"Key\"\n value={pair.key}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"key\", e.target.value)}\n className=\"w-1/2\"\n /> */}\n {/* <Input\n placeholder=\"Value\"\n value={pair.value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"value\", e.target.value)}\n className=\"w-1/2\"\n /> */}\n { input.isRemovebleOption && (<Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => handleRemovePair(index)}\n disabled={isSubmitting}\n >\n <Trash2 size={18} />\n </Button>)}\n </div>\n ))}\n\n <div className=\"flex justify-end mt-2\">\n <Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={handleAddPair}\n disabled={isSubmitting}\n >\n <Plus size={18} className=\"mr-1\" />\n </Button>\n </div>\n </div>\n </FormControl>\n\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\n\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Button,\n Badge,\n Popover,\n PopoverTrigger,\n PopoverContent,\n\n} from \"@/src/components/ui\";\nimport { Check, ChevronsUpDown } from \"lucide-react\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { cn } from \"@/src/lib/utils\";\nimport { useState } from \"react\";\nimport { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList } from \"@/src/components/ui/command\";\n\nexport class MultiSelectInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldMultiSelect input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldMultiSelect = ({ form, input, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"PERMISO 1\" },\n { id: 2, name: \"PERMISO 2\" },\n { id: 3, name: \"PERMISO 3\" },\n { id: 4, name: \"PERMISO 4\" },\n ];\n\n const lista = (input?.listConfig?.list ?? mockInputOptions) as InputOption[];\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n\n const getValue = (item: InputOption) => {\n if (optionValue === \"name\") return item[optionValue];\n return item.value ?? item.id;\n };\n\n const [open, setOpen] = useState(false);\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n const selectedValues: string[] = Array.isArray(field.value)\n ? field.value\n : [];\n\n const toggleOption = (value: string) => {\n const newValues = selectedValues.includes(value)\n ? selectedValues.filter((v) => v !== value)\n : [...selectedValues, value];\n field.onChange(newValues);\n };\n\n return (\n <FormItem className=\"flex flex-col rounded-lg border p-3 shadow bg-blue-100/20\">\n <FormLabel><b>{input.label}</b></FormLabel>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n\n <FormControl>\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n <Button\n variant=\"outline\"\n role=\"combobox\"\n disabled={input.disabled || isSubmitting}\n className={cn(\n \"justify-between w-full bg-black/10 dark:bg-white/10\",\n !selectedValues.length && \"text-muted-foreground\"\n )}\n >\n {selectedValues.length > 0 ? (\n <div className=\"flex flex-wrap gap-1\">\n {selectedValues.map((val) => {\n const option = lista.find(\n (item) => getValue(item).toString() === val\n );\n return (\n <Badge key={`${input.name}-${val}-ms`} variant=\"secondary\">\n {option?.name ?? val}\n </Badge>\n );\n })}\n </div>\n ) : (\n <span>{input.placeHolder ?? \"Selecciona...\"}</span>\n )}\n <ChevronsUpDown className=\"ml-2 h-4 w-4 opacity-50\" />\n </Button>\n </PopoverTrigger>\n\n <PopoverContent className=\"p-0 w-[var(--radix-popover-trigger-width)]\">\n <Command>\n <CommandInput placeholder=\"Buscar...\" />\n <CommandList>\n <CommandEmpty>No hay resultados.</CommandEmpty>\n <CommandGroup>\n {lista.map((item) => {\n const value = getValue(item).toString();\n const selected = selectedValues.includes(value);\n return (\n <CommandItem\n key={`${value}-ms`}\n onSelect={() => {\n handleOnChage(value,input,field)\n toggleOption(value)}\n }\n >\n <Check\n className={cn(\n \"mr-2 h-4 w-4\",\n selected ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n {item.name}\n </CommandItem>\n );\n })}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n </FormControl>\n\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\n\nimport { JSX, useState } from \"react\";\nimport { BaseInput, handleOnChage, isValidField } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { \n InputGroup, \n InputGroupAddon, \n InputGroupInput, \n InputGroupText \n} from \"@/src/components/ui/input-group\";\nimport { FieldProps, TextInputType } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Info, Loader2, Eye, EyeOff } from \"lucide-react\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/src/components/ui/tooltip\";\n\nexport class TextInputGroup extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTextGroup input={input} form={form} isSubmitting={isSubmitting}/>;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\n\nexport const FieldTextGroup = ({ form, input, isSubmitting }: Props) => {\n const groupConfig = input.inputGroupConfig;\n const infoTooltip = input?.infoTooltip;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez desde el primer render\n const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n // 👁️ Estado para mostrar/ocultar contraseña\n const [showPassword, setShowPassword] = useState(false);\n const isPasswordField = input.keyboardType === TextInputType.PASSWORD;\n const isNumberField = input.keyboardType === TextInputType.NUMBER;\n\n const showInputGroupAddons = iconsRight.length > 0 || textRight || autoValidate || infoTooltip || isPasswordField\n const formField = (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n setIsValid(isValidField(input, form));\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n <InputGroup>\n\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input principal */}\n <InputGroupInput\n placeholder={input.placeHolder}\n disabled={input.disabled || isSubmitting}\n onBlur={field.onBlur}\n name={field.name}\n ref={field.ref}\n type={\n isPasswordField && !showPassword\n ? \"password\"\n : isNumberField\n ? \"number\"\n : \"text\"\n }\n value={field.value ?? \"\"}\n onChange={(e) => {\n let value: any = e.target.value;\n if (isNumberField) {\n value = e.target.value === \"\" ? \"\" : Number(e.target.value); // 👈 conversión si es number\n }\n field.onChange(value);\n isValidField(input, form)\n handleOnChage(value, input, field)\n }}\n />\n\n {/* Iconos derecha */}\n {showInputGroupAddons && (\n <InputGroupAddon align=\"inline-end\">\n {/* Tooltip de información */}\n {infoTooltip && (\n <Tooltip>\n <TooltipTrigger asChild>\n <Info size={20} />\n </TooltipTrigger>\n <TooltipContent>\n <p>{infoTooltip}</p>\n </TooltipContent>\n </Tooltip>\n )}\n\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n\n {/* 👁️ Toggle mostrar/ocultar contraseña */}\n {isPasswordField && (\n <button\n type=\"button\"\n onClick={() => setShowPassword(!showPassword)}\n className=\"p-1\"\n >\n {showPassword ? <EyeOff size={20} /> : <Eye size={20} />}\n </button>\n )}\n\n {/* Icono de validación / loading */}\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n </InputGroup>\n </FormControl>\n\n {/* Descripción */}\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n \n return <>{formField}</>;\n};\n","'use client'\nimport { BaseInput, FieldProps, InputTypes } from \"../base\"\nimport { JSX } from \"react\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui\"\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldTextGroup } from \"./text-input-group\";\n\nexport class NumberInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (<FieldNumber form={form} input={input} isSubmitting={isSubmitting}/>)\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldNumber = ({form, input, isSubmitting}:Props) => {\n const fielInput: FieldProps = { ...input, inputType: InputTypes.NUMBER }\n return (<FieldTextGroup input={fielInput} form={form} isSubmitting={isSubmitting}/>)\n}\n\n","'use client'\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, InputOTP, InputOTPGroup, InputOTPSlot } from \"@/src/components/ui\"\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\nexport class OTPInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this; \n return (\n <FieldOTP form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn\n input: FieldProps,\n isSubmitting?: boolean;\n}\n\nconst FieldOTP = ({ form, input, isSubmitting }: Props ): JSX.Element => {\n\n const totalPositions = Array.from({ length: input.min ?? 6 }, (_, i) => i);\n \n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <InputOTP maxLength={totalPositions.length} {...field} onChange={(event)=> handleOnChage(event, input, field)}>\n <InputOTPGroup>\n {totalPositions.map((position) => (\n <InputOTPSlot key={position} index={position} />\n ))}\n </InputOTPGroup>\n </InputOTP>\n </FormControl>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )} />;\n}\n\n","'use client'\nimport { BaseInput, FieldProps, handleOnChage, InputOption } from \"../base\";\nimport { Card, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Label, RadioGroup, RadioGroupItem } from \"@/src/components/ui\";\nimport { cn } from \"@/src/lib/utils\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\n\nexport class RadioGroupInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldRadioGroup input={input} form={form} isSubmitting={isSubmitting}/>\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn\n input: FieldProps,\n isSubmitting?: boolean;\n}\n\nconst FieldRadioGroup = ({ input, form, isSubmitting }: Props): JSX.Element => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"A+\", value: \"A+\" },\n { id: 2, name: \"A-\", value: \"A-\" },\n { id: 3, name: \"B+\", value: \"B+\" },\n { id: 4, name: \"B-\", value: \"B-\" },\n { id: 5, name: \"O+\", value: \"O+\" },\n { id: 6, name: \"O-\", value: \"O-\" },\n { id: 7, name: \"AB+\", value: \"AB+\" },\n { id: 8, name: \"AB-\", value: \"AB-\" },\n ]\n\n const options = (input.listConfig?.list as InputOption[]) ?? mockInputOptions\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">\n {input.label || input.name}\n </FormLabel>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n </div>\n\n <FormControl>\n <RadioGroup\n {...field}\n value={field.value ?? \"\"}\n onValueChange={(e)=> handleOnChage(e, input, field)}\n className=\"space-y-2 mt-3\"\n >\n {options.map((opt, index) => (\n <div\n key={opt.id}\n className={cn(\n \"p-2 rounded-lg flex items-center gap-2 cursor-pointer\",\n index % 2 ? \"bg-black/5\" : \"bg-white/5\"\n )}\n >\n <RadioGroupItem\n disabled={input.disabled || isSubmitting}\n value={opt.value ?? String(opt.id)}\n id={`opt-${opt.id}`} />\n <Label htmlFor={`opt-${opt.id}`}>\n {opt.label || opt.name}\n </Label>\n </div>\n ))}\n </RadioGroup>\n </FormControl>\n\n <FormMessage />\n </FormItem>\n )} />;\n\n return <>{formField}</>;\n \n}","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { UseFormReturn, useFieldArray } from \"react-hook-form\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Plus, Trash2 } from \"lucide-react\";\nimport { FormFieldsGrid } from \"../FormFieldsGrid\";\n\nexport class RepeaterInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldRepeater form={form} input={input} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps\n isSubmitting?: boolean;\n}\n\nexport const FieldRepeater = ({ form, input, isSubmitting }: Props) => {\n const { control } = form;\n const { fields, append, remove } = useFieldArray({\n control,\n name: input.name,\n });\n\n const canAdd = !input.maxItems || fields.length < input.maxItems;\n const canRemove = fields.length > (input.minItems ?? 0);\n\n return (\n <FormField\n control={control}\n name={input.name}\n render={() => (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <div className=\"space-y-3\">\n {fields.map((item, index) => (\n <div\n key={item.id}\n className=\"border p-3 rounded-md flex flex-col gap-4 py-3\"\n >\n\n {/* <FormFieldsGrid fields={input?.repeaterFields ?? []} form={form} /> */}\n {input.repeaterFields?.map((fieldGroup, groupIndex) => {\n // Si el elemento es un array → varios campos en una línea\n const group =\n Array.isArray(fieldGroup) ? fieldGroup : [fieldGroup];\n const cols = group.length;\n\n return (\n <div\n key={groupIndex}\n className={`grid gap-3 grid-cols-${cols}`}\n >\n {group.map((subField) => (\n <FormField\n key={`${input.name}.${index}.${subField.name}`}\n control={control}\n name={`${input.name}.${index}.${subField.name}`}\n render={({ field, fieldState }) => (\n <FormItem className=\"flex-1\">\n <FormLabel>{subField.label}</FormLabel>\n <FormControl>\n <Input\n placeholder={subField.placeHolder}\n disabled={subField.disabled || isSubmitting}\n {...field}\n />\n </FormControl>\n <FormMessage>{fieldState.error?.message}</FormMessage>\n </FormItem>\n )}\n />\n ))}\n </div>\n );\n })}\n\n {/* Botón eliminar */}\n {canRemove && (\n <Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => remove(index)}\n className=\"self-end\"\n >\n <Trash2 size={18} />\n </Button>\n )}\n </div>\n ))}\n\n {/* Botón agregar */}\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"secondary\"\n onClick={() => append({})}\n disabled={isSubmitting}\n className=\"w-full\"\n >\n <Plus size={16} className=\"mr-2\" />\n Agregar\n </Button>\n )}\n </div>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};","import * as React from \"react\"\nimport * as TabsPrimitive from \"@radix-ui/react-tabs\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Tabs({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Root>) {\n return (\n <TabsPrimitive.Root\n data-slot=\"tabs\"\n className={cn(\"flex flex-col gap-2\", className)}\n {...props}\n />\n )\n}\n\nfunction TabsList({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.List>) {\n return (\n <TabsPrimitive.List\n data-slot=\"tabs-list\"\n className={cn(\n \"bg-muted text-muted-foreground inline-flex h-9 w-fit items-center justify-center rounded-lg p-[3px]\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction TabsTrigger({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Trigger>) {\n return (\n <TabsPrimitive.Trigger\n data-slot=\"tabs-trigger\"\n className={cn(\n \"data-[state=active]:bg-background dark:data-[state=active]:text-foreground focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring dark:data-[state=active]:border-input dark:data-[state=active]:bg-input/30 text-foreground dark:text-muted-foreground inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction TabsContent({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Content>) {\n return (\n <TabsPrimitive.Content\n data-slot=\"tabs-content\"\n className={cn(\"flex-1 outline-none\", className)}\n {...props}\n />\n )\n}\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent }\n","'use client'\n\nimport { JSX, useState } from \"react\";\nimport { UseFormReturn, useFieldArray } from \"react-hook-form\";\nimport { BaseInput } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Plus, Trash2 } from \"lucide-react\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { FieldProps } from \"../base/definitions\";\nimport { TabsContent, Tabs, TabsTrigger, TabsList } from '@/src/components/ui/tabs';\n\n/**\n * 🧱 Clase que extiende BaseInput\n * Se usa igual que tus otros inputs (TextInput, SelectInput, etc.)\n */\nexport class RepeaterTabsInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldRepeaterTabs form={form} input={input} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 📋 FieldRepeaterTabs\n * - Cada ítem del FieldArray se representa como un tab.\n * - Permite agregar/eliminar tabs.\n * - Mantiene sincronía con React Hook Form.\n */\nconst FieldRepeaterTabs = ({ form, input, isSubmitting }: Props): JSX.Element => {\n const { control } = form;\n const { fields, append, remove } = useFieldArray({\n control,\n name: input.name,\n });\n\n const [activeTab, setActiveTab] = useState<string>(fields[0]?.id ?? \"\");\n\n const canAdd = !input.maxItems || fields.length < input.maxItems;\n const canRemove = fields.length > (input.minItems ?? 0);\n\n const handleAdd = () => {\n const newItem = { id: `tab-${Date.now()}` };\n append(newItem);\n setActiveTab(newItem.id);\n };\n\n const handleRemove = (index: number) => {\n const removedId = fields[index].id;\n remove(index);\n if (activeTab === removedId && fields.length > 1) {\n const nextTab = fields[index - 1] ?? fields[0];\n if (nextTab) setActiveTab(nextTab.id);\n }\n };\n\n return (\n <FormField\n control={control}\n name={input.name}\n render={() => (\n <FormItem className={input.className}>\n {input.label && <FormLabel><b>{input.label}</b></FormLabel>}\n <FormControl>\n <div className=\"space-y-3\">\n <Tabs value={activeTab} onValueChange={setActiveTab} className=\"w-full\">\n {/* 🔹 Lista de Tabs */}\n <TabsList className=\"flex w-full justify-start overflow-x-auto\">\n {fields.map((item, index) => (\n <div key={item.id} className=\"flex items-center\">\n <TabsTrigger value={item.id} className=\"flex items-center gap-1\">\n {input.tabLabelField\n ? form.watch(`${input.name}.${index}.${input.tabLabelField}`) ||\n `Item ${index + 1}`\n : `Item ${index + 1}`}\n </TabsTrigger>\n {canRemove && (\n <Button\n type=\"button\"\n size=\"icon\"\n variant=\"ghost\"\n onClick={() => handleRemove(index)}\n >\n <Trash2 size={14} />\n </Button>\n )}\n </div>\n ))}\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"secondary\"\n size=\"sm\"\n onClick={handleAdd}\n disabled={isSubmitting}\n className=\"ml-2\"\n >\n <Plus size={14} className=\"mr-1\" /> Agregar\n </Button>\n )}\n </TabsList>\n\n {/* 🔹 Contenido de cada Tab */}\n {fields.map((item, index) => (\n <TabsContent key={item.id} value={item.id} className=\"mt-4\">\n {input.repeaterFields?.map((fieldGroup, groupIndex) => {\n const group = Array.isArray(fieldGroup)\n ? fieldGroup\n : [fieldGroup];\n const cols = group.length;\n\n return (\n <div key={groupIndex} className={`grid gap-3 grid-cols-${cols}`}>\n {group.map((subField) => (\n <FormField\n key={`${input.name}.${index}.${subField.name}`}\n control={control}\n name={`${input.name}.${index}.${subField.name}`}\n render={({ field, fieldState }) => (\n <FormItem className=\"flex-1\">\n <FormLabel>{subField.label}</FormLabel>\n <FormControl>\n <Input\n placeholder={subField.placeHolder}\n disabled={subField.disabled || isSubmitting}\n {...field}\n />\n </FormControl>\n <FormMessage>{fieldState.error?.message}</FormMessage>\n </FormItem>\n )}\n />\n ))}\n </div>\n );\n })}\n </TabsContent>\n ))}\n </Tabs>\n </div>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};\n","'use client'\n\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from \"@/src/components/ui\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { useEffect, useState } from \"react\";\n\nexport class SelectInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldSelect input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldSelect = ({ form, input, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { value: 1, id: 1, name: \"MOCK OPTION - PERMISO 1\" },\n { value: 2, id: 2, name: \"MOCK OPTION - PERMISO 2\" },\n { value: 3, id: 3, name: \"MOCK OPTION - PERMISO 3\" },\n { value: 4, id: 4, name: \"MOCK OPTION - PERMISO 4\" },\n ];\n\n // 🧩 Estado interno para lista y valor seleccionado\n const [lista, setLista] = useState<InputOption[]>(\n (input?.listConfig?.list?.every((item): item is InputOption => \"name\" in item)\n ? input.listConfig.list\n : mockInputOptions) as InputOption[]\n );\n const [loading, setLoading] = useState(false);\n const [value, setValue] = useState<string>(input.value?.toString() ?? \"\");\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n\n // 🧠 Sincroniza el valor inicial con react-hook-form\n useEffect(() => {\n const currentValue = form.getValues(input.name);\n if (!currentValue && input.value) {\n form.setValue(input.name, input.value);\n setValue(input.value.toString());\n }\n }, [form, input.name, input.value]);\n\n // 🪄 Nuevo: escucha cambios en el campo del que depende (si existe)\n useEffect(() => {\n if (input.dependsOn && input.loadOptions) {\n const subscription = form.watch(async (values) => {\n const dependencyValue = values[input.dependsOn!];\n if (dependencyValue) {\n try {\n setLoading(true);\n const newOptions = await input.loadOptions!(dependencyValue);\n setLista(newOptions);\n } catch (err) {\n console.error(`Error loading options for ${input.name}:`, err);\n setLista([]);\n } finally {\n setLoading(false);\n }\n } else {\n // Limpia opciones si el campo dependiente se vacía\n setLista([]);\n form.setValue(input.name, \"\"); // limpia selección\n }\n });\n\n // cleanup\n return () => subscription.unsubscribe?.();\n }\n }, [form, input.dependsOn, input.loadOptions, input.name]);\n\n const getValue = (item: InputOption): string => {\n const val =\n optionValue === \"name\"\n ? item.name\n : item.value?.toString?.() ?? item.id?.toString();\n return val?.toString() ?? \"\";\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n const currentValue = field.value?.toString() ?? value;\n\n return (\n <FormItem className=\"flex flex-row items-center justify-between rounded-lg border p-3 shadow-lg bg-blue-100/20\">\n <div className=\"space-y-0.5 pr-5\">\n <FormLabel>\n <b>{input.label}</b>\n </FormLabel>\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n <FormMessage />\n </div>\n\n <FormControl>\n <Select\n disabled={input.disabled || isSubmitting || loading}\n onValueChange={(val) => {\n handleOnChage(val, input, field)\n // field.onChange(val);\n setValue(val);\n\n // 🔸 Ejecuta el callback definido si existe\n if (input.listConfig?.onOptionChange) {\n const selectedItem = lista.find(\n (item) => getValue(item) === val\n );\n input.listConfig.onOptionChange(selectedItem);\n }\n }}\n value={currentValue || undefined}\n >\n <FormControl>\n <SelectTrigger className=\"w-[60%] bg-black/10 dark:bg-white/25\">\n <SelectValue\n placeholder={\n loading\n ? \"Cargando...\"\n : input.placeHolder ?? \"Seleccionar\"\n }\n />\n </SelectTrigger>\n </FormControl>\n\n <SelectContent>\n {lista.map((item) => (\n <SelectItem value={getValue(item)} key={`${input.name}-${item.id}-s`}>\n {item.name}\n </SelectItem>\n ))}\n {lista.length === 0 && !loading && (\n <div className=\"p-2 text-sm text-muted-foreground\">\n No hay opciones disponibles\n </div>\n )}\n </SelectContent>\n </Select>\n </FormControl>\n </FormItem>\n );\n }}\n />\n );\n};\n","\"use client\";\n\nimport { JSX, useState } from \"react\";\nimport { Card, Label, Checkbox } from \"@/src/components/ui\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FormControl, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { cn } from \"@/src/lib/utils\";\n\nexport class SimpleCheckListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FieldSimpleCheckList\n isSubmitting={isSubmitting}\n input={input}\n value={field.value || []}\n onChange={(e) =>handleOnChage(e, input, field)}\n />\n )}\n />\n );\n }\n}\n\ninterface Props {\n input: FieldProps;\n value: InputOption[];\n isSubmitting?: boolean;\n onChange: (value: InputOption[]) => void;\n}\n\nexport const FieldSimpleCheckList = ({ input, value, onChange, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"MOCK OPTION - CREATE\", checked: false },\n { id: 2, name: \"MOCK OPTION - READ\", checked: true },\n { id: 3, name: \"MOCK OPTION - UPDATE\", checked: false },\n { id: 4, name: \"MOCK OPTION - DELETE\", checked: false },\n ];\n\n // Usa las opciones del input o las mock\n const initialOptions =\n (input.listConfig?.list as InputOption[]) ?? mockInputOptions;\n\n // Estado local sincronizado con el form\n const [options, setOptions] = useState<InputOption[]>(\n value.length > 0 ? value : initialOptions\n );\n\n const allChecked = options.every((opt) => opt.checked);\n\n const handleMainToggle = (checked: boolean) => {\n const updated = options.map((opt) => ({ ...opt, checked }));\n setOptions(updated);\n handleOnChage(updated, input)\n onChange(updated); // sincroniza con el form\n };\n\n const handleChildToggle = (option: InputOption, checked: boolean) => {\n const updated = options.map((opt) =>\n opt.id === option.id ? { ...opt, checked } : opt\n );\n handleOnChage(updated, input)\n setOptions(updated);\n onChange(updated); // sincroniza con el form\n };\n\n const formField = <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">{input.label || input.name}</FormLabel>\n <div className=\"flex items-center gap-2\">\n <Label htmlFor=\"main\">Seleccionar todo</Label>\n <Checkbox\n id=\"main\"\n checked={allChecked}\n onCheckedChange={handleMainToggle} />\n </div>\n </div>\n\n <FormControl>\n <div className=\"space-y-2 mt-3\">\n {options.map((opt, index) => (\n <div\n key={opt.id}\n className={cn(\n \"p-2 rounded-lg flex justify-items-start gap-2 items-center\",\n index % 2 ? \"bg-black/5\" : \"bg-white/5\"\n )}\n >\n <Checkbox\n disabled={input.disabled || isSubmitting}\n id={String(opt.id)}\n checked={opt.checked || false}\n onCheckedChange={(checked) => handleChildToggle(opt, checked as boolean)} />\n <Label htmlFor={String(opt.id)}>{opt.label || opt.name}</Label>\n </div>\n ))}\n </div>\n </FormControl>\n\n <FormMessage />\n </FormItem>;\n\n return <>{formField}</>;\n \n};\n","import * as React from \"react\"\nimport * as SliderPrimitive from \"@radix-ui/react-slider\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Slider({\n className,\n defaultValue,\n value,\n min = 0,\n max = 100,\n ...props\n}: React.ComponentProps<typeof SliderPrimitive.Root>) {\n const _values = React.useMemo(\n () =>\n Array.isArray(value)\n ? value\n : Array.isArray(defaultValue)\n ? defaultValue\n : [min, max],\n [value, defaultValue, min, max]\n )\n\n return (\n <SliderPrimitive.Root\n data-slot=\"slider\"\n defaultValue={defaultValue}\n value={value}\n min={min}\n max={max}\n className={cn(\n \"relative flex w-full touch-none items-center select-none data-[disabled]:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:min-h-44 data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col\",\n className\n )}\n {...props}\n >\n <SliderPrimitive.Track\n data-slot=\"slider-track\"\n className={cn(\n \"bg-muted relative grow overflow-hidden rounded-full data-[orientation=horizontal]:h-1.5 data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-1.5\"\n )}\n >\n <SliderPrimitive.Range\n data-slot=\"slider-range\"\n className={cn(\n \"bg-primary absolute data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full\"\n )}\n />\n </SliderPrimitive.Track>\n {Array.from({ length: _values.length }, (_, index) => (\n <SliderPrimitive.Thumb\n data-slot=\"slider-thumb\"\n key={index}\n className=\"border-primary ring-ring/50 block size-4 shrink-0 rounded-full border bg-white shadow-sm transition-[color,box-shadow] hover:ring-4 focus-visible:ring-4 focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50\"\n />\n ))}\n </SliderPrimitive.Root>\n )\n}\n\nexport { Slider }\n","'use client'\n\nimport { JSX, useState } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Slider } from \"@/src/components/ui/slider\";\nimport { Card } from \"@/src/components/ui\";\n\nexport class SliderInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldSlider input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldSlider = ({ input, form, isSubmitting }: Props) => {\n // Valor inicial del slider\n const initialValue = form.getValues(input.name) ?? input.value ?? 0;\n const [value, setValue] = useState<number>(initialValue);\n\n const handleChange = (val: number) => {\n setValue(val);\n form.setValue(input.name, val);\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <Slider\n defaultValue={[initialValue]}\n value={[value]}\n max={input.max ?? 100}\n min={input.min ?? 0}\n step={1}\n className=\"w-[60%]\"\n disabled={input.disabled || isSubmitting}\n onValueChange={(val) => handleChange(val[0])}\n />\n </FormControl>\n\n <div className=\"mt-2 text-sm text-gray-700\">\n Valor actual: {value}\n </div>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};\n","'use client'\n\nimport { JSX, ReactNode, useState } from \"react\"\nimport { UseFormReturn } from \"react-hook-form\"\nimport {\n DndContext,\n closestCenter,\n KeyboardSensor,\n PointerSensor,\n useSensor,\n useSensors,\n} from \"@dnd-kit/core\"\nimport {\n arrayMove,\n SortableContext,\n sortableKeyboardCoordinates,\n verticalListSortingStrategy,\n} from \"@dnd-kit/sortable\"\nimport { useSortable } from \"@dnd-kit/sortable\"\nimport { CSS } from \"@dnd-kit/utilities\"\nimport { GripVertical } from \"lucide-react\"\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n} from \"@/src/components/ui/form\"\nimport { cn } from \"@/src/lib/utils\"\nimport { BaseInput, FieldProps } from \"../base\"\n\n// ============================================================================\n// 🔹 Clase principal que extiende de BaseInput\n// ============================================================================\n\nexport class SortableListInput<T> extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this\n const children = input.listConfig?.children ?? undefined\n return (\n <FieldSortableList<T>\n form={form}\n input={input}\n isSubmitting={isSubmitting}\n children={children as (item: T, index: number) => ReactNode}\n />\n )\n }\n}\n\n// ============================================================================\n// 🔹 Campo principal con lógica de drag & drop\n// ============================================================================\n\ninterface Props<T> {\n form: UseFormReturn\n input: FieldProps\n isSubmitting?: boolean\n children?: (item: T, index: number) => ReactNode\n}\n\nfunction FieldSortableList<T>({\n form,\n input,\n isSubmitting,\n children,\n}: Props<T>): JSX.Element {\n const [items, setItems] = useState<any[]>(() => input.listConfig?.list ?? [])\n const sortableEnabled = input.listConfig?.sortable ?? true;\n\n const sensors = useSensors(\n useSensor(PointerSensor),\n useSensor(KeyboardSensor, { coordinateGetter: sortableKeyboardCoordinates })\n )\n\n const handleDragEnd = (event: any) => {\n if (!sortableEnabled) return; \n const { active, over } = event\n if (!over || active.id === over.id) return\n\n const oldIndex = items.findIndex((i: any) => i.id === active.id)\n const newIndex = items.findIndex((i: any) => i.id === over.id)\n const newList = arrayMove(items, oldIndex, newIndex)\n\n setItems(newList)\n form.setValue(input.name, newList)\n input.listConfig?.onOptionChange?.(newList)\n }\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={() => (\n <FormItem className={cn(\"space-y-2\", input.className)}>\n {input.label && <FormLabel><b>{input.label}</b></FormLabel>}\n <FormControl>\n {sortableEnabled ? (\n <DndContext collisionDetection={closestCenter} onDragEnd={handleDragEnd}>\n <SortableContext\n items={items.map((i) => i.id)}\n strategy={verticalListSortingStrategy}\n >\n <div className=\"flex flex-col gap-2\">\n {items.map((item, index) => (\n <SortableWrapper key={item.id} id={item.id}>\n {typeof children === \"function\"\n ? children(item, index)\n : <div className=\"p-3 border rounded-md bg-white\">{item.name}</div>}\n </SortableWrapper>\n ))}\n </div>\n </SortableContext>\n </DndContext>\n ) : (\n <div className=\"flex flex-col gap-2\">\n {items.map((item, index) =>\n typeof children === \"function\"\n ? children(item, index)\n : <div key={item.id} className=\"p-3 border rounded-md bg-gray-50\">{item.name}</div>\n )}\n </div>\n )}\n </FormControl>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n )\n}\n\n// ============================================================================\n// 🔹 SortableWrapper: item individual draggable\n// ============================================================================\n\nfunction SortableWrapper({\n id,\n children,\n disabled,\n}: {\n id: string | number\n children: React.ReactNode\n disabled?: boolean\n}) {\n const {\n attributes,\n listeners,\n setNodeRef,\n transform,\n transition,\n isDragging,\n } = useSortable({ id, disabled })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div\n ref={setNodeRef}\n style={style}\n {...attributes}\n {...listeners}\n className={cn(\n \"flex items-center gap-2 p-2 border rounded-md mb-1 bg-muted/30 cursor-grab select-none transition-all\",\n isDragging && \"opacity-60 bg-muted/50 scale-[0.98]\"\n )}\n >\n <GripVertical className=\"w-4 h-4 opacity-70\" />\n <div className=\"flex-1\">{children}</div>\n </div>\n )\n}\n","'use client';\n\nimport { JSX, useEffect } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Plus, Trash2 } from \"lucide-react\";\n\nexport class StringValueListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldStringValueList\n input={input}\n form={form}\n isSubmitting={isSubmitting}\n />\n );\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 🧠 Lista editable de strings\n */\nexport const FieldStringValueList = ({ form, input, isSubmitting }: Props) => {\n const fieldName = input.name;\n const withAddBtn = input.withAddBtn ?? false\n\n // Inicializamos como array vacío si no existe\n useEffect(() => {\n const current = form.getValues(fieldName);\n if (!Array.isArray(current)) {\n form.setValue(fieldName, []);\n }\n }, [form, fieldName]);\n\n const handleAddItem = () => {\n const current = form.getValues(fieldName) || [];\n form.setValue(fieldName, [...current, \"\"]);\n };\n\n const handleRemoveItem = (index: number) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.filter((_: string, i: number) => i !== index);\n form.setValue(fieldName, updated);\n };\n\n const handleChange = (index: number, newValue: string) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.map((item: string, i: number) =>\n i === index ? newValue : item\n );\n form.setValue(fieldName, updated);\n };\n\n return (\n <FormField\n control={form.control}\n name={fieldName}\n render={() => {\n const items = form.watch(fieldName) || [];\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormMessage />\n <FormControl>\n <div className=\"flex flex-col gap-3 rounded-xl \">\n {items.length === 0 && (\n <p className=\"text-sm text-muted-foreground\">\n No items have been added yet.\n </p>\n )}\n\n {items.map((value: string, index: number) => (\n <div\n key={index}\n className=\"flex items-center gap-4 py-2\"\n >\n <Input\n placeholder={`Item ${index + 1}`}\n value={value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, e.target.value)}\n />\n {input.isRemovebleOption && (<Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => handleRemoveItem(index)}\n disabled={isSubmitting}\n >\n <Trash2 size={18} />\n </Button>)}\n </div>\n ))}\n\n <div className=\"flex justify-end mt-2\">\n { withAddBtn && (<Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={handleAddItem}\n disabled={isSubmitting}\n >\n <Plus size={18} className=\"mr-1\" />\n </Button>)}\n </div>\n </div>\n </FormControl>\n\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { Card, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Switch } from \"@/src/components/ui\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\n\nexport class SwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldSwitch input={input} form={form} isSubmitting={isSubmitting} />\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldSwitch = ({ input, form, isSubmitting }: Props): JSX.Element => {\n const className = input.className\n return (<FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <Card className={`${className ? className : 'p-3 shadow-lg bg-blue-100/20'}`}>\n\n <FormItem className=\"flex flex-row items-center justify-between rounded-lg\">\n <div className=\"space-y-0.5\">\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormDescription>{input.placeHolder ?? input.description}</FormDescription>\n <FormMessage />\n </div>\n <FormControl>\n <Switch checked={field.value} \n onCheckedChange={(event)=> { handleOnChage(event, input, field)}} \n disabled={false} />\n </FormControl>\n </FormItem>\n </Card>\n )} />)\n}\n\n","'use client'\nimport React, { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Badge, FormControl, FormField, FormItem, FormLabel, FormMessage, Input } from \"@/src/components/ui\";\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { cn } from \"@/src/lib/utils\";\n\n\n\n\nexport class TagInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldTags input={input} form={form} isSubmitting={isSubmitting}/>\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldTags = ({ input, form, isSubmitting }: Props): JSX.Element => {\n\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">\n {input.label || input.name}\n </FormLabel>\n </div>\n\n <FormControl>\n <TagsInput\n input={input}\n value={field.value ?? []}\n onValueChange={(event)=> handleOnChage(event, input, field)}\n placeholder=\"Enter for add tag\"\n />\n </FormControl>\n\n <FormMessage />\n </FormItem>\n )} />;\n\n return <>{formField}</>;\n \n}\n\n\n\n/**\n * used for identifying the split char and use will pasting\n */\nconst SPLITTER_REGEX = /[\\n#?=&\\t,./-]+/;\n\n/**\n * used for formatting the pasted element for the correct value format to be added\n */\n\nconst FORMATTING_REGEX = /^[^a-zA-Z0-9]*|[^a-zA-Z0-9]*$/g;\n\ninterface TagsInputProps extends React.HTMLAttributes<HTMLDivElement> {\n input: FieldProps;\n value: string[];\n onValueChange: (value: string[]) => void;\n placeholder?: string;\n maxItems?: number;\n minItems?: number;\n /** Donde mostrar los tags: 'top' o 'bottom', default 'bottom' */\n tagsPosition?: 'top' | 'bottom';\n}\n\nconst TagsInput = React.forwardRef<HTMLDivElement, TagsInputProps>(\n (\n {\n input,\n value,\n onValueChange,\n placeholder,\n maxItems,\n minItems,\n tagsPosition = 'bottom',\n className,\n dir,\n ...props\n },\n ref\n ) => {\n const [inputValue, setInputValue] = React.useState(\"\");\n const parseMinItems = minItems ?? 0;\n const parseMaxItems = maxItems ?? Infinity;\n\n const addTag = (val: string) => {\n if ((!value.includes(val) && value.length < parseMaxItems) || input.withDuplicatTag) {\n onValueChange([...value, val]);\n }\n };\n\n const removeTag = (val: string) => {\n if (value.includes(val) && value.length > parseMinItems) {\n onValueChange(value.filter((v) => v !== val));\n }\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter' && inputValue.trim() !== '') {\n e.preventDefault();\n addTag(inputValue.trim());\n setInputValue('');\n }\n if (e.key === 'Backspace' && inputValue === '' && value.length > 0) {\n removeTag(value[value.length - 1]);\n }\n };\n\n const handlePaste = (e: React.ClipboardEvent<HTMLInputElement>) => {\n e.preventDefault();\n const tags = e.clipboardData.getData('text').split(SPLITTER_REGEX)\n .map(t => t.replace(FORMATTING_REGEX, '').trim())\n .filter(t => t && !value.includes(t))\n .slice(0, parseMaxItems - value.length);\n if (tags.length) onValueChange([...value, ...tags]);\n };\n\n const renderTags = () => (\n <div className=\"flex flex-wrap gap-1 mb-1 mt-1\">\n {value.map(tag => (\n <Badge\n key={tag}\n className=\"flex items-center gap-1 px-2 py-0.5 rounded bg-muted text-muted-foreground text-xs\"\n >\n {tag}\n <button\n type=\"button\"\n onClick={() => removeTag(tag)}\n className=\"ml-1 text-xs hover:text-destructive\"\n >\n ×\n </button>\n </Badge>\n ))}\n </div>\n );\n\n return (\n <div {...props} ref={ref} className={cn(\"w-full\", className)}>\n {tagsPosition === 'top' && renderTags()}\n <input\n value={inputValue}\n onChange={(e) => setInputValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onPaste={handlePaste}\n placeholder={placeholder}\n className=\"w-full px-2 py-1 border rounded focus:outline-none focus:ring focus:ring-primary\"\n />\n {tagsPosition === 'bottom' && renderTags()}\n </div>\n );\n }\n);\n\nTagsInput.displayName = 'TagsInput';\n","'use client'\nimport { JSX, ChangeEvent } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Textarea } from \"@/src/components/ui\"\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base\";\n\n\nexport class TextAreaInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldTextArea form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nfunction FieldTextArea({ form, input, isSubmitting }: Props): JSX.Element {\n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className=\"shadow-lg\">\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <Textarea className=\"min-w-[260px] bg-white\" \n placeholder={input.placeHolder} \n {...field} \n onChange={(event: ChangeEvent<HTMLTextAreaElement>) => {\n handleOnChage(event, input, field)\n }}\n disabled={input.disabled || isSubmitting} />\n </FormControl>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )} />;\n}\n\n","'use client'\nimport { JSX } from \"react\";\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { BaseInput, FieldProps, handleOnChage, InputTypes } from \"../base\";\n\n\nexport class TextInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldText form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\n\nconst FieldText = ({input, form, isSubmitting }: Props ): JSX.Element => {\n const hidden = input.hidden ?? input.inputType === InputTypes.HIDDEN;\n const type = hidden ? \"hidden\" : input.keyboardType || \"text\";\n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className={input.className}>\n { !hidden && (<FormLabel><b>{input.label}</b></FormLabel>)}\n <FormControl className=\"shadow-lg\">\n <Input className=\"min-w-[180px]\" placeholder={input.placeHolder} {...field} type={type}\n onChange={(e)=> handleOnChage(e, input, field)}\n disabled={input.disabled || isSubmitting} />\n </FormControl>\n {input.description && <FormDescription> {input.description} </FormDescription>}\n <FormMessage />\n {/* <pre> {JSON.stringify(field, null, 2)}</pre> */}\n </FormItem>\n )} />;\n}\n\n","'use client'\n\nimport { JSX, useState, useEffect } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { InputGroup, InputGroupAddon, InputGroupInput, InputGroupText } from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class TimeInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldTimeInput = ({ form, input, isSubmitting }: Props) => {\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n // Estado local para la hora\n const [time, setTime] = useState<string>(() => form.getValues(input.name) ?? \"\");\n\n useEffect(() => {\n const fieldValue = form.getValues(input.name) ?? \"\";\n if (fieldValue !== time) setTime(fieldValue);\n }, [form.getValues(input.name)]);\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n\n const handleChange = (val: string) => {\n setTime(val);\n handleOnChage(val, input, field)\n field.onChange(val);\n };\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n <InputGroup>\n\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input de tipo time */}\n <InputGroupInput\n type=\"time\"\n value={time}\n disabled={input.disabled || isSubmitting}\n onChange={(e) => handleChange(e.target.value)}\n />\n\n {/* Iconos derecha */}\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <InputGroupAddon align=\"inline-end\">\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n\n </InputGroup>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport { UseFormReturn } from \"react-hook-form\";\nimport { BaseInput, FieldConfig, FieldProps, InputTypes } from \"./base\";\nimport { \n TextInput,\n SelectInput,\n ColorInput,\n DateInput,\n NumberInput,\n SwitchInput,\n GroupedSwitchInput,\n OTPInput,\n FileInput,\n TextAreaInput,\n TextInputGroup,\n CheckboxInput,\n SimpleCheckListInput,\n RadioGroupInput,\n TagInput,\n DateTimeInput,\n TimeInput,\n FileMultiUploadInput,\n SliderInput,\n ButtonGroupInput,\n CurrencyInput,\n KeyValueListInput,\n RepeaterInput,\n MultiSelectInput,\n ComboboxInput,\n SortableListInput,\n RepeaterTabsInput,\n StringValueListInput,\n // SwitchListInput, // ES LO MISMO QUE => GroupedSwitchInput\n // CheckListInput,\n} from \"./types\";\nimport { JSX } from \"react\";\nimport z, { ZodObject, ZodTypeAny } from \"zod\";\nimport { AccordionGroupedSwitchInput } from \"./types/accordion-grouped-switches\";\nimport { Card } from '@/src/components/ui/card';\n\n\ntype InputClassConstructor = new (\n input: FieldProps,\n form: UseFormReturn,\n isSubmitting?: boolean\n) => BaseInput;\n\n\nconst inputMap: Record<InputTypes, InputClassConstructor> = {\n [InputTypes.TEXT_GROUP]: TextInputGroup,\n [InputTypes.TEXT]: TextInput,\n [InputTypes.SWITCH]: SwitchInput,\n [InputTypes.COLOR]: ColorInput,\n [InputTypes.DATE]: DateInput,\n [InputTypes.NUMBER]: NumberInput,\n [InputTypes.SELECT]: SelectInput,\n [InputTypes.GROUPED_SWITCH_LIST]: GroupedSwitchInput,\n [InputTypes.ACCORDION_GROUPED_SWITCH_LIST]: AccordionGroupedSwitchInput,\n [InputTypes.CHECKBOX]: CheckboxInput,\n [InputTypes.OTP]: OTPInput,\n [InputTypes.FILE]: FileInput,\n [InputTypes.SIMPLE_CHECK_LIST]: SimpleCheckListInput,\n [InputTypes.TEXTAREA]: TextAreaInput,\n [InputTypes.RADIO_GROUP]: RadioGroupInput,\n [InputTypes.TAGS]: TagInput,\n [InputTypes.DATE_TIME]: DateTimeInput,\n [InputTypes.TIME]: TimeInput,\n [InputTypes.FILE_MULTI_UPLOAD]: FileMultiUploadInput,\n [InputTypes.BUTTON_GROUP]: ButtonGroupInput,\n [InputTypes.CURRENCY]: CurrencyInput,\n [InputTypes.KEY_VALUE]: KeyValueListInput,\n [InputTypes.REPEATER]: RepeaterInput,\n [InputTypes.MULTI_SELECT]: MultiSelectInput,\n [InputTypes.COMBOBOX]: ComboboxInput,\n [InputTypes.SORTABLE_LIST]: SortableListInput,\n [InputTypes.REPEATER_TABS]: RepeaterTabsInput,\n [InputTypes.STRING_LIST]: StringValueListInput,\n \n \n //ToDos: ============================================================\n [InputTypes.SLIDER]: SliderInput, //ToDo: // PENDIENTE ... VISUALMENTE NO SE VE BIEN.!!!\n [InputTypes.FORM]: TextInput,\n [InputTypes.HIDDEN]: TextInput,\n [InputTypes.CHECK_LIST]: TextInput,\n // [InputTypes.SWITCH_LIST]: SwitchListInput,\n\n // [InputTypes.RANGE]: TextInput,\n // [InputTypes.MULTISELECT]: TextInput,\n \n // [InputTypes.IMAGE_UPLOAD]: TextInput,\n // [InputTypes.AUDIO_UPLOAD]: TextInput,\n // [InputTypes.VIDEO_UPLOAD]: TextInput,\n \n // [InputTypes.CREDIT_CARD]: TextInput,\n\n};\n\nexport class InputFactory {\n static create<T extends Record<string, any> = Record<string, any>>(\n input: FieldProps<T>,\n form: UseFormReturn<T>,\n isSubmitting: boolean = false\n ): JSX.Element {\n input.form = form\n const inputType = (input.inputType as InputTypes) ?? InputTypes.TEXT;\n\n const InputClass = (inputMap[inputType] ??\n TextInput) as new (\n input: FieldProps<T>,\n form: UseFormReturn<T>,\n isSubmitting: boolean\n ) => { render: () => JSX.Element };\n\n const instance = new InputClass(input, form, isSubmitting);\n\n if (!input.wrapInCard) return instance.render();\n\n return (\n <Card className=\"p-4 space-y-3\">\n {instance.render()}\n </Card>\n );\n }\n}\n\nexport function getDefaultValues<T extends Record<string, any>>(\n entity?: Partial<T>,\n fields?: FieldConfig<T>[]\n): Record<string, any> {\n const defaults: Record<string, any> = {};\n\n if (entity) {\n Object.entries(entity).forEach(([key, value]) => {\n defaults[key] = value ?? \"\";\n });\n }\n\n if (fields) {\n const flatFields = flattenFields(fields); // ✅ aplanado recursivo completo\n for (const field of flatFields) {\n const key = field.name as string;\n if (defaults[key] === undefined) {\n defaults[key] = field.value ?? field.defaultValue ?? \"\";\n }\n }\n }\n\n return defaults;\n}\n\n\n\nconst flattenFields = <T extends Record<string, any>>(fields: FieldConfig<T>[]): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n result.push(...flattenFields((field as any).fields));\n } else {\n result.push(field);\n }\n }\n\n return result;\n};\n\nexport const getDynamicSchema = <T extends Record<string, any>>(\n fields: FieldConfig<T>[],\n extraValidations?: ((schema: ZodObject<any>) => ZodObject<any>)[]\n): ZodObject<Record<keyof T, ZodTypeAny>> => {\n\n // 🔁 aplanamos el árbol completo de campos\n const flatFields = flattenFields(fields);\n\n // 🎯 construimos el shape del schema\n const shape = flatFields.reduce((acc, f) => {\n acc[f.name as keyof T] = f.zodType ?? z.any();\n return acc;\n }, {} as Record<keyof T, ZodTypeAny>);\n\n let schema: ZodObject<Record<keyof T, ZodTypeAny>> = z.object(shape);\n\n // ⚙️ Aplicar validaciones adicionales si las hay\n if (extraValidations?.length) {\n for (const fn of extraValidations) {\n schema = fn(schema);\n }\n }\n\n return schema;\n};","import { FieldValues, FormState } from \"react-hook-form\";\nimport { CustomAlert } from \"@/src/components/custom/custom-alert\";\nimport { FieldConfig, FieldProps } from \"./definitions\";\n\n// ✅ mismo tipo recursivo que usamos antes\n\n\ninterface Props<T extends FieldValues = Record<string, any>> {\n formState: FormState<any>;\n fields: FieldConfig<T>[]; // 👈 ahora soporta anidación\n}\n\n/**\n * 🔁 Función recursiva para aplanar la estructura de campos\n */\nconst flattenFields = <T extends FieldValues>(\n fields: FieldConfig<T>[]\n): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n // 👇 si el campo tiene subcampos, también los aplanamos\n result.push(...flattenFields((field as any).fields));\n } else {\n result.push(field);\n }\n }\n\n return result;\n};\n\nexport const FormErrorsAlert = <T extends FieldValues = Record<string, any>>({\n formState,\n fields,\n}: Props<T>) => {\n const flatFields = flattenFields(fields); // ✅ recursivo\n\n const hasErrors = Object.keys(formState.errors).length > 0;\n\n return (\n <div style={{ marginTop: 4 }}>\n {hasErrors && (\n <CustomAlert\n title=\"Revisar los siguientes criterios\"\n description={\n <ul>\n {Object.entries(formState.errors).map(([key, value]) => (\n <li key={key}>\n <strong>{getFieldLabel<T>(key, flatFields)}:</strong>{\" \"}\n {value?.message?.toString() ?? \"\"}\n </li>\n ))}\n </ul>\n }\n className=\"mb-4\"\n variant=\"error\"\n />\n )}\n </div>\n );\n};\n\nexport const getFieldLabel = <T extends FieldValues>(\n fieldErrorKey: string,\n fields: ReadonlyArray<FieldProps<T>>\n): string => {\n const foundField = fields.find((field) => field.name === fieldErrorKey);\n return foundField?.label ?? fieldErrorKey;\n};\n","'use client';\n\nimport { JSX, ReactNode } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldConfig } from \"./base\";\nimport { InputFactory } from \"./input-factory\";\n\ninterface Props<T extends Record<string, any> = Record<string, any>> {\n fields: FieldConfig<T>[];\n form: UseFormReturn<any>;\n readOnly?: boolean;\n isPending?: boolean;\n className?: string;\n gap?: string; // opcional, para espacio entre columnas\n}\n\nconst isRenderableChild = (c?: ReactNode | ((item: any, index: number) => ReactNode)) =>\n c !== undefined && c !== null && typeof c !== \"function\";\n\n/**\n * 📋 FormFieldsGrid\n * Componente reutilizable para renderizar campos en una cuadrícula flexible.\n * - Si un elemento del arreglo es un solo FieldProps → muestra en una línea.\n * - Si es un arreglo de FieldProps → los muestra en una misma fila.\n */\nexport const FormFieldsGrid = <T extends Record<string, any> = Record<string, any>>({\n fields,\n form,\n isPending,\n readOnly,\n className = \"\",\n gap = \"gap-2\",\n}: Props<T>): JSX.Element => {\n return (\n <div className={`w-full grid grid-cols-1 ${gap} ${className}`}>\n {fields.map((inputOrGroup, idx) =>\n Array.isArray(inputOrGroup) ? (\n <div\n key={`field-group-${idx}`}\n className=\"w-full flex flex-row items-start gap-4 py-3\"\n >\n {inputOrGroup.map((field, subIdx) => {\n // NO mutamos field: creamos una copia (inmutable)\n const fieldCopy = {\n ...(field as any),\n disabled: readOnly ? true : (field as any).disabled,\n };\n\n const renderInlineChild =\n fieldCopy.childrenPosition !== \"down\" && isRenderableChild(fieldCopy.children);\n\n const renderInlineChildDown =\n fieldCopy.childrenPosition === \"down\" && isRenderableChild(fieldCopy.children);\n\n return (\n <div key={`field-${idx}-${subIdx}`} className=\"w-full px-2\">\n {renderInlineChild && <>{fieldCopy.children}</>}\n {/*\n Pasamos children a InputFactory.create para que el componente concreto\n (p. ej. SortableListInput) lo use si es función render-prop.\n InputFactory.create signature se adapta abajo si es necesario.\n */}\n {InputFactory.create(fieldCopy, form, isPending)}\n {renderInlineChildDown && <>{fieldCopy.children}</>}\n </div>\n );\n })}\n </div>\n ) : (\n <div\n key={`field-single-${idx}`}\n className=\"flex flex-col justify-between py-3 w-full px-2\"\n >\n {(() => {\n const fieldCopy = {\n ...(inputOrGroup as any),\n disabled: readOnly ? true : (inputOrGroup as any).disabled,\n };\n\n const renderUp = fieldCopy.childrenPosition !== \"down\" && isRenderableChild(fieldCopy.children);\n const renderDown = fieldCopy.childrenPosition === \"down\" && isRenderableChild(fieldCopy.children);\n\n return (\n <>\n {renderUp && <>{fieldCopy.children}</>}\n {InputFactory.create(fieldCopy, form, isPending)}\n {renderDown && <>{fieldCopy.children}</>}\n </>\n );\n })()}\n </div>\n )\n )}\n </div>\n );\n};","'use client';\n\nimport { ReactNode, useEffect, useMemo, useTransition } from \"react\";\nimport { useForm, UseFormReturn, DefaultValues, Resolver } from \"react-hook-form\";\nimport { BtnConfig, FieldConfig, FieldProps, flattenFields } from \"./base\";\nimport { getDefaultValues, getDynamicSchema } from \"./input-factory\";\nimport { FormErrorsAlert } from \"./base/form-errors\";\nimport { Button, Card, CardContent, CardDescription, CardTitle, Form } from '@/src/components/ui';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { Loader2, Pencil, Save } from \"lucide-react\";\nimport { ZodObject, z } from \"zod\";\nimport { FormFieldsGrid } from \"./FormFieldsGrid\";\nimport { ButtonGroup } from \"@/src/components/ui/button-group\";\nimport { cn } from \"@/src/lib/utils\";\n\ntype alertPositionType = 'up' | 'down';\n\nexport interface FormResp<T> {\n form?: UseFormReturn<any>;\n data: T;\n}\n\ninterface Props<T extends Record<string, any>> {\n showIcon?: boolean;\n showFormHeader?: boolean;\n formTitle: string;\n formSubTitle?: string;\n readOnly?: boolean;\n fields: FieldConfig<T>[];\n record?: Partial<T>;\n onAnyFieldChange?: (data: Record<string,any>) => void;\n onSubmit?: (resp: FormResp<T>) => void;\n onClick?: (resp: FormResp<T>) => void;\n extraValidations?: ((schema: ZodObject<any>) => ZodObject<any>)[];\n withErrorsAlert?: boolean;\n errorAlertPosition?: alertPositionType;\n withCard?: boolean;\n withFormWrapper?: boolean;\n withSubmitBtn?: boolean;\n submitBtnLabel?: string;\n submitBtnLabelSubmiting?: string;\n submitBtnClass?: string;\n btnGroupDirection?: 'flex-start' | 'flex-end' | 'flex-center';\n children?: ReactNode;\n childrenHeader?: ReactNode;\n listBtnConfig?: BtnConfig[];\n}\n\nexport const DynamicForm = <T extends Record<string, any>>({\n formTitle,\n formSubTitle,\n fields,\n readOnly = false,\n record = {},\n onAnyFieldChange,\n onSubmit,\n onClick,\n extraValidations,\n children,\n childrenHeader,\n showIcon = false,\n showFormHeader = true,\n withErrorsAlert = true,\n errorAlertPosition = 'up',\n withCard = false,\n submitBtnClass=\"\",\n listBtnConfig = [],\n submitBtnLabel = 'Guardar',\n submitBtnLabelSubmiting = 'Guardando...',\n withFormWrapper = true,\n btnGroupDirection = \"flex-end\",\n withSubmitBtn = true\n}: Props<T>) => {\n\n const [isPending, startTransition] = useTransition();\n\n /** ✅ Schema dinámico basado en los campos */\n const schema = useMemo(() => {\n // const flattenFields = (items: any[]): FieldProps<T>[] => {\n // return items.flatMap(item => \n // Array.isArray(item) ? flattenFields(item) : item\n // );\n // };\n\n const allFields = flattenFields(fields, onAnyFieldChange);\n return getDynamicSchema<T>(allFields, extraValidations);\n}, [fields, extraValidations]);\n\n type FormData = z.infer<typeof schema>;\n const resolver = zodResolver(schema) as unknown as Resolver<FormData>;\n\n const initialValues = useMemo(() => getDefaultValues<T>(record), [record]);\n\n const form = useForm<FormData>({\n resolver,\n defaultValues: initialValues as unknown as DefaultValues<FormData>,\n });\n\n /** 🔄 Reset cuando cambia record */\n useEffect(() => {\n form.reset(initialValues as unknown as DefaultValues<FormData>);\n // }, [initialValues, form]);\n }, []);\n\n /** 💾 onSubmit */\n const handleSubmit = (data: FormData) => {\n if (readOnly) return;\n startTransition(() => {\n const resp: FormResp<T> = { data: data as unknown as T, form };\n onSubmit?.(resp);\n });\n };\n\n /** 🖱️ onClick con validación */\n const handleClick = async () => {\n if (!onClick) return;\n const isValid = await form.trigger();\n if (!isValid) return;\n\n const data = form.getValues() as unknown as T;\n const resp: FormResp<T> = { data, form };\n onClick(resp);\n };\n\n const formBody = (\n <>\n <div className=\"w-full grid grid-cols-1\">\n <FormFieldsGrid\n fields={fields as unknown as FieldConfig<T>[]}\n form={form}\n readOnly={readOnly}\n />\n {children && (\n <div className=\"flex flex-row items-center gap-2 w-full h-full\">\n {children}\n </div>\n )}\n </div>\n\n <ButtonGroup className=\"flex flex-row w-full h-full\" style={{\n justifyContent: btnGroupDirection, // Alinea horizontalmente a la derecha\n alignItems: \"center\", // Centra verticalmente (opcional)\n }}>\n {listBtnConfig.map((btn, key) => (\n <Button\n type={btn.btnType}\n key={key}\n size=\"lg\"\n className={submitBtnClass}\n variant={btn.variant}\n onClick={btn.onClick}\n disabled={btn.disabled}\n >\n {btn.label}\n </Button>\n ))}\n {!readOnly && withSubmitBtn && (\n <Button\n type={onClick ? 'button' : 'submit'}\n size=\"lg\"\n className={cn(submitBtnClass)}\n disabled={isPending}\n onClick={onClick ? handleClick : undefined}\n >\n {isPending ? (\n <>\n <Loader2 className=\"h-5 w-5 mr-2 animate-spin\" />\n {submitBtnLabelSubmiting}\n </>\n ) : (\n <>\n <Save className=\"h-5 w-5 mr-2\" />\n {submitBtnLabel}\n </>\n )}\n </Button>\n )}\n </ButtonGroup>\n </>\n )\n\n /** 🧩 Render del contenido principal del formulario */\n const formContent = (\n <div>\n {showFormHeader && (\n <CardTitle className=\"flex flex-row items-center gap-2 p-2 border-b\">\n <div className=\"flex flex-row items-center gap-2 w-full\">\n {showIcon && <Pencil className=\"h-5 w-5\" />}\n <div className=\"flex flex-col\">\n <div className=\"text-xl\">{formTitle}</div>\n {formSubTitle && <CardDescription>{formSubTitle}</CardDescription>}\n </div>\n </div>\n {childrenHeader && (\n <div className=\"flex flex-row items-center gap-2 w-full h-full\">\n {childrenHeader}\n </div>\n )}\n </CardTitle>\n )}\n\n {withErrorsAlert && errorAlertPosition === 'up' && (\n <FormErrorsAlert\n formState={form.formState}\n fields={fields as unknown as FieldConfig<T>[]}\n />\n )}\n\n {withFormWrapper && (<FormWrapper form={form} handleSubmit={handleSubmit}>{formBody}</FormWrapper>)}\n {!withFormWrapper && (formBody)}\n\n\n {withErrorsAlert && errorAlertPosition === 'down' && (\n <FormErrorsAlert\n formState={form.formState}\n fields={fields.flatMap(f => Array.isArray(f) ? f : [f])}\n />\n )}\n </div>\n );\n\n if (!withCard) return formContent;\n\n return (\n <Card>\n <CardContent>{formContent}</CardContent>\n </Card>\n );\n};\n\n\ninterface FormWrapperProps {\n form:UseFormReturn<any>\n handleSubmit: (data: any) => void\n children: ReactNode;\n readOnly?: boolean\n}\n\nconst FormWrapper = ({form, handleSubmit, children, readOnly}: FormWrapperProps) => {\n return (\n <Form {...form}>\n <form\n onSubmit={form.handleSubmit(handleSubmit)}\n className={`flex flex-col gap-2 ${readOnly ? 'opacity-70 pointer-events-none select-none' : ''}`}\n >\n {children}\n </form>\n </Form>\n )\n}\n\n\n","\"use client\";\n\nimport z from \"zod\";\nimport { FieldProps, InputTypes, TextInputType } from \"./base\";\nimport { DynamicForm } from \"./DynamicForm\";\nimport validationMessages from \"../input-errors\";\n\ninterface UserFromDB {\n username: string;\n email: string;\n isActive: boolean;\n favoriteColor: undefined;\n age: number;\n role: string;\n}\n\nexport const DynamicFormExample = () => {\n const record: UserFromDB = {\n username: \"John Doe \",\n email: \"johndoe@example.com\",\n isActive: true,\n favoriteColor: undefined,\n age: 25,\n role: \"editor\",\n };\n\n return (\n <DynamicForm\n formTitle=\"User Form\"\n fields={mockFields}\n record={record}\n onSubmit={(data) => console.log(\"📤 Resultado final:\", data)}\n />\n );\n}\n\nexport const mockFields: Array<FieldProps |FieldProps[]> = [\n // 🧍♂️ Campo requerido simple\n {\n name: \"username\",\n label: \"Nombre de usuario\",\n inputType: InputTypes.TEXT,\n required: true,\n zodType: z\n .string()\n .min(3, \"El nombre debe tener al menos 3 caracteres\")\n .max(20, \"El nombre no puede tener más de 20 caracteres\"),\n },\n\n // 📧 Campo de correo con validación personalizada (ZodTypeAny)\n {\n name: \"email\",\n label: \"Correo electrónico\",\n inputType: InputTypes.TEXT,\n required: false,\n zodType: z\n .string()\n .email(\"Correo inválido\")\n .toLowerCase()\n .refine((val) => !val.endsWith(\"@spam.com\"), {\n message: \"No se permiten correos de spam.com\",\n }),\n },\n\n // 🔒 Campo opcional (no requerido)\n {\n name: \"password\",\n label: \"Contraseña\",\n inputType: InputTypes.TEXT,\n required: false,\n keyboardType: TextInputType.PASSWORD,\n zodType: z\n .string()\n .min(6, \"Debe tener al menos 6 caracteres\")\n .max(20, \"No más de 20 caracteres\")\n .optional(),\n },\n\n // 🟢 Campo tipo switch (boolean)\n {\n name: \"isActive\",\n label: \"Usuario activo\",\n inputType: InputTypes.SWITCH,\n required: false,\n zodType: z.boolean().default(true),\n },\n\n // 🎨 Color con validación personalizada\n [ \n {\n name: \"favoriteColor\",\n label: \"Color favorito\",\n inputType: InputTypes.COLOR,\n required: false,\n zodType: z\n .string()\n .regex(/^#([0-9A-Fa-f]{6})$/, \"Debe ser un color hexadecimal válido\"),\n },\n\n // 🔢 Número con rango\n {\n name: \"age\",\n label: \"Edad\",\n inputType: InputTypes.NUMBER,\n required: true,\n zodType: z\n .coerce.number() // fuerza a number\n .min(18, \"Debe ser mayor de 18\")\n .max(99, \"Debe ser menor de 99\"),\n }\n ],\n\n // 📅 Fecha\n {\n name: \"birthDate\",\n label: \"Fecha de nacimiento\",\n inputType: InputTypes.DATE,\n required: true,\n zodType: z.coerce.date().refine((d) => d < new Date(), {\n message: \"La fecha no puede ser futura\",\n }),\n },\n\n // 🎓 Select con validación personalizada\n {\n name: \"role\",\n label: \"Rol de usuario\",\n inputType: InputTypes.SELECT,\n required: true,\n listConfig: {\n onOptionChange: () =>{},\n list: [\n { id: 1, name: \"Administrador\", value: \"admin\" },\n { id: 2, name: \"Editor\", value: \"editor\" },\n { id: 3, name: \"Lector\", value: \"reader\" },\n ]\n },\n zodType: z.enum([\"admin\", \"editor\", \"reader\"]),\n },\n\n // 🧾 Campo tipo archivo (file)\n {\n name: \"profileImage\",\n label: \"Imagen de perfil\",\n inputType: InputTypes.FILE,\n required: false,\n zodType: z\n .any()\n .refine(\n (file) => {\n if (!file) return true;\n return (\n file.size <= 10 * 1024 * 1024 &&\n [\"image/jpeg\", \"image/png\"].includes(file.type)\n );\n },\n { message: \"Solo se permiten imágenes JPG o PNG de menos de 10MB\" }\n )\n .optional(),\n },\n\n // 🔢 OTP (código)\n {\n name: \"otpCode\",\n label: \"Código OTP\",\n inputType: InputTypes.OTP,\n required: true,\n zodType: z\n .string()\n .min(4, \"Debe tener al menos 4 dígitos\")\n .max(6, \"Debe tener máximo 6 dígitos\"),\n },\n ];","import { useState } from \"react\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Switch } from \"@/src/components/ui/switch\";\nimport { Accordion, AccordionContent, AccordionItem, AccordionTrigger } from \"@/src/components/ui/accordion\";\nimport { Plus } from 'lucide-react';\nimport { InputSetup, InputTypes } from \"./form/inputs/base\";\n\ninterface Props {\n handleAddInput: (type: InputTypes, config?: InputSetup) => void;\n inputsTypes: InputTypes[];\n}\n\n\n\nexport const InputList = ({ handleAddInput, inputsTypes, }: Props) => {\n // Estado: un objeto donde la clave es el inputType y el valor su configuración\n const [inputSetups, setInputSetups] = useState<Record<string, InputSetup>>(() =>\n Object.fromEntries(\n inputsTypes.map((type) => [type, { required: false, disabled: false }])\n )\n );\n\n const toggleConfig = (type: string, key: keyof InputSetup) => {\n setInputSetups((prev) => ({\n ...prev,\n [type]: { ...prev[type], [key]: !prev[type][key] },\n }));\n };\n\n return (\n <div className=\"grid grid-cols-1 gap-1\">\n {inputsTypes.map((type) => {\n const setup = inputSetups[type];\n return (\n <div\n key={type}\n className=\"border rounded-lg p-2 flex flex-col-2 gap-1 shadow-sm\"\n >\n <Button size=\"icon\" onClick={() => handleAddInput(type, setup)} >\n <Plus/>\n </Button>\n <Accordion type=\"single\" collapsible className=\"w-full\">\n <AccordionItem value=\"item-1\">\n <AccordionTrigger>\n <div className=\"flex flex-row justify-center w-full content-center\">\n <span className=\"font-semibold text-xl\">{type}</span>\n </div>\n </AccordionTrigger>\n <AccordionContent>\n {/* ✅ Controles para configurar */}\n <div className=\"flex flex-col gap-1\">\n <label className=\"flex items-center gap-2\">\n <Switch\n checked={setup.required}\n onCheckedChange={() => toggleConfig(type, \"required\")}\n />\n <span>Required</span>\n </label>\n\n <label className=\"flex items-center gap-2\">\n <Switch\n checked={setup.disabled}\n onCheckedChange={() => toggleConfig(type, \"disabled\")}\n />\n <span>Disabled</span>\n </label>\n </div>\n </AccordionContent>\n </AccordionItem>\n </Accordion>\n\n {/* <div className=\"flex justify-between items-center\">\n \n <Button\n size=\"sm\"\n onClick={() => handleAddInput(type, setup)}\n >\n Agregar\n </Button>\n </div> */}\n\n \n </div>\n );\n })}\n </div>\n );\n};\n","\"use client\"\n\nimport { useState, useEffect, useRef } from \"react\"\nimport { FieldProps, GroupedOption, InputOption, InputTypes } from \"../form/inputs/base\"\nimport { DynamicForm } from \"../form/inputs/DynamicForm\"\nimport { Search } from \"lucide-react\"\n\n\ninterface GenericFilterProps<T> {\n filters?: Array<FieldProps | FieldProps[]>\n pagination?: boolean\n autoSubmit?: boolean\n defaultValues?: Record<string, any>\n initPage?: number\n initLimit?: number\n onChange?: (values: Record<string, any>) => void\n rangeLimit?: number[]\n withSearch?: boolean\n withInitDate?: boolean\n withEndDate?: boolean\n withActive?: boolean\n withLimit?: boolean\n wrapInCard?: boolean\n}\n\ninterface Filter {\n page?: number\n limit?: number\n search?: string\n active?: boolean\n initDate?: Date\n endDate?: Date\n defaultValues?: Record<string, any>\n}\n\n/**\n * ✅ Componente genérico y dinámico de filtro\n */\nexport const GenericFilter = <T,>({\n filters = [],\n pagination,\n autoSubmit = false,\n defaultValues = {},\n initPage = 1,\n initLimit = 10,\n rangeLimit = [10, 25, 50, 100],\n onChange,\n withSearch = true,\n withInitDate = true,\n withEndDate = true,\n withActive = true,\n withLimit = true,\n wrapInCard = true,\n}: GenericFilterProps<T>) => {\n const record: Filter = {\n page: initPage,\n limit: initLimit,\n ...defaultValues,\n }\n\n const [values, setValues] = useState<Filter>(record)\n const isFirstRender = useRef(true)\n\n useEffect(() => {\n if (isFirstRender.current) {\n isFirstRender.current = false\n return\n }\n }, [values])\n\n const handleChange = (name: string, value: any) => {\n setValues((prev) => ({ ...prev, [name]: value }))\n if (autoSubmit && onChange) onChange({ ...values, [name]: value })\n }\n\n const handleReset = () => {\n setValues({\n page: initPage,\n limit: initLimit,\n ...defaultValues,\n })\n }\n\n // 🧩 Filtros base (predefinidos)\n const baseFields: FieldProps[] = [\n ...(withSearch\n ? [\n {\n name: \"search\",\n label: \"Buscar\",\n inputType: InputTypes.TEXT_GROUP,\n inputGroupConfig: { iconsLeft: [Search] },\n onChange: (value: any) => handleChange(\"search\", value),\n } as FieldProps,\n ]\n : []),\n ...(withInitDate\n ? [\n {\n name: \"initDate\",\n label: \"Fecha de Inicio\",\n inputType: InputTypes.DATE,\n onChange: (value: any) => handleChange(\"initDate\", value),\n } as FieldProps,\n ]\n : []),\n ...(withEndDate\n ? [\n {\n name: \"endDate\",\n label: \"Fecha Final\",\n inputType: InputTypes.DATE,\n onChange: (value: any) => handleChange(\"endDate\", value),\n } as FieldProps,\n ]\n : []),\n ...(withActive\n ? [\n {\n wrapInCard: true,\n name: \"active\",\n label: \"\",\n inputType: InputTypes.BUTTON_GROUP,\n description: \"Estado\",\n listConfig: {\n list: [\n { id: 1, name: \"Activo\", value: true },\n { id: 2, name: \"Inactivo\", value: false },\n { id: 3, name: \"Todos\", value: undefined },\n ],\n onOptionChange: (item?: InputOption | InputOption[]) => {\n if (Array.isArray(item) && item[0]) handleChange(\"active\", item[0].value)\n else if (item && \"value\" in item) handleChange(\"active\", item.value)\n },\n },\n } as FieldProps,\n ]\n : []),\n ...(withLimit\n ? [\n {\n name: \"limit\",\n label: \"Límite por página\",\n inputType: InputTypes.SELECT,\n listConfig: {\n list: rangeLimit.map((num) => ({\n value: String(num),\n id: num,\n name: String(num),\n })),\n onOptionChange: (item: any) => handleChange(\"limit\", Number(item?.value ?? 10)),\n },\n } as FieldProps,\n ]\n : []),\n ]\n\n \n // 🧱 Combina todos los campos\n const fieldsConfig: Array<FieldProps | FieldProps[]> = [\n ...filters,\n baseFields,\n ]\n\n return (\n <div className=\"flex flex-col md:flex-row md:items-end gap-4 py-3\">\n <div className=\"flex-1\">\n <DynamicForm<Filter>\n withCard={wrapInCard}\n withSubmitBtn={!autoSubmit}\n formTitle=\"\"\n submitBtnLabel=\"Buscar\"\n fields={fieldsConfig}\n record={values}\n showFormHeader={false}\n onSubmit={({ data }) => {\n if (onChange && !autoSubmit) onChange(data)\n }}\n />\n </div>\n </div>\n )\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../node_modules/clsx/dist/clsx.mjs","../src/lib/utils.ts","../src/components/ui/alert.tsx","../src/components/custom/custom-alert.tsx","../src/components/custom/form/input-errors.ts","../src/components/custom/form/inputs/base/base-input.ts","../src/components/custom/form/inputs/base/definitions.ts","../src/components/custom/form/inputs/base/input-types.ts","../src/components/ui/accordion.tsx","../src/components/ui/badge.tsx","../src/components/ui/button.tsx","../src/components/ui/calendar.tsx","../src/components/ui/card.tsx","../src/components/ui/checkbox.tsx","../src/components/ui/popover.tsx","../src/components/ui/color-input.tsx","../src/components/ui/dialog.tsx","../src/components/ui/label.tsx","../src/components/ui/separator.tsx","../src/components/ui/field.tsx","../src/components/ui/form.tsx","../src/components/ui/input.tsx","../src/components/ui/textarea.tsx","../src/components/ui/input-group.tsx","../src/components/ui/input-otp.tsx","../src/components/ui/radio-group.tsx","../src/components/ui/resizable.tsx","../src/components/ui/scroll-area.tsx","../src/components/ui/select.tsx","../src/components/ui/sonner.tsx","../src/components/ui/switch.tsx","../src/components/ui/tooltip.tsx","../src/components/custom/form/inputs/types/grouped-switches-input.tsx","../src/components/custom/form/inputs/types/accordion-grouped-switches.tsx","../src/components/ui/button-group.tsx","../src/components/custom/form/inputs/types/button-group-input.tsx","../src/components/custom/form/inputs/types/check-list-input.tsx","../src/components/custom/form/inputs/types/checkbox-input.tsx","../src/components/custom/form/inputs/types/color-input.tsx","../src/components/ui/command.tsx","../src/components/custom/form/inputs/types/combo-box-input.tsx","../src/components/custom/form/inputs/types/currency-input.tsx","../node_modules/date-fns/constants.js","../node_modules/date-fns/constructFrom.js","../node_modules/date-fns/toDate.js","../node_modules/date-fns/_lib/defaultOptions.js","../node_modules/date-fns/startOfWeek.js","../node_modules/date-fns/startOfISOWeek.js","../node_modules/date-fns/getISOWeekYear.js","../node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js","../node_modules/date-fns/_lib/normalizeDates.js","../node_modules/date-fns/startOfDay.js","../node_modules/date-fns/differenceInCalendarDays.js","../node_modules/date-fns/startOfISOWeekYear.js","../node_modules/date-fns/isDate.js","../node_modules/date-fns/isValid.js","../node_modules/date-fns/startOfYear.js","../node_modules/date-fns/locale/en-US/_lib/formatDistance.js","../node_modules/date-fns/locale/_lib/buildFormatLongFn.js","../node_modules/date-fns/locale/en-US/_lib/formatLong.js","../node_modules/date-fns/locale/en-US/_lib/formatRelative.js","../node_modules/date-fns/locale/_lib/buildLocalizeFn.js","../node_modules/date-fns/locale/en-US/_lib/localize.js","../node_modules/date-fns/locale/_lib/buildMatchFn.js","../node_modules/date-fns/locale/_lib/buildMatchPatternFn.js","../node_modules/date-fns/locale/en-US/_lib/match.js","../node_modules/date-fns/locale/en-US.js","../node_modules/date-fns/getDayOfYear.js","../node_modules/date-fns/getISOWeek.js","../node_modules/date-fns/getWeekYear.js","../node_modules/date-fns/startOfWeekYear.js","../node_modules/date-fns/getWeek.js","../node_modules/date-fns/_lib/addLeadingZeros.js","../node_modules/date-fns/_lib/format/lightFormatters.js","../node_modules/date-fns/_lib/format/formatters.js","../node_modules/date-fns/_lib/format/longFormatters.js","../node_modules/date-fns/_lib/protectedTokens.js","../node_modules/date-fns/format.js","../src/components/custom/form/inputs/types/date-input.tsx","../src/components/custom/form/inputs/types/date-time-input.tsx","../src/components/custom/form/inputs/types/file-input.tsx","../src/components/custom/form/inputs/types/file-multi-input.tsx","../src/components/custom/form/inputs/types/key-value-input.tsx","../src/components/custom/form/inputs/types/multi-select-input.tsx","../src/components/custom/form/inputs/types/text-input-group.tsx","../src/components/custom/form/inputs/types/number-input.tsx","../src/components/custom/form/inputs/types/otp-input.tsx","../src/components/custom/form/inputs/types/radio-group-input.tsx","../src/components/custom/form/inputs/types/repeater-input.tsx","../src/components/ui/tabs.tsx","../src/components/custom/form/inputs/types/repeater-tabs-input.tsx","../src/components/custom/form/inputs/types/select-input.tsx","../src/components/custom/form/inputs/types/simple-check-list-input.tsx","../src/components/ui/slider.tsx","../src/components/custom/form/inputs/types/slide-input.tsx","../src/components/custom/form/inputs/types/sortable-list-input.tsx","../src/components/custom/form/inputs/types/string-value-input.tsx","../src/components/custom/form/inputs/types/switch-input.tsx","../src/components/custom/form/inputs/types/tags-input.tsx","../src/components/custom/form/inputs/types/text-area-input.tsx","../src/components/custom/form/inputs/types/text-input.tsx","../src/components/custom/form/inputs/types/time-input.tsx","../src/components/custom/form/inputs/input-factory.tsx","../src/components/custom/form/inputs/base/form-errors.tsx","../src/components/custom/form/inputs/FormFieldsGrid.tsx","../src/components/custom/form/inputs/DynamicForm.tsx","../src/components/custom/form/inputs/DynamicFormExample.tsx","../src/components/custom/input-list.tsx","../src/components/custom/others/GenericFilter.tsx"],"names":["jsx","TextInputType","InputTypes","jsxs","cva","Slot","formatters","className","props","ChevronDownIcon","React","React2","React4","CheckIcon","Sonner","useState","input","useEffect","useColor","ColorPicker","CommandPrimitive","React6","value","isValid","useMemo","defaultOptions","format","localize","formatLong","CircleCheck","CircleX","Loader2","React7","Fragment","useRef","Label","ChevronsUpDown","Check","EyeOff","Eye","OTPInput","Trash2","Plus","useFieldArray","React8","FieldTimeInput","flattenFields","z"],"mappings":"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","file":"index.mjs","sourcesContent":["function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","import { clsx, type ClassValue } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n","import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst alertVariants = cva(\n \"relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current\",\n {\n variants: {\n variant: {\n default: \"bg-card text-card-foreground\",\n destructive:\n \"text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Alert({\n className,\n variant,\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof alertVariants>) {\n return (\n <div\n data-slot=\"alert\"\n role=\"alert\"\n className={cn(alertVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nfunction AlertTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"alert-title\"\n className={cn(\n \"col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction AlertDescription({\n className,\n ...props\n}: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"alert-description\"\n className={cn(\n \"text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Alert, AlertTitle, AlertDescription }\n","'use client'\n\nimport { ReactNode } from \"react\";\nimport { MessageCircleWarning } from \"lucide-react\";\nimport { InfoCircledIcon } from '@radix-ui/react-icons';\nimport { Alert, AlertDescription, AlertTitle } from \"@/src/components/ui/alert\";\nimport { cn } from \"@/src/lib/utils\";\n\ninterface Props {\n title: string;\n description: string | ReactNode;\n className?: string;\n variant?: \"info\" | \"warning\" | \"error\" | \"success\";\n}\n\nexport const CustomAlert = ({\n title,\n description,\n className = \"\",\n variant = \"info\",\n}: Props) => {\n const variantClasses = {\n info: \"bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200\",\n warning: \"bg-yellow-100 text-yellow-800 dark:bg-yellow-900 dark:text-yellow-200\",\n error: \"bg-red-100 text-red-800 dark:bg-red-900 dark:text-red-200\",\n success: \"bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200\",\n };\n\n const variantIcons = {\n info: <MessageCircleWarning size={32} className=\"text-blue-500 dark:text-blue-300\" />,\n warning: <MessageCircleWarning size={32} className=\"text-yellow-500 dark:text-yellow-300\" />,\n error: <MessageCircleWarning size={32} className=\"text-red-500 dark:text-red-300\" />,\n success: <InfoCircledIcon className=\"w-8 h-8 text-green-500 dark:text-green-300\" />,\n };\n\n return (\n <Alert\n className={cn(\n \"mb-4 flex items-start gap-3 border-l-4 p-4 rounded-lg\",\n variantClasses[variant],\n className\n )}\n >\n {/* Icono a la izquierda */}\n <div className=\"flex flex-col shrink-0\">{variantIcons[variant]}</div>\n\n {/* Texto a la derecha */}\n <div className=\"flex flex-col\">\n <AlertTitle className=\"font-semibold text-lg\">{title}</AlertTitle>\n <AlertDescription className=\"text-sm text-muted-foreground dark:text-gray-300\">\n {description}\n </AlertDescription>\n </div>\n </Alert>\n );\n};\n","export const validationMessages = {\n required: \"Este campo es obligatorio\",\n email: \"El correo electrónico no es válido\",\n invalidFormat: \"Formato inválido\",\n onlyPositive: \"Solo números positivos\",\n minLength: (length: number) => `Debe tener al menos ${length} caracteres`,\n maxLength: (length: number) => `No puede tener más de ${length} caracteres`,\n passwordMismatch: \"Las contraseñas no coinciden\",\n invalidPhone: \"El número de teléfono no es válido\",\n};\n\nexport default validationMessages;","import { JSX, ReactNode } from \"react\";\n\nimport { ControllerRenderProps, FieldValues, UseFormReturn } from \"react-hook-form\";\nimport { FieldProps, GroupedOption, InputOption } from \"./definitions\";\n// import { FieldProps } from \"./field-props\";\n\n\nexport abstract class BaseInput {\n constructor(\n protected readonly input: FieldProps,\n protected readonly form: UseFormReturn,\n protected readonly isSubmitting?: boolean,\n ) {}\n\n abstract render(): JSX.Element;\n}\n\n\nexport const entityToInputOption = (entitiy:any, name:string = 'name', description:string = 'description', groupedLabel?:string): InputOption => ({\n id: entitiy['id'],\n name: entitiy[name],\n description: entitiy[description],\n groupedLabel\n})\n\nexport const entitiesToInputOption = (data:any[], optionValue:string = 'name', groupedLabel?:string): InputOption[] => {\n const entities: InputOption[] = [];\n for (const key of data) {\n const entidad = entityToInputOption(key, optionValue, undefined, groupedLabel);\n if(entidad) entities.push(entidad);\n }\n return entities;\n}\nexport const entityToGroupedOption = (entitiy:any, name:string = 'name'): GroupedOption => ({\n id: entitiy['id'],\n label: entitiy[name] || entitiy['label'],\n options: entitiy['options'] || [],\n selectedOptions: [],\n})\n\n\nexport const entitiesToGroupedOption = (data:any[], optionValue:string = 'name' ): GroupedOption[] => {\n const entities: GroupedOption[] = [];\n for (const key of data) {\n const entidad = entityToGroupedOption(key, optionValue);\n if(entidad) entities.push(entidad);\n }\n return entities;\n}\n\nexport const handleOnChage = (\n event: any[] | any,\n input: FieldProps,\n field?: ControllerRenderProps<FieldValues, string>\n): void => {\n let value: any = event;\n\n // 🔹 Detecta si el valor viene de un input DOM normal\n if (event && typeof event === \"object\" && \"target\" in event) {\n value = (event.target as HTMLInputElement).value;\n }\n\n // 🔹 React Hook Form: actualiza el valor del campo\n field?.onChange(value);\n\n // 🔹 Obtiene los valores actuales del formulario\n const data = input.form?.getValues();\n\n // 🔹 Llama al callback específico del input (si existe)\n input.onChange?.(value, data);\n\n // 🔹 Callback global (si existe)\n input.onAnyFieldChange?.(data);\n};\n\nexport const isValidField = (input: FieldProps, form: UseFormReturn, defaultValue?: any): boolean => {\n const value = defaultValue ?? form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n \n // Si el campo tiene un esquema zod, validamos con él\n if (input.zodType) {\n const result = input.zodType.safeParse(value);\n return result.success;\n }\n // Si no tiene zodType, usamos la validación estándar de react-hook-form\n return !fieldState.error && value !== undefined && value !== \"\";\n }\n","import { z, ZodTypeAny } from \"zod\";\nimport { InputTypes } from \"./input-types\"\nimport { LucideProps } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\nexport const flattenFields = <T extends Record<string, any>>(\n fields: FieldConfig<T>[],\n onAnyFieldChange?: (data:any) => void\n): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n result.push(...flattenFields((field as any).fields));\n } else {\n if (onAnyFieldChange) field.onAnyFieldChange = (data:any) => onAnyFieldChange(data)\n result.push(field);\n }\n }\n\n return result;\n};\n\n\nexport type FieldConfig<T, RT = Record<string,any>> = FieldProps<T,RT> | FieldConfig<T,RT>[];\n\nexport interface FieldProps<T = Record<string,any>, RT = Record<string,any>> {\n name: keyof T // Campo debe coincidir con la definición en el esquema\n label: string\n \n withAddBtn?: boolean;\n form?: UseFormReturn<any>;\n isRemovebleOption?:boolean\n withDuplicatTag?: boolean\n onChange?: (event: any[], formValues?: Record<string,any>) => void\n tabLabelField?:string\n childrenPosition?: 'up' | 'down'\n children?: ReactNode | ((item: any, index: number) => ReactNode);\n defaultValue?: any;\n direction?: 'row' | 'col';\n \n repeaterFields?: Array<FieldProps<RT> | FieldProps<RT>[]>;\n minItems?: number;\n maxItems?: number;\n\n\n currencyFormat?: Intl.NumberFormatOptions\n mask?: string | RegExp;\n\n onAnyFieldChange?: (data:Record<string,any>) => void\n wrapInCard?: boolean\n placeHolder?: string\n description?: string\n className?: string\n inputType?: InputTypes\n keyboardType?: TextInputType\n disabled?: boolean\n required?: boolean\n value?: any\n min?: number,\n max?: number,\n zodType?: ZodTypeAny;\n\n infoTooltip?: string\n \n // list?: any[]\n dependsOn?: string // Nombre del campo del que depende este campo\n loadOptions?: (dependencyValue: any) => Promise<any[]> // Función para cargar opciones dinámicamente\n optionLabel?: string // Propiedad a mostrar como etiqueta en el select\n optionValue?: string // Propiedad a usar como valor en el select\n optionDescription?: string // Propiedad a usar como valor en el select\n hidden?:boolean\n onListOptionChange?: (item: any) => void\n\n\n listConfig?: ListConfig\n\n fileConfig?: {\n previewSize?: number\n showPreview?: boolean\n accept: string // tipos de archivo permitidos\n multiple: boolean // múltiples archivos\n maxSize: number\n }\n\n inputGroupConfig?: inputGroudConfig\n}\n\ninterface inputGroudConfig {\n\n autoValidIcons?: boolean \n\n iconsLeft?: React.ForwardRefExoticComponent<Omit<LucideProps, \"ref\"> & React.RefAttributes<SVGSVGElement>>[];\n iconsRight?: React.ForwardRefExoticComponent<Omit<LucideProps, \"ref\"> & React.RefAttributes<SVGSVGElement>>[];\n\n textLeft?: string;\n textRight?: string;\n}\n\n\ninterface ListConfig {\n children?: ReactNode | ((item: any, index: number) => ReactNode);\n list: InputOption[] | GroupedOption[]\n optionLabel?: string\n optionValue?: InputOption| string | number | object\n onOptionChange: (item?: InputOption | InputOption[] | GroupedOption ) => void\n optionDescription?: string\n selectedList?: InputOption[]\n sortable?: boolean;\n}\nexport interface BtnConfig {\n label: string;\n btnType: 'submit' | 'button';\n onClick: () => void\n variant?: \"default\" | \"link\" | \"destructive\" | \"outline\" | \"secondary\" | \"ghost\" | null | undefined;\n disabled?: boolean;\n}\n\nexport interface InputOption {\n id: number | string\n name: string\n label?: string\n description?: string\n disabled?: boolean\n checked?: boolean\n groupedLabel?: string\n value?:any\n}\nexport interface GroupedOption {\n id?: number\n label: string\n options: InputOption[]\n selectedOptions: InputOption[]\n totalSelected?: number\n disabled?: boolean\n value?:any\n}\n\nexport interface InputSetup {\n required: boolean;\n disabled: boolean;\n minLegth?: number;\n maxLength?: number;\n pattern?: RegExp;\n min?:number;\n max?:number;\n isObscure?:boolean;\n isEmail?:boolean;\n isUrl?:boolean;\n zopType?: z.ZodType\n}\n\n\nexport enum TextInputType {\n DEFAULT = \"default\",\n NUMBER = \"number\",\n EMAIL = \"email\",\n PHONE = \"phone\",\n PASSWORD = \"password\",\n}","export enum InputTypes {\n HIDDEN = \"hidden\",\n TEXT = \"text\",\n TEXT_GROUP = \"text_group\",\n NUMBER = \"number\",\n SWITCH = \"switch\",\n CHECKBOX = \"checkbox\",\n SELECT = \"select\",\n SIMPLE_CHECK_LIST = \"siple_checklist\",\n CHECK_LIST = \"checklist\",\n // SWITCH_LIST = \"switchlist\",\n GROUPED_SWITCH_LIST = \"grouped_switchlist\",\n ACCORDION_GROUPED_SWITCH_LIST = \"accordion_grouped_switchlist\",\n DATE = \"date\",\n TEXTAREA = \"textarea\",\n FILE = \"file\",\n OTP = \"otp\",\n FORM = \"form\",\n COLOR = \"color\",\n RADIO_GROUP = \"radio_group\",\n TAGS = \"tags\",\n DATE_TIME = \"date_time\",\n TIME = \"time\",\n FILE_MULTI_UPLOAD = \"file_multi_upload\",\n SLIDER = \"slider\",\n BUTTON_GROUP = \"button_group\",\n CURRENCY = \"currency\",\n KEY_VALUE = \"key_value\",\n REPEATER = \"repeater\",\n MULTI_SELECT = \"multi_select\",\n COMBOBOX = \"COMBO_BOX\",\n SORTABLE_LIST = \"sortable_list\",\n REPEATER_TABS = \"repeater_tabs\",\n STRING_LIST = \"string_list\",\n}\n\nexport const inputFieldComp = [\n InputTypes.STRING_LIST,\n InputTypes.REPEATER_TABS,\n InputTypes.SORTABLE_LIST,\n InputTypes.COMBOBOX,\n InputTypes.MULTI_SELECT,\n InputTypes.REPEATER,\n InputTypes.KEY_VALUE,\n InputTypes.CURRENCY,\n InputTypes.BUTTON_GROUP,\n InputTypes.SLIDER,\n InputTypes.FILE_MULTI_UPLOAD,\n InputTypes.TIME,\n InputTypes.DATE_TIME,\n InputTypes.TAGS,\n InputTypes.RADIO_GROUP,\n InputTypes.TEXT_GROUP,\n InputTypes.ACCORDION_GROUPED_SWITCH_LIST,\n InputTypes.GROUPED_SWITCH_LIST,\n InputTypes.TEXT,\n InputTypes.SWITCH,\n InputTypes.SIMPLE_CHECK_LIST,\n InputTypes.CHECKBOX,\n InputTypes.COLOR,\n InputTypes.OTP,\n InputTypes.SELECT,\n InputTypes.DATE,\n InputTypes.FILE,\n InputTypes.FORM,\n InputTypes.NUMBER,\n InputTypes.TEXTAREA,\n // InputTypes.SWITCH_LIST,\n InputTypes.HIDDEN,\n]","\"use client\"\n\nimport * as React from \"react\"\nimport * as AccordionPrimitive from \"@radix-ui/react-accordion\"\nimport { ChevronDownIcon } from \"lucide-react\"\nimport { cn } from \"@/src/lib/utils\"\n\n\nfunction Accordion({\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Root>) {\n return <AccordionPrimitive.Root data-slot=\"accordion\" {...props} />\n}\n\nfunction AccordionItem({\n className,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Item>) {\n return (\n <AccordionPrimitive.Item\n data-slot=\"accordion-item\"\n className={cn(\"border-b last:border-b-0\", className)}\n {...props}\n />\n )\n}\n\nfunction AccordionTrigger({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Trigger>) {\n return (\n <AccordionPrimitive.Header className=\"flex\">\n <AccordionPrimitive.Trigger\n data-slot=\"accordion-trigger\"\n className={cn(\n \"focus-visible:border-ring focus-visible:ring-ring/50 flex flex-1 items-start justify-between gap-4 rounded-md py-4 text-left text-sm font-medium transition-all outline-none hover:underline focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 [&[data-state=open]>svg]:rotate-180\",\n className\n )}\n {...props}\n >\n {children}\n <ChevronDownIcon className=\"text-muted-foreground pointer-events-none size-4 shrink-0 translate-y-0.5 transition-transform duration-200\" />\n </AccordionPrimitive.Trigger>\n </AccordionPrimitive.Header>\n )\n}\n\nfunction AccordionContent({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Content>) {\n return (\n <AccordionPrimitive.Content\n data-slot=\"accordion-content\"\n className=\"data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down overflow-hidden text-sm\"\n {...props}\n >\n <div className={cn(\"pt-0 pb-4\", className)}>{children}</div>\n </AccordionPrimitive.Content>\n )\n}\n\nexport { Accordion, AccordionItem, AccordionTrigger, AccordionContent }\n","import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst badgeVariants = cva(\n \"inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden\",\n {\n variants: {\n variant: {\n default:\n \"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90\",\n secondary:\n \"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90\",\n destructive:\n \"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction Badge({\n className,\n variant,\n asChild = false,\n ...props\n}: React.ComponentProps<\"span\"> &\n VariantProps<typeof badgeVariants> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"span\"\n\n return (\n <Comp\n data-slot=\"badge\"\n className={cn(badgeVariants({ variant }), className)}\n {...props}\n />\n )\n}\n\nexport { Badge, badgeVariants }\n","import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n {\n variants: {\n variant: {\n default: \"bg-primary text-primary-foreground hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50\",\n secondary:\n \"bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n ghost:\n \"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-9 px-4 py-2 has-[>svg]:px-3\",\n sm: \"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5\",\n lg: \"h-10 rounded-md px-6 has-[>svg]:px-4\",\n icon: \"size-9\",\n \"icon-sm\": \"size-8\",\n \"icon-lg\": \"size-10\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nfunction Button({\n className,\n variant,\n size,\n asChild = false,\n ...props\n}: React.ComponentProps<\"button\"> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean\n }) {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n data-slot=\"button\"\n className={cn(buttonVariants({ variant, size, className }))}\n {...props}\n />\n )\n}\n\nexport { Button, buttonVariants }\n","\"use client\"\n\nimport * as React from \"react\"\nimport {\n ChevronDownIcon,\n ChevronLeftIcon,\n ChevronRightIcon,\n} from \"lucide-react\"\nimport { DayButton, DayPicker, getDefaultClassNames } from \"react-day-picker\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Button, buttonVariants } from \"./button\"\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = \"label\",\n buttonVariant = \"ghost\",\n formatters,\n components,\n ...props\n}: React.ComponentProps<typeof DayPicker> & {\n buttonVariant?: React.ComponentProps<typeof Button>[\"variant\"]\n}) {\n const defaultClassNames = getDefaultClassNames()\n\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n \"bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent\",\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n className\n )}\n captionLayout={captionLayout}\n formatters={{\n formatMonthDropdown: (date) =>\n date.toLocaleString(\"default\", { month: \"short\" }),\n ...formatters,\n }}\n classNames={{\n root: cn(\"w-fit\", defaultClassNames.root),\n months: cn(\n \"flex gap-4 flex-col md:flex-row relative\",\n defaultClassNames.months\n ),\n month: cn(\"flex flex-col w-full gap-4\", defaultClassNames.month),\n nav: cn(\n \"flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between\",\n defaultClassNames.nav\n ),\n button_previous: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_previous\n ),\n button_next: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_next\n ),\n month_caption: cn(\n \"flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)\",\n defaultClassNames.month_caption\n ),\n dropdowns: cn(\n \"w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5\",\n defaultClassNames.dropdowns\n ),\n dropdown_root: cn(\n \"relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md\",\n defaultClassNames.dropdown_root\n ),\n dropdown: cn(\n \"absolute bg-popover inset-0 opacity-0\",\n defaultClassNames.dropdown\n ),\n caption_label: cn(\n \"select-none font-medium\",\n captionLayout === \"label\"\n ? \"text-sm\"\n : \"rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5\",\n defaultClassNames.caption_label\n ),\n table: \"w-full border-collapse\",\n weekdays: cn(\"flex\", defaultClassNames.weekdays),\n weekday: cn(\n \"text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none\",\n defaultClassNames.weekday\n ),\n week: cn(\"flex w-full mt-2\", defaultClassNames.week),\n week_number_header: cn(\n \"select-none w-(--cell-size)\",\n defaultClassNames.week_number_header\n ),\n week_number: cn(\n \"text-[0.8rem] select-none text-muted-foreground\",\n defaultClassNames.week_number\n ),\n day: cn(\n \"relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none\",\n defaultClassNames.day\n ),\n range_start: cn(\n \"rounded-l-md bg-accent\",\n defaultClassNames.range_start\n ),\n range_middle: cn(\"rounded-none\", defaultClassNames.range_middle),\n range_end: cn(\"rounded-r-md bg-accent\", defaultClassNames.range_end),\n today: cn(\n \"bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none\",\n defaultClassNames.today\n ),\n outside: cn(\n \"text-muted-foreground aria-selected:text-muted-foreground\",\n defaultClassNames.outside\n ),\n disabled: cn(\n \"text-muted-foreground opacity-50\",\n defaultClassNames.disabled\n ),\n hidden: cn(\"invisible\", defaultClassNames.hidden),\n ...classNames,\n }}\n components={{\n Root: ({ className, rootRef, ...props }) => {\n return (\n <div\n data-slot=\"calendar\"\n ref={rootRef}\n className={cn(className)}\n {...props}\n />\n )\n },\n Chevron: ({ className, orientation, ...props }) => {\n if (orientation === \"left\") {\n return (\n <ChevronLeftIcon className={cn(\"size-4\", className)} {...props} />\n )\n }\n\n if (orientation === \"right\") {\n return (\n <ChevronRightIcon\n className={cn(\"size-4\", className)}\n {...props}\n />\n )\n }\n\n return (\n <ChevronDownIcon className={cn(\"size-4\", className)} {...props} />\n )\n },\n DayButton: CalendarDayButton,\n WeekNumber: ({ children, ...props }) => {\n return (\n <td {...props}>\n <div className=\"flex size-(--cell-size) items-center justify-center text-center\">\n {children}\n </div>\n </td>\n )\n },\n ...components,\n }}\n {...props}\n />\n )\n}\n\nfunction CalendarDayButton({\n className,\n day,\n modifiers,\n ...props\n}: React.ComponentProps<typeof DayButton>) {\n const defaultClassNames = getDefaultClassNames()\n\n const ref = React.useRef<HTMLButtonElement>(null)\n React.useEffect(() => {\n if (modifiers.focused) ref.current?.focus()\n }, [modifiers.focused])\n\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n data-day={day.date.toLocaleDateString()}\n data-selected-single={\n modifiers.selected &&\n !modifiers.range_start &&\n !modifiers.range_end &&\n !modifiers.range_middle\n }\n data-range-start={modifiers.range_start}\n data-range-end={modifiers.range_end}\n data-range-middle={modifiers.range_middle}\n className={cn(\n \"data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70\",\n defaultClassNames.day,\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Calendar, CalendarDayButton }\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Card({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card\"\n className={cn(\n \"bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-header\"\n className={cn(\n \"@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-title\"\n className={cn(\"leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-action\"\n className={cn(\n \"col-start-2 row-span-2 row-start-1 self-start justify-self-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-content\"\n className={cn(\"px-6\", className)}\n {...props}\n />\n )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"card-footer\"\n className={cn(\"flex items-center px-6 [.border-t]:pt-6\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Card,\n CardHeader,\n CardFooter,\n CardTitle,\n CardAction,\n CardDescription,\n CardContent,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as CheckboxPrimitive from \"@radix-ui/react-checkbox\"\nimport { CheckIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Checkbox({\n className,\n ...props\n}: React.ComponentProps<typeof CheckboxPrimitive.Root>) {\n return (\n <CheckboxPrimitive.Root\n data-slot=\"checkbox\"\n className={cn(\n \"peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator\n data-slot=\"checkbox-indicator\"\n className=\"flex items-center justify-center text-current transition-none\"\n >\n <CheckIcon className=\"size-3.5\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n )\n}\n\nexport { Checkbox }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Popover({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Root>) {\n return <PopoverPrimitive.Root data-slot=\"popover\" {...props} />\n}\n\nfunction PopoverTrigger({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Trigger>) {\n return <PopoverPrimitive.Trigger data-slot=\"popover-trigger\" {...props} />\n}\n\nfunction PopoverContent({\n className,\n align = \"center\",\n sideOffset = 4,\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Content>) {\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n data-slot=\"popover-content\"\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden\",\n className\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n )\n}\n\nfunction PopoverAnchor({\n ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Anchor>) {\n return <PopoverPrimitive.Anchor data-slot=\"popover-anchor\" {...props} />\n}\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n","\"use client\"\n\nimport * as React from \"react\"\nimport { ColorPicker, IColor, useColor } from \"react-color-palette\"\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/src/components/ui/popover\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { cn } from \"@/src/lib/utils\"\nimport \"react-color-palette/css\"\n\nexport interface Props {\n value?: string\n onChange?: (color: string) => void\n onBlur?: () => void\n disabled?: boolean\n className?: string\n placeholder?: string\n}\n\nconst ColorCnInput = React.forwardRef<HTMLButtonElement, Props>(\n ({ value = \"#000000\", onChange, onBlur, disabled, className }, ref) => {\n const [color, setColor] = useColor(value)\n const [open, setOpen] = React.useState(false)\n\n React.useEffect(() => {\n if (value !== color.hex) {\n setColor({ ...color, hex: value })\n }\n }, [color, setColor, value])\n\n const handleColorChange = (newColor: IColor) => {\n setColor(newColor)\n onChange?.(newColor.hex)\n }\n\n const handleOpenChange = (newOpen: boolean) => {\n setOpen(newOpen)\n if (!newOpen) {\n onBlur?.()\n }\n }\n\n return (\n <Popover open={open} onOpenChange={handleOpenChange}>\n <PopoverTrigger asChild>\n <Button\n ref={ref}\n variant=\"outline\"\n disabled={disabled}\n className={cn(\"w-full justify-start text-left font-normal\", !value && \"text-muted-foreground\", className)}\n >\n <div className=\"flex items-center gap-2\">\n <div className=\"h-4 w-4 rounded border border-border\" style={{ backgroundColor: color.hex }} />\n <span>{color.hex}</span>\n </div>\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-3\" align=\"start\">\n <ColorPicker color={color} onChange={handleColorChange} hideInput={[\"rgb\", \"hsv\"]} />\n </PopoverContent>\n </Popover>\n )\n },\n)\n\nColorCnInput.displayName = \"ColorCnInput\"\n\nexport { ColorCnInput }\n","import * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { XIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Dialog({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Root>) {\n return <DialogPrimitive.Root data-slot=\"dialog\" {...props} />\n}\n\nfunction DialogTrigger({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Trigger>) {\n return <DialogPrimitive.Trigger data-slot=\"dialog-trigger\" {...props} />\n}\n\nfunction DialogPortal({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Portal>) {\n return <DialogPrimitive.Portal data-slot=\"dialog-portal\" {...props} />\n}\n\nfunction DialogClose({\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Close>) {\n return <DialogPrimitive.Close data-slot=\"dialog-close\" {...props} />\n}\n\nfunction DialogOverlay({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Overlay>) {\n return (\n <DialogPrimitive.Overlay\n data-slot=\"dialog-overlay\"\n className={cn(\n \"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction DialogContent({\n className,\n children,\n showCloseButton = true,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Content> & {\n showCloseButton?: boolean\n}) {\n return (\n <DialogPortal data-slot=\"dialog-portal\">\n <DialogOverlay />\n <DialogPrimitive.Content\n data-slot=\"dialog-content\"\n className={cn(\n \"bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg\",\n className\n )}\n {...props}\n >\n {children}\n {showCloseButton && (\n <DialogPrimitive.Close\n data-slot=\"dialog-close\"\n className=\"ring-offset-background focus:ring-ring data-[state=open]:bg-accent data-[state=open]:text-muted-foreground absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\"\n >\n <XIcon />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n )}\n </DialogPrimitive.Content>\n </DialogPortal>\n )\n}\n\nfunction DialogHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-header\"\n className={cn(\"flex flex-col gap-2 text-center sm:text-left\", className)}\n {...props}\n />\n )\n}\n\nfunction DialogFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"dialog-footer\"\n className={cn(\n \"flex flex-col-reverse gap-2 sm:flex-row sm:justify-end\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction DialogTitle({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Title>) {\n return (\n <DialogPrimitive.Title\n data-slot=\"dialog-title\"\n className={cn(\"text-lg leading-none font-semibold\", className)}\n {...props}\n />\n )\n}\n\nfunction DialogDescription({\n className,\n ...props\n}: React.ComponentProps<typeof DialogPrimitive.Description>) {\n return (\n <DialogPrimitive.Description\n data-slot=\"dialog-description\"\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nexport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n}\n","import * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Label({\n className,\n ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n return (\n <LabelPrimitive.Root\n data-slot=\"label\"\n className={cn(\n \"flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Label }\n","import * as React from \"react\"\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Separator({\n className,\n orientation = \"horizontal\",\n decorative = true,\n ...props\n}: React.ComponentProps<typeof SeparatorPrimitive.Root>) {\n return (\n <SeparatorPrimitive.Root\n data-slot=\"separator\"\n decorative={decorative}\n orientation={orientation}\n className={cn(\n \"bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Separator }\n","import { useMemo } from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Label } from \"@/src/components/ui/label\"\nimport { Separator } from \"@/src/components/ui/separator\"\n\nfunction FieldSet({ className, ...props }: React.ComponentProps<\"fieldset\">) {\n return (\n <fieldset\n data-slot=\"field-set\"\n className={cn(\n \"flex flex-col gap-6\",\n \"has-[>[data-slot=checkbox-group]]:gap-3 has-[>[data-slot=radio-group]]:gap-3\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldLegend({\n className,\n variant = \"legend\",\n ...props\n}: React.ComponentProps<\"legend\"> & { variant?: \"legend\" | \"label\" }) {\n return (\n <legend\n data-slot=\"field-legend\"\n data-variant={variant}\n className={cn(\n \"mb-3 font-medium\",\n \"data-[variant=legend]:text-base\",\n \"data-[variant=label]:text-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-group\"\n className={cn(\n \"group/field-group @container/field-group flex w-full flex-col gap-7 data-[slot=checkbox-group]:gap-3 [&>[data-slot=field-group]]:gap-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nconst fieldVariants = cva(\n \"group/field flex w-full gap-3 data-[invalid=true]:text-destructive\",\n {\n variants: {\n orientation: {\n vertical: [\"flex-col [&>*]:w-full [&>.sr-only]:w-auto\"],\n horizontal: [\n \"flex-row items-center\",\n \"[&>[data-slot=field-label]]:flex-auto\",\n \"has-[>[data-slot=field-content]]:items-start has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px\",\n ],\n responsive: [\n \"flex-col [&>*]:w-full [&>.sr-only]:w-auto @md/field-group:flex-row @md/field-group:items-center @md/field-group:[&>*]:w-auto\",\n \"@md/field-group:[&>[data-slot=field-label]]:flex-auto\",\n \"@md/field-group:has-[>[data-slot=field-content]]:items-start @md/field-group:has-[>[data-slot=field-content]]:[&>[role=checkbox],[role=radio]]:mt-px\",\n ],\n },\n },\n defaultVariants: {\n orientation: \"vertical\",\n },\n }\n)\n\nfunction Field({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof fieldVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"field\"\n data-orientation={orientation}\n className={cn(fieldVariants({ orientation }), className)}\n {...props}\n />\n )\n}\n\nfunction FieldContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-content\"\n className={cn(\n \"group/field-content flex flex-1 flex-col gap-1.5 leading-snug\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldLabel({\n className,\n ...props\n}: React.ComponentProps<typeof Label>) {\n return (\n <Label\n data-slot=\"field-label\"\n className={cn(\n \"group/field-label peer/field-label flex w-fit gap-2 leading-snug group-data-[disabled=true]/field:opacity-50\",\n \"has-[>[data-slot=field]]:w-full has-[>[data-slot=field]]:flex-col has-[>[data-slot=field]]:rounded-md has-[>[data-slot=field]]:border [&>*]:data-[slot=field]:p-4\",\n \"has-data-[state=checked]:bg-primary/5 has-data-[state=checked]:border-primary dark:has-data-[state=checked]:bg-primary/10\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"field-label\"\n className={cn(\n \"flex w-fit items-center gap-2 text-sm leading-snug font-medium group-data-[disabled=true]/field:opacity-50\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldDescription({ className, ...props }: React.ComponentProps<\"p\">) {\n return (\n <p\n data-slot=\"field-description\"\n className={cn(\n \"text-muted-foreground text-sm leading-normal font-normal group-has-[[data-orientation=horizontal]]/field:text-balance\",\n \"last:mt-0 nth-last-2:-mt-1 [[data-variant=legend]+&]:-mt-1.5\",\n \"[&>a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction FieldSeparator({\n children,\n className,\n ...props\n}: React.ComponentProps<\"div\"> & {\n children?: React.ReactNode\n}) {\n return (\n <div\n data-slot=\"field-separator\"\n data-content={!!children}\n className={cn(\n \"relative -my-2 h-5 text-sm group-data-[variant=outline]/field-group:-mb-2\",\n className\n )}\n {...props}\n >\n <Separator className=\"absolute inset-0 top-1/2\" />\n {children && (\n <span\n className=\"bg-background text-muted-foreground relative mx-auto block w-fit px-2\"\n data-slot=\"field-separator-content\"\n >\n {children}\n </span>\n )}\n </div>\n )\n}\n\nfunction FieldError({\n className,\n children,\n errors,\n ...props\n}: React.ComponentProps<\"div\"> & {\n errors?: Array<{ message?: string } | undefined>\n}) {\n const content = useMemo(() => {\n if (children) {\n return children\n }\n\n if (!errors?.length) {\n return null\n }\n\n const uniqueErrors = [\n ...new Map(errors.map((error) => [error?.message, error])).values(),\n ]\n\n if (uniqueErrors?.length == 1) {\n return uniqueErrors[0]?.message\n }\n\n return (\n <ul className=\"ml-4 flex list-disc flex-col gap-1\">\n {uniqueErrors.map(\n (error, index) =>\n error?.message && <li key={index}>{error.message}</li>\n )}\n </ul>\n )\n }, [children, errors])\n\n if (!content) {\n return null\n }\n\n return (\n <div\n role=\"alert\"\n data-slot=\"field-error\"\n className={cn(\"text-destructive text-sm font-normal\", className)}\n {...props}\n >\n {content}\n </div>\n )\n}\n\nexport {\n Field,\n FieldLabel,\n FieldDescription,\n FieldError,\n FieldGroup,\n FieldLegend,\n FieldSeparator,\n FieldSet,\n FieldContent,\n FieldTitle,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport {\n Controller,\n FormProvider,\n useFormContext,\n useFormState,\n type ControllerProps,\n type FieldPath,\n type FieldValues,\n} from \"react-hook-form\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Label } from \"@/src/components/ui/label\"\n\nconst Form = FormProvider\n\ntype FormFieldContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n> = {\n name: TName\n}\n\nconst FormFieldContext = React.createContext<FormFieldContextValue>(\n {} as FormFieldContextValue\n)\n\nconst FormField = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n>({\n ...props\n}: ControllerProps<TFieldValues, TName>) => {\n return (\n <FormFieldContext.Provider value={{ name: props.name }}>\n <Controller {...props} />\n </FormFieldContext.Provider>\n )\n}\n\nconst useFormField = () => {\n const fieldContext = React.useContext(FormFieldContext)\n const itemContext = React.useContext(FormItemContext)\n const { getFieldState } = useFormContext()\n const formState = useFormState({ name: fieldContext.name })\n const fieldState = getFieldState(fieldContext.name, formState)\n\n if (!fieldContext) {\n throw new Error(\"useFormField should be used within <FormField>\")\n }\n\n const { id } = itemContext\n\n return {\n id,\n name: fieldContext.name,\n formItemId: `${id}-form-item`,\n formDescriptionId: `${id}-form-item-description`,\n formMessageId: `${id}-form-item-message`,\n ...fieldState,\n }\n}\n\ntype FormItemContextValue = {\n id: string\n}\n\nconst FormItemContext = React.createContext<FormItemContextValue>(\n {} as FormItemContextValue\n)\n\nfunction FormItem({ className, ...props }: React.ComponentProps<\"div\">) {\n const id = React.useId()\n\n return (\n <FormItemContext.Provider value={{ id }}>\n <div\n data-slot=\"form-item\"\n className={cn(\"grid gap-2\", className)}\n {...props}\n />\n </FormItemContext.Provider>\n )\n}\n\nfunction FormLabel({\n className,\n ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n const { error, formItemId } = useFormField()\n\n return (\n <Label\n data-slot=\"form-label\"\n data-error={!!error}\n className={cn(\"data-[error=true]:text-destructive\", className)}\n htmlFor={formItemId}\n {...props}\n />\n )\n}\n\nfunction FormControl({ ...props }: React.ComponentProps<typeof Slot>) {\n const { error, formItemId, formDescriptionId, formMessageId } = useFormField()\n\n return (\n <Slot\n data-slot=\"form-control\"\n id={formItemId}\n aria-describedby={\n !error\n ? `${formDescriptionId}`\n : `${formDescriptionId} ${formMessageId}`\n }\n aria-invalid={!!error}\n {...props}\n />\n )\n}\n\nfunction FormDescription({ className, ...props }: React.ComponentProps<\"p\">) {\n const { formDescriptionId } = useFormField()\n\n return (\n <p\n data-slot=\"form-description\"\n id={formDescriptionId}\n className={cn(\"text-muted-foreground text-sm\", className)}\n {...props}\n />\n )\n}\n\nfunction FormMessage({ className, ...props }: React.ComponentProps<\"p\">) {\n const { error, formMessageId } = useFormField()\n const body = error ? String(error?.message ?? \"\") : props.children\n\n if (!body) {\n return null\n }\n\n return (\n <p\n data-slot=\"form-message\"\n id={formMessageId}\n className={cn(\"text-destructive text-sm\", className)}\n {...props}\n >\n {body}\n </p>\n )\n}\n\nexport {\n useFormField,\n Form,\n FormItem,\n FormLabel,\n FormControl,\n FormDescription,\n FormMessage,\n FormField,\n}\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Input({ className, type, ...props }: React.ComponentProps<\"input\">) {\n return (\n <input\n type={type}\n data-slot=\"input\"\n className={cn(\n \"file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n \"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]\",\n \"aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Input }\n","import * as React from \"react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Textarea({ className, ...props }: React.ComponentProps<\"textarea\">) {\n return (\n <textarea\n data-slot=\"textarea\"\n className={cn(\n \"border-input placeholder:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 flex field-sizing-content min-h-16 w-full rounded-md border bg-transparent px-3 py-2 text-base shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 md:text-sm\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Textarea }\n","import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { Input } from \"@/src/components/ui/input\"\nimport { Textarea } from \"@/src/components/ui/textarea\"\n\nfunction InputGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"input-group\"\n role=\"group\"\n className={cn(\n \"group/input-group border-input dark:bg-input/30 relative flex w-full items-center rounded-md border shadow-xs transition-[color,box-shadow] outline-none\",\n \"h-9 min-w-0 has-[>textarea]:h-auto\",\n\n // Variants based on alignment.\n \"has-[>[data-align=inline-start]]:[&>input]:pl-2\",\n \"has-[>[data-align=inline-end]]:[&>input]:pr-2\",\n \"has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3\",\n \"has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3\",\n\n // Focus state.\n \"has-[[data-slot=input-group-control]:focus-visible]:border-ring has-[[data-slot=input-group-control]:focus-visible]:ring-ring/50 has-[[data-slot=input-group-control]:focus-visible]:ring-[3px]\",\n\n // Error state.\n \"has-[[data-slot][aria-invalid=true]]:ring-destructive/20 has-[[data-slot][aria-invalid=true]]:border-destructive dark:has-[[data-slot][aria-invalid=true]]:ring-destructive/40\",\n\n className\n )}\n {...props}\n />\n )\n}\n\nconst inputGroupAddonVariants = cva(\n \"text-muted-foreground flex h-auto cursor-text items-center justify-center gap-2 py-1.5 text-sm font-medium select-none [&>svg:not([class*='size-'])]:size-4 [&>kbd]:rounded-[calc(var(--radius)-5px)] group-data-[disabled=true]/input-group:opacity-50\",\n {\n variants: {\n align: {\n \"inline-start\":\n \"order-first pl-3 has-[>button]:ml-[-0.45rem] has-[>kbd]:ml-[-0.35rem]\",\n \"inline-end\":\n \"order-last pr-3 has-[>button]:mr-[-0.45rem] has-[>kbd]:mr-[-0.35rem]\",\n \"block-start\":\n \"order-first w-full justify-start px-3 pt-3 [.border-b]:pb-3 group-has-[>input]/input-group:pt-2.5\",\n \"block-end\":\n \"order-last w-full justify-start px-3 pb-3 [.border-t]:pt-3 group-has-[>input]/input-group:pb-2.5\",\n },\n },\n defaultVariants: {\n align: \"inline-start\",\n },\n }\n)\n\nfunction InputGroupAddon({\n className,\n align = \"inline-start\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof inputGroupAddonVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"input-group-addon\"\n data-align={align}\n className={cn(inputGroupAddonVariants({ align }), className)}\n onClick={(e) => {\n if ((e.target as HTMLElement).closest(\"button\")) {\n return\n }\n e.currentTarget.parentElement?.querySelector(\"input\")?.focus()\n }}\n {...props}\n />\n )\n}\n\nconst inputGroupButtonVariants = cva(\n \"text-sm shadow-none flex gap-2 items-center\",\n {\n variants: {\n size: {\n xs: \"h-6 gap-1 px-2 rounded-[calc(var(--radius)-5px)] [&>svg:not([class*='size-'])]:size-3.5 has-[>svg]:px-2\",\n sm: \"h-8 px-2.5 gap-1.5 rounded-md has-[>svg]:px-2.5\",\n \"icon-xs\":\n \"size-6 rounded-[calc(var(--radius)-5px)] p-0 has-[>svg]:p-0\",\n \"icon-sm\": \"size-8 p-0 has-[>svg]:p-0\",\n },\n },\n defaultVariants: {\n size: \"xs\",\n },\n }\n)\n\nfunction InputGroupButton({\n className,\n type = \"button\",\n variant = \"ghost\",\n size = \"xs\",\n ...props\n}: Omit<React.ComponentProps<typeof Button>, \"size\"> &\n VariantProps<typeof inputGroupButtonVariants>) {\n return (\n <Button\n type={type}\n data-size={size}\n variant={variant}\n className={cn(inputGroupButtonVariants({ size }), className)}\n {...props}\n />\n )\n}\n\nfunction InputGroupText({ className, ...props }: React.ComponentProps<\"span\">) {\n return (\n <span\n className={cn(\n \"text-muted-foreground flex items-center gap-2 text-sm [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupInput({\n className,\n ...props\n}: React.ComponentProps<\"input\">) {\n return (\n <Input\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 rounded-none border-0 bg-transparent shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupTextarea({\n className,\n ...props\n}: React.ComponentProps<\"textarea\">) {\n return (\n <Textarea\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 resize-none rounded-none border-0 bg-transparent py-3 shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n InputGroup,\n InputGroupAddon,\n InputGroupButton,\n InputGroupText,\n InputGroupInput,\n InputGroupTextarea,\n}\n","\"use client\"\n\nimport * as React from \"react\"\nimport { OTPInput, OTPInputContext } from \"input-otp\"\nimport { MinusIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction InputOTP({\n className,\n containerClassName,\n ...props\n}: React.ComponentProps<typeof OTPInput> & {\n containerClassName?: string\n}) {\n return (\n <OTPInput\n data-slot=\"input-otp\"\n containerClassName={cn(\n \"flex items-center gap-2 has-disabled:opacity-50\",\n containerClassName\n )}\n className={cn(\"disabled:cursor-not-allowed\", className)}\n {...props}\n />\n )\n}\n\nfunction InputOTPGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"input-otp-group\"\n className={cn(\"flex items-center\", className)}\n {...props}\n />\n )\n}\n\nfunction InputOTPSlot({\n index,\n className,\n ...props\n}: React.ComponentProps<\"div\"> & {\n index: number\n}) {\n const inputOTPContext = React.useContext(OTPInputContext)\n const { char, hasFakeCaret, isActive } = inputOTPContext?.slots[index] ?? {}\n\n return (\n <div\n data-slot=\"input-otp-slot\"\n data-active={isActive}\n className={cn(\n \"data-[active=true]:border-ring data-[active=true]:ring-ring/50 data-[active=true]:aria-invalid:ring-destructive/20 dark:data-[active=true]:aria-invalid:ring-destructive/40 aria-invalid:border-destructive data-[active=true]:aria-invalid:border-destructive dark:bg-input/30 border-input relative flex h-9 w-9 items-center justify-center border-y border-r text-sm shadow-xs transition-all outline-none first:rounded-l-md first:border-l last:rounded-r-md data-[active=true]:z-10 data-[active=true]:ring-[3px]\",\n className\n )}\n {...props}\n >\n {char}\n {hasFakeCaret && (\n <div className=\"pointer-events-none absolute inset-0 flex items-center justify-center\">\n <div className=\"animate-caret-blink bg-foreground h-4 w-px duration-1000\" />\n </div>\n )}\n </div>\n )\n}\n\nfunction InputOTPSeparator({ ...props }: React.ComponentProps<\"div\">) {\n return (\n <div data-slot=\"input-otp-separator\" role=\"separator\" {...props}>\n <MinusIcon />\n </div>\n )\n}\n\nexport { InputOTP, InputOTPGroup, InputOTPSlot, InputOTPSeparator }\n","import * as React from \"react\"\nimport * as RadioGroupPrimitive from \"@radix-ui/react-radio-group\"\nimport { CircleIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction RadioGroup({\n className,\n ...props\n}: React.ComponentProps<typeof RadioGroupPrimitive.Root>) {\n return (\n <RadioGroupPrimitive.Root\n data-slot=\"radio-group\"\n className={cn(\"grid gap-3\", className)}\n {...props}\n />\n )\n}\n\nfunction RadioGroupItem({\n className,\n ...props\n}: React.ComponentProps<typeof RadioGroupPrimitive.Item>) {\n return (\n <RadioGroupPrimitive.Item\n data-slot=\"radio-group-item\"\n className={cn(\n \"border-input text-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 aspect-square size-4 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <RadioGroupPrimitive.Indicator\n data-slot=\"radio-group-indicator\"\n className=\"relative flex items-center justify-center\"\n >\n <CircleIcon className=\"fill-primary absolute top-1/2 left-1/2 size-2 -translate-x-1/2 -translate-y-1/2\" />\n </RadioGroupPrimitive.Indicator>\n </RadioGroupPrimitive.Item>\n )\n}\n\nexport { RadioGroup, RadioGroupItem }\n","\"use client\"\n\nimport * as React from \"react\"\nimport { GripVerticalIcon } from \"lucide-react\"\nimport * as ResizablePrimitive from \"react-resizable-panels\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction ResizablePanelGroup({\n className,\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) {\n return (\n <ResizablePrimitive.PanelGroup\n data-slot=\"resizable-panel-group\"\n className={cn(\n \"flex h-full w-full data-[panel-group-direction=vertical]:flex-col\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ResizablePanel({\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.Panel>) {\n return <ResizablePrimitive.Panel data-slot=\"resizable-panel\" {...props} />\n}\n\nfunction ResizableHandle({\n withHandle,\n className,\n ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelResizeHandle> & {\n withHandle?: boolean\n}) {\n return (\n <ResizablePrimitive.PanelResizeHandle\n data-slot=\"resizable-handle\"\n className={cn(\n \"bg-border focus-visible:ring-ring relative flex w-px items-center justify-center after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:ring-1 focus-visible:ring-offset-1 focus-visible:outline-hidden data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:translate-x-0 data-[panel-group-direction=vertical]:after:-translate-y-1/2 [&[data-panel-group-direction=vertical]>div]:rotate-90\",\n className\n )}\n {...props}\n >\n {withHandle && (\n <div className=\"bg-border z-10 flex h-4 w-3 items-center justify-center rounded-xs border\">\n <GripVerticalIcon className=\"size-2.5\" />\n </div>\n )}\n </ResizablePrimitive.PanelResizeHandle>\n )\n}\n\nexport { ResizablePanelGroup, ResizablePanel, ResizableHandle }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction ScrollArea({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.Root>) {\n return (\n <ScrollAreaPrimitive.Root\n data-slot=\"scroll-area\"\n className={cn(\"relative\", className)}\n {...props}\n >\n <ScrollAreaPrimitive.Viewport\n data-slot=\"scroll-area-viewport\"\n className=\"focus-visible:ring-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:outline-1\"\n >\n {children}\n </ScrollAreaPrimitive.Viewport>\n <ScrollBar />\n <ScrollAreaPrimitive.Corner />\n </ScrollAreaPrimitive.Root>\n )\n}\n\nfunction ScrollBar({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>) {\n return (\n <ScrollAreaPrimitive.ScrollAreaScrollbar\n data-slot=\"scroll-area-scrollbar\"\n orientation={orientation}\n className={cn(\n \"flex touch-none p-px transition-colors select-none\",\n orientation === \"vertical\" &&\n \"h-full w-2.5 border-l border-l-transparent\",\n orientation === \"horizontal\" &&\n \"h-2.5 flex-col border-t border-t-transparent\",\n className\n )}\n {...props}\n >\n <ScrollAreaPrimitive.ScrollAreaThumb\n data-slot=\"scroll-area-thumb\"\n className=\"bg-border relative flex-1 rounded-full\"\n />\n </ScrollAreaPrimitive.ScrollAreaScrollbar>\n )\n}\n\nexport { ScrollArea, ScrollBar }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as SelectPrimitive from \"@radix-ui/react-select\"\nimport { CheckIcon, ChevronDownIcon, ChevronUpIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Select({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Root>) {\n return <SelectPrimitive.Root data-slot=\"select\" {...props} />\n}\n\nfunction SelectGroup({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Group>) {\n return <SelectPrimitive.Group data-slot=\"select-group\" {...props} />\n}\n\nfunction SelectValue({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Value>) {\n return <SelectPrimitive.Value data-slot=\"select-value\" {...props} />\n}\n\nfunction SelectTrigger({\n className,\n size = \"default\",\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Trigger> & {\n size?: \"sm\" | \"default\"\n}) {\n return (\n <SelectPrimitive.Trigger\n data-slot=\"select-trigger\"\n data-size={size}\n className={cn(\n \"border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDownIcon className=\"size-4 opacity-50\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n )\n}\n\nfunction SelectContent({\n className,\n children,\n position = \"popper\",\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Content>) {\n return (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n data-slot=\"select-content\"\n className={cn(\n \"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md\",\n position === \"popper\" &&\n \"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\",\n className\n )}\n position={position}\n {...props}\n >\n <SelectScrollUpButton />\n <SelectPrimitive.Viewport\n className={cn(\n \"p-1\",\n position === \"popper\" &&\n \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectScrollDownButton />\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n )\n}\n\nfunction SelectLabel({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Label>) {\n return (\n <SelectPrimitive.Label\n data-slot=\"select-label\"\n className={cn(\"text-muted-foreground px-2 py-1.5 text-xs\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectItem({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Item>) {\n return (\n <SelectPrimitive.Item\n data-slot=\"select-item\"\n className={cn(\n \"focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2\",\n className\n )}\n {...props}\n >\n <span className=\"absolute right-2 flex size-3.5 items-center justify-center\">\n <SelectPrimitive.ItemIndicator>\n <CheckIcon className=\"size-4\" />\n </SelectPrimitive.ItemIndicator>\n </span>\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n </SelectPrimitive.Item>\n )\n}\n\nfunction SelectSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Separator>) {\n return (\n <SelectPrimitive.Separator\n data-slot=\"select-separator\"\n className={cn(\"bg-border pointer-events-none -mx-1 my-1 h-px\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectScrollUpButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollUpButton>) {\n return (\n <SelectPrimitive.ScrollUpButton\n data-slot=\"select-scroll-up-button\"\n className={cn(\n \"flex cursor-default items-center justify-center py-1\",\n className\n )}\n {...props}\n >\n <ChevronUpIcon className=\"size-4\" />\n </SelectPrimitive.ScrollUpButton>\n )\n}\n\nfunction SelectScrollDownButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollDownButton>) {\n return (\n <SelectPrimitive.ScrollDownButton\n data-slot=\"select-scroll-down-button\"\n className={cn(\n \"flex cursor-default items-center justify-center py-1\",\n className\n )}\n {...props}\n >\n <ChevronDownIcon className=\"size-4\" />\n </SelectPrimitive.ScrollDownButton>\n )\n}\n\nexport {\n Select,\n SelectContent,\n SelectGroup,\n SelectItem,\n SelectLabel,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n}\n","\"use client\"\n\nimport { useTheme } from \"next-themes\"\nimport { Toaster as Sonner, ToasterProps } from \"sonner\"\n\nconst Toaster = ({ ...props }: ToasterProps) => {\n const { theme = \"system\" } = useTheme()\n\n return (\n <Sonner\n theme={theme as ToasterProps[\"theme\"]}\n className=\"toaster group\"\n style={\n {\n \"--normal-bg\": \"var(--popover)\",\n \"--normal-text\": \"var(--popover-foreground)\",\n \"--normal-border\": \"var(--border)\",\n } as React.CSSProperties\n }\n {...props}\n />\n )\n}\n\nexport { Toaster }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as SwitchPrimitive from \"@radix-ui/react-switch\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Switch({\n className,\n ...props\n}: React.ComponentProps<typeof SwitchPrimitive.Root>) {\n return (\n <SwitchPrimitive.Root\n data-slot=\"switch\"\n className={cn(\n \"peer data-[state=checked]:bg-primary data-[state=unchecked]:bg-input focus-visible:border-ring focus-visible:ring-ring/50 dark:data-[state=unchecked]:bg-input/80 inline-flex h-[1.15rem] w-8 shrink-0 items-center rounded-full border border-transparent shadow-xs transition-all outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n >\n <SwitchPrimitive.Thumb\n data-slot=\"switch-thumb\"\n className={cn(\n \"bg-background dark:data-[state=unchecked]:bg-foreground dark:data-[state=checked]:bg-primary-foreground pointer-events-none block size-4 rounded-full ring-0 transition-transform data-[state=checked]:translate-x-[calc(100%-2px)] data-[state=unchecked]:translate-x-0\"\n )}\n />\n </SwitchPrimitive.Root>\n )\n}\n\nexport { Switch }\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction TooltipProvider({\n delayDuration = 0,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Provider>) {\n return (\n <TooltipPrimitive.Provider\n data-slot=\"tooltip-provider\"\n delayDuration={delayDuration}\n {...props}\n />\n )\n}\n\nfunction Tooltip({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Root>) {\n return (\n <TooltipProvider>\n <TooltipPrimitive.Root data-slot=\"tooltip\" {...props} />\n </TooltipProvider>\n )\n}\n\nfunction TooltipTrigger({\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {\n return <TooltipPrimitive.Trigger data-slot=\"tooltip-trigger\" {...props} />\n}\n\nfunction TooltipContent({\n className,\n sideOffset = 0,\n children,\n ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Content>) {\n return (\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n data-slot=\"tooltip-content\"\n sideOffset={sideOffset}\n className={cn(\n \"bg-foreground text-background animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance\",\n className\n )}\n {...props}\n >\n {children}\n <TooltipPrimitive.Arrow className=\"bg-foreground fill-foreground z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]\" />\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n )\n}\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }\n","\"use client\"\n\nimport { JSX, useState } from \"react\"\nimport { Switch, Label, Card } from \"@/src/components/ui\"\nimport { BaseInput, handleOnChage } from \"../base\"\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { cn } from \"@/src/lib/utils\";\n\n\n// interface Props {\n// options: InputOption[]\n// onChange?: (optionsUpdated: InputOption[]) => void\n// }\n\n// export const GroupedSwitches = ({ options, onChange, }: Props) => {\nexport class GroupedSwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, isSubmitting } = this;\n return (\n <GroupedSwitches options={[]} input={input} isSubmitting={isSubmitting} />\n )\n }\n}\n\ninterface Props {\n input: FieldProps;\n options?: InputOption[];\n isSubmitting?: boolean;\n onChange?: (optionsUpdated: InputOption[]) => void\n}\n\nexport const GroupedSwitches = ({ options, onChange, input, isSubmitting}: Props) => {\n\n const mockInputOptions:InputOption[] = [\n { id: 1, name: 'MOCK OPTION - CREATE', checked: false },\n { id: 2, name: 'MOCK OPTION - READ', checked: true },\n { id: 3, name: 'MOCK OPTION - UPDATE', checked: false },\n { id: 4, name: 'MOCK OPTION - DELETE ', checked: false },\n ]\n \n const initialSwitches: InputOption[] = options ? (options.length > 0 ? options : ((input.listConfig?.list as InputOption[]) ?? []) ) : mockInputOptions \n const [switches, setSwitches] = useState<InputOption[]>(initialSwitches)\n const [allChecked, setAllChecked] = useState<boolean>(initialSwitches.every((opt) => opt.checked))\n \n const [bgColor, setBgColor] = useState<string>('bg-green-500/5 border-green-400/10')\n\n const handleMainToggle = (checked: boolean) => {\n const updated = switches.map((opt) => ({ ...opt, checked }));\n setSwitches(updated);\n setAllChecked(checked);\n onChange?.(updated.filter((opt) => opt.checked));\n }\n\n const handleChildToggle = (option: InputOption, checked: boolean, input: FieldProps) => {\n const updated = switches.map((opt) =>\n opt.id === option.id ? { ...opt, checked } : opt\n );\n setSwitches(updated);\n setAllChecked(updated.every((opt) => opt.checked));\n onChange?.(updated.filter((opt) => opt.checked));\n handleOnChage(updated.filter((opt) => opt.checked),input)\n }\n\n return (\n <Card >\n <div className={cn(`w-full h-full space-y-4 p-4 border-2 rounded-xl bg-green-500 ${allChecked ? 'bg-green-500/5 border-green-400/10' : 'bg-black/5'}`)}>\n {/* Switch principal */}\n <div className=\"flex items-center justify-between border-b p-2\">\n <div>{input.name}</div>\n <div className=\"flex flex-row gap-2\">\n <Label htmlFor=\"main\">Seleccionar todo</Label>\n <Switch id=\"main\" checked={allChecked} onCheckedChange={handleMainToggle} />\n </div>\n </div>\n\n {/* Switches hijos */}\n {switches.map((opt, index) => (\n <div key={opt.id} className={`p-2 rounded-lg flex flex-row w-full items-center justify-between ${!(index % 2 )? 'bg-black/5' : 'bg-white/5'}`}>\n <Label htmlFor={String(opt.id)}>{opt.label || opt.name}</Label>\n <Switch\n disabled={input.disabled || isSubmitting}\n id={String(opt.id)}\n checked={opt?.checked || false}\n onCheckedChange={checked => handleChildToggle(opt, checked, input) }\n />\n </div>\n ))}\n </div>\n </Card>\n )\n}\n\n","'use client'\n\n\nimport { UseFormReturn } from 'react-hook-form'\nimport { JSX, useEffect, useState } from 'react'\nimport { BaseInput, FieldProps, GroupedOption, handleOnChage, InputOption } from '../base'\nimport { GroupedSwitches } from './grouped-switches-input'\nimport { \n Accordion,\n AccordionContent,\n AccordionItem,\n AccordionTrigger,\n Badge,\n Card,\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormMessage \n} from '@/src/components/ui'\n\n/* ========= INPUT PRINCIPAL ========= */\n\nexport class AccordionGroupedSwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this\n return (\n <AccordionGroupedSwitches\n form={form}\n input={input}\n isSubmitting={isSubmitting}\n groups={(input?.listConfig?.list as GroupedOption[]) ?? []}\n onChange={input?.listConfig?.onOptionChange ?? (() => {})}\n />\n )\n }\n}\n\n/* ========= COMPONENTE ========= */\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n groups?: GroupedOption[];\n isSubmitting?: boolean;\n onChange?: (optionsUpdated: InputOption[]) => void\n}\n\nexport const AccordionGroupedSwitches = ({ form, input, groups = [], onChange, isSubmitting }: Props) => {\n const [groupsState, setGroupsState] = useState<GroupedOption[]>([])\n const [selectedOptions, setSelectedOptions] = useState<InputOption[]>([])\n\n // 🔹 Cargar los grupos y sincronizar seleccionados\n useEffect(() => {\n const selected = input.listConfig?.selectedList ?? []\n const updatedGroups = groups.map((group) => ({\n ...group,\n options: group.options.map((opt) => ({\n ...opt,\n checked: selected.some((sel) => sel.id === opt.id),\n groupedLabel: group.label,\n })),\n }))\n setGroupsState(updatedGroups)\n setSelectedOptions(selected)\n }, [groups, input])\n\n // 🔹 Calcular cuántos están seleccionados por grupo\n const countCheckedByGroup = (group: GroupedOption): number => {\n return group.options.filter((opt) => opt.checked).length\n }\n\n // 🔹 Manejar cambio en switches individuales\n const handleOptionChange = (field: any, updatedGroupLabel: string, updatedOptions: InputOption[], input: FieldProps) => {\n const newGroups = groupsState.map((group) =>\n group.label === updatedGroupLabel ? { ...group, options: updatedOptions } : group\n )\n\n setGroupsState(newGroups)\n\n const allChecked = newGroups.flatMap((g) => g.options).filter((o) => o.checked)\n setSelectedOptions(allChecked)\n field.onChange(allChecked)\n onChange?.(allChecked)\n handleOnChage(allChecked, input, field)\n }\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className=\"shadow-lg\">\n <FormControl>\n <Card className=\"p-4 space-y-4\">\n <h2 className=\"text-2xl font-bold\">{input.label}</h2>\n <Accordion type=\"multiple\">\n {groupsState.map((group, indx) => (\n <AccordionItem\n key={indx}\n value={group.label}\n className={`px-1 ${indx % 2 ? `bg-black/10` : 'bg-black/5'}`}\n >\n <AccordionTrigger>\n <div className=\"grid grid-cols-2 w-full\">\n {group.label}{' '}\n <Badge>\n {countCheckedByGroup(group)} / {group.options.length}\n </Badge>\n </div>\n </AccordionTrigger>\n <AccordionContent>\n <GroupedSwitches\n isSubmitting={isSubmitting}\n input={input}\n options={group.options}\n onChange={(updated: InputOption[]) =>\n handleOptionChange(field, group.label, updated, input)\n }\n />\n </AccordionContent>\n </AccordionItem>\n ))}\n </Accordion>\n </Card>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n\n {/* Debug visual opcional */}\n {/* <pre className=\"text-xs font-bold mt-2 bg-black/5 p-2 rounded-lg\">\n <code>{JSON.stringify(selectedOptions, null, 2)}</code>\n </pre> */}\n </FormItem>\n )}\n />\n )\n}\n","import { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport { Separator } from \"@/src/components/ui/separator\"\n\nconst buttonGroupVariants = cva(\n \"flex w-fit items-stretch [&>*]:focus-visible:z-10 [&>*]:focus-visible:relative [&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1 has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-md has-[>[data-slot=button-group]]:gap-2\",\n {\n variants: {\n orientation: {\n horizontal:\n \"[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none\",\n vertical:\n \"flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none\",\n },\n },\n defaultVariants: {\n orientation: \"horizontal\",\n },\n }\n)\n\nfunction ButtonGroup({\n className,\n orientation,\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof buttonGroupVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"button-group\"\n data-orientation={orientation}\n className={cn(buttonGroupVariants({ orientation }), className)}\n {...props}\n />\n )\n}\n\nfunction ButtonGroupText({\n className,\n asChild = false,\n ...props\n}: React.ComponentProps<\"div\"> & {\n asChild?: boolean\n}) {\n const Comp = asChild ? Slot : \"div\"\n\n return (\n <Comp\n className={cn(\n \"bg-muted flex items-center gap-2 rounded-md border px-4 text-sm font-medium shadow-xs [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ButtonGroupSeparator({\n className,\n orientation = \"vertical\",\n ...props\n}: React.ComponentProps<typeof Separator>) {\n return (\n <Separator\n data-slot=\"button-group-separator\"\n orientation={orientation}\n className={cn(\n \"bg-input relative !m-0 self-stretch data-[orientation=vertical]:h-auto\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n ButtonGroup,\n ButtonGroupSeparator,\n ButtonGroupText,\n buttonGroupVariants,\n}\n","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput, FieldProps, handleOnChage, InputOption } from \"../base\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { ButtonGroup } from \"@/src/components/ui/button-group\";\n\ninterface Option {\n label: string;\n value: string | number;\n}\n\nexport class ButtonGroupInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n const className = input.className\n return <FieldButtonGroup input={input} form={form} isSubmitting={isSubmitting} className={className}/>;\n }\n}\n\ninterface Props {\n input: FieldProps;\n form: UseFormReturn;\n isSubmitting?: boolean;\n className?: string;\n}\n\nexport const FieldButtonGroup = ({ input, form, isSubmitting, className = \"w-full flex-1\" }: Props) => {\n const options: InputOption[] = (input.listConfig?.list ?? []).filter((option): option is InputOption => 'name' in option);\n\n const handleSelect = (value: any) => {\n form.setValue(input.name, value, { shouldValidate: true });\n if (input.listConfig?.onOptionChange) input.listConfig.onOptionChange(value);\n };\n\n\n\n const selectedValue = form.watch(input.name);\n\n return (\n <ButtonGroup className=\"flex flex-row w-full\">\n {options.map((option, key) => (\n <Button\n type=\"button\"\n className={className}\n key={`${input.name}-${key}-btn-g`}\n variant={selectedValue === option.value ? \"default\" : \"outline\"}\n onClick={() => {\n handleSelect(option.value)\n handleOnChage(option.value, input)\n }}\n disabled={isSubmitting}\n >\n {option.label ?? option.name }\n </Button>\n ))}\n </ButtonGroup>\n );\n};\n","'use client'\nimport { JSX } from 'react';\nimport { BaseInput, handleOnChage } from '../base'\nimport { Card, CardContent, CardHeader, CardTitle, Checkbox, Label } from '@/src/components/ui';\n\n\n\n// interface Props {\n// title?: string,\n// input: FieldProps,\n// onCheckedChange: (value : InputOption) => void\n// }\n\nexport class CheckListInput extends BaseInput {\n render(): JSX.Element {\n const { input, isSubmitting } = this;\n const listConfig = input?.listConfig\n // export const InputCheckList = ({input, onCheckedChange, title}:Props) => {\n let lista = listConfig?.list ?? []\n if (lista == undefined) lista = []\n const title = 'title' //listConfig?.title\n\n const value: string[] = input.value\n const label = (listConfig?.optionLabel ?? \"name\") as string;\n const optionValue = (listConfig?.optionValue ?? \"id\") as string;\n const description = (listConfig?.optionDescription ?? \"description\") as string;\n return (\n <Card key={title}>\n <CardHeader className=\"pb-3\">\n <CardTitle className=\"text-base\">{title ?? input.label}</CardTitle>\n </CardHeader>\n <CardContent className=\"space-y-3\">\n {lista.map((item) => ( \n <div key={item[optionValue as keyof typeof item] as React.Key} className=\"flex items-center space-x-2\">\n <Checkbox\n onChange={(e) => handleOnChage(e, input)}\n disabled={input.disabled || isSubmitting}\n id={String(item[optionValue as keyof typeof item])}\n checked={value.includes(item[optionValue as keyof typeof item] as string)}\n onCheckedChange={() => {/* onCheckedChange(item[optionValue as keyof typeof item]) */}}\n />\n <div className=\"grid gap-1.5 leading-none\">\n <Label\n htmlFor={String(item[optionValue as keyof typeof item])}\n className=\"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\"\n >\n {item[label as keyof typeof item]}\n </Label>\n <p className=\"text-xs text-muted-foreground\">{item[description as keyof typeof item]}</p>\n </div>\n </div>\n )\n )}\n </CardContent>\n </Card>\n )\n }\n}\n","'use client'\n\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { JSX } from \"react\";\nimport { Checkbox } from \"@/src/components/ui/checkbox\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n} from \"@/src/components/ui/form\";\nimport { UseFormReturn } from \"react-hook-form\";\n\nexport class CheckboxInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n\n return (\n <FieldCheckbox form={form} input={input} isSubmitting={isSubmitting} />\n );\n }\n}\n\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldCheckbox = ({ input, form, isSubmitting }: Props) => {\n const className = input.className;\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem\n className={`hover:bg-accent/50 flex items-start gap-3 rounded-lg border p-3 transition \n has-[[aria-checked=true]]:border-blue-600 \n has-[[aria-checked=true]]:bg-blue-50 \n dark:has-[[aria-checked=true]]:border-blue-900 \n dark:has-[[aria-checked=true]]:bg-blue-950\n ${className ?? \"\"}`}\n >\n <FormControl>\n <Checkbox\n id={input.name}\n checked={field.value}\n onCheckedChange={(e) => handleOnChage(e, input, field)}\n disabled={input.disabled || isSubmitting}\n className=\"data-[state=checked]:border-blue-600 data-[state=checked]:bg-blue-600 data-[state=checked]:text-white \n dark:data-[state=checked]:border-blue-700 dark:data-[state=checked]:bg-blue-700\"\n />\n </FormControl>\n\n <div className=\"grid gap-1.5 font-normal\">\n <FormLabel htmlFor={input.name} className=\"text-sm leading-none font-medium\">\n {input.label ?? \"Enable notifications\"}\n </FormLabel>\n {(input.description || input.placeHolder) && (\n <FormDescription className=\"text-muted-foreground text-sm\">\n {input.description ?? input.placeHolder}\n </FormDescription>\n )}\n <FormMessage />\n </div>\n </FormItem>\n )}\n />\n )\n}","\"use client\"\nimport React, { JSX, useEffect, useState } from \"react\"\nimport { ColorPicker, useColor } from 'react-color-palette';\nimport { UseFormReturn } from \"react-hook-form\"\nimport \"react-color-palette/css\"\nimport { cn } from \"@/src/lib/utils\"\nimport { \n Button,\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Popover, \n PopoverContent, \n PopoverTrigger,\n} from \"@/src/components/ui\"\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\"\n// ...existing code...\n\nexport class ColorInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldColor input={input} form={form} isSubmitting={isSubmitting} />\n )\n }\n}\n\ntype HideInputOption = \"rgb\" | \"hsv\" | \"hex\";\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst PRESET_COLORS = [\n \"#ef4444\", // red\n \"#f97316\", // orange\n \"#eab308\", // yellow\n \"#22c55e\", // green\n \"#06b6d4\", // cyan\n \"#3b82f6\", // blue\n \"#8b5cf6\", // purple\n \"#ec4899\", // pink\n \"#64748b\", // slate\n \"#000000\", // black\n]\n\n\nconst FieldColor = ({ form, input, isSubmitting }: Props) => {\n const [ColorCmp, _setColorCmp] = useState<any>(ColorComp)\n\n \n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n {ColorCmp ? (\n <ColorCmp\n value={field.value || \"#000000\"}\n onChange={(event: any[])=> {\n handleOnChage(event, input, field)\n }}\n onBlur={field.onBlur}\n disabled={input.disabled || isSubmitting}\n placeholder={input.placeHolder}\n />\n ) : (\n 'N/A'\n // <input\n // type=\"color\"\n // value={field.value || \"#000000\"}\n // onChange={(e) => {\n // field.onChange(e.target.value);\n // input.onChange?.(e)\n // }}\n // onBlur={() => field.onBlur()}\n // disabled={input.disabled || isSubmitting}\n // placeholder={input.placeHolder}\n // style={{ width: 48, height: 28 }}\n // />\n )}\n </FormControl>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )}\n />\n )\n}\n// ...existing code...\n\n\nexport interface ColorCompProps {\n value?: string;\n onChange?: (color: string) => void;\n onBlur?: () => void;\n disabled?: boolean;\n className?: string;\n placeholder?: string;\n hideInput?: HideInputOption[];\n}\n\nconst ColorComp = React.forwardRef<HTMLButtonElement, ColorCompProps>(\n ({ value = \"#000000\", onChange, onBlur, disabled, className, hideInput =[\"hsv\"] }, ref) => {\n // const [color, setColor] = useColor(value)\n // const [open, setOpen] = React.useState(false)\n\n // React.useEffect(() => {\n // if (value !== color.hex) {\n // setColor({ ...color, hex: value })\n // }\n // }, [color, setColor, value])\n\n // const handleColorChange = (newColor: IColor) => {\n // setColor(newColor)\n // onChange?.(newColor.hex)\n // }\n\n // const handleOpenChange = (newOpen: boolean) => {\n // setOpen(newOpen)\n // if (!newOpen) {\n // onBlur?.()\n // }\n // }\n\n const [color, setColor] = useColor(value)\n const [open, setOpen] = useState(false)\n\n React.useEffect(() => {\n if (value !== color.hex) {\n setColor({ ...color, hex: value })\n }\n }, [value])\n\n const handleColorChange = (newColor: string) => {\n setColor({ ...color, hex: newColor })\n onChange?.(newColor)\n }\n\n const handlePickerChange = (newColor: any) => {\n setColor(newColor)\n onChange?.(newColor.hex)\n }\n\n const handleOpenChange = (newOpen: boolean) => {\n setOpen(newOpen)\n if (!newOpen) {\n onBlur?.()\n }\n }\n\n return (\n <div className=\"flex flex-col gap-3\">\n <div className=\"flex flex-wrap gap-2 p-2\">\n {PRESET_COLORS.map((presetColor) => (\n <button\n key={presetColor}\n type=\"button\"\n disabled={disabled}\n className={cn(\n \"size-6 rounded-md border-2 transition-all hover:scale-110 disabled:opacity-50 disabled:cursor-not-allowed\",\n color.hex === presetColor\n ? \"border-foreground ring-2 ring-foreground/20\"\n : \"border-border hover:border-foreground/50\",\n )}\n style={{ backgroundColor: presetColor }}\n onClick={() => handleColorChange(presetColor)}\n aria-label={`Select color ${presetColor}`}\n />\n ))}\n </div>\n \n <Popover open={open} onOpenChange={handleOpenChange}>\n <PopoverTrigger asChild>\n <Button\n ref={ref}\n variant=\"outline\"\n disabled={disabled}\n className={cn(\"w-full justify-start text-left font-normal\", !value && \"text-muted-foreground\", className)}\n >\n <div className=\"flex items-center gap-2\">\n <div className=\"h-4 w-4 border border-border rounded-sm\" style={{ backgroundColor: color.hex, width: 20, height:20 }} />\n <span>{color.hex}</span>\n </div>\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-3\" align=\"start\">\n <ColorPicker color={color} onChange={handlePickerChange} hideInput={hideInput} />\n </PopoverContent>\n </Popover>\n </div>\n )\n },\n)","\"use client\"\n\nimport * as React from \"react\"\nimport { Command as CommandPrimitive } from \"cmdk\"\nimport { SearchIcon } from \"lucide-react\"\n\nimport { cn } from \"@/src/lib/utils\"\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n} from \"@/src/components/ui/dialog\"\n\nfunction Command({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive>) {\n return (\n <CommandPrimitive\n data-slot=\"command\"\n className={cn(\n \"bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandDialog({\n title = \"Command Palette\",\n description = \"Search for a command to run...\",\n children,\n className,\n showCloseButton = true,\n ...props\n}: React.ComponentProps<typeof Dialog> & {\n title?: string\n description?: string\n className?: string\n showCloseButton?: boolean\n}) {\n return (\n <Dialog {...props}>\n <DialogHeader className=\"sr-only\">\n <DialogTitle>{title}</DialogTitle>\n <DialogDescription>{description}</DialogDescription>\n </DialogHeader>\n <DialogContent\n className={cn(\"overflow-hidden p-0\", className)}\n showCloseButton={showCloseButton}\n >\n <Command className=\"[&_[cmdk-group-heading]]:text-muted-foreground **:data-[slot=command-input-wrapper]:h-12 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group]]:px-2 [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n )\n}\n\nfunction CommandInput({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Input>) {\n return (\n <div\n data-slot=\"command-input-wrapper\"\n className=\"flex h-9 items-center gap-2 border-b px-3\"\n >\n <SearchIcon className=\"size-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n data-slot=\"command-input\"\n className={cn(\n \"placeholder:text-muted-foreground flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden disabled:cursor-not-allowed disabled:opacity-50\",\n className\n )}\n {...props}\n />\n </div>\n )\n}\n\nfunction CommandList({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.List>) {\n return (\n <CommandPrimitive.List\n data-slot=\"command-list\"\n className={cn(\n \"max-h-[300px] scroll-py-1 overflow-x-hidden overflow-y-auto\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandEmpty({\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Empty>) {\n return (\n <CommandPrimitive.Empty\n data-slot=\"command-empty\"\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n )\n}\n\nfunction CommandGroup({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Group>) {\n return (\n <CommandPrimitive.Group\n data-slot=\"command-group\"\n className={cn(\n \"text-foreground [&_[cmdk-group-heading]]:text-muted-foreground overflow-hidden p-1 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Separator>) {\n return (\n <CommandPrimitive.Separator\n data-slot=\"command-separator\"\n className={cn(\"bg-border -mx-1 h-px\", className)}\n {...props}\n />\n )\n}\n\nfunction CommandItem({\n className,\n ...props\n}: React.ComponentProps<typeof CommandPrimitive.Item>) {\n return (\n <CommandPrimitive.Item\n data-slot=\"command-item\"\n className={cn(\n \"data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction CommandShortcut({\n className,\n ...props\n}: React.ComponentProps<\"span\">) {\n return (\n <span\n data-slot=\"command-shortcut\"\n className={cn(\n \"text-muted-foreground ml-auto text-xs tracking-widest\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n}\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Check, ChevronsUpDown } from \"lucide-react\";\nimport { cn } from \"@/src/lib/utils\";\nimport { Button } from \"@/src/components/ui/button\";\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"@/src/components/ui/command\";\nimport {\n Popover,\n PopoverContent,\n PopoverTrigger,\n} from \"@/src/components/ui/popover\";\n\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\n\nexport class ComboboxInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldCombobox input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldCombobox = ({ form, input, isSubmitting }: Props) => {\n const [open, setOpen] = React.useState(false);\n const [options, setOptions] = React.useState<InputOption[]>(\n () =>\n input.listConfig?.list?.length\n ? (input.listConfig.list as InputOption[])\n : []\n );\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n const [value, setValue] = React.useState<string>(input.value?.toString() ?? \"\");\n\n // 🔁 Si depende de otro campo\n React.useEffect(() => {\n const dependsOn = input.dependsOn;\n if (!dependsOn || !input.loadOptions) return;\n\n const subscription = form.watch(async (values) => {\n const parentValue = values[dependsOn];\n if (parentValue) {\n const loader = input.loadOptions!;\n const newOptions = await loader(parentValue);\n setOptions(newOptions as InputOption[]);\n form.setValue(input.name, \"\");\n setValue(\"\");\n } else {\n setOptions([]);\n }\n });\n\n return () => subscription.unsubscribe?.();\n }, [form, input.loadOptions, input.dependsOn]);\n\n // Sincronizar valor inicial\n React.useEffect(() => {\n const currentValue = form.getValues(input.name);\n if (!currentValue && input.value) {\n form.setValue(input.name, input.value);\n setValue(input.value.toString());\n }\n }, [form, input.name, input.value]);\n\n const getValue = (item: InputOption): string =>\n (optionValue === \"name\"\n ? item.name\n : item.value?.toString() ?? item.id?.toString()) ?? \"\";\n\n const selectedOption = options.find((o) => getValue(o) === value);\n\n return (\n <div className=\"flex flex-col gap-2\">\n {input.label && (\n <label className=\"font-medium text-sm\">{input.label}</label>\n )}\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n <Button\n disabled={input.disabled || isSubmitting}\n variant=\"outline\"\n role=\"combobox\"\n aria-expanded={open}\n className=\"w-[60%] justify-between bg-black/10 dark:bg-white/25\"\n >\n {selectedOption ? selectedOption.name : input.placeHolder ?? \"Seleccionar...\"}\n <ChevronsUpDown className=\"opacity-50\" />\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-[60%] p-0\">\n <Command\n filter={(value, search) => {\n const option = options.find((o) => getValue(o) === value);\n return option?.name?.toLowerCase().includes(search.toLowerCase())\n ? 1\n : 0;\n }}\n >\n <CommandInput placeholder={`Buscar ${input.label?.toLowerCase()}...`} className=\"h-9\" />\n <CommandList>\n <CommandEmpty>No se encontraron resultados.</CommandEmpty>\n <CommandGroup>\n {options.map((item) => (\n <CommandItem\n key={item.id}\n value={getValue(item)}\n onSelect={(currentValue) => {\n const newValue = currentValue === value ? \"\" : currentValue;\n setValue(newValue);\n form.setValue(input.name, newValue);\n handleOnChage(options.find((o) => getValue(o) === newValue), input)\n input.listConfig?.onOptionChange?.(\n options.find((o) => getValue(o) === newValue)\n );\n setOpen(false);\n }}\n >\n {item.name}\n <Check\n className={cn(\n \"ml-auto\",\n value === getValue(item) ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n </div>\n );\n};\n","'use client'\n\nimport { JSX, useState, useMemo } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { \n FormField, \n FormItem, \n FormLabel, \n FormControl, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { \n InputGroup, \n InputGroupAddon, \n InputGroupInput, \n InputGroupText \n} from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class CurrencyInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldCurrency input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\n/**\n * Campo numérico con formato monetario.\n * Acepta solo números y el punto mientras se edita.\n */\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldCurrency = ({ form, input, isSubmitting }: Props): JSX.Element => {\n const groupConfig = input.inputGroupConfig;\n const infoTooltip = input?.infoTooltip;\n const autoValidate = groupConfig?.autoValidIcons;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n // Estado local para manejar validez desde el primer render\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n const defaultCurrencyFormat: Intl.NumberFormatOptions = {\n style: 'currency',\n currency: 'USD',\n minimumFractionDigits: 2,\n maximumFractionDigits: 2,\n };\n\n const mask = input?.mask;\n const currencyFormat = input?.currencyFormat ?? defaultCurrencyFormat;\n\n const [rawValue, setRawValue] = useState<string>(form.getValues(input.name) ?? \"\");\n\n // Formateador monetario (por defecto: español - República Dominicana)\n const formatter = useMemo(() => {\n return new Intl.NumberFormat('es-DO', currencyFormat);\n }, [currencyFormat]);\n\n // 🔢 Limpia y convierte el texto a número\n const parseValue = (formatted: string): number | null => {\n const numeric = parseFloat(formatted.replace(/[^0-9.-]/g, \"\"));\n return isNaN(numeric) ? null : numeric;\n };\n\n // 🎨 Aplica formato visual\n const formatValue = (value: string): string => {\n if (!value) return \"\";\n const numeric = parseFloat(value.replace(/[^0-9.-]/g, \"\"));\n if (isNaN(numeric)) return \"\";\n\n if (typeof mask === \"string\") {\n return mask.replace(/0+(?:[.,]0+)?/, formatter.format(numeric).replace(/[^\\d.,]/g, \"\"));\n }\n\n if (mask instanceof RegExp) {\n const valid = mask.test(value);\n return valid ? value : rawValue;\n }\n\n return formatter.format(numeric);\n };\n\n // 🚫 Permite solo números y punto\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n const allowedKeys = [\n \"Backspace\",\n \"Delete\",\n \"Tab\",\n \"ArrowLeft\",\n \"ArrowRight\",\n \"Home\",\n \"End\",\n ];\n\n // Permitir navegación y borrado\n if (allowedKeys.includes(e.key)) return;\n\n // Permitir solo dígitos y un único punto decimal\n if (!/^[0-9.]$/.test(e.key)) {\n e.preventDefault();\n return;\n }\n\n // Impedir más de un punto\n if (e.key === \".\" && rawValue.includes(\".\")) {\n e.preventDefault();\n }\n };\n\n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <InputGroup>\n {/* Prefijo */}\n <InputGroupAddon>\n <InputGroupText>$</InputGroupText>\n {input.inputGroupConfig?.textLeft && (\n <InputGroupText>{input.inputGroupConfig.textLeft}</InputGroupText>\n )}\n </InputGroupAddon>\n\n {/* Input principal */}\n <InputGroupInput\n {...field}\n disabled={input.disabled || isSubmitting}\n placeholder={input.placeHolder ?? \"0.00\"}\n inputMode=\"decimal\"\n value={rawValue}\n onKeyDown={handleKeyDown}\n onChange={(e) => {\n const newVal = e.target.value;\n setRawValue(newVal);\n const parsed = parseValue(newVal);\n if (parsed !== null) field.onChange(parsed);\n handleOnChage(parsed, input, field)\n }}\n onBlur={(e) => {\n const formatted = formatValue(e.target.value);\n setRawValue(formatted);\n }}\n onFocus={(e) => {\n const numeric = e.target.value.replace(/[^0-9.-]/g, \"\");\n setRawValue(numeric);\n }}\n />\n\n {/* Sufijo */}\n <InputGroupAddon align=\"inline-end\">\n <InputGroupText>{currencyFormat.currency}</InputGroupText>\n {input.inputGroupConfig?.textRight && (\n <InputGroupText>{input.inputGroupConfig.textRight}</InputGroupText>\n )}\n {/* Icono de validación / loading */}\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n </InputGroup>\n </FormControl>\n <FormMessage />\n </FormItem>\n )}}\n />\n );\n};\n","/**\n * @module constants\n * @summary Useful constants\n * @description\n * Collection of useful date constants.\n *\n * The constants could be imported from `date-fns/constants`:\n *\n * ```ts\n * import { maxTime, minTime } from \"./constants/date-fns/constants\";\n *\n * function isAllowedTime(time) {\n * return time <= maxTime && time >= minTime;\n * }\n * ```\n */\n\n/**\n * @constant\n * @name daysInWeek\n * @summary Days in 1 week.\n */\nexport const daysInWeek = 7;\n\n/**\n * @constant\n * @name daysInYear\n * @summary Days in 1 year.\n *\n * @description\n * How many days in a year.\n *\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate<DateType extends Date>(date: DateType): DateType {\n * return constructFrom(\n * date, // Use constructor from the given date\n * date.getTime() // Use the date value to create a new date\n * );\n * }\n */\nexport function constructFrom(date, value) {\n if (typeof date === \"function\") return date(value);\n\n if (date && typeof date === \"object\" && constructFromSymbol in date)\n return date[constructFromSymbol](value);\n\n if (date instanceof Date) return new date.constructor(value);\n\n return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n // [TODO] Get rid of `toDate` or `constructFrom`?\n return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n","let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\n}\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfWeek} function options.\n */\n\n/**\n * @name startOfWeek\n * @category Week Helpers\n * @summary Return the start of a week for the given date.\n *\n * @description\n * Return the start of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week\n *\n * @example\n * // The start of a week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date, options?.in);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n\n _date.setDate(_date.getDate() - diff);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeek;\n","import { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfISOWeek} function options.\n */\n\n/**\n * @name startOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the start of an ISO week for the given date.\n *\n * @description\n * Return the start of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * const result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfISOWeek(date, options) {\n return startOfWeek(date, { ...options, weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeekYear} function options.\n */\n\n/**\n * @name getISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Get the ISO week-numbering year of the given date.\n *\n * @description\n * Get the ISO week-numbering year of the given date,\n * which always starts 3 days before the year's first Thursday.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n *\n * @returns The ISO week-numbering year\n *\n * @example\n * // Which ISO-week numbering year is 2 January 2005?\n * const result = getISOWeekYear(new Date(2005, 0, 2))\n * //=> 2004\n */\nexport function getISOWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const fourthOfJanuaryOfNextYear = constructFrom(_date, 0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n\n const fourthOfJanuaryOfThisYear = constructFrom(_date, 0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getISOWeekYear;\n","import { toDate } from \"../toDate.js\";\n\n/**\n * Google Chrome as of 67.0.3396.87 introduced timezones with offset that includes seconds.\n * They usually appear for dates that denote time before the timezones were introduced\n * (e.g. for 'Europe/Prague' timezone the offset is GMT+00:57:44 before 1 October 1891\n * and GMT+01:00:00 after that date)\n *\n * Date#getTimezoneOffset returns the offset in minutes and would return 57 for the example above,\n * which would lead to incorrect calculations.\n *\n * This function returns the timezone offset in milliseconds that takes seconds in account.\n */\nexport function getTimezoneOffsetInMilliseconds(date) {\n const _date = toDate(date);\n const utcDate = new Date(\n Date.UTC(\n _date.getFullYear(),\n _date.getMonth(),\n _date.getDate(),\n _date.getHours(),\n _date.getMinutes(),\n _date.getSeconds(),\n _date.getMilliseconds(),\n ),\n );\n utcDate.setUTCFullYear(_date.getFullYear());\n return +date - +utcDate;\n}\n","import { constructFrom } from \"../constructFrom.js\";\n\nexport function normalizeDates(context, ...dates) {\n const normalize = constructFrom.bind(\n null,\n context || dates.find((date) => typeof date === \"object\"),\n );\n return dates.map(normalize);\n}\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfDay} function options.\n */\n\n/**\n * @name startOfDay\n * @category Day Helpers\n * @summary Return the start of a day for the given date.\n *\n * @description\n * Return the start of a day for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a day\n *\n * @example\n * // The start of a day for 2 September 2014 11:55:00:\n * const result = startOfDay(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 02 2014 00:00:00\n */\nexport function startOfDay(date, options) {\n const _date = toDate(date, options?.in);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfDay;\n","import { getTimezoneOffsetInMilliseconds } from \"./_lib/getTimezoneOffsetInMilliseconds.js\";\nimport { normalizeDates } from \"./_lib/normalizeDates.js\";\nimport { millisecondsInDay } from \"./constants.js\";\nimport { startOfDay } from \"./startOfDay.js\";\n\n/**\n * The {@link differenceInCalendarDays} function options.\n */\n\n/**\n * @name differenceInCalendarDays\n * @category Day Helpers\n * @summary Get the number of calendar days between the given dates.\n *\n * @description\n * Get the number of calendar days between the given dates. This means that the times are removed\n * from the dates and then the difference in days is calculated.\n *\n * @param laterDate - The later date\n * @param earlierDate - The earlier date\n * @param options - The options object\n *\n * @returns The number of calendar days\n *\n * @example\n * // How many calendar days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInCalendarDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 366\n * // How many calendar days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInCalendarDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 1\n */\nexport function differenceInCalendarDays(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n\n const laterStartOfDay = startOfDay(laterDate_);\n const earlierStartOfDay = startOfDay(earlierDate_);\n\n const laterTimestamp =\n +laterStartOfDay - getTimezoneOffsetInMilliseconds(laterStartOfDay);\n const earlierTimestamp =\n +earlierStartOfDay - getTimezoneOffsetInMilliseconds(earlierStartOfDay);\n\n // Round the number of days to the nearest integer because the number of\n // milliseconds in a day is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay);\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarDays;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { getISOWeekYear } from \"./getISOWeekYear.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\n\n/**\n * The {@link startOfISOWeekYear} function options.\n */\n\n/**\n * @name startOfISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Return the start of an ISO week-numbering year for the given date.\n *\n * @description\n * Return the start of an ISO week-numbering year,\n * which always starts 3 days before the year's first Thursday.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week-numbering year\n *\n * @example\n * // The start of an ISO week-numbering year for 2 July 2005:\n * const result = startOfISOWeekYear(new Date(2005, 6, 2))\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfISOWeekYear(date, options) {\n const year = getISOWeekYear(date, options);\n const fourthOfJanuary = constructFrom(options?.in || date, 0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n return startOfISOWeek(fourthOfJanuary);\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeekYear;\n","/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param value - The value to check\n *\n * @returns True if the given value is a date\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport function isDate(value) {\n return (\n value instanceof Date ||\n (typeof value === \"object\" &&\n Object.prototype.toString.call(value) === \"[object Date]\")\n );\n}\n\n// Fallback for modularized imports:\nexport default isDate;\n","import { isDate } from \"./isDate.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate](https://date-fns.org/docs/toDate)\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @param date - The date to check\n *\n * @returns The date is valid\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertible into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport function isValid(date) {\n return !((!isDate(date) && typeof date !== \"number\") || isNaN(+toDate(date)));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfYear} function options.\n */\n\n/**\n * @name startOfYear\n * @category Year Helpers\n * @summary Return the start of a year for the given date.\n *\n * @description\n * Return the start of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a year\n *\n * @example\n * // The start of a year for 2 September 2014 11:55:00:\n * const result = startOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Jan 01 2014 00:00:00\n */\nexport function startOfYear(date, options) {\n const date_ = toDate(date, options?.in);\n date_.setFullYear(date_.getFullYear(), 0, 1);\n date_.setHours(0, 0, 0, 0);\n return date_;\n}\n\n// Fallback for modularized imports:\nexport default startOfYear;\n","const formatDistanceLocale = {\n lessThanXSeconds: {\n one: \"less than a second\",\n other: \"less than {{count}} seconds\",\n },\n\n xSeconds: {\n one: \"1 second\",\n other: \"{{count}} seconds\",\n },\n\n halfAMinute: \"half a minute\",\n\n lessThanXMinutes: {\n one: \"less than a minute\",\n other: \"less than {{count}} minutes\",\n },\n\n xMinutes: {\n one: \"1 minute\",\n other: \"{{count}} minutes\",\n },\n\n aboutXHours: {\n one: \"about 1 hour\",\n other: \"about {{count}} hours\",\n },\n\n xHours: {\n one: \"1 hour\",\n other: \"{{count}} hours\",\n },\n\n xDays: {\n one: \"1 day\",\n other: \"{{count}} days\",\n },\n\n aboutXWeeks: {\n one: \"about 1 week\",\n other: \"about {{count}} weeks\",\n },\n\n xWeeks: {\n one: \"1 week\",\n other: \"{{count}} weeks\",\n },\n\n aboutXMonths: {\n one: \"about 1 month\",\n other: \"about {{count}} months\",\n },\n\n xMonths: {\n one: \"1 month\",\n other: \"{{count}} months\",\n },\n\n aboutXYears: {\n one: \"about 1 year\",\n other: \"about {{count}} years\",\n },\n\n xYears: {\n one: \"1 year\",\n other: \"{{count}} years\",\n },\n\n overXYears: {\n one: \"over 1 year\",\n other: \"over {{count}} years\",\n },\n\n almostXYears: {\n one: \"almost 1 year\",\n other: \"almost {{count}} years\",\n },\n};\n\nexport const formatDistance = (token, count, options) => {\n let result;\n\n const tokenValue = formatDistanceLocale[token];\n if (typeof tokenValue === \"string\") {\n result = tokenValue;\n } else if (count === 1) {\n result = tokenValue.one;\n } else {\n result = tokenValue.other.replace(\"{{count}}\", count.toString());\n }\n\n if (options?.addSuffix) {\n if (options.comparison && options.comparison > 0) {\n return \"in \" + result;\n } else {\n return result + \" ago\";\n }\n }\n\n return result;\n};\n","export function buildFormatLongFn(args) {\n return (options = {}) => {\n // TODO: Remove String()\n const width = options.width ? String(options.width) : args.defaultWidth;\n const format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}\n","import { buildFormatLongFn } from \"../../_lib/buildFormatLongFn.js\";\n\nconst dateFormats = {\n full: \"EEEE, MMMM do, y\",\n long: \"MMMM do, y\",\n medium: \"MMM d, y\",\n short: \"MM/dd/yyyy\",\n};\n\nconst timeFormats = {\n full: \"h:mm:ss a zzzz\",\n long: \"h:mm:ss a z\",\n medium: \"h:mm:ss a\",\n short: \"h:mm a\",\n};\n\nconst dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: \"{{date}}, {{time}}\",\n short: \"{{date}}, {{time}}\",\n};\n\nexport const formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: \"full\",\n }),\n\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: \"full\",\n }),\n\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: \"full\",\n }),\n};\n","const formatRelativeLocale = {\n lastWeek: \"'last' eeee 'at' p\",\n yesterday: \"'yesterday at' p\",\n today: \"'today at' p\",\n tomorrow: \"'tomorrow at' p\",\n nextWeek: \"eeee 'at' p\",\n other: \"P\",\n};\n\nexport const formatRelative = (token, _date, _baseDate, _options) =>\n formatRelativeLocale[token];\n","/**\n * The localize function argument callback which allows to convert raw value to\n * the actual type.\n *\n * @param value - The value to convert\n *\n * @returns The converted value\n */\n\n/**\n * The map of localized values for each width.\n */\n\n/**\n * The index type of the locale unit value. It types conversion of units of\n * values that don't start at 0 (i.e. quarters).\n */\n\n/**\n * Converts the unit value to the tuple of values.\n */\n\n/**\n * The tuple of localized era values. The first element represents BC,\n * the second element represents AD.\n */\n\n/**\n * The tuple of localized quarter values. The first element represents Q1.\n */\n\n/**\n * The tuple of localized day values. The first element represents Sunday.\n */\n\n/**\n * The tuple of localized month values. The first element represents January.\n */\n\nexport function buildLocalizeFn(args) {\n return (value, options) => {\n const context = options?.context ? String(options.context) : \"standalone\";\n\n let valuesArray;\n if (context === \"formatting\" && args.formattingValues) {\n const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n const width = options?.width ? String(options.width) : defaultWidth;\n\n valuesArray =\n args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n const defaultWidth = args.defaultWidth;\n const width = options?.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[width] || args.values[defaultWidth];\n }\n const index = args.argumentCallback ? args.argumentCallback(value) : value;\n\n // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n return valuesArray[index];\n };\n}\n","import { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.js\";\n\nconst eraValues = {\n narrow: [\"B\", \"A\"],\n abbreviated: [\"BC\", \"AD\"],\n wide: [\"Before Christ\", \"Anno Domini\"],\n};\n\nconst quarterValues = {\n narrow: [\"1\", \"2\", \"3\", \"4\"],\n abbreviated: [\"Q1\", \"Q2\", \"Q3\", \"Q4\"],\n wide: [\"1st quarter\", \"2nd quarter\", \"3rd quarter\", \"4th quarter\"],\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nconst monthValues = {\n narrow: [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"],\n abbreviated: [\n \"Jan\",\n \"Feb\",\n \"Mar\",\n \"Apr\",\n \"May\",\n \"Jun\",\n \"Jul\",\n \"Aug\",\n \"Sep\",\n \"Oct\",\n \"Nov\",\n \"Dec\",\n ],\n\n wide: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n};\n\nconst dayValues = {\n narrow: [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"],\n short: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n abbreviated: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n wide: [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n ],\n};\n\nconst dayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n};\n\nconst formattingDayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n};\n\nconst ordinalNumber = (dirtyNumber, _options) => {\n const number = Number(dirtyNumber);\n\n // If ordinal numbers depend on context, for example,\n // if they are different for different grammatical genders,\n // use `options.unit`.\n //\n // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n // 'day', 'hour', 'minute', 'second'.\n\n const rem100 = number % 100;\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + \"st\";\n case 2:\n return number + \"nd\";\n case 3:\n return number + \"rd\";\n }\n }\n return number + \"th\";\n};\n\nexport const localize = {\n ordinalNumber,\n\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: \"wide\",\n }),\n\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: \"wide\",\n argumentCallback: (quarter) => quarter - 1,\n }),\n\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: \"wide\",\n }),\n\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: \"wide\",\n }),\n\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: \"wide\",\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: \"wide\",\n }),\n};\n","export function buildMatchFn(args) {\n return (string, options = {}) => {\n const width = options.width;\n\n const matchPattern =\n (width && args.matchPatterns[width]) ||\n args.matchPatterns[args.defaultMatchWidth];\n const matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n const matchedString = matchResult[0];\n\n const parsePatterns =\n (width && args.parsePatterns[width]) ||\n args.parsePatterns[args.defaultParseWidth];\n\n const key = Array.isArray(parsePatterns)\n ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))\n : // [TODO] -- I challenge you to fix the type\n findKey(parsePatterns, (pattern) => pattern.test(matchedString));\n\n let value;\n\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback\n ? // [TODO] -- I challenge you to fix the type\n options.valueCallback(value)\n : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n\nfunction findKey(object, predicate) {\n for (const key in object) {\n if (\n Object.prototype.hasOwnProperty.call(object, key) &&\n predicate(object[key])\n ) {\n return key;\n }\n }\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (let key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n return undefined;\n}\n","export function buildMatchPatternFn(args) {\n return (string, options = {}) => {\n const matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n const matchedString = matchResult[0];\n\n const parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n let value = args.valueCallback\n ? args.valueCallback(parseResult[0])\n : parseResult[0];\n\n // [TODO] I challenge you to fix the type\n value = options.valueCallback ? options.valueCallback(value) : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n","import { buildMatchFn } from \"../../_lib/buildMatchFn.js\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.js\";\n\nconst matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nconst parseOrdinalNumberPattern = /\\d+/i;\n\nconst matchEraPatterns = {\n narrow: /^(b|a)/i,\n abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n wide: /^(before christ|before common era|anno domini|common era)/i,\n};\nconst parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i],\n};\n\nconst matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i,\n};\nconst parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i],\n};\n\nconst matchMonthPatterns = {\n narrow: /^[jfmasond]/i,\n abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i,\n};\nconst parseMonthPatterns = {\n narrow: [\n /^j/i,\n /^f/i,\n /^m/i,\n /^a/i,\n /^m/i,\n /^j/i,\n /^j/i,\n /^a/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n\n any: [\n /^ja/i,\n /^f/i,\n /^mar/i,\n /^ap/i,\n /^may/i,\n /^jun/i,\n /^jul/i,\n /^au/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n};\n\nconst matchDayPatterns = {\n narrow: /^[smtwf]/i,\n short: /^(su|mo|tu|we|th|fr|sa)/i,\n abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i,\n};\nconst parseDayPatterns = {\n narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i],\n};\n\nconst matchDayPeriodPatterns = {\n narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i,\n};\nconst parseDayPeriodPatterns = {\n any: {\n am: /^a/i,\n pm: /^p/i,\n midnight: /^mi/i,\n noon: /^no/i,\n morning: /morning/i,\n afternoon: /afternoon/i,\n evening: /evening/i,\n night: /night/i,\n },\n};\n\nexport const match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: (value) => parseInt(value, 10),\n }),\n\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseEraPatterns,\n defaultParseWidth: \"any\",\n }),\n\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: \"any\",\n valueCallback: (index) => index + 1,\n }),\n\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: \"any\",\n }),\n\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseDayPatterns,\n defaultParseWidth: \"any\",\n }),\n\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: \"any\",\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: \"any\",\n }),\n};\n","import { formatDistance } from \"./en-US/_lib/formatDistance.js\";\nimport { formatLong } from \"./en-US/_lib/formatLong.js\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.js\";\nimport { localize } from \"./en-US/_lib/localize.js\";\nimport { match } from \"./en-US/_lib/match.js\";\n\n/**\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp](https://github.com/kossnocorp)\n * @author Lesha Koss [@leshakoss](https://github.com/leshakoss)\n */\nexport const enUS = {\n code: \"en-US\",\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0 /* Sunday */,\n firstWeekContainsDate: 1,\n },\n};\n\n// Fallback for modularized imports:\nexport default enUS;\n","import { differenceInCalendarDays } from \"./differenceInCalendarDays.js\";\nimport { startOfYear } from \"./startOfYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getDayOfYear} function options.\n */\n\n/**\n * @name getDayOfYear\n * @category Day Helpers\n * @summary Get the day of the year of the given date.\n *\n * @description\n * Get the day of the year of the given date.\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The day of year\n *\n * @example\n * // Which day of the year is 2 July 2014?\n * const result = getDayOfYear(new Date(2014, 6, 2))\n * //=> 183\n */\nexport function getDayOfYear(date, options) {\n const _date = toDate(date, options?.in);\n const diff = differenceInCalendarDays(_date, startOfYear(_date));\n const dayOfYear = diff + 1;\n return dayOfYear;\n}\n\n// Fallback for modularized imports:\nexport default getDayOfYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeek} function options.\n */\n\n/**\n * @name getISOWeek\n * @category ISO Week Helpers\n * @summary Get the ISO week of the given date.\n *\n * @description\n * Get the ISO week of the given date.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The ISO week\n *\n * @example\n * // Which week of the ISO-week numbering year is 2 January 2005?\n * const result = getISOWeek(new Date(2005, 0, 2))\n * //=> 53\n */\nexport function getISOWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getISOWeek;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeekYear} function options.\n */\n\n/**\n * @name getWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Get the local week-numbering year of the given date.\n *\n * @description\n * Get the local week-numbering year of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options.\n *\n * @returns The local week-numbering year\n *\n * @example\n * // Which week numbering year is 26 December 2004 with the default settings?\n * const result = getWeekYear(new Date(2004, 11, 26))\n * //=> 2005\n *\n * @example\n * // Which week numbering year is 26 December 2004 if week starts on Saturday?\n * const result = getWeekYear(new Date(2004, 11, 26), { weekStartsOn: 6 })\n * //=> 2004\n *\n * @example\n * // Which week numbering year is 26 December 2004 if the first week contains 4 January?\n * const result = getWeekYear(new Date(2004, 11, 26), { firstWeekContainsDate: 4 })\n * //=> 2004\n */\nexport function getWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const firstWeekOfNextYear = constructFrom(options?.in || date, 0);\n firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);\n\n const firstWeekOfThisYear = constructFrom(options?.in || date, 0);\n firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);\n\n if (+_date >= +startOfNextYear) {\n return year + 1;\n } else if (+_date >= +startOfThisYear) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getWeekYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { getWeekYear } from \"./getWeekYear.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfWeekYear} function options.\n */\n\n/**\n * @name startOfWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Return the start of a local week-numbering year for the given date.\n *\n * @description\n * Return the start of a local week-numbering year.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week-numbering year\n *\n * @example\n * // The start of an a week-numbering year for 2 July 2005 with default settings:\n * const result = startOfWeekYear(new Date(2005, 6, 2))\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // The start of a week-numbering year for 2 July 2005\n * // if Monday is the first day of week\n * // and 4 January is always in the first week of the year:\n * const result = startOfWeekYear(new Date(2005, 6, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfWeekYear(date, options) {\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const year = getWeekYear(date, options);\n const firstWeek = constructFrom(options?.in || date, 0);\n firstWeek.setFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setHours(0, 0, 0, 0);\n const _date = startOfWeek(firstWeek, options);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeekYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { startOfWeekYear } from \"./startOfWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeek} function options.\n */\n\n/**\n * @name getWeek\n * @category Week Helpers\n * @summary Get the local week index of the given date.\n *\n * @description\n * Get the local week index of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The week\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005 with default options?\n * const result = getWeek(new Date(2005, 0, 2))\n * //=> 2\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January?\n * const result = getWeek(new Date(2005, 0, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> 53\n */\nexport function getWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getWeek;\n","export function addLeadingZeros(number, targetLength) {\n const sign = number < 0 ? \"-\" : \"\";\n const output = Math.abs(number).toString().padStart(targetLength, \"0\");\n return sign + output;\n}\n","import { addLeadingZeros } from \"../addLeadingZeros.js\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | |\n * | d | Day of month | D | |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | m | Minute | M | Month |\n * | s | Second | S | Fraction of second |\n * | y | Year (abs) | Y | |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\n\nexport const lightFormatters = {\n // Year\n y(date, token) {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === \"yy\" ? year % 100 : year, token.length);\n },\n\n // Month\n M(date, token) {\n const month = date.getMonth();\n return token === \"M\" ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n\n // Day of the month\n d(date, token) {\n return addLeadingZeros(date.getDate(), token.length);\n },\n\n // AM or PM\n a(date, token) {\n const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return dayPeriodEnumValue.toUpperCase();\n case \"aaa\":\n return dayPeriodEnumValue;\n case \"aaaaa\":\n return dayPeriodEnumValue[0];\n case \"aaaa\":\n default:\n return dayPeriodEnumValue === \"am\" ? \"a.m.\" : \"p.m.\";\n }\n },\n\n // Hour [1-12]\n h(date, token) {\n return addLeadingZeros(date.getHours() % 12 || 12, token.length);\n },\n\n // Hour [0-23]\n H(date, token) {\n return addLeadingZeros(date.getHours(), token.length);\n },\n\n // Minute\n m(date, token) {\n return addLeadingZeros(date.getMinutes(), token.length);\n },\n\n // Second\n s(date, token) {\n return addLeadingZeros(date.getSeconds(), token.length);\n },\n\n // Fraction of second\n S(date, token) {\n const numberOfDigits = token.length;\n const milliseconds = date.getMilliseconds();\n const fractionalSeconds = Math.trunc(\n milliseconds * Math.pow(10, numberOfDigits - 3),\n );\n return addLeadingZeros(fractionalSeconds, token.length);\n },\n};\n","import { getDayOfYear } from \"../../getDayOfYear.js\";\nimport { getISOWeek } from \"../../getISOWeek.js\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.js\";\nimport { getWeek } from \"../../getWeek.js\";\nimport { getWeekYear } from \"../../getWeekYear.js\";\n\nimport { addLeadingZeros } from \"../addLeadingZeros.js\";\nimport { lightFormatters } from \"./lightFormatters.js\";\n\nconst dayPeriodEnum = {\n am: \"am\",\n pm: \"pm\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n};\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O | Timezone (GMT) |\n * | p! | Long localized time | P! | Long localized date |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nexport const formatters = {\n // Era\n G: function (date, token, localize) {\n const era = date.getFullYear() > 0 ? 1 : 0;\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return localize.era(era, { width: \"abbreviated\" });\n // A, B\n case \"GGGGG\":\n return localize.era(era, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return localize.era(era, { width: \"wide\" });\n }\n },\n\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === \"yo\") {\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, { unit: \"year\" });\n }\n\n return lightFormatters.y(date, token);\n },\n\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n const signedWeekYear = getWeekYear(date, options);\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n // Two digit year\n if (token === \"YY\") {\n const twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n }\n\n // Ordinal number\n if (token === \"Yo\") {\n return localize.ordinalNumber(weekYear, { unit: \"year\" });\n }\n\n // Padding\n return addLeadingZeros(weekYear, token.length);\n },\n\n // ISO week-numbering year\n R: function (date, token) {\n const isoWeekYear = getISOWeekYear(date);\n\n // Padding\n return addLeadingZeros(isoWeekYear, token.length);\n },\n\n // Extended year. This is a single number designating the year of this calendar system.\n // The main difference between `y` and `u` localizers are B.C. years:\n // | Year | `y` | `u` |\n // |------|-----|-----|\n // | AC 1 | 1 | 1 |\n // | BC 1 | 1 | 0 |\n // | BC 2 | 2 | -1 |\n // Also `yy` always returns the last two digits of a year,\n // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n u: function (date, token) {\n const year = date.getFullYear();\n return addLeadingZeros(year, token.length);\n },\n\n // Quarter\n Q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"QQ\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone quarter\n q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"qq\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // Month\n M: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n case \"M\":\n case \"MM\":\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // J, F, ..., D\n case \"MMMMM\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return localize.month(month, { width: \"wide\", context: \"formatting\" });\n }\n },\n\n // Stand-alone month\n L: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return String(month + 1);\n // 01, 02, ..., 12\n case \"LL\":\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // J, F, ..., D\n case \"LLLLL\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return localize.month(month, { width: \"wide\", context: \"standalone\" });\n }\n },\n\n // Local week of year\n w: function (date, token, localize, options) {\n const week = getWeek(date, options);\n\n if (token === \"wo\") {\n return localize.ordinalNumber(week, { unit: \"week\" });\n }\n\n return addLeadingZeros(week, token.length);\n },\n\n // ISO week of year\n I: function (date, token, localize) {\n const isoWeek = getISOWeek(date);\n\n if (token === \"Io\") {\n return localize.ordinalNumber(isoWeek, { unit: \"week\" });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n\n // Day of the month\n d: function (date, token, localize) {\n if (token === \"do\") {\n return localize.ordinalNumber(date.getDate(), { unit: \"date\" });\n }\n\n return lightFormatters.d(date, token);\n },\n\n // Day of year\n D: function (date, token, localize) {\n const dayOfYear = getDayOfYear(date);\n\n if (token === \"Do\") {\n return localize.ordinalNumber(dayOfYear, { unit: \"dayOfYear\" });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n\n // Day of week\n E: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"EEEEE\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"EEEE\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Local day of week\n e: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (Nth day of week with current locale or weekStartsOn)\n case \"e\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"ee\":\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n case \"eo\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"eee\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"eeeee\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"eeee\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (same as in `e`)\n case \"c\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"cc\":\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n case \"co\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"ccc\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // T\n case \"ccccc\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"standalone\",\n });\n // Tuesday\n case \"cccc\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // ISO day of week\n i: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n switch (token) {\n // 2\n case \"i\":\n return String(isoDayOfWeek);\n // 02\n case \"ii\":\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n case \"io\":\n return localize.ordinalNumber(isoDayOfWeek, { unit: \"day\" });\n // Tue\n case \"iii\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"iiiii\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"iiiiii\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"iiii\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM or PM\n a: function (date, token, localize) {\n const hours = date.getHours();\n const dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"aaa\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"aaaaa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours === 12) {\n dayPeriodEnumValue = dayPeriodEnum.noon;\n } else if (hours === 0) {\n dayPeriodEnumValue = dayPeriodEnum.midnight;\n } else {\n dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n }\n\n switch (token) {\n case \"b\":\n case \"bb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"bbb\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"bbbbb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours >= 17) {\n dayPeriodEnumValue = dayPeriodEnum.evening;\n } else if (hours >= 12) {\n dayPeriodEnumValue = dayPeriodEnum.afternoon;\n } else if (hours >= 4) {\n dayPeriodEnumValue = dayPeriodEnum.morning;\n } else {\n dayPeriodEnumValue = dayPeriodEnum.night;\n }\n\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"BBBBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === \"ho\") {\n let hours = date.getHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return lightFormatters.h(date, token);\n },\n\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === \"Ho\") {\n return localize.ordinalNumber(date.getHours(), { unit: \"hour\" });\n }\n\n return lightFormatters.H(date, token);\n },\n\n // Hour [0-11]\n K: function (date, token, localize) {\n const hours = date.getHours() % 12;\n\n if (token === \"Ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Hour [1-24]\n k: function (date, token, localize) {\n let hours = date.getHours();\n if (hours === 0) hours = 24;\n\n if (token === \"ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Minute\n m: function (date, token, localize) {\n if (token === \"mo\") {\n return localize.ordinalNumber(date.getMinutes(), { unit: \"minute\" });\n }\n\n return lightFormatters.m(date, token);\n },\n\n // Second\n s: function (date, token, localize) {\n if (token === \"so\") {\n return localize.ordinalNumber(date.getSeconds(), { unit: \"second\" });\n }\n\n return lightFormatters.s(date, token);\n },\n\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n if (timezoneOffset === 0) {\n return \"Z\";\n }\n\n switch (token) {\n // Hours and optional minutes\n case \"X\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XX`\n case \"XXXX\":\n case \"XX\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XXX`\n case \"XXXXX\":\n case \"XXX\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case \"x\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xx`\n case \"xxxx\":\n case \"xx\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xxx`\n case \"xxxxx\":\n case \"xxx\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (GMT)\n O: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"O\":\n case \"OO\":\n case \"OOO\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"OOOO\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (specific non-location)\n z: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"z\":\n case \"zz\":\n case \"zzz\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"zzzz\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Seconds timestamp\n t: function (date, token, _localize) {\n const timestamp = Math.trunc(+date / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n return addLeadingZeros(+date, token.length);\n },\n};\n\nfunction formatTimezoneShort(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = Math.trunc(absOffset / 60);\n const minutes = absOffset % 60;\n if (minutes === 0) {\n return sign + String(hours);\n }\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, delimiter) {\n if (offset % 60 === 0) {\n const sign = offset > 0 ? \"-\" : \"+\";\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n return formatTimezone(offset, delimiter);\n}\n\nfunction formatTimezone(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);\n const minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n","const dateLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"P\":\n return formatLong.date({ width: \"short\" });\n case \"PP\":\n return formatLong.date({ width: \"medium\" });\n case \"PPP\":\n return formatLong.date({ width: \"long\" });\n case \"PPPP\":\n default:\n return formatLong.date({ width: \"full\" });\n }\n};\n\nconst timeLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"p\":\n return formatLong.time({ width: \"short\" });\n case \"pp\":\n return formatLong.time({ width: \"medium\" });\n case \"ppp\":\n return formatLong.time({ width: \"long\" });\n case \"pppp\":\n default:\n return formatLong.time({ width: \"full\" });\n }\n};\n\nconst dateTimeLongFormatter = (pattern, formatLong) => {\n const matchResult = pattern.match(/(P+)(p+)?/) || [];\n const datePattern = matchResult[1];\n const timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n let dateTimeFormat;\n\n switch (datePattern) {\n case \"P\":\n dateTimeFormat = formatLong.dateTime({ width: \"short\" });\n break;\n case \"PP\":\n dateTimeFormat = formatLong.dateTime({ width: \"medium\" });\n break;\n case \"PPP\":\n dateTimeFormat = formatLong.dateTime({ width: \"long\" });\n break;\n case \"PPPP\":\n default:\n dateTimeFormat = formatLong.dateTime({ width: \"full\" });\n break;\n }\n\n return dateTimeFormat\n .replace(\"{{date}}\", dateLongFormatter(datePattern, formatLong))\n .replace(\"{{time}}\", timeLongFormatter(timePattern, formatLong));\n};\n\nexport const longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter,\n};\n","const dayOfYearTokenRE = /^D+$/;\nconst weekYearTokenRE = /^Y+$/;\n\nconst throwTokens = [\"D\", \"DD\", \"YY\", \"YYYY\"];\n\nexport function isProtectedDayOfYearToken(token) {\n return dayOfYearTokenRE.test(token);\n}\n\nexport function isProtectedWeekYearToken(token) {\n return weekYearTokenRE.test(token);\n}\n\nexport function warnOrThrowProtectedError(token, format, input) {\n const _message = message(token, format, input);\n console.warn(_message);\n if (throwTokens.includes(token)) throw new RangeError(_message);\n}\n\nfunction message(token, format, input) {\n const subject = token[0] === \"Y\" ? \"years\" : \"days of the month\";\n return `Use \\`${token.toLowerCase()}\\` instead of \\`${token}\\` (in \\`${format}\\`) for formatting ${subject} to the input \\`${input}\\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;\n}\n","import { defaultLocale } from \"./_lib/defaultLocale.js\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { formatters } from \"./_lib/format/formatters.js\";\nimport { longFormatters } from \"./_lib/format/longFormatters.js\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.js\";\nimport { isValid } from \"./isValid.js\";\nimport { toDate } from \"./toDate.js\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { formatters, longFormatters };\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\nexport { format as formatDate };\n\n/**\n * The {@link format} function options.\n */\n\n/**\n * @name format\n * @alias formatDate\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit | Pattern | Result examples | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era | G..GGG | AD, BC | |\n * | | GGGG | Anno Domini, Before Christ | 2 |\n * | | GGGGG | A, B | |\n * | Calendar year | y | 44, 1, 1900, 2017 | 5 |\n * | | yo | 44th, 1st, 0th, 17th | 5,7 |\n * | | yy | 44, 01, 00, 17 | 5 |\n * | | yyy | 044, 001, 1900, 2017 | 5 |\n * | | yyyy | 0044, 0001, 1900, 2017 | 5 |\n * | | yyyyy | ... | 3,5 |\n * | Local week-numbering year | Y | 44, 1, 1900, 2017 | 5 |\n * | | Yo | 44th, 1st, 1900th, 2017th | 5,7 |\n * | | YY | 44, 01, 00, 17 | 5,8 |\n * | | YYY | 044, 001, 1900, 2017 | 5 |\n * | | YYYY | 0044, 0001, 1900, 2017 | 5,8 |\n * | | YYYYY | ... | 3,5 |\n * | ISO week-numbering year | R | -43, 0, 1, 1900, 2017 | 5,7 |\n * | | RR | -43, 00, 01, 1900, 2017 | 5,7 |\n * | | RRR | -043, 000, 001, 1900, 2017 | 5,7 |\n * | | RRRR | -0043, 0000, 0001, 1900, 2017 | 5,7 |\n * | | RRRRR | ... | 3,5,7 |\n * | Extended year | u | -43, 0, 1, 1900, 2017 | 5 |\n * | | uu | -43, 01, 1900, 2017 | 5 |\n * | | uuu | -043, 001, 1900, 2017 | 5 |\n * | | uuuu | -0043, 0001, 1900, 2017 | 5 |\n * | | uuuuu | ... | 3,5 |\n * | Quarter (formatting) | Q | 1, 2, 3, 4 | |\n * | | Qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | QQ | 01, 02, 03, 04 | |\n * | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | q | 1, 2, 3, 4 | |\n * | | qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | qq | 01, 02, 03, 04 | |\n * | | qqq | Q1, Q2, Q3, Q4 | |\n * | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | qqqqq | 1, 2, 3, 4 | 4 |\n * | Month (formatting) | M | 1, 2, ..., 12 | |\n * | | Mo | 1st, 2nd, ..., 12th | 7 |\n * | | MM | 01, 02, ..., 12 | |\n * | | MMM | Jan, Feb, ..., Dec | |\n * | | MMMM | January, February, ..., December | 2 |\n * | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | L | 1, 2, ..., 12 | |\n * | | Lo | 1st, 2nd, ..., 12th | 7 |\n * | | LL | 01, 02, ..., 12 | |\n * | | LLL | Jan, Feb, ..., Dec | |\n * | | LLLL | January, February, ..., December | 2 |\n * | | LLLLL | J, F, ..., D | |\n * | Local week of year | w | 1, 2, ..., 53 | |\n * | | wo | 1st, 2nd, ..., 53th | 7 |\n * | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | I | 1, 2, ..., 53 | 7 |\n * | | Io | 1st, 2nd, ..., 53th | 7 |\n * | | II | 01, 02, ..., 53 | 7 |\n * | Day of month | d | 1, 2, ..., 31 | |\n * | | do | 1st, 2nd, ..., 31st | 7 |\n * | | dd | 01, 02, ..., 31 | |\n * | Day of year | D | 1, 2, ..., 365, 366 | 9 |\n * | | Do | 1st, 2nd, ..., 365th, 366th | 7 |\n * | | DD | 01, 02, ..., 365, 366 | 9 |\n * | | DDD | 001, 002, ..., 365, 366 | |\n * | | DDDD | ... | 3 |\n * | Day of week (formatting) | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | EEEEE | M, T, W, T, F, S, S | |\n * | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | i | 1, 2, 3, ..., 7 | 7 |\n * | | io | 1st, 2nd, ..., 7th | 7 |\n * | | ii | 01, 02, ..., 07 | 7 |\n * | | iii | Mon, Tue, Wed, ..., Sun | 7 |\n * | | iiii | Monday, Tuesday, ..., Sunday | 2,7 |\n * | | iiiii | M, T, W, T, F, S, S | 7 |\n * | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 7 |\n * | Local day of week (formatting) | e | 2, 3, 4, ..., 1 | |\n * | | eo | 2nd, 3rd, ..., 1st | 7 |\n * | | ee | 02, 03, ..., 01 | |\n * | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | eeeee | M, T, W, T, F, S, S | |\n * | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | c | 2, 3, 4, ..., 1 | |\n * | | co | 2nd, 3rd, ..., 1st | 7 |\n * | | cc | 02, 03, ..., 01 | |\n * | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | ccccc | M, T, W, T, F, S, S | |\n * | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | a..aa | AM, PM | |\n * | | aaa | am, pm | |\n * | | aaaa | a.m., p.m. | 2 |\n * | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | b..bb | AM, PM, noon, midnight | |\n * | | bbb | am, pm, noon, midnight | |\n * | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | bbbbb | a, p, n, mi | |\n * | Flexible day period | B..BBB | at night, in the morning, ... | |\n * | | BBBB | at night, in the morning, ... | 2 |\n * | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | h | 1, 2, ..., 11, 12 | |\n * | | ho | 1st, 2nd, ..., 11th, 12th | 7 |\n * | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | H | 0, 1, 2, ..., 23 | |\n * | | Ho | 0th, 1st, 2nd, ..., 23rd | 7 |\n * | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | K | 1, 2, ..., 11, 0 | |\n * | | Ko | 1st, 2nd, ..., 11th, 0th | 7 |\n * | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | k | 24, 1, 2, ..., 23 | |\n * | | ko | 24th, 1st, 2nd, ..., 23rd | 7 |\n * | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | m | 0, 1, ..., 59 | |\n * | | mo | 0th, 1st, ..., 59th | 7 |\n * | | mm | 00, 01, ..., 59 | |\n * | Second | s | 0, 1, ..., 59 | |\n * | | so | 0th, 1st, ..., 59th | 7 |\n * | | ss | 00, 01, ..., 59 | |\n * | Fraction of second | S | 0, 1, ..., 9 | |\n * | | SS | 00, 01, ..., 99 | |\n * | | SSS | 000, 001, ..., 999 | |\n * | | SSSS | ... | 3 |\n * | Timezone (ISO-8601 w/ Z) | X | -08, +0530, Z | |\n * | | XX | -0800, +0530, Z | |\n * | | XXX | -08:00, +05:30, Z | |\n * | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | x | -08, +0530, +00 | |\n * | | xx | -0800, +0530, +0000 | |\n * | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Timezone (GMT) | O...OOO | GMT-8, GMT+5:30, GMT+0 | |\n * | | OOOO | GMT-08:00, GMT+05:30, GMT+00:00 | 2 |\n * | Timezone (specific non-locat.) | z...zzz | GMT-8, GMT+5:30, GMT+0 | 6 |\n * | | zzzz | GMT-08:00, GMT+05:30, GMT+00:00 | 2,6 |\n * | Seconds timestamp | t | 512969520 | 7 |\n * | | tt | ... | 3,7 |\n * | Milliseconds timestamp | T | 512969520900 | 7 |\n * | | TT | ... | 3,7 |\n * | Long localized date | P | 04/29/1453 | 7 |\n * | | PP | Apr 29, 1453 | 7 |\n * | | PPP | April 29th, 1453 | 7 |\n * | | PPPP | Friday, April 29th, 1453 | 2,7 |\n * | Long localized time | p | 12:00 AM | 7 |\n * | | pp | 12:00:00 AM | 7 |\n * | | ppp | 12:00:00 AM GMT+2 | 7 |\n * | | pppp | 12:00:00 AM GMT+02:00 | 2,7 |\n * | Combination of date and time | Pp | 04/29/1453, 12:00 AM | 7 |\n * | | PPpp | Apr 29, 1453, 12:00:00 AM | 7 |\n * | | PPPppp | April 29th, 1453 at ... | 7 |\n * | | PPPPpppp| Friday, April 29th, 1453 at ... | 2,7 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n * the output will be the same as default pattern for this unit, usually\n * the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n * are marked with \"2\" in the last column of the table.\n *\n * `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n * `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n * The output will be padded with zeros to match the length of the pattern.\n *\n * `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` always returns the last two digits of a year,\n * while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n * | Year | `yy` | `uu` |\n * |------|------|------|\n * | 1 | 01 | 01 |\n * | 14 | 14 | 14 |\n * | 376 | 76 | 376 |\n * | 1453 | 53 | 1453 |\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [getISOWeekYear](https://date-fns.org/docs/getISOWeekYear)\n * and [getWeekYear](https://date-fns.org/docs/getWeekYear)).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n * so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `t`: seconds timestamp\n * - `T`: milliseconds timestamp\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @param date - The original date\n * @param format - The string of tokens\n * @param options - An object with options\n *\n * @returns The formatted date string\n *\n * @throws `date` must not be Invalid Date\n * @throws `options.locale` must contain `localize` property\n * @throws `options.locale` must contain `formatLong` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n * locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\nexport function format(date, formatStr, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const originalDate = toDate(date, options?.in);\n\n if (!isValid(originalDate)) {\n throw new RangeError(\"Invalid time value\");\n }\n\n let parts = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter === \"p\" || firstCharacter === \"P\") {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp)\n .map((substring) => {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return { isToken: false, value: \"'\" };\n }\n\n const firstCharacter = substring[0];\n if (firstCharacter === \"'\") {\n return { isToken: false, value: cleanEscapedString(substring) };\n }\n\n if (formatters[firstCharacter]) {\n return { isToken: true, value: substring };\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n return { isToken: false, value: substring };\n });\n\n // invoke localize preprocessor (only for french locales at the moment)\n if (locale.localize.preprocessor) {\n parts = locale.localize.preprocessor(originalDate, parts);\n }\n\n const formatterOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n return parts\n .map((part) => {\n if (!part.isToken) return part.value;\n\n const token = part.value;\n\n if (\n (!options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)) ||\n (!options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token))\n ) {\n warnOrThrowProtectedError(token, formatStr, String(date));\n }\n\n const formatter = formatters[token[0]];\n return formatter(originalDate, token, locale.localize, formatterOptions);\n })\n .join(\"\");\n}\n\nfunction cleanEscapedString(input) {\n const matched = input.match(escapedStringRegExp);\n\n if (!matched) {\n return input;\n }\n\n return matched[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default format;\n","\"use client\"\n\nimport * as React from \"react\"\nimport { format } from \"date-fns\"\nimport { CalendarIcon, CircleCheck, CircleX, Loader2 } from \"lucide-react\"\n\nimport { Button } from \"@/src/components/ui/button\"\nimport { Calendar } from \"@/src/components/ui/calendar\"\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/src/components/ui/popover\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\"\nimport { BaseInput, FieldProps, handleOnChage, isValidField } from \"../base\"\nimport { JSX, useState } from \"react\"\nimport { cn } from '@/src/lib/utils';\nimport { UseFormReturn } from \"react-hook-form\"\nimport { InputGroup, InputGroupAddon, InputGroupButton, InputGroupText } from \"@/src/components/ui/input-group\"\n\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\nexport class DateInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\nconst FieldTimeInput = ({ form, input, isSubmitting }: Props) => {\n\n const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n \n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n setIsValid(isValidField(input, form));\n // 🔑 Inicializa el estado con el valor actual del formulario (si existe)\n const [date, setDate] = React.useState<Date | undefined>(\n field.value ? new Date(field.value) : undefined\n )\n\n // 🔑 Sincroniza el estado con el form cuando cambie\n React.useEffect(() => {\n if (field.value && !date) {\n setDate(new Date(field.value))\n setIsValid(isValidField(input, form));\n }\n }, [field.value])\n\n const handleSelect = (selectedDate?: Date) => {\n // setIsValid(isValidField(input, form));\n setDate(selectedDate)\n // field.onChange(selectedDate) // <-- Actualiza el form\n handleOnChage(selectedDate, input, field)\n }\n\n return (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <Popover>\n <PopoverTrigger asChild>\n {/* <div className=\"flex flex-col justify-start gap-2 \"> */}\n <FormControl>\n <InputGroup className=\"flex flex-row gap-1\">\n\n <Button\n variant=\"outline\"\n className={cn(\n \"w-full justify-start text-left py-0.5 \",\n !date && \"text-muted-foreground\"\n )}\n >\n <div className=\"flex flex-1 items-center gap-1 justify-start text-left \">\n <CalendarIcon />\n {date ? format(date, \"PPP\") : <span>{input.placeHolder ?? 'Fecha'}</span>}\n </div>\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <>\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={24} className=\"w-6! h-6!\" />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </>\n )}\n \n </Button>\n\n\n </InputGroup>\n </FormControl>\n {/* </div> */}\n </PopoverTrigger>\n <PopoverContent className=\"w-auto p-0\">\n <Calendar\n mode=\"single\"\n selected={date}\n onSelect={handleSelect}\n initialFocus />\n </PopoverContent>\n </Popover>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )\n } } />\n return <>{formField}</>;\n}\n\n\n","'use client'\n\nimport { JSX, useState, useEffect } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { InputGroup, InputGroupAddon, InputGroupInput, InputGroupText } from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class DateTimeInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldDateTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldDateTimeInput = ({ form, input, isSubmitting }: Props) => {\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n // Estado local para la fecha y hora\n const [dateTime, setDateTime] = useState<string>(() => form.getValues(input.name) ?? \"\");\n\n useEffect(() => {\n const fieldValue = form.getValues(input.name) ?? \"\";\n if (fieldValue !== dateTime) setDateTime(fieldValue);\n }, [form.getValues(input.name)]);\n\n const handleChange = (val: string) => {\n setDateTime(val);\n form.setValue(input.name, val);\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n <InputGroup>\n\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input de tipo datetime-local */}\n <InputGroupInput\n type=\"datetime-local\"\n value={dateTime}\n disabled={input.disabled || isSubmitting}\n onChange={(e) =>{ \n handleOnChage(e.target.value, input, field);\n handleChange(e.target.value);\n }}\n />\n\n {/* Iconos derecha */}\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <InputGroupAddon align=\"inline-end\">\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={24} />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n\n </InputGroup>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport type { UseFormReturn } from \"react-hook-form\"\nimport { useEffect, useState } from \"react\";\nimport { Eye, EyeOff } from \"lucide-react\"\nimport { Button } from \"@/src/components/ui/button\"\nimport { Card } from \"@/src/components/ui/card\"\nimport { FieldProps, BaseInput, handleOnChage } from \"../base\";\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Input } from \"@/src/components/ui\";\nimport { JSX } from \"react\"\n\nexport class FileInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return ( <FieldFile input={input} form={form} isSubmitting={isSubmitting} /> )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldFile = ({ form, input, isSubmitting }: Props) => {\n const [preview, setPreview] = useState<string | null>(form.getValues(input.name) ?? null)\n const [showPreview, setShowPreview] = useState<boolean>(input.fileConfig?.showPreview ?? false)\n \n const accept = input.fileConfig?.accept || \"*/*\";\n const multiple = input.fileConfig?.multiple || false;\n // const maxSize = input.fileConfig?.maxSize || 25;\n // const previewSize = input.fileConfig?.previewSize || 60;\n\n useEffect(() => {\n setPreview(form.getValues(input.name) || null)\n }, [input])\n\n\n const handleFileChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const file = e.target.files?.[0]\n if (file) {\n const objectUrl = URL.createObjectURL(file)\n setPreview(objectUrl)\n } else {\n setPreview(null)\n }\n }\n\n return (\n <>\n \n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <div className=\"flex gap-1\">\n <FormControl>\n <Input \n type=\"file\"\n accept={accept}\n multiple={multiple}\n placeholder={input.placeHolder}\n name={field.name}\n disabled={input.disabled || isSubmitting}\n onChange={(e) => {\n field.onChange(e.target.files?.[0]); handleFileChange(e)\n handleOnChage(e.target.files?.[0], input, field)\n }} \n />\n </FormControl>\n { preview && (<Button type=\"button\" onClick={() => { setShowPreview(!showPreview); }}>\n {showPreview ? <EyeOff /> : <Eye />}\n </Button>) }\n <FormDescription>{input.description}</FormDescription>\n </div>\n {/* <pre> <b>{JSON.stringify(field, null, 2) } </b> </pre> */}\n <FormMessage />\n {\n (preview && showPreview) && (\n <Card>\n {/* <Image\n src={preview}\n alt=\"Preview\"\n width={previewSize}\n height={previewSize}\n /> */}\n </Card> ) \n }\n </FormItem>\n )}\n />\n </>\n )\n}\n\n","'use client'\n\nimport { JSX, useRef, useState } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2, Upload } from \"lucide-react\";\nimport { cn } from \"@/src/lib/utils\";\n\nexport class FileMultiUploadInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldFileMultiUpload input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldFileMultiUpload = ({ input, form, isSubmitting }: Props) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const [files, setFiles] = useState<File[]>(form.getValues(input.name) || []);\n const [dragOver, setDragOver] = useState(false);\n\n const autoValidate = input.inputGroupConfig?.autoValidIcons;\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const handleFileSelect = (event: React.ChangeEvent<HTMLInputElement>) => {\n const selectedFiles = event.target.files ? Array.from(event.target.files) : [];\n setFiles(selectedFiles);\n form.setValue(input.name, selectedFiles);\n };\n\n const handleDrop = (event: React.DragEvent<HTMLDivElement>) => {\n event.preventDefault();\n const droppedFiles = event.dataTransfer.files ? Array.from(event.dataTransfer.files) : [];\n const updatedFiles = [...files, ...droppedFiles];\n setFiles(updatedFiles);\n form.setValue(input.name, updatedFiles);\n setDragOver(false);\n };\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const isValid = !fieldState.error && files.length > 0;\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <div\n ref={inputRef}\n onClick={() => inputRef.current?.click()}\n onDragOver={(e) => { e.preventDefault(); setDragOver(true); } }\n onDragLeave={() => setDragOver(false)}\n onDrop={handleDrop}\n className={cn(\n \"w-full h-40 border-2 border-dashed rounded-lg flex flex-col items-center justify-center cursor-pointer transition-all duration-200\",\n dragOver ? \"border-blue-500 bg-blue-50\" : \"border-gray-400 bg-gray-50\",\n isSubmitting && \"opacity-50 cursor-not-allowed\"\n )}\n >\n <Upload className=\"w-10 h-10 text-gray-500 mb-2\" />\n <span className=\"text-gray-600 text-sm text-center px-2\">\n {files.length === 0\n ? \"Arrastra tus archivos aquí o haz click para seleccionar\"\n : `${files.length} archivo(s) seleccionados`}\n </span>\n <input\n ref={inputRef}\n type=\"file\"\n multiple\n className=\"hidden\"\n disabled={input.disabled || isSubmitting}\n onChange={handleFileSelect} />\n </div>\n </FormControl>\n\n {/* Lista de archivos seleccionados */}\n {files.length > 0 && (\n <ul className=\"mt-2 max-h-40 overflow-y-auto border rounded-md p-2 bg-white\">\n {files.map((f, idx) => (\n <li key={idx} className=\"flex justify-between items-center py-1 px-2 rounded hover:bg-gray-100\">\n <span className=\"truncate\">{f.name}</span>\n <button\n type=\"button\"\n onClick={() => {\n const filtered = files.filter((_, i) => i !== idx);\n setFiles(filtered);\n form.setValue(input.name, filtered);\n } }\n className=\"text-red-500 hover:text-red-700 text-sm\"\n >\n Eliminar\n </button>\n </li>\n ))}\n </ul>\n )}\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n\n {autoValidate && (\n <div className=\"mt-1\">\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n\n <FormMessage />\n </FormItem>\n );\n } } />;\n\n return <>{formField}</>;\n \n};\n","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Link2Icon, Plus, Trash2 } from \"lucide-react\";\nimport { useEffect } from \"react\";\nimport { FieldTextGroup } from \"./text-input-group\";\nimport { InputGroup, InputGroupAddon, InputGroupInput } from \"@/src/components/ui/input-group\";\nimport { ButtonGroup, ButtonGroupText } from \"@/src/components/ui/button-group\";\nimport { Label } from \"@radix-ui/react-label\";\n\nexport class KeyValueListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldKeyValueList\n input={input}\n form={form}\n isSubmitting={isSubmitting}\n />\n );\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 🧠 Lista editable de pares clave-valor\n */\nexport const FieldKeyValueList = ({ form, input, isSubmitting }: Props) => {\n const fieldName = input.name;\n\n // Inicializamos el valor como array vacío si no existe\n useEffect(() => {\n const current = form.getValues(fieldName);\n if (!Array.isArray(current)) {\n form.setValue(fieldName, []);\n }\n }, [form, fieldName]);\n\n const handleAddPair = () => {\n const current = form.getValues(fieldName) || [];\n form.setValue(fieldName, [...current, { key: \"\", value: \"\" }]);\n };\n\n const handleRemovePair = (index: number) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.filter((_: any, i: number) => i !== index);\n form.setValue(fieldName, updated);\n };\n\n const handleChange = (index: number, fieldType: \"key\" | \"value\", newValue: string) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.map((item: any, i: number) =>\n i === index ? { ...item, [fieldType]: newValue } : item\n );\n form.setValue(fieldName, updated);\n };\n\n return (\n <FormField\n control={form.control}\n name={fieldName}\n render={() => {\n const pairs = form.watch(fieldName) || [];\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormMessage />\n <FormControl>\n <div className=\"flex flex-col gap-3 rounded-xl \">\n {pairs.length === 0 && (\n <p className=\"text-sm text-muted-foreground\">\n No pairs have been added yet.\n </p>\n )}\n\n {pairs.map((pair: { key: string; value: string }, index: number) => (\n <div\n key={index}\n className=\"flex flex-row w-full gap-2 items-center py-0.5\"\n > \n\n <ButtonGroup className=\"w-full\">\n <ButtonGroupText asChild>\n <Label htmlFor=\"key\">Key</Label>\n </ButtonGroupText>\n <InputGroup>\n <InputGroupInput\n placeholder=\"Key\"\n value={pair.key}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"key\", e.target.value)}\n className=\"flex-1\"\n />\n </InputGroup>\n </ButtonGroup>\n\n <ButtonGroup className=\"w-full\">\n <ButtonGroupText asChild>\n <Label htmlFor=\"value\">Value</Label>\n </ButtonGroupText>\n <InputGroup>\n <InputGroupInput\n placeholder=\"Value\"\n value={pair.value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"value\", e.target.value)}\n className=\"flex-1\"\n />\n </InputGroup>\n </ButtonGroup>\n\n {/* <Input\n placeholder=\"Key\"\n value={pair.key}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"key\", e.target.value)}\n className=\"w-1/2\"\n /> */}\n {/* <Input\n placeholder=\"Value\"\n value={pair.value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, \"value\", e.target.value)}\n className=\"w-1/2\"\n /> */}\n { input.isRemovebleOption && (<Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => handleRemovePair(index)}\n disabled={isSubmitting}\n >\n <Trash2 size={18} />\n </Button>)}\n </div>\n ))}\n\n <div className=\"flex justify-end mt-2\">\n <Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={handleAddPair}\n disabled={isSubmitting}\n >\n <Plus size={18} className=\"mr-1\" />\n </Button>\n </div>\n </div>\n </FormControl>\n\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\n\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Button,\n Badge,\n Popover,\n PopoverTrigger,\n PopoverContent,\n\n} from \"@/src/components/ui\";\nimport { Check, ChevronsUpDown } from \"lucide-react\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { cn } from \"@/src/lib/utils\";\nimport { useState } from \"react\";\nimport { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList } from \"@/src/components/ui/command\";\n\nexport class MultiSelectInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldMultiSelect input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldMultiSelect = ({ form, input, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"PERMISO 1\" },\n { id: 2, name: \"PERMISO 2\" },\n { id: 3, name: \"PERMISO 3\" },\n { id: 4, name: \"PERMISO 4\" },\n ];\n\n const lista = (input?.listConfig?.list ?? mockInputOptions) as InputOption[];\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n\n const getValue = (item: InputOption) => {\n if (optionValue === \"name\") return item[optionValue];\n return item.value ?? item.id;\n };\n\n const [open, setOpen] = useState(false);\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n const selectedValues: string[] = Array.isArray(field.value)\n ? field.value\n : [];\n\n const toggleOption = (value: string) => {\n const newValues = selectedValues.includes(value)\n ? selectedValues.filter((v) => v !== value)\n : [...selectedValues, value];\n field.onChange(newValues);\n };\n\n return (\n <FormItem className=\"flex flex-col rounded-lg border p-3 shadow bg-blue-100/20\">\n <FormLabel><b>{input.label}</b></FormLabel>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n\n <FormControl>\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n <Button\n variant=\"outline\"\n role=\"combobox\"\n disabled={input.disabled || isSubmitting}\n className={cn(\n \"justify-between w-full bg-black/10 dark:bg-white/10\",\n !selectedValues.length && \"text-muted-foreground\"\n )}\n >\n {selectedValues.length > 0 ? (\n <div className=\"flex flex-wrap gap-1\">\n {selectedValues.map((val) => {\n const option = lista.find(\n (item) => getValue(item).toString() === val\n );\n return (\n <Badge key={`${input.name}-${val}-ms`} variant=\"secondary\">\n {option?.name ?? val}\n </Badge>\n );\n })}\n </div>\n ) : (\n <span>{input.placeHolder ?? \"Selecciona...\"}</span>\n )}\n <ChevronsUpDown className=\"ml-2 h-4 w-4 opacity-50\" />\n </Button>\n </PopoverTrigger>\n\n <PopoverContent className=\"p-0 w-[var(--radix-popover-trigger-width)]\">\n <Command>\n <CommandInput placeholder=\"Buscar...\" />\n <CommandList>\n <CommandEmpty>No hay resultados.</CommandEmpty>\n <CommandGroup>\n {lista.map((item) => {\n const value = getValue(item).toString();\n const selected = selectedValues.includes(value);\n return (\n <CommandItem\n key={`${value}-ms`}\n onSelect={() => {\n handleOnChage(value,input,field)\n toggleOption(value)}\n }\n >\n <Check\n className={cn(\n \"mr-2 h-4 w-4\",\n selected ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n {item.name}\n </CommandItem>\n );\n })}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n </FormControl>\n\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\n\nimport { ChangeEventHandler, Dispatch, ForwardRefExoticComponent, JSX, RefAttributes, SetStateAction, useEffect, useState } from \"react\";\nimport { BaseInput, handleOnChage, isValidField } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { \n InputGroup, \n InputGroupAddon, \n InputGroupInput, \n InputGroupText \n} from \"@/src/components/ui/input-group\";\nimport { FieldProps, TextInputType } from \"../base/definitions\";\nimport { ControllerRenderProps, FieldValues, UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Info, Loader2, Eye, EyeOff, LucideProps } from \"lucide-react\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/src/components/ui/tooltip\";\n\nexport class TextInputGroup extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTextGroup input={input} form={form} isSubmitting={isSubmitting}/>;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\n\nexport const FieldTextGroup = ({ form, input, isSubmitting }: Props) => {\n // Estado local para manejar validez desde el primer render\n const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n const formField = (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n setIsValid(isValidField(input, form));\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n {\n CustomInputGroup({\n input,\n isSubmitting,\n field,\n form,\n isValid,\n })\n }\n </FormControl>\n\n {/* Descripción */}\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n \n return <>{formField}</>;\n};\n\n\ninterface customInputGroup {\n value?: any;\n input: FieldProps<Record<string,any>,Record<string,any>>,\n field?: ControllerRenderProps<FieldValues, string>,\n form: UseFormReturn, \n isSubmitting?: boolean,\n isValid?: boolean,\n setShowPassword?: Dispatch<SetStateAction<boolean>>, \n autoValidate?: boolean, \n onChange?: ChangeEventHandler<HTMLInputElement> | undefined\n}\n\nexport const CustomInputGroup = ({\n value,\n input,\n field,\n form,\n isSubmitting,\n onChange,\n isValid\n }: customInputGroup) => {\n \n const groupConfig = input.inputGroupConfig;\n const infoTooltip = input?.infoTooltip;\n const autoValidate = groupConfig?.autoValidIcons ?? input.zodType ? true : false;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez desde el primer render\n // const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n // 👁️ Estado para mostrar/ocultar contraseña\n const [showPassword, setShowPassword] = useState(false);\n const isPasswordField = input.keyboardType === TextInputType.PASSWORD;\n const isNumberField = input.keyboardType === TextInputType.NUMBER;\n\n const showInputGroupAddons = iconsRight.length > 0 || textRight || autoValidate || infoTooltip || isPasswordField\n \n // useEffect(()=>{\n // setIsValid(isValidField(input, form));\n // },[input])\n return (\n <InputGroup>\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input principal */}\n <InputGroupInput\n placeholder={input.placeHolder}\n disabled={input.disabled || isSubmitting}\n onBlur={field?.onBlur}\n name={field?.name}\n ref={field?.ref}\n type={isPasswordField && !showPassword\n ? \"password\"\n : isNumberField\n ? \"number\"\n : \"text\"}\n value={field?.value ?? value ?? \"\"}\n onChange={(e) => {\n if (onChange) {\n onChange(e)\n }\n let value: any = e.target.value;\n if (isNumberField) {\n value = e.target.value === \"\" ? \"\" : Number(e.target.value); // 👈 conversión si es number\n }\n field?.onChange(value);\n isValidField(input, form);\n handleOnChage(value, input, field);\n } } />\n\n {/* Iconos derecha */}\n {showInputGroupAddons && (\n <InputGroupAddon align=\"inline-end\">\n {/* Tooltip de información */}\n {infoTooltip && (\n <Tooltip>\n <TooltipTrigger asChild>\n <Info size={20} />\n </TooltipTrigger>\n <TooltipContent>\n <p>{infoTooltip}</p>\n </TooltipContent>\n </Tooltip>\n )}\n\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n\n {/* 👁️ Toggle mostrar/ocultar contraseña */}\n {isPasswordField && (\n <button\n type=\"button\"\n onClick={() => setShowPassword(!showPassword) }\n className=\"p-1\"\n >\n {showPassword ? <EyeOff size={20} /> : <Eye size={20} />}\n </button>\n )}\n\n {/* Icono de validación / loading */}\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n </InputGroup>\n );\n}\n\n","'use client'\nimport { BaseInput, FieldProps, InputTypes } from \"../base\"\nimport { JSX } from \"react\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui\"\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldTextGroup } from \"./text-input-group\";\n\nexport class NumberInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (<FieldNumber form={form} input={input} isSubmitting={isSubmitting}/>)\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldNumber = ({form, input, isSubmitting}:Props) => {\n const fielInput: FieldProps = { ...input, inputType: InputTypes.NUMBER }\n return (<FieldTextGroup input={fielInput} form={form} isSubmitting={isSubmitting}/>)\n}\n\n","'use client'\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, InputOTP, InputOTPGroup, InputOTPSlot } from \"@/src/components/ui\"\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\nexport class OTPInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this; \n return (\n <FieldOTP form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn\n input: FieldProps,\n isSubmitting?: boolean;\n}\n\nconst FieldOTP = ({ form, input, isSubmitting }: Props ): JSX.Element => {\n\n const totalPositions = Array.from({ length: input.min ?? 6 }, (_, i) => i);\n \n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <InputOTP maxLength={totalPositions.length} {...field} onChange={(event)=> handleOnChage(event, input, field)}>\n <InputOTPGroup>\n {totalPositions.map((position) => (\n <InputOTPSlot key={position} index={position} />\n ))}\n </InputOTPGroup>\n </InputOTP>\n </FormControl>\n <FormDescription>{input.description}</FormDescription>\n <FormMessage />\n </FormItem>\n )} />;\n}\n\n","'use client'\nimport { BaseInput, FieldProps, handleOnChage, InputOption } from \"../base\";\nimport { Card, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Label, RadioGroup, RadioGroupItem } from \"@/src/components/ui\";\nimport { cn } from \"@/src/lib/utils\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\n\nexport class RadioGroupInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldRadioGroup input={input} form={form} isSubmitting={isSubmitting}/>\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn\n input: FieldProps,\n isSubmitting?: boolean;\n}\n\nconst FieldRadioGroup = ({ input, form, isSubmitting }: Props): JSX.Element => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"A+\", value: \"A+\" },\n { id: 2, name: \"A-\", value: \"A-\" },\n { id: 3, name: \"B+\", value: \"B+\" },\n { id: 4, name: \"B-\", value: \"B-\" },\n { id: 5, name: \"O+\", value: \"O+\" },\n { id: 6, name: \"O-\", value: \"O-\" },\n { id: 7, name: \"AB+\", value: \"AB+\" },\n { id: 8, name: \"AB-\", value: \"AB-\" },\n ]\n\n const options = (input.listConfig?.list as InputOption[]) ?? mockInputOptions\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">\n {input.label || input.name}\n </FormLabel>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n </div>\n\n <FormControl>\n <RadioGroup\n {...field}\n value={field.value ?? \"\"}\n onValueChange={(e)=> handleOnChage(e, input, field)}\n className=\"space-y-2 mt-3\"\n >\n {options.map((opt, index) => (\n <div\n key={opt.id}\n className={cn(\n \"p-2 rounded-lg flex items-center gap-2 cursor-pointer\",\n index % 2 ? \"bg-black/5\" : \"bg-white/5\"\n )}\n >\n <RadioGroupItem\n disabled={input.disabled || isSubmitting}\n value={opt.value ?? String(opt.id)}\n id={`opt-${opt.id}`} />\n <Label htmlFor={`opt-${opt.id}`}>\n {opt.label || opt.name}\n </Label>\n </div>\n ))}\n </RadioGroup>\n </FormControl>\n\n <FormMessage />\n </FormItem>\n )} />;\n\n return <>{formField}</>;\n \n}","'use client'\n\nimport { JSX } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { UseFormReturn, useFieldArray } from \"react-hook-form\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Plus, Trash2 } from \"lucide-react\";\nimport { FormFieldsGrid } from \"../FormFieldsGrid\";\n\nexport class RepeaterInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldRepeater form={form} input={input} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps\n isSubmitting?: boolean;\n}\n\nexport const FieldRepeater = ({ form, input, isSubmitting }: Props) => {\n const { control } = form;\n const { fields, append, remove } = useFieldArray({\n control,\n name: input.name,\n });\n\n const canAdd = !input.maxItems || fields.length < input.maxItems;\n const canRemove = fields.length > (input.minItems ?? 0);\n\n return (\n <FormField\n control={control}\n name={input.name}\n render={() => (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <div className=\"space-y-3\">\n {fields.map((item, index) => (\n <div\n key={item.id}\n className=\"border p-3 rounded-md flex flex-col gap-4 py-3\"\n >\n\n {/* <FormFieldsGrid fields={input?.repeaterFields ?? []} form={form} /> */}\n {input.repeaterFields?.map((fieldGroup, groupIndex) => {\n // Si el elemento es un array → varios campos en una línea\n const group =\n Array.isArray(fieldGroup) ? fieldGroup : [fieldGroup];\n const cols = group.length;\n\n return (\n <div\n key={groupIndex}\n className={`grid gap-3 grid-cols-${cols}`}\n >\n {group.map((subField) => (\n <FormField\n key={`${input.name}.${index}.${subField.name}`}\n control={control}\n name={`${input.name}.${index}.${subField.name}`}\n render={({ field, fieldState }) => (\n <FormItem className=\"flex-1\">\n <FormLabel>{subField.label}</FormLabel>\n <FormControl>\n <Input\n placeholder={subField.placeHolder}\n disabled={subField.disabled || isSubmitting}\n {...field}\n />\n </FormControl>\n <FormMessage>{fieldState.error?.message}</FormMessage>\n </FormItem>\n )}\n />\n ))}\n </div>\n );\n })}\n\n {/* Botón eliminar */}\n {canRemove && (\n <Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => remove(index)}\n className=\"self-end\"\n >\n <Trash2 size={18} />\n </Button>\n )}\n </div>\n ))}\n\n {/* Botón agregar */}\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"secondary\"\n onClick={() => append({})}\n disabled={isSubmitting}\n className=\"w-full\"\n >\n <Plus size={16} className=\"mr-2\" />\n Agregar\n </Button>\n )}\n </div>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};","import * as React from \"react\"\nimport * as TabsPrimitive from \"@radix-ui/react-tabs\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Tabs({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Root>) {\n return (\n <TabsPrimitive.Root\n data-slot=\"tabs\"\n className={cn(\"flex flex-col gap-2\", className)}\n {...props}\n />\n )\n}\n\nfunction TabsList({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.List>) {\n return (\n <TabsPrimitive.List\n data-slot=\"tabs-list\"\n className={cn(\n \"bg-muted text-muted-foreground inline-flex h-9 w-fit items-center justify-center rounded-lg p-[3px]\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction TabsTrigger({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Trigger>) {\n return (\n <TabsPrimitive.Trigger\n data-slot=\"tabs-trigger\"\n className={cn(\n \"data-[state=active]:bg-background dark:data-[state=active]:text-foreground focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring dark:data-[state=active]:border-input dark:data-[state=active]:bg-input/30 text-foreground dark:text-muted-foreground inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction TabsContent({\n className,\n ...props\n}: React.ComponentProps<typeof TabsPrimitive.Content>) {\n return (\n <TabsPrimitive.Content\n data-slot=\"tabs-content\"\n className={cn(\"flex-1 outline-none\", className)}\n {...props}\n />\n )\n}\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent }\n","'use client'\n\nimport { JSX, useState } from \"react\";\nimport { UseFormReturn, useFieldArray } from \"react-hook-form\";\nimport { BaseInput } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Plus, Trash2 } from \"lucide-react\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { FieldProps } from \"../base/definitions\";\nimport { TabsContent, Tabs, TabsTrigger, TabsList } from '@/src/components/ui/tabs';\n\n/**\n * 🧱 Clase que extiende BaseInput\n * Se usa igual que tus otros inputs (TextInput, SelectInput, etc.)\n */\nexport class RepeaterTabsInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldRepeaterTabs form={form} input={input} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 📋 FieldRepeaterTabs\n * - Cada ítem del FieldArray se representa como un tab.\n * - Permite agregar/eliminar tabs.\n * - Mantiene sincronía con React Hook Form.\n */\nconst FieldRepeaterTabs = ({ form, input, isSubmitting }: Props): JSX.Element => {\n const { control } = form;\n const { fields, append, remove } = useFieldArray({\n control,\n name: input.name,\n });\n\n const [activeTab, setActiveTab] = useState<string>(fields[0]?.id ?? \"\");\n\n const canAdd = !input.maxItems || fields.length < input.maxItems;\n const canRemove = fields.length > (input.minItems ?? 0);\n\n const handleAdd = () => {\n const newItem = { id: `tab-${Date.now()}` };\n append(newItem);\n setActiveTab(newItem.id);\n };\n\n const handleRemove = (index: number) => {\n const removedId = fields[index].id;\n remove(index);\n if (activeTab === removedId && fields.length > 1) {\n const nextTab = fields[index - 1] ?? fields[0];\n if (nextTab) setActiveTab(nextTab.id);\n }\n };\n\n return (\n <FormField\n control={control}\n name={input.name}\n render={() => (\n <FormItem className={input.className}>\n {input.label && <FormLabel><b>{input.label}</b></FormLabel>}\n <FormControl>\n <div className=\"space-y-3\">\n <Tabs value={activeTab} onValueChange={setActiveTab} className=\"w-full\">\n {/* 🔹 Lista de Tabs */}\n <TabsList className=\"flex w-full justify-start overflow-x-auto\">\n {fields.map((item, index) => (\n <div key={item.id} className=\"flex items-center\">\n <TabsTrigger value={item.id} className=\"flex items-center gap-1\">\n {input.tabLabelField\n ? form.watch(`${input.name}.${index}.${input.tabLabelField}`) ||\n `Item ${index + 1}`\n : `Item ${index + 1}`}\n </TabsTrigger>\n {canRemove && (\n <Button\n type=\"button\"\n size=\"icon\"\n variant=\"ghost\"\n onClick={() => handleRemove(index)}\n >\n <Trash2 size={14} />\n </Button>\n )}\n </div>\n ))}\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"secondary\"\n size=\"sm\"\n onClick={handleAdd}\n disabled={isSubmitting}\n className=\"ml-2\"\n >\n <Plus size={14} className=\"mr-1\" /> Agregar\n </Button>\n )}\n </TabsList>\n\n {/* 🔹 Contenido de cada Tab */}\n {fields.map((item, index) => (\n <TabsContent key={item.id} value={item.id} className=\"mt-4\">\n {input.repeaterFields?.map((fieldGroup, groupIndex) => {\n const group = Array.isArray(fieldGroup)\n ? fieldGroup\n : [fieldGroup];\n const cols = group.length;\n\n return (\n <div key={groupIndex} className={`grid gap-3 grid-cols-${cols}`}>\n {group.map((subField) => (\n <FormField\n key={`${input.name}.${index}.${subField.name}`}\n control={control}\n name={`${input.name}.${index}.${subField.name}`}\n render={({ field, fieldState }) => (\n <FormItem className=\"flex-1\">\n <FormLabel>{subField.label}</FormLabel>\n <FormControl>\n <Input\n placeholder={subField.placeHolder}\n disabled={subField.disabled || isSubmitting}\n {...field}\n />\n </FormControl>\n <FormMessage>{fieldState.error?.message}</FormMessage>\n </FormItem>\n )}\n />\n ))}\n </div>\n );\n })}\n </TabsContent>\n ))}\n </Tabs>\n </div>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};\n","'use client'\n\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n SelectValue,\n} from \"@/src/components/ui\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { useEffect, useState } from \"react\";\n\nexport class SelectInput extends BaseInput {\n render() {\n const { input, form, isSubmitting } = this;\n return <FieldSelect input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldSelect = ({ form, input, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { value: 1, id: 1, name: \"MOCK OPTION - PERMISO 1\" },\n { value: 2, id: 2, name: \"MOCK OPTION - PERMISO 2\" },\n { value: 3, id: 3, name: \"MOCK OPTION - PERMISO 3\" },\n { value: 4, id: 4, name: \"MOCK OPTION - PERMISO 4\" },\n ];\n\n // 🧩 Estado interno para lista y valor seleccionado\n const [lista, setLista] = useState<InputOption[]>(\n (input?.listConfig?.list?.every((item): item is InputOption => \"name\" in item)\n ? input.listConfig.list\n : mockInputOptions) as InputOption[]\n );\n const [loading, setLoading] = useState(false);\n const [value, setValue] = useState<string>(input.value?.toString() ?? \"\");\n\n const optionValue = input?.listConfig?.optionValue ?? input.optionValue ?? \"id\";\n\n // 🧠 Sincroniza el valor inicial con react-hook-form\n useEffect(() => {\n const currentValue = form.getValues(input.name);\n if (!currentValue && input.value) {\n form.setValue(input.name, input.value);\n setValue(input.value.toString());\n }\n }, [form, input.name, input.value]);\n\n // 🪄 Nuevo: escucha cambios en el campo del que depende (si existe)\n useEffect(() => {\n if (input.dependsOn && input.loadOptions) {\n const subscription = form.watch(async (values) => {\n const dependencyValue = values[input.dependsOn!];\n if (dependencyValue) {\n try {\n setLoading(true);\n const newOptions = await input.loadOptions!(dependencyValue);\n setLista(newOptions);\n } catch (err) {\n console.error(`Error loading options for ${input.name}:`, err);\n setLista([]);\n } finally {\n setLoading(false);\n }\n } else {\n // Limpia opciones si el campo dependiente se vacía\n setLista([]);\n form.setValue(input.name, \"\"); // limpia selección\n }\n });\n\n // cleanup\n return () => subscription.unsubscribe?.();\n }\n }, [form, input.dependsOn, input.loadOptions, input.name]);\n\n const getValue = (item: InputOption): string => {\n const val =\n optionValue === \"name\"\n ? item.name\n : item.value?.toString?.() ?? item.id?.toString();\n return val?.toString() ?? \"\";\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => {\n const currentValue = field.value?.toString() ?? value;\n\n return (\n <FormItem className=\"flex flex-row items-center justify-between rounded-lg border p-3 shadow-lg bg-blue-100/20\">\n <div className=\"space-y-0.5 pr-5\">\n <FormLabel>\n <b>{input.label}</b>\n </FormLabel>\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n <FormMessage />\n </div>\n\n <FormControl>\n <Select\n disabled={input.disabled || isSubmitting || loading}\n onValueChange={(val) => {\n handleOnChage(val, input, field)\n // field.onChange(val);\n setValue(val);\n\n // 🔸 Ejecuta el callback definido si existe\n if (input.listConfig?.onOptionChange) {\n const selectedItem = lista.find(\n (item) => getValue(item) === val\n );\n input.listConfig.onOptionChange(selectedItem);\n }\n }}\n value={currentValue || undefined}\n >\n <FormControl>\n <SelectTrigger className=\"w-[60%] bg-black/10 dark:bg-white/25\">\n <SelectValue\n placeholder={\n loading\n ? \"Cargando...\"\n : input.placeHolder ?? \"Seleccionar\"\n }\n />\n </SelectTrigger>\n </FormControl>\n\n <SelectContent>\n {lista.map((item) => (\n <SelectItem value={getValue(item)} key={`${input.name}-${item.id}-s`}>\n {item.name}\n </SelectItem>\n ))}\n {lista.length === 0 && !loading && (\n <div className=\"p-2 text-sm text-muted-foreground\">\n No hay opciones disponibles\n </div>\n )}\n </SelectContent>\n </Select>\n </FormControl>\n </FormItem>\n );\n }}\n />\n );\n};\n","\"use client\";\n\nimport { JSX, useState } from \"react\";\nimport { Card, Label, Checkbox } from \"@/src/components/ui\";\nimport { BaseInput, handleOnChage } from \"../base\";\nimport { FormControl, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\";\nimport { FieldProps, InputOption } from \"../base/definitions\";\nimport { cn } from \"@/src/lib/utils\";\n\nexport class SimpleCheckListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FormField\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FieldSimpleCheckList\n isSubmitting={isSubmitting}\n input={input}\n value={field.value || []}\n onChange={(e) =>handleOnChage(e, input, field)}\n />\n )}\n />\n );\n }\n}\n\ninterface Props {\n input: FieldProps;\n value: InputOption[];\n isSubmitting?: boolean;\n onChange: (value: InputOption[]) => void;\n}\n\nexport const FieldSimpleCheckList = ({ input, value, onChange, isSubmitting }: Props) => {\n const mockInputOptions: InputOption[] = [\n { id: 1, name: \"MOCK OPTION - CREATE\", checked: false },\n { id: 2, name: \"MOCK OPTION - READ\", checked: true },\n { id: 3, name: \"MOCK OPTION - UPDATE\", checked: false },\n { id: 4, name: \"MOCK OPTION - DELETE\", checked: false },\n ];\n\n // Usa las opciones del input o las mock\n const initialOptions =\n (input.listConfig?.list as InputOption[]) ?? mockInputOptions;\n\n // Estado local sincronizado con el form\n const [options, setOptions] = useState<InputOption[]>(\n value.length > 0 ? value : initialOptions\n );\n\n const allChecked = options.every((opt) => opt.checked);\n\n const handleMainToggle = (checked: boolean) => {\n const updated = options.map((opt) => ({ ...opt, checked }));\n setOptions(updated);\n handleOnChage(updated, input)\n onChange(updated); // sincroniza con el form\n };\n\n const handleChildToggle = (option: InputOption, checked: boolean) => {\n const updated = options.map((opt) =>\n opt.id === option.id ? { ...opt, checked } : opt\n );\n handleOnChage(updated, input)\n setOptions(updated);\n onChange(updated); // sincroniza con el form\n };\n\n const formField = <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">{input.label || input.name}</FormLabel>\n <div className=\"flex items-center gap-2\">\n <Label htmlFor=\"main\">Seleccionar todo</Label>\n <Checkbox\n id=\"main\"\n checked={allChecked}\n onCheckedChange={handleMainToggle} />\n </div>\n </div>\n\n <FormControl>\n <div className=\"space-y-2 mt-3\">\n {options.map((opt, index) => (\n <div\n key={opt.id}\n className={cn(\n \"p-2 rounded-lg flex justify-items-start gap-2 items-center\",\n index % 2 ? \"bg-black/5\" : \"bg-white/5\"\n )}\n >\n <Checkbox\n disabled={input.disabled || isSubmitting}\n id={String(opt.id)}\n checked={opt.checked || false}\n onCheckedChange={(checked) => handleChildToggle(opt, checked as boolean)} />\n <Label htmlFor={String(opt.id)}>{opt.label || opt.name}</Label>\n </div>\n ))}\n </div>\n </FormControl>\n\n <FormMessage />\n </FormItem>;\n\n return <>{formField}</>;\n \n};\n","import * as React from \"react\"\nimport * as SliderPrimitive from \"@radix-ui/react-slider\"\n\nimport { cn } from \"@/src/lib/utils\"\n\nfunction Slider({\n className,\n defaultValue,\n value,\n min = 0,\n max = 100,\n ...props\n}: React.ComponentProps<typeof SliderPrimitive.Root>) {\n const _values = React.useMemo(\n () =>\n Array.isArray(value)\n ? value\n : Array.isArray(defaultValue)\n ? defaultValue\n : [min, max],\n [value, defaultValue, min, max]\n )\n\n return (\n <SliderPrimitive.Root\n data-slot=\"slider\"\n defaultValue={defaultValue}\n value={value}\n min={min}\n max={max}\n className={cn(\n \"relative flex w-full touch-none items-center select-none data-[disabled]:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:min-h-44 data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col\",\n className\n )}\n {...props}\n >\n <SliderPrimitive.Track\n data-slot=\"slider-track\"\n className={cn(\n \"bg-muted relative grow overflow-hidden rounded-full data-[orientation=horizontal]:h-1.5 data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-1.5\"\n )}\n >\n <SliderPrimitive.Range\n data-slot=\"slider-range\"\n className={cn(\n \"bg-primary absolute data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full\"\n )}\n />\n </SliderPrimitive.Track>\n {Array.from({ length: _values.length }, (_, index) => (\n <SliderPrimitive.Thumb\n data-slot=\"slider-thumb\"\n key={index}\n className=\"border-primary ring-ring/50 block size-4 shrink-0 rounded-full border bg-white shadow-sm transition-[color,box-shadow] hover:ring-4 focus-visible:ring-4 focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50\"\n />\n ))}\n </SliderPrimitive.Root>\n )\n}\n\nexport { Slider }\n","'use client'\n\nimport { JSX, useState } from \"react\";\nimport { BaseInput } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Slider } from \"@/src/components/ui/slider\";\nimport { Card } from \"@/src/components/ui\";\n\nexport class SliderInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldSlider input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldSlider = ({ input, form, isSubmitting }: Props) => {\n // Valor inicial del slider\n const initialValue = form.getValues(input.name) ?? input.value ?? 0;\n const [value, setValue] = useState<number>(initialValue);\n\n const handleChange = (val: number) => {\n setValue(val);\n form.setValue(input.name, val);\n };\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n\n <FormControl>\n <Slider\n defaultValue={[initialValue]}\n value={[value]}\n max={input.max ?? 100}\n min={input.min ?? 0}\n step={1}\n className=\"w-[60%]\"\n disabled={input.disabled || isSubmitting}\n onValueChange={(val) => handleChange(val[0])}\n />\n </FormControl>\n\n <div className=\"mt-2 text-sm text-gray-700\">\n Valor actual: {value}\n </div>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n );\n};\n","'use client'\n\nimport { JSX, ReactNode, useState } from \"react\"\nimport { UseFormReturn } from \"react-hook-form\"\nimport {\n DndContext,\n closestCenter,\n KeyboardSensor,\n PointerSensor,\n useSensor,\n useSensors,\n} from \"@dnd-kit/core\"\nimport {\n arrayMove,\n SortableContext,\n sortableKeyboardCoordinates,\n verticalListSortingStrategy,\n} from \"@dnd-kit/sortable\"\nimport { useSortable } from \"@dnd-kit/sortable\"\nimport { CSS } from \"@dnd-kit/utilities\"\nimport { GripVertical } from \"lucide-react\"\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n} from \"@/src/components/ui/form\"\nimport { cn } from \"@/src/lib/utils\"\nimport { BaseInput, FieldProps } from \"../base\"\n\n// ============================================================================\n// 🔹 Clase principal que extiende de BaseInput\n// ============================================================================\n\nexport class SortableListInput<T> extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this\n const children = input.listConfig?.children ?? undefined\n return (\n <FieldSortableList<T>\n form={form}\n input={input}\n isSubmitting={isSubmitting}\n children={children as (item: T, index: number) => ReactNode}\n />\n )\n }\n}\n\n// ============================================================================\n// 🔹 Campo principal con lógica de drag & drop\n// ============================================================================\n\ninterface Props<T> {\n form: UseFormReturn\n input: FieldProps\n isSubmitting?: boolean\n children?: (item: T, index: number) => ReactNode\n}\n\nfunction FieldSortableList<T>({\n form,\n input,\n isSubmitting,\n children,\n}: Props<T>): JSX.Element {\n const [items, setItems] = useState<any[]>(() => input.listConfig?.list ?? [])\n const sortableEnabled = input.listConfig?.sortable ?? true;\n\n const sensors = useSensors(\n useSensor(PointerSensor),\n useSensor(KeyboardSensor, { coordinateGetter: sortableKeyboardCoordinates })\n )\n\n const handleDragEnd = (event: any) => {\n if (!sortableEnabled) return; \n const { active, over } = event\n if (!over || active.id === over.id) return\n\n const oldIndex = items.findIndex((i: any) => i.id === active.id)\n const newIndex = items.findIndex((i: any) => i.id === over.id)\n const newList = arrayMove(items, oldIndex, newIndex)\n\n setItems(newList)\n form.setValue(input.name, newList)\n input.listConfig?.onOptionChange?.(newList)\n }\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={() => (\n <FormItem className={cn(\"space-y-2\", input.className)}>\n {input.label && <FormLabel><b>{input.label}</b></FormLabel>}\n <FormControl>\n {sortableEnabled ? (\n <DndContext collisionDetection={closestCenter} onDragEnd={handleDragEnd}>\n <SortableContext\n items={items.map((i) => i.id)}\n strategy={verticalListSortingStrategy}\n >\n <div className=\"flex flex-col gap-2\">\n {items.map((item, index) => (\n <SortableWrapper key={item.id} id={item.id}>\n {typeof children === \"function\"\n ? children(item, index)\n : <div className=\"p-3 border rounded-md bg-white\">{item.name}</div>}\n </SortableWrapper>\n ))}\n </div>\n </SortableContext>\n </DndContext>\n ) : (\n <div className=\"flex flex-col gap-2\">\n {items.map((item, index) =>\n typeof children === \"function\"\n ? children(item, index)\n : <div key={item.id} className=\"p-3 border rounded-md bg-gray-50\">{item.name}</div>\n )}\n </div>\n )}\n </FormControl>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )}\n />\n )\n}\n\n// ============================================================================\n// 🔹 SortableWrapper: item individual draggable\n// ============================================================================\n\nfunction SortableWrapper({\n id,\n children,\n disabled,\n}: {\n id: string | number\n children: React.ReactNode\n disabled?: boolean\n}) {\n const {\n attributes,\n listeners,\n setNodeRef,\n transform,\n transition,\n isDragging,\n } = useSortable({ id, disabled })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div\n ref={setNodeRef}\n style={style}\n {...attributes}\n {...listeners}\n className={cn(\n \"flex items-center gap-2 p-2 border rounded-md mb-1 bg-muted/30 cursor-grab select-none transition-all\",\n isDragging && \"opacity-60 bg-muted/50 scale-[0.98]\"\n )}\n >\n <GripVertical className=\"w-4 h-4 opacity-70\" />\n <div className=\"flex-1\">{children}</div>\n </div>\n )\n}\n","'use client';\n\nimport { JSX, useEffect, useState } from \"react\";\nimport { BaseInput, isValidField } from \"../base/base-input\";\nimport {\n FormControl,\n FormDescription,\n FormField,\n FormItem,\n FormLabel,\n FormMessage\n} from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base/definitions\";\nimport { Plus, Trash2 } from \"lucide-react\";\nimport { CustomInputGroup } from \"./text-input-group\";\n\nexport class StringValueListInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldStringValueList\n input={input}\n form={form}\n isSubmitting={isSubmitting}\n />\n );\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\n/**\n * 🧠 Lista editable de strings\n */\nexport const FieldStringValueList = ({ form, input, isSubmitting }: Props) => {\n const fieldName = input.name;\n const withAddBtn = input.withAddBtn ?? false\n const [isValid, setIsValid] = useState<boolean>(isValidField(input, form));\n\n // Inicializamos como array vacío si no existe\n useEffect(() => {\n setIsValid(isValidField(input, form));\n },[input])\n \n useEffect(() => {\n const current = form.getValues(fieldName);\n if (!Array.isArray(current)) {\n form.setValue(fieldName, []);\n }\n }, [form, fieldName]);\n\n const handleAddItem = () => {\n const current = form.getValues(fieldName) || [];\n form.setValue(fieldName, [...current, \"\"]);\n };\n\n const handleRemoveItem = (index: number) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.filter((_: string, i: number) => i !== index);\n form.setValue(fieldName, updated);\n };\n\n const handleChange = (index: number, newValue: string) => {\n const current = form.getValues(fieldName) || [];\n const updated = current.map((item: string, i: number) =>\n i === index ? newValue : item\n );\n form.setValue(fieldName, updated);\n };\n\n return (\n <FormField\n control={form.control}\n name={fieldName}\n render={(field) => {\n const items = form.watch(fieldName) || [];\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormMessage />\n <FormControl>\n <div className=\"flex flex-col gap-3 rounded-xl \">\n {items.length === 0 && (\n <p className=\"text-sm text-muted-foreground\">\n No items have been added yet.\n </p>\n )}\n\n {items.map((value: string, index: number) => (\n <div\n key={index}\n className=\"flex items-center gap-4 py-2\"\n >\n <CustomInputGroup \n autoValidate={true}\n value={value}\n input={input}\n isValid={isValid}\n onChange={(e) => handleChange(index, e.target.value)}\n // field={field}\n form={form}\n />\n {/* <Input\n placeholder={`Item ${index + 1}`}\n value={value}\n disabled={isSubmitting}\n onChange={(e) => handleChange(index, e.target.value)}\n /> */}\n {input.isRemovebleOption && (<Button\n type=\"button\"\n variant=\"destructive\"\n size=\"icon\"\n onClick={() => handleRemoveItem(index)}\n disabled={isSubmitting}\n >\n <Trash2 size={18} />\n </Button>)}\n </div>\n ))}\n\n <div className=\"flex justify-end mt-2\">\n { withAddBtn && (<Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={handleAddItem}\n disabled={isSubmitting}\n >\n <Plus size={18} className=\"mr-1\" />\n </Button>)}\n </div>\n </div>\n </FormControl>\n\n {input.description && (\n <FormDescription>{input.description}</FormDescription>\n )}\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { Card, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Switch } from \"@/src/components/ui\";\nimport { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\n\n\n\n\nexport class SwitchInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldSwitch input={input} form={form} isSubmitting={isSubmitting} />\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldSwitch = ({ input, form, isSubmitting }: Props): JSX.Element => {\n const className = input.className\n return (<FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <Card className={`${className ? className : 'p-3 shadow-lg bg-blue-100/20'}`}>\n\n <FormItem className=\"flex flex-row items-center justify-between rounded-lg\">\n <div className=\"space-y-0.5\">\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormDescription>{input.placeHolder ?? input.description}</FormDescription>\n <FormMessage />\n </div>\n <FormControl>\n <Switch checked={field.value} \n onCheckedChange={(event)=> { handleOnChage(event, input, field)}} \n disabled={false} />\n </FormControl>\n </FormItem>\n </Card>\n )} />)\n}\n\n","'use client'\nimport React, { JSX } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { Badge, FormControl, FormField, FormItem, FormLabel, FormMessage, Input } from \"@/src/components/ui\";\nimport { BaseInput, FieldProps, handleOnChage } from \"../base\";\nimport { cn } from \"@/src/lib/utils\";\n\n\n\n\nexport class TagInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldTags input={input} form={form} isSubmitting={isSubmitting}/>\n )\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nconst FieldTags = ({ input, form, isSubmitting }: Props): JSX.Element => {\n\n\n const formField = <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem>\n <div className=\"flex items-center justify-between p-2 border-b\">\n <FormLabel className=\"font-semibold\">\n {input.label || input.name}\n </FormLabel>\n </div>\n\n <FormControl>\n <TagsInput\n input={input}\n value={field.value ?? []}\n onValueChange={(event)=> handleOnChage(event, input, field)}\n placeholder=\"Enter for add tag\"\n />\n </FormControl>\n\n <FormMessage />\n </FormItem>\n )} />;\n\n return <>{formField}</>;\n \n}\n\n\n\n/**\n * used for identifying the split char and use will pasting\n */\nconst SPLITTER_REGEX = /[\\n#?=&\\t,./-]+/;\n\n/**\n * used for formatting the pasted element for the correct value format to be added\n */\n\nconst FORMATTING_REGEX = /^[^a-zA-Z0-9]*|[^a-zA-Z0-9]*$/g;\n\ninterface TagsInputProps extends React.HTMLAttributes<HTMLDivElement> {\n input: FieldProps;\n value: string[];\n onValueChange: (value: string[]) => void;\n placeholder?: string;\n maxItems?: number;\n minItems?: number;\n /** Donde mostrar los tags: 'top' o 'bottom', default 'bottom' */\n tagsPosition?: 'top' | 'bottom';\n}\n\nconst TagsInput = React.forwardRef<HTMLDivElement, TagsInputProps>(\n (\n {\n input,\n value,\n onValueChange,\n placeholder,\n maxItems,\n minItems,\n tagsPosition = 'bottom',\n className,\n dir,\n ...props\n },\n ref\n ) => {\n const [inputValue, setInputValue] = React.useState(\"\");\n const parseMinItems = minItems ?? 0;\n const parseMaxItems = maxItems ?? Infinity;\n\n const addTag = (val: string) => {\n if ((!value.includes(val) && value.length < parseMaxItems) || input.withDuplicatTag) {\n onValueChange([...value, val]);\n }\n };\n\n const removeTag = (val: string) => {\n if (value.includes(val) && value.length > parseMinItems) {\n onValueChange(value.filter((v) => v !== val));\n }\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter' && inputValue.trim() !== '') {\n e.preventDefault();\n addTag(inputValue.trim());\n setInputValue('');\n }\n if (e.key === 'Backspace' && inputValue === '' && value.length > 0) {\n removeTag(value[value.length - 1]);\n }\n };\n\n const handlePaste = (e: React.ClipboardEvent<HTMLInputElement>) => {\n e.preventDefault();\n const tags = e.clipboardData.getData('text').split(SPLITTER_REGEX)\n .map(t => t.replace(FORMATTING_REGEX, '').trim())\n .filter(t => t && !value.includes(t))\n .slice(0, parseMaxItems - value.length);\n if (tags.length) onValueChange([...value, ...tags]);\n };\n\n const renderTags = () => (\n <div className=\"flex flex-wrap gap-1 mb-1 mt-1\">\n {value.map(tag => (\n <Badge\n key={tag}\n className=\"flex items-center gap-1 px-2 py-0.5 rounded bg-muted text-muted-foreground text-xs\"\n >\n {tag}\n <button\n type=\"button\"\n onClick={() => removeTag(tag)}\n className=\"ml-1 text-xs hover:text-destructive\"\n >\n ×\n </button>\n </Badge>\n ))}\n </div>\n );\n\n return (\n <div {...props} ref={ref} className={cn(\"w-full\", className)}>\n {tagsPosition === 'top' && renderTags()}\n <input\n value={inputValue}\n onChange={(e) => setInputValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onPaste={handlePaste}\n placeholder={placeholder}\n className=\"w-full px-2 py-1 border rounded focus:outline-none focus:ring focus:ring-primary\"\n />\n {tagsPosition === 'bottom' && renderTags()}\n </div>\n );\n }\n);\n\nTagsInput.displayName = 'TagsInput';\n","'use client'\nimport { JSX, ChangeEvent } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\"\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, Textarea } from \"@/src/components/ui\"\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldProps } from \"../base\";\n\n\nexport class TextAreaInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldTextArea form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nfunction FieldTextArea({ form, input, isSubmitting }: Props): JSX.Element {\n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className=\"shadow-lg\">\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl>\n <Textarea className=\"min-w-[260px] bg-white\" \n placeholder={input.placeHolder} \n {...field} \n onChange={(event: ChangeEvent<HTMLTextAreaElement>) => {\n handleOnChage(event, input, field)\n }}\n disabled={input.disabled || isSubmitting} />\n </FormControl>\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n )} />;\n}\n\n","'use client'\nimport { JSX } from \"react\";\nimport { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from \"@/src/components/ui/form\";\nimport { Input } from \"@/src/components/ui/input\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { BaseInput, FieldProps, handleOnChage, InputTypes } from \"../base\";\n\n\nexport class TextInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return (\n <FieldText form={form} input={input} isSubmitting={isSubmitting} />\n )\n\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean; // estado submit externo opcional\n}\n\nconst FieldText = ({input, form, isSubmitting }: Props ): JSX.Element => {\n const hidden = input.hidden ?? input.inputType === InputTypes.HIDDEN;\n const type = hidden ? \"hidden\" : input.keyboardType || \"text\";\n return <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field }) => (\n <FormItem className={input.className}>\n { !hidden && (<FormLabel><b>{input.label}</b></FormLabel>)}\n <FormControl className=\"shadow-lg\">\n <Input className=\"min-w-[180px]\" placeholder={input.placeHolder} {...field} type={type}\n onChange={(e)=> handleOnChage(e, input, field)}\n disabled={input.disabled || isSubmitting} />\n </FormControl>\n {input.description && <FormDescription> {input.description} </FormDescription>}\n <FormMessage />\n {/* <pre> {JSON.stringify(field, null, 2)}</pre> */}\n </FormItem>\n )} />;\n}\n\n","'use client'\n\nimport { JSX, useState, useEffect } from \"react\";\nimport { BaseInput, handleOnChage } from \"../base/base-input\";\nimport { \n FormControl, \n FormDescription, \n FormField, \n FormItem, \n FormLabel, \n FormMessage \n} from \"@/src/components/ui/form\";\nimport { InputGroup, InputGroupAddon, InputGroupInput, InputGroupText } from \"@/src/components/ui/input-group\";\nimport { FieldProps } from \"../base/definitions\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { CircleCheck, CircleX, Loader2 } from \"lucide-react\";\n\nexport class TimeInput extends BaseInput {\n render(): JSX.Element {\n const { input, form, isSubmitting } = this;\n return <FieldTimeInput input={input} form={form} isSubmitting={isSubmitting} />;\n }\n}\n\ninterface Props {\n form: UseFormReturn;\n input: FieldProps;\n isSubmitting?: boolean;\n}\n\nexport const FieldTimeInput = ({ form, input, isSubmitting }: Props) => {\n const groupConfig = input.inputGroupConfig;\n const autoValidate = groupConfig?.autoValidIcons;\n\n const iconValidState = <CircleCheck style={{ color: \"#00bf3e\" }} />;\n const iconInvalidState = <CircleX style={{ color: \"#ff8080\" }} />;\n const iconLoadingState = <Loader2 className=\"animate-spin\" style={{ color: \"#1e90ff\" }} />;\n\n const iconsRight = groupConfig?.iconsRight ?? [];\n const iconsLeft = groupConfig?.iconsLeft ?? [];\n const textLeft = groupConfig?.textLeft;\n const textRight = groupConfig?.textRight;\n\n // Estado local para manejar validez\n const [isValid, setIsValid] = useState<boolean>(() => {\n const value = form.getValues(input.name);\n const fieldState = form.getFieldState(input.name);\n return !fieldState.error && value !== undefined && value !== \"\";\n });\n\n // Estado local para la hora\n const [time, setTime] = useState<string>(() => form.getValues(input.name) ?? \"\");\n\n useEffect(() => {\n const fieldValue = form.getValues(input.name) ?? \"\";\n if (fieldValue !== time) setTime(fieldValue);\n }, [form.getValues(input.name)]);\n\n return (\n <FormField\n key={input.name}\n control={form.control}\n name={input.name}\n render={({ field, fieldState }) => {\n const validNow = !fieldState.error && field.value !== undefined && field.value !== \"\";\n if (validNow !== isValid) setIsValid(validNow);\n\n const handleChange = (val: string) => {\n setTime(val);\n handleOnChage(val, input, field)\n field.onChange(val);\n };\n\n return (\n <FormItem className={input.className}>\n <FormLabel><b>{input.label}</b></FormLabel>\n <FormControl className=\"shadow-lg\">\n <InputGroup>\n\n {/* Iconos izquierda */}\n {(iconsLeft.length > 0 || textLeft) && (\n <InputGroupAddon>\n {textLeft && <InputGroupText>{textLeft}</InputGroupText>}\n {iconsLeft.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n </InputGroupAddon>\n )}\n\n {/* Input de tipo time */}\n <InputGroupInput\n type=\"time\"\n value={time}\n disabled={input.disabled || isSubmitting}\n onChange={(e) => handleChange(e.target.value)}\n />\n\n {/* Iconos derecha */}\n {(iconsRight.length > 0 || textRight || autoValidate) && (\n <InputGroupAddon align=\"inline-end\">\n {textRight && <InputGroupText>{textRight}</InputGroupText>}\n {iconsRight.map((IconComponent, index) => (\n <IconComponent key={index} size={20} />\n ))}\n\n {autoValidate && (\n <div>\n {isSubmitting\n ? iconLoadingState\n : isValid\n ? iconValidState\n : iconInvalidState}\n </div>\n )}\n </InputGroupAddon>\n )}\n\n </InputGroup>\n </FormControl>\n\n {input.description && <FormDescription>{input.description}</FormDescription>}\n <FormMessage />\n </FormItem>\n );\n }}\n />\n );\n};\n","'use client'\nimport { UseFormReturn } from \"react-hook-form\";\nimport { BaseInput, FieldConfig, FieldProps, InputTypes } from \"./base\";\nimport { \n TextInput,\n SelectInput,\n ColorInput,\n DateInput,\n NumberInput,\n SwitchInput,\n GroupedSwitchInput,\n OTPInput,\n FileInput,\n TextAreaInput,\n TextInputGroup,\n CheckboxInput,\n SimpleCheckListInput,\n RadioGroupInput,\n TagInput,\n DateTimeInput,\n TimeInput,\n FileMultiUploadInput,\n SliderInput,\n ButtonGroupInput,\n CurrencyInput,\n KeyValueListInput,\n RepeaterInput,\n MultiSelectInput,\n ComboboxInput,\n SortableListInput,\n RepeaterTabsInput,\n StringValueListInput,\n // SwitchListInput, // ES LO MISMO QUE => GroupedSwitchInput\n // CheckListInput,\n} from \"./types\";\nimport { JSX } from \"react\";\nimport z, { ZodObject, ZodTypeAny } from \"zod\";\nimport { AccordionGroupedSwitchInput } from \"./types/accordion-grouped-switches\";\nimport { Card } from '@/src/components/ui/card';\n\n\ntype InputClassConstructor = new (\n input: FieldProps,\n form: UseFormReturn,\n isSubmitting?: boolean\n) => BaseInput;\n\n\nconst inputMap: Record<InputTypes, InputClassConstructor> = {\n [InputTypes.TEXT_GROUP]: TextInputGroup,\n [InputTypes.TEXT]: TextInput,\n [InputTypes.SWITCH]: SwitchInput,\n [InputTypes.COLOR]: ColorInput,\n [InputTypes.DATE]: DateInput,\n [InputTypes.NUMBER]: NumberInput,\n [InputTypes.SELECT]: SelectInput,\n [InputTypes.GROUPED_SWITCH_LIST]: GroupedSwitchInput,\n [InputTypes.ACCORDION_GROUPED_SWITCH_LIST]: AccordionGroupedSwitchInput,\n [InputTypes.CHECKBOX]: CheckboxInput,\n [InputTypes.OTP]: OTPInput,\n [InputTypes.FILE]: FileInput,\n [InputTypes.SIMPLE_CHECK_LIST]: SimpleCheckListInput,\n [InputTypes.TEXTAREA]: TextAreaInput,\n [InputTypes.RADIO_GROUP]: RadioGroupInput,\n [InputTypes.TAGS]: TagInput,\n [InputTypes.DATE_TIME]: DateTimeInput,\n [InputTypes.TIME]: TimeInput,\n [InputTypes.FILE_MULTI_UPLOAD]: FileMultiUploadInput,\n [InputTypes.BUTTON_GROUP]: ButtonGroupInput,\n [InputTypes.CURRENCY]: CurrencyInput,\n [InputTypes.KEY_VALUE]: KeyValueListInput,\n [InputTypes.REPEATER]: RepeaterInput,\n [InputTypes.MULTI_SELECT]: MultiSelectInput,\n [InputTypes.COMBOBOX]: ComboboxInput,\n [InputTypes.SORTABLE_LIST]: SortableListInput,\n [InputTypes.REPEATER_TABS]: RepeaterTabsInput,\n [InputTypes.STRING_LIST]: StringValueListInput,\n \n \n //ToDos: ============================================================\n [InputTypes.SLIDER]: SliderInput, //ToDo: // PENDIENTE ... VISUALMENTE NO SE VE BIEN.!!!\n [InputTypes.FORM]: TextInput,\n [InputTypes.HIDDEN]: TextInput,\n [InputTypes.CHECK_LIST]: TextInput,\n // [InputTypes.SWITCH_LIST]: SwitchListInput,\n\n // [InputTypes.RANGE]: TextInput,\n // [InputTypes.MULTISELECT]: TextInput,\n \n // [InputTypes.IMAGE_UPLOAD]: TextInput,\n // [InputTypes.AUDIO_UPLOAD]: TextInput,\n // [InputTypes.VIDEO_UPLOAD]: TextInput,\n \n // [InputTypes.CREDIT_CARD]: TextInput,\n\n};\n\nexport class InputFactory {\n static create<T extends Record<string, any> = Record<string, any>>(\n input: FieldProps<T>,\n form: UseFormReturn<T>,\n isSubmitting: boolean = false\n ): JSX.Element {\n input.form = form\n const inputType = (input.inputType as InputTypes) ?? InputTypes.TEXT;\n\n const InputClass = (inputMap[inputType] ??\n TextInput) as new (\n input: FieldProps<T>,\n form: UseFormReturn<T>,\n isSubmitting: boolean\n ) => { render: () => JSX.Element };\n\n const instance = new InputClass(input, form, isSubmitting);\n\n if (!input.wrapInCard) return instance.render();\n\n return (\n <Card className=\"p-4 space-y-3\">\n {instance.render()}\n </Card>\n );\n }\n}\n\nexport function getDefaultValues<T extends Record<string, any>>(\n entity?: Partial<T>,\n fields?: FieldConfig<T>[]\n): Record<string, any> {\n const defaults: Record<string, any> = {};\n\n if (entity) {\n Object.entries(entity).forEach(([key, value]) => {\n defaults[key] = value ?? \"\";\n });\n }\n\n if (fields) {\n const flatFields = flattenFields(fields); // ✅ aplanado recursivo completo\n for (const field of flatFields) {\n const key = field.name as string;\n if (defaults[key] === undefined) {\n defaults[key] = field.value ?? field.defaultValue ?? \"\";\n }\n }\n }\n\n return defaults;\n}\n\n\n\nconst flattenFields = <T extends Record<string, any>>(fields: FieldConfig<T>[]): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n result.push(...flattenFields((field as any).fields));\n } else {\n result.push(field);\n }\n }\n\n return result;\n};\n\nexport const getDynamicSchema = <T extends Record<string, any>>(\n fields: FieldConfig<T>[],\n extraValidations?: ((schema: ZodObject<any>) => ZodObject<any>)[]\n): ZodObject<Record<keyof T, ZodTypeAny>> => {\n\n // 🔁 aplanamos el árbol completo de campos\n const flatFields = flattenFields(fields);\n\n // 🎯 construimos el shape del schema\n const shape = flatFields.reduce((acc, f) => {\n acc[f.name as keyof T] = f.zodType ?? z.any();\n return acc;\n }, {} as Record<keyof T, ZodTypeAny>);\n\n let schema: ZodObject<Record<keyof T, ZodTypeAny>> = z.object(shape);\n\n // ⚙️ Aplicar validaciones adicionales si las hay\n if (extraValidations?.length) {\n for (const fn of extraValidations) {\n schema = fn(schema);\n }\n }\n\n return schema;\n};","import { FieldValues, FormState } from \"react-hook-form\";\nimport { CustomAlert } from \"@/src/components/custom/custom-alert\";\nimport { FieldConfig, FieldProps } from \"./definitions\";\n\n// ✅ mismo tipo recursivo que usamos antes\n\n\ninterface Props<T extends FieldValues = Record<string, any>> {\n formState: FormState<any>;\n fields: FieldConfig<T>[]; // 👈 ahora soporta anidación\n}\n\n/**\n * 🔁 Función recursiva para aplanar la estructura de campos\n */\nconst flattenFields = <T extends FieldValues>(\n fields: FieldConfig<T>[]\n): FieldProps<T>[] => {\n const result: FieldProps<T>[] = [];\n\n for (const field of fields) {\n if (Array.isArray(field)) {\n result.push(...flattenFields(field));\n } else if ((field as any).fields) {\n // 👇 si el campo tiene subcampos, también los aplanamos\n result.push(...flattenFields((field as any).fields));\n } else {\n result.push(field);\n }\n }\n\n return result;\n};\n\nexport const FormErrorsAlert = <T extends FieldValues = Record<string, any>>({\n formState,\n fields,\n}: Props<T>) => {\n const flatFields = flattenFields(fields); // ✅ recursivo\n\n const hasErrors = Object.keys(formState.errors).length > 0;\n\n return (\n <div style={{ marginTop: 4 }}>\n {hasErrors && (\n <CustomAlert\n title=\"Revisar los siguientes criterios\"\n description={\n <ul>\n {Object.entries(formState.errors).map(([key, value]) => (\n <li key={key}>\n <strong>{getFieldLabel<T>(key, flatFields)}:</strong>{\" \"}\n {value?.message?.toString() ?? \"\"}\n </li>\n ))}\n </ul>\n }\n className=\"mb-4\"\n variant=\"error\"\n />\n )}\n </div>\n );\n};\n\nexport const getFieldLabel = <T extends FieldValues>(\n fieldErrorKey: string,\n fields: ReadonlyArray<FieldProps<T>>\n): string => {\n const foundField = fields.find((field) => field.name === fieldErrorKey);\n return foundField?.label ?? fieldErrorKey;\n};\n","'use client';\n\nimport { JSX, ReactNode } from \"react\";\nimport { UseFormReturn } from \"react-hook-form\";\nimport { FieldConfig } from \"./base\";\nimport { InputFactory } from \"./input-factory\";\n\ninterface Props<T extends Record<string, any> = Record<string, any>> {\n fields: FieldConfig<T>[];\n form: UseFormReturn<any>;\n readOnly?: boolean;\n isPending?: boolean;\n className?: string;\n gap?: string; // opcional, para espacio entre columnas\n}\n\nconst isRenderableChild = (c?: ReactNode | ((item: any, index: number) => ReactNode)) =>\n c !== undefined && c !== null && typeof c !== \"function\";\n\n/**\n * 📋 FormFieldsGrid\n * Componente reutilizable para renderizar campos en una cuadrícula flexible.\n * - Si un elemento del arreglo es un solo FieldProps → muestra en una línea.\n * - Si es un arreglo de FieldProps → los muestra en una misma fila.\n */\nexport const FormFieldsGrid = <T extends Record<string, any> = Record<string, any>>({\n fields,\n form,\n isPending,\n readOnly,\n className = \"\",\n gap = \"gap-2\",\n}: Props<T>): JSX.Element => {\n return (\n <div className={`w-full grid grid-cols-1 ${gap} ${className}`}>\n {fields.map((inputOrGroup, idx) =>\n Array.isArray(inputOrGroup) ? (\n <div\n key={`field-group-${idx}`}\n className=\"w-full flex flex-row items-start gap-4 py-3\"\n >\n {inputOrGroup.map((field, subIdx) => {\n // NO mutamos field: creamos una copia (inmutable)\n const fieldCopy = {\n ...(field as any),\n disabled: readOnly ? true : (field as any).disabled,\n };\n\n const renderInlineChild =\n fieldCopy.childrenPosition !== \"down\" && isRenderableChild(fieldCopy.children);\n\n const renderInlineChildDown =\n fieldCopy.childrenPosition === \"down\" && isRenderableChild(fieldCopy.children);\n\n return (\n <div key={`field-${idx}-${subIdx}`} className=\"w-full px-2\">\n {renderInlineChild && <>{fieldCopy.children}</>}\n {/*\n Pasamos children a InputFactory.create para que el componente concreto\n (p. ej. SortableListInput) lo use si es función render-prop.\n InputFactory.create signature se adapta abajo si es necesario.\n */}\n {InputFactory.create(fieldCopy, form, isPending)}\n {renderInlineChildDown && <>{fieldCopy.children}</>}\n </div>\n );\n })}\n </div>\n ) : (\n <div\n key={`field-single-${idx}`}\n className=\"flex flex-col justify-between py-3 w-full px-2\"\n >\n {(() => {\n const fieldCopy = {\n ...(inputOrGroup as any),\n disabled: readOnly ? true : (inputOrGroup as any).disabled,\n };\n\n const renderUp = fieldCopy.childrenPosition !== \"down\" && isRenderableChild(fieldCopy.children);\n const renderDown = fieldCopy.childrenPosition === \"down\" && isRenderableChild(fieldCopy.children);\n\n return (\n <>\n {renderUp && <>{fieldCopy.children}</>}\n {InputFactory.create(fieldCopy, form, isPending)}\n {renderDown && <>{fieldCopy.children}</>}\n </>\n );\n })()}\n </div>\n )\n )}\n </div>\n );\n};","'use client';\n\nimport { ReactNode, useEffect, useMemo, useTransition } from \"react\";\nimport { useForm, UseFormReturn, DefaultValues, Resolver } from \"react-hook-form\";\nimport { BtnConfig, FieldConfig, FieldProps, flattenFields } from \"./base\";\nimport { getDefaultValues, getDynamicSchema } from \"./input-factory\";\nimport { FormErrorsAlert } from \"./base/form-errors\";\nimport { Button, Card, CardContent, CardDescription, CardTitle, Form } from '@/src/components/ui';\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport { Loader2, Pencil, Save } from \"lucide-react\";\nimport { ZodObject, z } from \"zod\";\nimport { FormFieldsGrid } from \"./FormFieldsGrid\";\nimport { ButtonGroup } from \"@/src/components/ui/button-group\";\nimport { cn } from \"@/src/lib/utils\";\n\ntype alertPositionType = 'up' | 'down';\n\nexport interface FormResp<T> {\n form?: UseFormReturn<any>;\n data: T;\n}\n\ninterface Props<T extends Record<string, any>> {\n showIcon?: boolean;\n showFormHeader?: boolean;\n formTitle: string;\n formSubTitle?: string;\n readOnly?: boolean;\n fields: FieldConfig<T>[];\n record?: Partial<T>;\n onAnyFieldChange?: (data: Record<string,any>) => void;\n onSubmit?: (resp: FormResp<T>) => void;\n onClick?: (resp: FormResp<T>) => void;\n extraValidations?: ((schema: ZodObject<any>) => ZodObject<any>)[];\n withErrorsAlert?: boolean;\n errorAlertPosition?: alertPositionType;\n withCard?: boolean;\n withFormWrapper?: boolean;\n withSubmitBtn?: boolean;\n submitBtnLabel?: string;\n submitBtnLabelSubmiting?: string;\n submitBtnClass?: string;\n btnGroupDirection?: 'flex-start' | 'flex-end' | 'flex-center';\n children?: ReactNode;\n childrenHeader?: ReactNode;\n listBtnConfig?: BtnConfig[];\n}\n\nexport const DynamicForm = <T extends Record<string, any>>({\n formTitle,\n formSubTitle,\n fields,\n readOnly = false,\n record = {},\n onAnyFieldChange,\n onSubmit,\n onClick,\n extraValidations,\n children,\n childrenHeader,\n showIcon = false,\n showFormHeader = true,\n withErrorsAlert = true,\n errorAlertPosition = 'up',\n withCard = false,\n submitBtnClass=\"\",\n listBtnConfig = [],\n submitBtnLabel = 'Guardar',\n submitBtnLabelSubmiting = 'Guardando...',\n withFormWrapper = true,\n btnGroupDirection = \"flex-end\",\n withSubmitBtn = true\n}: Props<T>) => {\n\n const [isPending, startTransition] = useTransition();\n\n /** ✅ Schema dinámico basado en los campos */\n const schema = useMemo(() => {\n // const flattenFields = (items: any[]): FieldProps<T>[] => {\n // return items.flatMap(item => \n // Array.isArray(item) ? flattenFields(item) : item\n // );\n // };\n\n const allFields = flattenFields(fields, onAnyFieldChange);\n return getDynamicSchema<T>(allFields, extraValidations);\n}, [fields, extraValidations]);\n\n type FormData = z.infer<typeof schema>;\n const resolver = zodResolver(schema) as unknown as Resolver<FormData>;\n\n const initialValues = useMemo(() => getDefaultValues<T>(record), [record]);\n\n const form = useForm<FormData>({\n resolver,\n defaultValues: initialValues as unknown as DefaultValues<FormData>,\n });\n\n /** 🔄 Reset cuando cambia record */\n useEffect(() => {\n form.reset(initialValues as unknown as DefaultValues<FormData>);\n // }, [initialValues, form]);\n }, []);\n\n /** 💾 onSubmit */\n const handleSubmit = (data: FormData) => {\n if (readOnly) return;\n startTransition(() => {\n const resp: FormResp<T> = { data: data as unknown as T, form };\n onSubmit?.(resp);\n });\n };\n\n /** 🖱️ onClick con validación */\n const handleClick = async () => {\n if (!onClick) return;\n const isValid = await form.trigger();\n if (!isValid) return;\n\n const data = form.getValues() as unknown as T;\n const resp: FormResp<T> = { data, form };\n onClick(resp);\n };\n\n const formBody = (\n <>\n <div className=\"w-full grid grid-cols-1\">\n <FormFieldsGrid\n fields={fields as unknown as FieldConfig<T>[]}\n form={form}\n readOnly={readOnly}\n />\n {children && (\n <div className=\"flex flex-row items-center gap-2 w-full h-full\">\n {children}\n </div>\n )}\n </div>\n\n <ButtonGroup className=\"flex flex-row w-full h-full\" style={{\n justifyContent: btnGroupDirection, // Alinea horizontalmente a la derecha\n alignItems: \"center\", // Centra verticalmente (opcional)\n }}>\n {listBtnConfig.map((btn, key) => (\n <Button\n type={btn.btnType}\n key={key}\n size=\"lg\"\n className={submitBtnClass}\n variant={btn.variant}\n onClick={btn.onClick}\n disabled={btn.disabled}\n >\n {btn.label}\n </Button>\n ))}\n {!readOnly && withSubmitBtn && (\n <Button\n type={onClick ? 'button' : 'submit'}\n size=\"lg\"\n className={cn(submitBtnClass)}\n disabled={isPending}\n onClick={onClick ? handleClick : undefined}\n >\n {isPending ? (\n <>\n <Loader2 className=\"h-5 w-5 mr-2 animate-spin\" />\n {submitBtnLabelSubmiting}\n </>\n ) : (\n <>\n <Save className=\"h-5 w-5 mr-2\" />\n {submitBtnLabel}\n </>\n )}\n </Button>\n )}\n </ButtonGroup>\n </>\n )\n\n /** 🧩 Render del contenido principal del formulario */\n const formContent = (\n <div>\n {showFormHeader && (\n <CardTitle className=\"flex flex-row items-center gap-2 p-2 border-b\">\n <div className=\"flex flex-row items-center gap-2 w-full\">\n {showIcon && <Pencil className=\"h-5 w-5\" />}\n <div className=\"flex flex-col\">\n <div className=\"text-xl\">{formTitle}</div>\n {formSubTitle && <CardDescription>{formSubTitle}</CardDescription>}\n </div>\n </div>\n {childrenHeader && (\n <div className=\"flex flex-row items-center gap-2 w-full h-full\">\n {childrenHeader}\n </div>\n )}\n </CardTitle>\n )}\n\n {withErrorsAlert && errorAlertPosition === 'up' && (\n <FormErrorsAlert\n formState={form.formState}\n fields={fields as unknown as FieldConfig<T>[]}\n />\n )}\n\n {withFormWrapper && (<FormWrapper form={form} handleSubmit={handleSubmit}>{formBody}</FormWrapper>)}\n {!withFormWrapper && (formBody)}\n\n\n {withErrorsAlert && errorAlertPosition === 'down' && (\n <FormErrorsAlert\n formState={form.formState}\n fields={fields.flatMap(f => Array.isArray(f) ? f : [f])}\n />\n )}\n </div>\n );\n\n if (!withCard) return formContent;\n\n return (\n <Card>\n <CardContent>{formContent}</CardContent>\n </Card>\n );\n};\n\n\ninterface FormWrapperProps {\n form:UseFormReturn<any>\n handleSubmit: (data: any) => void\n children: ReactNode;\n readOnly?: boolean\n}\n\nconst FormWrapper = ({form, handleSubmit, children, readOnly}: FormWrapperProps) => {\n return (\n <Form {...form}>\n <form\n onSubmit={form.handleSubmit(handleSubmit)}\n className={`flex flex-col gap-2 ${readOnly ? 'opacity-70 pointer-events-none select-none' : ''}`}\n >\n {children}\n </form>\n </Form>\n )\n}\n\n\n","\"use client\";\n\nimport z from \"zod\";\nimport { FieldProps, InputTypes, TextInputType } from \"./base\";\nimport { DynamicForm } from \"./DynamicForm\";\nimport validationMessages from \"../input-errors\";\n\ninterface UserFromDB {\n username: string;\n email: string;\n isActive: boolean;\n favoriteColor: undefined;\n age: number;\n role: string;\n}\n\nexport const DynamicFormExample = () => {\n const record: UserFromDB = {\n username: \"John Doe \",\n email: \"johndoe@example.com\",\n isActive: true,\n favoriteColor: undefined,\n age: 25,\n role: \"editor\",\n };\n\n return (\n <DynamicForm\n formTitle=\"User Form\"\n fields={mockFields}\n record={record}\n onSubmit={(data) => console.log(\"📤 Resultado final:\", data)}\n />\n );\n}\n\nexport const mockFields: Array<FieldProps |FieldProps[]> = [\n // 🧍♂️ Campo requerido simple\n {\n name: \"username\",\n label: \"Nombre de usuario\",\n inputType: InputTypes.TEXT,\n required: true,\n zodType: z\n .string()\n .min(3, \"El nombre debe tener al menos 3 caracteres\")\n .max(20, \"El nombre no puede tener más de 20 caracteres\"),\n },\n\n // 📧 Campo de correo con validación personalizada (ZodTypeAny)\n {\n name: \"email\",\n label: \"Correo electrónico\",\n inputType: InputTypes.TEXT,\n required: false,\n zodType: z\n .string()\n .email(\"Correo inválido\")\n .toLowerCase()\n .refine((val) => !val.endsWith(\"@spam.com\"), {\n message: \"No se permiten correos de spam.com\",\n }),\n },\n\n // 🔒 Campo opcional (no requerido)\n {\n name: \"password\",\n label: \"Contraseña\",\n inputType: InputTypes.TEXT,\n required: false,\n keyboardType: TextInputType.PASSWORD,\n zodType: z\n .string()\n .min(6, \"Debe tener al menos 6 caracteres\")\n .max(20, \"No más de 20 caracteres\")\n .optional(),\n },\n\n // 🟢 Campo tipo switch (boolean)\n {\n name: \"isActive\",\n label: \"Usuario activo\",\n inputType: InputTypes.SWITCH,\n required: false,\n zodType: z.boolean().default(true),\n },\n\n // 🎨 Color con validación personalizada\n [ \n {\n name: \"favoriteColor\",\n label: \"Color favorito\",\n inputType: InputTypes.COLOR,\n required: false,\n zodType: z\n .string()\n .regex(/^#([0-9A-Fa-f]{6})$/, \"Debe ser un color hexadecimal válido\"),\n },\n\n // 🔢 Número con rango\n {\n name: \"age\",\n label: \"Edad\",\n inputType: InputTypes.NUMBER,\n required: true,\n zodType: z\n .coerce.number() // fuerza a number\n .min(18, \"Debe ser mayor de 18\")\n .max(99, \"Debe ser menor de 99\"),\n }\n ],\n\n // 📅 Fecha\n {\n name: \"birthDate\",\n label: \"Fecha de nacimiento\",\n inputType: InputTypes.DATE,\n required: true,\n zodType: z.coerce.date().refine((d) => d < new Date(), {\n message: \"La fecha no puede ser futura\",\n }),\n },\n\n // 🎓 Select con validación personalizada\n {\n name: \"role\",\n label: \"Rol de usuario\",\n inputType: InputTypes.SELECT,\n required: true,\n listConfig: {\n onOptionChange: () =>{},\n list: [\n { id: 1, name: \"Administrador\", value: \"admin\" },\n { id: 2, name: \"Editor\", value: \"editor\" },\n { id: 3, name: \"Lector\", value: \"reader\" },\n ]\n },\n zodType: z.enum([\"admin\", \"editor\", \"reader\"]),\n },\n\n // 🧾 Campo tipo archivo (file)\n {\n name: \"profileImage\",\n label: \"Imagen de perfil\",\n inputType: InputTypes.FILE,\n required: false,\n zodType: z\n .any()\n .refine(\n (file) => {\n if (!file) return true;\n return (\n file.size <= 10 * 1024 * 1024 &&\n [\"image/jpeg\", \"image/png\"].includes(file.type)\n );\n },\n { message: \"Solo se permiten imágenes JPG o PNG de menos de 10MB\" }\n )\n .optional(),\n },\n\n // 🔢 OTP (código)\n {\n name: \"otpCode\",\n label: \"Código OTP\",\n inputType: InputTypes.OTP,\n required: true,\n zodType: z\n .string()\n .min(4, \"Debe tener al menos 4 dígitos\")\n .max(6, \"Debe tener máximo 6 dígitos\"),\n },\n ];","import { useState } from \"react\";\nimport { Button } from \"@/src/components/ui/button\";\nimport { Switch } from \"@/src/components/ui/switch\";\nimport { Accordion, AccordionContent, AccordionItem, AccordionTrigger } from \"@/src/components/ui/accordion\";\nimport { Plus } from 'lucide-react';\nimport { InputSetup, InputTypes } from \"./form/inputs/base\";\n\ninterface Props {\n handleAddInput: (type: InputTypes, config?: InputSetup) => void;\n inputsTypes: InputTypes[];\n}\n\n\n\nexport const InputList = ({ handleAddInput, inputsTypes, }: Props) => {\n // Estado: un objeto donde la clave es el inputType y el valor su configuración\n const [inputSetups, setInputSetups] = useState<Record<string, InputSetup>>(() =>\n Object.fromEntries(\n inputsTypes.map((type) => [type, { required: false, disabled: false }])\n )\n );\n\n const toggleConfig = (type: string, key: keyof InputSetup) => {\n setInputSetups((prev) => ({\n ...prev,\n [type]: { ...prev[type], [key]: !prev[type][key] },\n }));\n };\n\n return (\n <div className=\"grid grid-cols-1 gap-1\">\n {inputsTypes.map((type) => {\n const setup = inputSetups[type];\n return (\n <div\n key={type}\n className=\"border rounded-lg p-2 flex flex-col-2 gap-1 shadow-sm\"\n >\n <Button size=\"icon\" onClick={() => handleAddInput(type, setup)} >\n <Plus/>\n </Button>\n <Accordion type=\"single\" collapsible className=\"w-full\">\n <AccordionItem value=\"item-1\">\n <AccordionTrigger>\n <div className=\"flex flex-row justify-center w-full content-center\">\n <span className=\"font-semibold text-xl\">{type}</span>\n </div>\n </AccordionTrigger>\n <AccordionContent>\n {/* ✅ Controles para configurar */}\n <div className=\"flex flex-col gap-1\">\n <label className=\"flex items-center gap-2\">\n <Switch\n checked={setup.required}\n onCheckedChange={() => toggleConfig(type, \"required\")}\n />\n <span>Required</span>\n </label>\n\n <label className=\"flex items-center gap-2\">\n <Switch\n checked={setup.disabled}\n onCheckedChange={() => toggleConfig(type, \"disabled\")}\n />\n <span>Disabled</span>\n </label>\n </div>\n </AccordionContent>\n </AccordionItem>\n </Accordion>\n\n {/* <div className=\"flex justify-between items-center\">\n \n <Button\n size=\"sm\"\n onClick={() => handleAddInput(type, setup)}\n >\n Agregar\n </Button>\n </div> */}\n\n \n </div>\n );\n })}\n </div>\n );\n};\n","\"use client\"\n\nimport { useState, useEffect, useRef } from \"react\"\nimport { FieldProps, GroupedOption, InputOption, InputTypes } from \"../form/inputs/base\"\nimport { DynamicForm } from \"../form/inputs/DynamicForm\"\nimport { Search } from \"lucide-react\"\n\n\ninterface GenericFilterProps<T> {\n filters?: Array<FieldProps | FieldProps[]>\n pagination?: boolean\n autoSubmit?: boolean\n defaultValues?: Record<string, any>\n initPage?: number\n initLimit?: number\n onChange?: (values: Record<string, any>) => void\n rangeLimit?: number[]\n withSearch?: boolean\n withInitDate?: boolean\n withEndDate?: boolean\n withActive?: boolean\n withLimit?: boolean\n wrapInCard?: boolean\n}\n\ninterface Filter {\n page?: number\n limit?: number\n search?: string\n active?: boolean\n initDate?: Date\n endDate?: Date\n defaultValues?: Record<string, any>\n}\n\n/**\n * ✅ Componente genérico y dinámico de filtro\n */\nexport const GenericFilter = <T,>({\n filters = [],\n pagination,\n autoSubmit = false,\n defaultValues = {},\n initPage = 1,\n initLimit = 10,\n rangeLimit = [10, 25, 50, 100],\n onChange,\n withSearch = true,\n withInitDate = true,\n withEndDate = true,\n withActive = true,\n withLimit = true,\n wrapInCard = true,\n}: GenericFilterProps<T>) => {\n const record: Filter = {\n page: initPage,\n limit: initLimit,\n ...defaultValues,\n }\n\n const [values, setValues] = useState<Filter>(record)\n const isFirstRender = useRef(true)\n\n useEffect(() => {\n if (isFirstRender.current) {\n isFirstRender.current = false\n return\n }\n }, [values])\n\n const handleChange = (name: string, value: any) => {\n setValues((prev) => ({ ...prev, [name]: value }))\n if (autoSubmit && onChange) onChange({ ...values, [name]: value })\n }\n\n const handleReset = () => {\n setValues({\n page: initPage,\n limit: initLimit,\n ...defaultValues,\n })\n }\n\n // 🧩 Filtros base (predefinidos)\n const baseFields: FieldProps[] = [\n ...(withSearch\n ? [\n {\n name: \"search\",\n label: \"Buscar\",\n inputType: InputTypes.TEXT_GROUP,\n inputGroupConfig: { iconsLeft: [Search] },\n onChange: (value: any) => handleChange(\"search\", value),\n } as FieldProps,\n ]\n : []),\n ...(withInitDate\n ? [\n {\n name: \"initDate\",\n label: \"Fecha de Inicio\",\n inputType: InputTypes.DATE,\n onChange: (value: any) => handleChange(\"initDate\", value),\n } as FieldProps,\n ]\n : []),\n ...(withEndDate\n ? [\n {\n name: \"endDate\",\n label: \"Fecha Final\",\n inputType: InputTypes.DATE,\n onChange: (value: any) => handleChange(\"endDate\", value),\n } as FieldProps,\n ]\n : []),\n ...(withActive\n ? [\n {\n wrapInCard: true,\n name: \"active\",\n label: \"\",\n inputType: InputTypes.BUTTON_GROUP,\n description: \"Estado\",\n listConfig: {\n list: [\n { id: 1, name: \"Activo\", value: true },\n { id: 2, name: \"Inactivo\", value: false },\n { id: 3, name: \"Todos\", value: undefined },\n ],\n onOptionChange: (item?: InputOption | InputOption[]) => {\n if (Array.isArray(item) && item[0]) handleChange(\"active\", item[0].value)\n else if (item && \"value\" in item) handleChange(\"active\", item.value)\n },\n },\n } as FieldProps,\n ]\n : []),\n ...(withLimit\n ? [\n {\n name: \"limit\",\n label: \"Límite por página\",\n inputType: InputTypes.SELECT,\n listConfig: {\n list: rangeLimit.map((num) => ({\n value: String(num),\n id: num,\n name: String(num),\n })),\n onOptionChange: (item: any) => handleChange(\"limit\", Number(item?.value ?? 10)),\n },\n } as FieldProps,\n ]\n : []),\n ]\n\n \n // 🧱 Combina todos los campos\n const fieldsConfig: Array<FieldProps | FieldProps[]> = [\n ...filters,\n baseFields,\n ]\n\n return (\n <div className=\"flex flex-col md:flex-row md:items-end gap-4 py-3\">\n <div className=\"flex-1\">\n <DynamicForm<Filter>\n withCard={wrapInCard}\n withSubmitBtn={!autoSubmit}\n formTitle=\"\"\n submitBtnLabel=\"Buscar\"\n fields={fieldsConfig}\n record={values}\n showFormHeader={false}\n onSubmit={({ data }) => {\n if (onChange && !autoSubmit) onChange(data)\n }}\n />\n </div>\n </div>\n )\n}\n"]}
|