@douglasneuroinformatics/libui 2.0.2 → 2.0.4
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/components/Accordion/Accordion.d.ts +7 -0
- package/dist/components/Accordion/Accordion.d.ts.map +1 -0
- package/dist/components/Accordion/Accordion.js +9 -0
- package/dist/components/Accordion/AccordionContent.d.ts +4 -0
- package/dist/components/Accordion/AccordionContent.d.ts.map +1 -0
- package/dist/components/Accordion/AccordionContent.js +7 -0
- package/dist/components/Accordion/AccordionItem.d.ts +4 -0
- package/dist/components/Accordion/AccordionItem.d.ts.map +1 -0
- package/dist/components/Accordion/AccordionItem.js +6 -0
- package/dist/components/Accordion/AccordionRoot.d.ts +4 -0
- package/dist/components/Accordion/AccordionRoot.d.ts.map +1 -0
- package/dist/components/Accordion/AccordionRoot.js +5 -0
- package/dist/components/Accordion/AccordionTrigger.d.ts +4 -0
- package/dist/components/Accordion/AccordionTrigger.d.ts.map +1 -0
- package/dist/components/Accordion/AccordionTrigger.js +10 -0
- package/dist/components/AlertDialog/AlertDialog.d.ts +13 -0
- package/dist/components/AlertDialog/AlertDialog.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialog.js +20 -0
- package/dist/components/AlertDialog/AlertDialogAction.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogAction.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogAction.js +7 -0
- package/dist/components/AlertDialog/AlertDialogCancel.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogCancel.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogCancel.js +7 -0
- package/dist/components/AlertDialog/AlertDialogContent.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogContent.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogContent.js +9 -0
- package/dist/components/AlertDialog/AlertDialogDescription.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogDescription.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogDescription.js +6 -0
- package/dist/components/AlertDialog/AlertDialogFooter.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogFooter.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogFooter.js +3 -0
- package/dist/components/AlertDialog/AlertDialogHeader.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogHeader.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogHeader.js +3 -0
- package/dist/components/AlertDialog/AlertDialogOverlay.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogOverlay.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogOverlay.js +6 -0
- package/dist/components/AlertDialog/AlertDialogTitle.d.ts +3 -0
- package/dist/components/AlertDialog/AlertDialogTitle.d.ts.map +1 -0
- package/dist/components/AlertDialog/AlertDialogTitle.js +6 -0
- package/dist/components/ArrowToggle/ArrowToggle.d.ts +287 -0
- package/dist/components/ArrowToggle/ArrowToggle.d.ts.map +1 -0
- package/dist/components/ArrowToggle/ArrowToggle.js +22 -0
- package/dist/components/Avatar/Avatar.d.ts +6 -0
- package/dist/components/Avatar/Avatar.d.ts.map +1 -0
- package/dist/components/Avatar/Avatar.js +7 -0
- package/dist/components/Avatar/AvatarFallback.d.ts +4 -0
- package/dist/components/Avatar/AvatarFallback.d.ts.map +1 -0
- package/dist/components/Avatar/AvatarFallback.js +6 -0
- package/dist/components/Avatar/AvatarImage.d.ts +4 -0
- package/dist/components/Avatar/AvatarImage.d.ts.map +1 -0
- package/dist/components/Avatar/AvatarImage.js +6 -0
- package/dist/components/Avatar/AvatarRoot.d.ts +4 -0
- package/dist/components/Avatar/AvatarRoot.d.ts.map +1 -0
- package/dist/components/Avatar/AvatarRoot.js +6 -0
- package/dist/components/Badge/Badge.d.ts +9 -0
- package/dist/components/Badge/Badge.d.ts.map +1 -0
- package/dist/components/Badge/Badge.js +20 -0
- package/dist/components/Breadcrumb/Breadcrumb.d.ts +14 -0
- package/dist/components/Breadcrumb/Breadcrumb.d.ts.map +1 -0
- package/dist/components/Breadcrumb/Breadcrumb.js +15 -0
- package/dist/components/Breadcrumb/BreadcrumbEllipsis.d.ts +3 -0
- package/dist/components/Breadcrumb/BreadcrumbEllipsis.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbEllipsis.js +5 -0
- package/dist/components/Breadcrumb/BreadcrumbItem.d.ts +3 -0
- package/dist/components/Breadcrumb/BreadcrumbItem.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbItem.js +5 -0
- package/dist/components/Breadcrumb/BreadcrumbLink.d.ts +5 -0
- package/dist/components/Breadcrumb/BreadcrumbLink.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbLink.js +7 -0
- package/dist/components/Breadcrumb/BreadcrumbList.d.ts +3 -0
- package/dist/components/Breadcrumb/BreadcrumbList.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbList.js +5 -0
- package/dist/components/Breadcrumb/BreadcrumbPage.d.ts +3 -0
- package/dist/components/Breadcrumb/BreadcrumbPage.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbPage.js +5 -0
- package/dist/components/Breadcrumb/BreadcrumbRoot.d.ts +5 -0
- package/dist/components/Breadcrumb/BreadcrumbRoot.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbRoot.js +4 -0
- package/dist/components/Breadcrumb/BreadcrumbSeparator.d.ts +3 -0
- package/dist/components/Breadcrumb/BreadcrumbSeparator.d.ts.map +1 -0
- package/dist/components/Breadcrumb/BreadcrumbSeparator.js +4 -0
- package/dist/components/Button/Button.d.ts +299 -0
- package/dist/components/Button/Button.d.ts.map +1 -0
- package/dist/components/Button/Button.js +37 -0
- package/dist/components/Card/Card.d.ts +9 -0
- package/dist/components/Card/Card.d.ts.map +1 -0
- package/dist/components/Card/Card.js +14 -0
- package/dist/components/Checkbox/Checkbox.d.ts +4 -0
- package/dist/components/Checkbox/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox/Checkbox.js +9 -0
- package/dist/components/Collapsible/Collapsible.d.ts +6 -0
- package/dist/components/Collapsible/Collapsible.d.ts.map +1 -0
- package/dist/components/Collapsible/Collapsible.js +6 -0
- package/dist/components/Collapsible/CollapsibleRoot.d.ts +3 -0
- package/dist/components/Collapsible/CollapsibleRoot.d.ts.map +1 -0
- package/dist/components/Collapsible/CollapsibleRoot.js +5 -0
- package/dist/components/Command/Command.d.ts +336 -0
- package/dist/components/Command/Command.d.ts.map +1 -0
- package/dist/components/Command/Command.js +22 -0
- package/dist/components/Command/CommandEmpty.d.ts +9 -0
- package/dist/components/Command/CommandEmpty.d.ts.map +1 -0
- package/dist/components/Command/CommandEmpty.js +5 -0
- package/dist/components/Command/CommandGroup.d.ts +13 -0
- package/dist/components/Command/CommandGroup.d.ts.map +1 -0
- package/dist/components/Command/CommandGroup.js +6 -0
- package/dist/components/Command/CommandInput.d.ts +10 -0
- package/dist/components/Command/CommandInput.d.ts.map +1 -0
- package/dist/components/Command/CommandInput.js +11 -0
- package/dist/components/Command/CommandItem.d.ts +15 -0
- package/dist/components/Command/CommandItem.d.ts.map +1 -0
- package/dist/components/Command/CommandItem.js +6 -0
- package/dist/components/Command/CommandList.d.ts +11 -0
- package/dist/components/Command/CommandList.d.ts.map +1 -0
- package/dist/components/Command/CommandList.js +6 -0
- package/dist/components/Command/CommandSeparator.d.ts +9 -0
- package/dist/components/Command/CommandSeparator.d.ts.map +1 -0
- package/dist/components/Command/CommandSeparator.js +6 -0
- package/dist/components/Command/CommandShortcut.d.ts +3 -0
- package/dist/components/Command/CommandShortcut.d.ts.map +1 -0
- package/dist/components/Command/CommandShortcut.js +5 -0
- package/dist/components/ContextMenu/ContextMenu.d.ts +24 -0
- package/dist/components/ContextMenu/ContextMenu.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenu.js +26 -0
- package/dist/components/ContextMenu/ContextMenuCheckboxItem.d.ts +4 -0
- package/dist/components/ContextMenu/ContextMenuCheckboxItem.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuCheckboxItem.js +11 -0
- package/dist/components/ContextMenu/ContextMenuContent.d.ts +4 -0
- package/dist/components/ContextMenu/ContextMenuContent.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuContent.js +7 -0
- package/dist/components/ContextMenu/ContextMenuItem.d.ts +6 -0
- package/dist/components/ContextMenu/ContextMenuItem.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuItem.js +6 -0
- package/dist/components/ContextMenu/ContextMenuLabel.d.ts +6 -0
- package/dist/components/ContextMenu/ContextMenuLabel.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuLabel.js +6 -0
- package/dist/components/ContextMenu/ContextMenuRadioItem.d.ts +4 -0
- package/dist/components/ContextMenu/ContextMenuRadioItem.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuRadioItem.js +11 -0
- package/dist/components/ContextMenu/ContextMenuSeparator.d.ts +4 -0
- package/dist/components/ContextMenu/ContextMenuSeparator.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuSeparator.js +6 -0
- package/dist/components/ContextMenu/ContextMenuShortcut.d.ts +3 -0
- package/dist/components/ContextMenu/ContextMenuShortcut.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuShortcut.js +5 -0
- package/dist/components/ContextMenu/ContextMenuSubContent.d.ts +4 -0
- package/dist/components/ContextMenu/ContextMenuSubContent.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuSubContent.js +6 -0
- package/dist/components/ContextMenu/ContextMenuSubTrigger.d.ts +6 -0
- package/dist/components/ContextMenu/ContextMenuSubTrigger.d.ts.map +1 -0
- package/dist/components/ContextMenu/ContextMenuSubTrigger.js +9 -0
- package/dist/components/DatePicker/Calendar.d.ts +9 -0
- package/dist/components/DatePicker/Calendar.d.ts.map +1 -0
- package/dist/components/DatePicker/Calendar.js +28 -0
- package/dist/components/DatePicker/DatePicker.d.ts +8 -0
- package/dist/components/DatePicker/DatePicker.d.ts.map +1 -0
- package/dist/components/DatePicker/DatePicker.js +79 -0
- package/dist/components/DatePicker/YearSelector.d.ts +7 -0
- package/dist/components/DatePicker/YearSelector.d.ts.map +1 -0
- package/dist/components/DatePicker/YearSelector.js +20 -0
- package/dist/components/Dialog/Dialog.d.ts +10 -0
- package/dist/components/Dialog/Dialog.d.ts.map +1 -0
- package/dist/components/Dialog/Dialog.js +14 -0
- package/dist/components/Dialog/DialogContent.d.ts +3 -0
- package/dist/components/Dialog/DialogContent.d.ts.map +1 -0
- package/dist/components/Dialog/DialogContent.js +13 -0
- package/dist/components/Dialog/DialogDescription.d.ts +3 -0
- package/dist/components/Dialog/DialogDescription.d.ts.map +1 -0
- package/dist/components/Dialog/DialogDescription.js +6 -0
- package/dist/components/Dialog/DialogFooter.d.ts +3 -0
- package/dist/components/Dialog/DialogFooter.d.ts.map +1 -0
- package/dist/components/Dialog/DialogFooter.js +3 -0
- package/dist/components/Dialog/DialogHeader.d.ts +3 -0
- package/dist/components/Dialog/DialogHeader.d.ts.map +1 -0
- package/dist/components/Dialog/DialogHeader.js +3 -0
- package/dist/components/Dialog/DialogOverlay.d.ts +3 -0
- package/dist/components/Dialog/DialogOverlay.d.ts.map +1 -0
- package/dist/components/Dialog/DialogOverlay.js +6 -0
- package/dist/components/Dialog/DialogTitle.d.ts +3 -0
- package/dist/components/Dialog/DialogTitle.d.ts.map +1 -0
- package/dist/components/Dialog/DialogTitle.js +6 -0
- package/dist/components/Drawer/Drawer.d.ts +14 -0
- package/dist/components/Drawer/Drawer.d.ts.map +1 -0
- package/dist/components/Drawer/Drawer.js +17 -0
- package/dist/components/Drawer/DrawerContent.d.ts +5 -0
- package/dist/components/Drawer/DrawerContent.d.ts.map +1 -0
- package/dist/components/Drawer/DrawerContent.js +10 -0
- package/dist/components/Drawer/DrawerDescription.d.ts +3 -0
- package/dist/components/Drawer/DrawerDescription.d.ts.map +1 -0
- package/dist/components/Drawer/DrawerDescription.js +6 -0
- package/dist/components/Drawer/DrawerFooter.d.ts +3 -0
- package/dist/components/Drawer/DrawerFooter.d.ts.map +1 -0
- package/dist/components/Drawer/DrawerFooter.js +3 -0
- package/dist/components/Drawer/DrawerHeader.d.ts +3 -0
- package/dist/components/Drawer/DrawerHeader.d.ts.map +1 -0
- package/dist/components/Drawer/DrawerHeader.js +3 -0
- package/dist/components/Drawer/DrawerTitle.d.ts +3 -0
- package/dist/components/Drawer/DrawerTitle.d.ts.map +1 -0
- package/dist/components/Drawer/DrawerTitle.js +6 -0
- package/dist/components/DropdownButton/DropdownButton.d.ts +3 -0
- package/dist/components/DropdownButton/DropdownButton.d.ts.map +1 -0
- package/dist/components/DropdownButton/DropdownButton.js +8 -0
- package/dist/components/DropdownMenu/DropdownMenu.d.ts +27 -0
- package/dist/components/DropdownMenu/DropdownMenu.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenu.js +26 -0
- package/dist/components/DropdownMenu/DropdownMenuCheckboxItem.d.ts +4 -0
- package/dist/components/DropdownMenu/DropdownMenuCheckboxItem.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuCheckboxItem.js +11 -0
- package/dist/components/DropdownMenu/DropdownMenuContent.d.ts +9 -0
- package/dist/components/DropdownMenu/DropdownMenuContent.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuContent.js +7 -0
- package/dist/components/DropdownMenu/DropdownMenuItem.d.ts +6 -0
- package/dist/components/DropdownMenu/DropdownMenuItem.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuItem.js +6 -0
- package/dist/components/DropdownMenu/DropdownMenuLabel.d.ts +6 -0
- package/dist/components/DropdownMenu/DropdownMenuLabel.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuLabel.js +6 -0
- package/dist/components/DropdownMenu/DropdownMenuRadioItem.d.ts +4 -0
- package/dist/components/DropdownMenu/DropdownMenuRadioItem.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuRadioItem.js +11 -0
- package/dist/components/DropdownMenu/DropdownMenuSeparator.d.ts +4 -0
- package/dist/components/DropdownMenu/DropdownMenuSeparator.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuSeparator.js +6 -0
- package/dist/components/DropdownMenu/DropdownMenuShortcut.d.ts +3 -0
- package/dist/components/DropdownMenu/DropdownMenuShortcut.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuShortcut.js +5 -0
- package/dist/components/DropdownMenu/DropdownMenuSubContent.d.ts +4 -0
- package/dist/components/DropdownMenu/DropdownMenuSubContent.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuSubContent.js +6 -0
- package/dist/components/DropdownMenu/DropdownMenuSubTrigger.d.ts +6 -0
- package/dist/components/DropdownMenu/DropdownMenuSubTrigger.d.ts.map +1 -0
- package/dist/components/DropdownMenu/DropdownMenuSubTrigger.js +9 -0
- package/dist/components/ErrorBoundary/ErrorBoundary.d.ts +5 -0
- package/dist/components/ErrorBoundary/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ErrorBoundary/ErrorBoundary.js +6 -0
- package/dist/components/ErrorFallback/ErrorFallback.d.ts +8 -0
- package/dist/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
- package/dist/components/ErrorFallback/ErrorFallback.js +16 -0
- package/dist/components/Form/BaseRadioField.d.ts +13 -0
- package/dist/components/Form/BaseRadioField.d.ts.map +1 -0
- package/dist/components/Form/BaseRadioField.js +27 -0
- package/dist/components/Form/BooleanField/BooleanField.d.ts +6 -0
- package/dist/components/Form/BooleanField/BooleanField.d.ts.map +1 -0
- package/dist/components/Form/BooleanField/BooleanField.js +10 -0
- package/dist/components/Form/BooleanField/BooleanFieldCheckbox.d.ts +9 -0
- package/dist/components/Form/BooleanField/BooleanFieldCheckbox.d.ts.map +1 -0
- package/dist/components/Form/BooleanField/BooleanFieldCheckbox.js +15 -0
- package/dist/components/Form/BooleanField/BooleanFieldRadio.d.ts +9 -0
- package/dist/components/Form/BooleanField/BooleanFieldRadio.d.ts.map +1 -0
- package/dist/components/Form/BooleanField/BooleanFieldRadio.js +31 -0
- package/dist/components/Form/DateField/DateField.d.ts +7 -0
- package/dist/components/Form/DateField/DateField.d.ts.map +1 -0
- package/dist/components/Form/DateField/DateField.js +40 -0
- package/dist/components/Form/DynamicField.d.ts +13 -0
- package/dist/components/Form/DynamicField.d.ts.map +1 -0
- package/dist/components/Form/DynamicField.js +21 -0
- package/dist/components/Form/ErrorMessage.d.ts +5 -0
- package/dist/components/Form/ErrorMessage.d.ts.map +1 -0
- package/dist/components/Form/ErrorMessage.js +5 -0
- package/dist/components/Form/FieldGroup/FieldGroup.d.ts +15 -0
- package/dist/components/Form/FieldGroup/FieldGroup.d.ts.map +1 -0
- package/dist/components/Form/FieldGroup/FieldGroup.js +9 -0
- package/dist/components/Form/FieldGroup/FieldGroupDescription.d.ts +5 -0
- package/dist/components/Form/FieldGroup/FieldGroupDescription.d.ts.map +1 -0
- package/dist/components/Form/FieldGroup/FieldGroupDescription.js +8 -0
- package/dist/components/Form/FieldGroup/FieldGroupRoot.d.ts +5 -0
- package/dist/components/Form/FieldGroup/FieldGroupRoot.d.ts.map +1 -0
- package/dist/components/Form/FieldGroup/FieldGroupRoot.js +2 -0
- package/dist/components/Form/FieldGroup/FieldGroupRow.d.ts +5 -0
- package/dist/components/Form/FieldGroup/FieldGroupRow.d.ts.map +1 -0
- package/dist/components/Form/FieldGroup/FieldGroupRow.js +2 -0
- package/dist/components/Form/FieldsComponent.d.ts +13 -0
- package/dist/components/Form/FieldsComponent.d.ts.map +1 -0
- package/dist/components/Form/FieldsComponent.js +13 -0
- package/dist/components/Form/Form.d.ts +18 -0
- package/dist/components/Form/Form.d.ts.map +1 -0
- package/dist/components/Form/Form.js +64 -0
- package/dist/components/Form/NumberField/NumberField.d.ts +7 -0
- package/dist/components/Form/NumberField/NumberField.d.ts.map +1 -0
- package/dist/components/Form/NumberField/NumberField.js +12 -0
- package/dist/components/Form/NumberField/NumberFieldInput.d.ts +9 -0
- package/dist/components/Form/NumberField/NumberFieldInput.d.ts.map +1 -0
- package/dist/components/Form/NumberField/NumberFieldInput.js +21 -0
- package/dist/components/Form/NumberField/NumberFieldRadio.d.ts +9 -0
- package/dist/components/Form/NumberField/NumberFieldRadio.d.ts.map +1 -0
- package/dist/components/Form/NumberField/NumberFieldRadio.js +19 -0
- package/dist/components/Form/NumberField/NumberFieldSlider.d.ts +9 -0
- package/dist/components/Form/NumberField/NumberFieldSlider.d.ts.map +1 -0
- package/dist/components/Form/NumberField/NumberFieldSlider.js +14 -0
- package/dist/components/Form/NumberRecordField.d.ts +7 -0
- package/dist/components/Form/NumberRecordField.d.ts.map +1 -0
- package/dist/components/Form/NumberRecordField.js +17 -0
- package/dist/components/Form/RecordArrayField.d.ts +23 -0
- package/dist/components/Form/RecordArrayField.d.ts.map +1 -0
- package/dist/components/Form/RecordArrayField.js +56 -0
- package/dist/components/Form/ScalarField.d.ts +8 -0
- package/dist/components/Form/ScalarField.d.ts.map +1 -0
- package/dist/components/Form/ScalarField.js +22 -0
- package/dist/components/Form/SetField/SetField.d.ts +7 -0
- package/dist/components/Form/SetField/SetField.d.ts.map +1 -0
- package/dist/components/Form/SetField/SetField.js +27 -0
- package/dist/components/Form/SetField/SetFieldListbox.d.ts +7 -0
- package/dist/components/Form/SetField/SetFieldListbox.d.ts.map +1 -0
- package/dist/components/Form/SetField/SetFieldListbox.js +16 -0
- package/dist/components/Form/SetField/SetFieldSelect.d.ts +7 -0
- package/dist/components/Form/SetField/SetFieldSelect.d.ts.map +1 -0
- package/dist/components/Form/SetField/SetFieldSelect.js +23 -0
- package/dist/components/Form/StaticField.d.ts +14 -0
- package/dist/components/Form/StaticField.d.ts.map +1 -0
- package/dist/components/Form/StaticField.js +17 -0
- package/dist/components/Form/StringField/StringField.d.ts +8 -0
- package/dist/components/Form/StringField/StringField.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringField.js +16 -0
- package/dist/components/Form/StringField/StringFieldInput.d.ts +6 -0
- package/dist/components/Form/StringField/StringFieldInput.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringFieldInput.js +12 -0
- package/dist/components/Form/StringField/StringFieldPassword.d.ts +6 -0
- package/dist/components/Form/StringField/StringFieldPassword.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringFieldPassword.js +19 -0
- package/dist/components/Form/StringField/StringFieldRadio.d.ts +9 -0
- package/dist/components/Form/StringField/StringFieldRadio.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringFieldRadio.js +5 -0
- package/dist/components/Form/StringField/StringFieldSelect.d.ts +9 -0
- package/dist/components/Form/StringField/StringFieldSelect.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringFieldSelect.js +16 -0
- package/dist/components/Form/StringField/StringFieldTextArea.d.ts +6 -0
- package/dist/components/Form/StringField/StringFieldTextArea.d.ts.map +1 -0
- package/dist/components/Form/StringField/StringFieldTextArea.js +12 -0
- package/dist/components/Form/types.d.ts +23 -0
- package/dist/components/Form/types.d.ts.map +1 -0
- package/dist/components/Form/types.js +1 -0
- package/dist/components/Form/utils.d.ts +10 -0
- package/dist/components/Form/utils.d.ts.map +1 -0
- package/dist/components/Form/utils.js +44 -0
- package/dist/components/Heading/Heading.d.ts +8 -0
- package/dist/components/Heading/Heading.d.ts.map +1 -0
- package/dist/components/Heading/Heading.js +18 -0
- package/dist/components/HoverCard/HoverCard.d.ts +6 -0
- package/dist/components/HoverCard/HoverCard.d.ts.map +1 -0
- package/dist/components/HoverCard/HoverCard.js +6 -0
- package/dist/components/HoverCard/HoverCardContent.d.ts +3 -0
- package/dist/components/HoverCard/HoverCardContent.d.ts.map +1 -0
- package/dist/components/HoverCard/HoverCardContent.js +6 -0
- package/dist/components/Input/Input.d.ts +4 -0
- package/dist/components/Input/Input.d.ts.map +1 -0
- package/dist/components/Input/Input.js +5 -0
- package/dist/components/Label/Label.d.ts +6 -0
- package/dist/components/Label/Label.d.ts.map +1 -0
- package/dist/components/Label/Label.js +8 -0
- package/dist/components/LanguageToggle/LanguageToggle.d.ts +12 -0
- package/dist/components/LanguageToggle/LanguageToggle.d.ts.map +1 -0
- package/dist/components/LanguageToggle/LanguageToggle.js +13 -0
- package/dist/components/LegacyDropdown/LegacyDropdown.d.ts +21 -0
- package/dist/components/LegacyDropdown/LegacyDropdown.d.ts.map +1 -0
- package/dist/components/LegacyDropdown/LegacyDropdown.js +17 -0
- package/dist/components/LegacyModal/LegacyModal.d.ts +13 -0
- package/dist/components/LegacyModal/LegacyModal.d.ts.map +1 -0
- package/dist/components/LegacyModal/LegacyModal.js +25 -0
- package/dist/components/LegacySelectDropdown/LegacySelectDropdown.d.ts +21 -0
- package/dist/components/LegacySelectDropdown/LegacySelectDropdown.d.ts.map +1 -0
- package/dist/components/LegacySelectDropdown/LegacySelectDropdown.js +18 -0
- package/dist/components/LegacySlider/LegacySlider.d.ts +11 -0
- package/dist/components/LegacySlider/LegacySlider.d.ts.map +1 -0
- package/dist/components/LegacySlider/LegacySlider.js +24 -0
- package/dist/components/LegacyStepper/LegacyStepper.d.ts +15 -0
- package/dist/components/LegacyStepper/LegacyStepper.d.ts.map +1 -0
- package/dist/components/LegacyStepper/LegacyStepper.js +46 -0
- package/dist/components/LegacyTable/LegacyClientTable.d.ts +5 -0
- package/dist/components/LegacyTable/LegacyClientTable.d.ts.map +1 -0
- package/dist/components/LegacyTable/LegacyClientTable.js +29 -0
- package/dist/components/LegacyTable/LegacyTable.d.ts +29 -0
- package/dist/components/LegacyTable/LegacyTable.d.ts.map +1 -0
- package/dist/components/LegacyTable/LegacyTable.js +54 -0
- package/dist/components/LegacyTable/LegacyTableColumnHeader.d.ts +16 -0
- package/dist/components/LegacyTable/LegacyTableColumnHeader.d.ts.map +1 -0
- package/dist/components/LegacyTable/LegacyTableColumnHeader.js +20 -0
- package/dist/components/LineGraph/LineGraph.d.ts +28 -0
- package/dist/components/LineGraph/LineGraph.d.ts.map +1 -0
- package/dist/components/LineGraph/LineGraph.js +42 -0
- package/dist/components/MenuBar/MenuBar.d.ts +28 -0
- package/dist/components/MenuBar/MenuBar.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBar.js +29 -0
- package/dist/components/MenuBar/MenuBarCheckboxItem.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarCheckboxItem.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarCheckboxItem.js +11 -0
- package/dist/components/MenuBar/MenuBarContent.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarContent.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarContent.js +7 -0
- package/dist/components/MenuBar/MenuBarItem.d.ts +5 -0
- package/dist/components/MenuBar/MenuBarItem.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarItem.js +6 -0
- package/dist/components/MenuBar/MenuBarLabel.d.ts +5 -0
- package/dist/components/MenuBar/MenuBarLabel.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarLabel.js +6 -0
- package/dist/components/MenuBar/MenuBarRadioItem.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarRadioItem.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarRadioItem.js +11 -0
- package/dist/components/MenuBar/MenuBarRoot.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarRoot.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarRoot.js +6 -0
- package/dist/components/MenuBar/MenuBarSeparator.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarSeparator.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarSeparator.js +6 -0
- package/dist/components/MenuBar/MenuBarShortcut.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarShortcut.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarShortcut.js +5 -0
- package/dist/components/MenuBar/MenuBarSubContent.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarSubContent.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarSubContent.js +6 -0
- package/dist/components/MenuBar/MenuBarSubTrigger.d.ts +5 -0
- package/dist/components/MenuBar/MenuBarSubTrigger.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarSubTrigger.js +9 -0
- package/dist/components/MenuBar/MenuBarTrigger.d.ts +3 -0
- package/dist/components/MenuBar/MenuBarTrigger.d.ts.map +1 -0
- package/dist/components/MenuBar/MenuBarTrigger.js +6 -0
- package/dist/components/NotificationHub/NotificationHub.d.ts +8 -0
- package/dist/components/NotificationHub/NotificationHub.d.ts.map +1 -0
- package/dist/components/NotificationHub/NotificationHub.js +28 -0
- package/dist/components/NotificationHub/NotificationIcon.d.ts +7 -0
- package/dist/components/NotificationHub/NotificationIcon.d.ts.map +1 -0
- package/dist/components/NotificationHub/NotificationIcon.js +15 -0
- package/dist/components/Pagination/Pagination.d.ts +845 -0
- package/dist/components/Pagination/Pagination.d.ts.map +1 -0
- package/dist/components/Pagination/Pagination.js +15 -0
- package/dist/components/Pagination/PaginationContent.d.ts +3 -0
- package/dist/components/Pagination/PaginationContent.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationContent.js +3 -0
- package/dist/components/Pagination/PaginationEllipsis.d.ts +3 -0
- package/dist/components/Pagination/PaginationEllipsis.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationEllipsis.js +6 -0
- package/dist/components/Pagination/PaginationItem.d.ts +3 -0
- package/dist/components/Pagination/PaginationItem.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationItem.js +2 -0
- package/dist/components/Pagination/PaginationLink.d.ts +8 -0
- package/dist/components/Pagination/PaginationLink.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationLink.js +7 -0
- package/dist/components/Pagination/PaginationNext.d.ts +4 -0
- package/dist/components/Pagination/PaginationNext.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationNext.js +11 -0
- package/dist/components/Pagination/PaginationPrevious.d.ts +4 -0
- package/dist/components/Pagination/PaginationPrevious.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationPrevious.js +11 -0
- package/dist/components/Pagination/PaginationRoot.d.ts +3 -0
- package/dist/components/Pagination/PaginationRoot.d.ts.map +1 -0
- package/dist/components/Pagination/PaginationRoot.js +3 -0
- package/dist/components/Popover/Popover.d.ts +6 -0
- package/dist/components/Popover/Popover.d.ts.map +1 -0
- package/dist/components/Popover/Popover.js +6 -0
- package/dist/components/Popover/PopoverContent.d.ts +19 -0
- package/dist/components/Popover/PopoverContent.d.ts.map +1 -0
- package/dist/components/Popover/PopoverContent.js +7 -0
- package/dist/components/Progress/Progress.d.ts +4 -0
- package/dist/components/Progress/Progress.d.ts.map +1 -0
- package/dist/components/Progress/Progress.js +7 -0
- package/dist/components/RadioGroup/RadioGroup.d.ts +8 -0
- package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -0
- package/dist/components/RadioGroup/RadioGroup.js +10 -0
- package/dist/components/RadioGroup/RadioGroupItem.d.ts +4 -0
- package/dist/components/RadioGroup/RadioGroupItem.d.ts.map +1 -0
- package/dist/components/RadioGroup/RadioGroupItem.js +9 -0
- package/dist/components/Resizable/Resizable.d.ts +15 -0
- package/dist/components/Resizable/Resizable.d.ts.map +1 -0
- package/dist/components/Resizable/Resizable.js +11 -0
- package/dist/components/Resizable/ResizableHandle.d.ts +7 -0
- package/dist/components/Resizable/ResizableHandle.d.ts.map +1 -0
- package/dist/components/Resizable/ResizableHandle.js +6 -0
- package/dist/components/Resizable/ResizablePanelGroup.d.ts +5 -0
- package/dist/components/Resizable/ResizablePanelGroup.d.ts.map +1 -0
- package/dist/components/Resizable/ResizablePanelGroup.js +4 -0
- package/dist/components/ScrollArea/ScrollArea.d.ts +3 -0
- package/dist/components/ScrollArea/ScrollArea.d.ts.map +1 -0
- package/dist/components/ScrollArea/ScrollArea.js +10 -0
- package/dist/components/ScrollArea/ScrollBar.d.ts +3 -0
- package/dist/components/ScrollArea/ScrollBar.d.ts.map +1 -0
- package/dist/components/ScrollArea/ScrollBar.js +7 -0
- package/dist/components/SearchBar/SearchBar.d.ts +23 -0
- package/dist/components/SearchBar/SearchBar.d.ts.map +1 -0
- package/dist/components/SearchBar/SearchBar.js +13 -0
- package/dist/components/Select/Select.d.ts +14 -0
- package/dist/components/Select/Select.d.ts.map +1 -0
- package/dist/components/Select/Select.js +19 -0
- package/dist/components/Select/SelectContent.d.ts +4 -0
- package/dist/components/Select/SelectContent.d.ts.map +1 -0
- package/dist/components/Select/SelectContent.js +14 -0
- package/dist/components/Select/SelectItem.d.ts +4 -0
- package/dist/components/Select/SelectItem.d.ts.map +1 -0
- package/dist/components/Select/SelectItem.js +11 -0
- package/dist/components/Select/SelectLabel.d.ts +4 -0
- package/dist/components/Select/SelectLabel.d.ts.map +1 -0
- package/dist/components/Select/SelectLabel.js +6 -0
- package/dist/components/Select/SelectScrollDownButton.d.ts +4 -0
- package/dist/components/Select/SelectScrollDownButton.d.ts.map +1 -0
- package/dist/components/Select/SelectScrollDownButton.js +8 -0
- package/dist/components/Select/SelectScrollUpButton.d.ts +4 -0
- package/dist/components/Select/SelectScrollUpButton.d.ts.map +1 -0
- package/dist/components/Select/SelectScrollUpButton.js +8 -0
- package/dist/components/Select/SelectSeparator.d.ts +4 -0
- package/dist/components/Select/SelectSeparator.d.ts.map +1 -0
- package/dist/components/Select/SelectSeparator.js +6 -0
- package/dist/components/Select/SelectTrigger.d.ts +4 -0
- package/dist/components/Select/SelectTrigger.d.ts.map +1 -0
- package/dist/components/Select/SelectTrigger.js +7 -0
- package/dist/components/Separator/Separator.d.ts +4 -0
- package/dist/components/Separator/Separator.d.ts.map +1 -0
- package/dist/components/Separator/Separator.js +6 -0
- package/dist/components/Sheet/Sheet.d.ts +15 -0
- package/dist/components/Sheet/Sheet.d.ts.map +1 -0
- package/dist/components/Sheet/Sheet.js +18 -0
- package/dist/components/Sheet/SheetContent.d.ts +11 -0
- package/dist/components/Sheet/SheetContent.d.ts.map +1 -0
- package/dist/components/Sheet/SheetContent.js +27 -0
- package/dist/components/Sheet/SheetDescription.d.ts +3 -0
- package/dist/components/Sheet/SheetDescription.d.ts.map +1 -0
- package/dist/components/Sheet/SheetDescription.js +6 -0
- package/dist/components/Sheet/SheetFooter.d.ts +3 -0
- package/dist/components/Sheet/SheetFooter.d.ts.map +1 -0
- package/dist/components/Sheet/SheetFooter.js +3 -0
- package/dist/components/Sheet/SheetHeader.d.ts +3 -0
- package/dist/components/Sheet/SheetHeader.d.ts.map +1 -0
- package/dist/components/Sheet/SheetHeader.js +3 -0
- package/dist/components/Sheet/SheetOverlay.d.ts +3 -0
- package/dist/components/Sheet/SheetOverlay.d.ts.map +1 -0
- package/dist/components/Sheet/SheetOverlay.js +6 -0
- package/dist/components/Sheet/SheetTitle.d.ts +3 -0
- package/dist/components/Sheet/SheetTitle.d.ts.map +1 -0
- package/dist/components/Sheet/SheetTitle.js +6 -0
- package/dist/components/Slider/Slider.d.ts +3 -0
- package/dist/components/Slider/Slider.d.ts.map +1 -0
- package/dist/components/Slider/Slider.js +9 -0
- package/dist/components/Spinner/Spinner.d.ts +4 -0
- package/dist/components/Spinner/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner/Spinner.js +13 -0
- package/dist/components/SpinnerIcon/SpinnerIcon.d.ts +3 -0
- package/dist/components/SpinnerIcon/SpinnerIcon.d.ts.map +1 -0
- package/dist/components/SpinnerIcon/SpinnerIcon.js +4 -0
- package/dist/components/Switch/Switch.d.ts +4 -0
- package/dist/components/Switch/Switch.d.ts.map +1 -0
- package/dist/components/Switch/Switch.js +7 -0
- package/dist/components/Table/Table.d.ts +11 -0
- package/dist/components/Table/Table.d.ts.map +1 -0
- package/dist/components/Table/Table.js +17 -0
- package/dist/components/Table/TableBody.d.ts +3 -0
- package/dist/components/Table/TableBody.d.ts.map +1 -0
- package/dist/components/Table/TableBody.js +5 -0
- package/dist/components/Table/TableCaption.d.ts +3 -0
- package/dist/components/Table/TableCaption.d.ts.map +1 -0
- package/dist/components/Table/TableCaption.js +5 -0
- package/dist/components/Table/TableCell.d.ts +3 -0
- package/dist/components/Table/TableCell.d.ts.map +1 -0
- package/dist/components/Table/TableCell.js +5 -0
- package/dist/components/Table/TableFooter.d.ts +3 -0
- package/dist/components/Table/TableFooter.d.ts.map +1 -0
- package/dist/components/Table/TableFooter.js +5 -0
- package/dist/components/Table/TableHead.d.ts +3 -0
- package/dist/components/Table/TableHead.d.ts.map +1 -0
- package/dist/components/Table/TableHead.js +5 -0
- package/dist/components/Table/TableHeader.d.ts +3 -0
- package/dist/components/Table/TableHeader.d.ts.map +1 -0
- package/dist/components/Table/TableHeader.js +5 -0
- package/dist/components/Table/TableRoot.d.ts +3 -0
- package/dist/components/Table/TableRoot.d.ts.map +1 -0
- package/dist/components/Table/TableRoot.js +6 -0
- package/dist/components/Table/TableRow.d.ts +3 -0
- package/dist/components/Table/TableRow.d.ts.map +1 -0
- package/dist/components/Table/TableRow.js +5 -0
- package/dist/components/Tabs/Tabs.d.ts +7 -0
- package/dist/components/Tabs/Tabs.d.ts.map +1 -0
- package/dist/components/Tabs/Tabs.js +9 -0
- package/dist/components/Tabs/TabsContent.d.ts +4 -0
- package/dist/components/Tabs/TabsContent.d.ts.map +1 -0
- package/dist/components/Tabs/TabsContent.js +6 -0
- package/dist/components/Tabs/TabsList.d.ts +4 -0
- package/dist/components/Tabs/TabsList.d.ts.map +1 -0
- package/dist/components/Tabs/TabsList.js +6 -0
- package/dist/components/Tabs/TabsRoot.d.ts +3 -0
- package/dist/components/Tabs/TabsRoot.d.ts.map +1 -0
- package/dist/components/Tabs/TabsRoot.js +5 -0
- package/dist/components/Tabs/TabsTrigger.d.ts +4 -0
- package/dist/components/Tabs/TabsTrigger.d.ts.map +1 -0
- package/dist/components/Tabs/TabsTrigger.js +6 -0
- package/dist/components/TextArea/TextArea.d.ts +4 -0
- package/dist/components/TextArea/TextArea.d.ts.map +1 -0
- package/dist/components/TextArea/TextArea.js +5 -0
- package/dist/components/ThemeToggle/ThemeToggle.d.ts +5 -0
- package/dist/components/ThemeToggle/ThemeToggle.d.ts.map +1 -0
- package/dist/components/ThemeToggle/ThemeToggle.js +16 -0
- package/dist/components/Tooltip/Tooltip.d.ts +6 -0
- package/dist/components/Tooltip/Tooltip.d.ts.map +1 -0
- package/dist/components/Tooltip/Tooltip.js +7 -0
- package/dist/components/Tooltip/TooltipContent.d.ts +15 -0
- package/dist/components/Tooltip/TooltipContent.d.ts.map +1 -0
- package/dist/components/Tooltip/TooltipContent.js +6 -0
- package/dist/components/Tooltip/TooltipRoot.d.ts +11 -0
- package/dist/components/Tooltip/TooltipRoot.d.ts.map +1 -0
- package/dist/components/Tooltip/TooltipRoot.js +6 -0
- package/dist/components/Tooltip/TooltipTrigger.d.ts +5 -0
- package/dist/components/Tooltip/TooltipTrigger.d.ts.map +1 -0
- package/dist/components/Tooltip/TooltipTrigger.js +7 -0
- package/dist/components.d.ts +55 -0
- package/dist/components.d.ts.map +1 -0
- package/dist/components.js +54 -0
- package/dist/context/LegacyStepperContext.d.ts +7 -0
- package/dist/context/LegacyStepperContext.d.ts.map +1 -0
- package/dist/context/LegacyStepperContext.js +3 -0
- package/dist/hooks/useDownload.d.ts +13 -0
- package/dist/hooks/useDownload.d.ts.map +1 -0
- package/dist/hooks/useDownload.js +42 -0
- package/dist/hooks/useEventCallback.d.ts +2 -0
- package/dist/hooks/useEventCallback.d.ts.map +1 -0
- package/dist/hooks/useEventCallback.js +11 -0
- package/dist/hooks/useEventListener.d.ts +7 -0
- package/dist/hooks/useEventListener.d.ts.map +1 -0
- package/dist/hooks/useEventListener.js +23 -0
- package/dist/hooks/useInterval.d.ts +2 -0
- package/dist/hooks/useInterval.d.ts.map +1 -0
- package/dist/hooks/useInterval.js +19 -0
- package/dist/hooks/useIsomorphicLayoutEffect.d.ts +3 -0
- package/dist/hooks/useIsomorphicLayoutEffect.d.ts.map +1 -0
- package/dist/hooks/useIsomorphicLayoutEffect.js +3 -0
- package/dist/hooks/useLegacyStepper.d.ts +7 -0
- package/dist/hooks/useLegacyStepper.d.ts.map +1 -0
- package/dist/hooks/useLegacyStepper.js +6 -0
- package/dist/hooks/useMediaQuery.d.ts +11 -0
- package/dist/hooks/useMediaQuery.d.ts.map +1 -0
- package/dist/hooks/useMediaQuery.js +34 -0
- package/dist/hooks/useNotificationsStore.d.ts +14 -0
- package/dist/hooks/useNotificationsStore.d.ts.map +1 -0
- package/dist/hooks/useNotificationsStore.js +14 -0
- package/dist/hooks/useOnClickOutside.d.ts +5 -0
- package/dist/hooks/useOnClickOutside.d.ts.map +1 -0
- package/dist/hooks/useOnClickOutside.js +12 -0
- package/dist/hooks/useSessionStorage.d.ts +38 -0
- package/dist/hooks/useSessionStorage.d.ts.map +1 -0
- package/dist/hooks/useSessionStorage.js +99 -0
- package/dist/hooks/useTheme.d.ts +19 -0
- package/dist/hooks/useTheme.d.ts.map +1 -0
- package/dist/hooks/useTheme.js +60 -0
- package/dist/hooks/useWindowSize.d.ts +6 -0
- package/dist/hooks/useWindowSize.d.ts.map +1 -0
- package/dist/hooks/useWindowSize.js +21 -0
- package/dist/hooks.d.ts +13 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +12 -0
- package/dist/i18n.d.ts +13 -14
- package/dist/i18n.d.ts.map +1 -0
- package/dist/i18n.js +46 -211
- package/dist/testing/mocks.d.ts +16 -0
- package/dist/testing/mocks.d.ts.map +1 -0
- package/dist/testing/mocks.js +46 -0
- package/dist/testing/setup-tests.d.ts +2 -0
- package/dist/testing/setup-tests.d.ts.map +1 -0
- package/dist/testing/setup-tests.js +8 -0
- package/dist/translations/libui.json +154 -0
- package/dist/utils.d.ts +4 -6
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +8 -9
- package/package.json +13 -10
- package/src/assets/libui-logo.svg +113 -0
- package/src/components/Accordion/Accordion.tsx +10 -0
- package/src/components/Accordion/AccordionContent.tsx +20 -0
- package/src/components/Accordion/AccordionItem.tsx +12 -0
- package/src/components/Accordion/AccordionRoot.tsx +10 -0
- package/src/components/Accordion/AccordionTrigger.tsx +27 -0
- package/src/components/AlertDialog/AlertDialog.tsx +22 -0
- package/src/components/AlertDialog/AlertDialogAction.tsx +13 -0
- package/src/components/AlertDialog/AlertDialogCancel.tsx +15 -0
- package/src/components/AlertDialog/AlertDialogContent.tsx +25 -0
- package/src/components/AlertDialog/AlertDialogDescription.tsx +12 -0
- package/src/components/AlertDialog/AlertDialogFooter.tsx +7 -0
- package/src/components/AlertDialog/AlertDialogHeader.tsx +7 -0
- package/src/components/AlertDialog/AlertDialogOverlay.tsx +21 -0
- package/src/components/AlertDialog/AlertDialogTitle.tsx +12 -0
- package/src/components/ArrowToggle/ArrowToggle.tsx +63 -0
- package/src/components/Avatar/Avatar.tsx +8 -0
- package/src/components/Avatar/AvatarFallback.tsx +18 -0
- package/src/components/Avatar/AvatarImage.tsx +12 -0
- package/src/components/Avatar/AvatarRoot.tsx +19 -0
- package/src/components/Badge/Badge.tsx +30 -0
- package/src/components/Breadcrumb/Breadcrumb.tsx +16 -0
- package/src/components/Breadcrumb/BreadcrumbEllipsis.tsx +16 -0
- package/src/components/Breadcrumb/BreadcrumbItem.tsx +9 -0
- package/src/components/Breadcrumb/BreadcrumbLink.tsx +15 -0
- package/src/components/Breadcrumb/BreadcrumbList.tsx +18 -0
- package/src/components/Breadcrumb/BreadcrumbPage.tsx +18 -0
- package/src/components/Breadcrumb/BreadcrumbRoot.tsx +10 -0
- package/src/components/Breadcrumb/BreadcrumbSeparator.tsx +11 -0
- package/src/components/Button/Button.tsx +61 -0
- package/src/components/Card/Card.tsx +37 -0
- package/src/components/Checkbox/Checkbox.tsx +27 -0
- package/src/components/Collapsible/Collapsible.tsx +8 -0
- package/src/components/Collapsible/CollapsibleRoot.tsx +10 -0
- package/src/components/Command/Command.tsx +41 -0
- package/src/components/Command/CommandEmpty.tsx +10 -0
- package/src/components/Command/CommandGroup.tsx +21 -0
- package/src/components/Command/CommandInput.tsx +26 -0
- package/src/components/Command/CommandItem.tsx +21 -0
- package/src/components/Command/CommandList.tsx +18 -0
- package/src/components/Command/CommandSeparator.tsx +12 -0
- package/src/components/Command/CommandShortcut.tsx +7 -0
- package/src/components/ContextMenu/ContextMenu.tsx +28 -0
- package/src/components/ContextMenu/ContextMenuCheckboxItem.tsx +30 -0
- package/src/components/ContextMenu/ContextMenuContent.tsx +23 -0
- package/src/components/ContextMenu/ContextMenuItem.tsx +24 -0
- package/src/components/ContextMenu/ContextMenuLabel.tsx +20 -0
- package/src/components/ContextMenu/ContextMenuRadioItem.tsx +29 -0
- package/src/components/ContextMenu/ContextMenuSeparator.tsx +12 -0
- package/src/components/ContextMenu/ContextMenuShortcut.tsx +7 -0
- package/src/components/ContextMenu/ContextMenuSubContent.tsx +21 -0
- package/src/components/ContextMenu/ContextMenuSubTrigger.tsx +28 -0
- package/src/components/DatePicker/Calendar.tsx +64 -0
- package/src/components/DatePicker/DatePicker.tsx +156 -0
- package/src/components/DatePicker/YearSelector.tsx +49 -0
- package/src/components/Dialog/Dialog.tsx +16 -0
- package/src/components/Dialog/DialogContent.tsx +31 -0
- package/src/components/Dialog/DialogDescription.tsx +12 -0
- package/src/components/Dialog/DialogFooter.tsx +7 -0
- package/src/components/Dialog/DialogHeader.tsx +7 -0
- package/src/components/Dialog/DialogOverlay.tsx +21 -0
- package/src/components/Dialog/DialogTitle.tsx +12 -0
- package/src/components/Drawer/Drawer.tsx +23 -0
- package/src/components/Drawer/DrawerContent.tsx +27 -0
- package/src/components/Drawer/DrawerDescription.tsx +14 -0
- package/src/components/Drawer/DrawerFooter.tsx +7 -0
- package/src/components/Drawer/DrawerHeader.tsx +7 -0
- package/src/components/Drawer/DrawerTitle.tsx +18 -0
- package/src/components/DropdownButton/DropdownButton.tsx +25 -0
- package/src/components/DropdownMenu/DropdownMenu.tsx +28 -0
- package/src/components/DropdownMenu/DropdownMenuCheckboxItem.tsx +30 -0
- package/src/components/DropdownMenu/DropdownMenuContent.tsx +29 -0
- package/src/components/DropdownMenu/DropdownMenuItem.tsx +24 -0
- package/src/components/DropdownMenu/DropdownMenuLabel.tsx +20 -0
- package/src/components/DropdownMenu/DropdownMenuRadioItem.tsx +29 -0
- package/src/components/DropdownMenu/DropdownMenuSeparator.tsx +12 -0
- package/src/components/DropdownMenu/DropdownMenuShortcut.tsx +7 -0
- package/src/components/DropdownMenu/DropdownMenuSubContent.tsx +21 -0
- package/src/components/DropdownMenu/DropdownMenuSubTrigger.tsx +28 -0
- package/src/components/ErrorBoundary/ErrorBoundary.tsx +9 -0
- package/src/components/ErrorFallback/ErrorFallback.tsx +34 -0
- package/src/components/Form/BaseRadioField.tsx +68 -0
- package/src/components/Form/BooleanField/BooleanField.tsx +15 -0
- package/src/components/Form/BooleanField/BooleanFieldCheckbox.tsx +35 -0
- package/src/components/Form/BooleanField/BooleanFieldRadio.tsx +59 -0
- package/src/components/Form/DateField/DateField.tsx +68 -0
- package/src/components/Form/DynamicField.tsx +45 -0
- package/src/components/Form/ErrorMessage.tsx +11 -0
- package/src/components/Form/FieldGroup/FieldGroup.tsx +10 -0
- package/src/components/Form/FieldGroup/FieldGroupDescription.tsx +17 -0
- package/src/components/Form/FieldGroup/FieldGroupRoot.tsx +5 -0
- package/src/components/Form/FieldGroup/FieldGroupRow.tsx +5 -0
- package/src/components/Form/FieldsComponent.tsx +27 -0
- package/src/components/Form/Form.tsx +145 -0
- package/src/components/Form/NumberField/NumberField.tsx +17 -0
- package/src/components/Form/NumberField/NumberFieldInput.tsx +44 -0
- package/src/components/Form/NumberField/NumberFieldRadio.tsx +58 -0
- package/src/components/Form/NumberField/NumberFieldSlider.tsx +41 -0
- package/src/components/Form/NumberRecordField.tsx +60 -0
- package/src/components/Form/RecordArrayField.tsx +99 -0
- package/src/components/Form/ScalarField.tsx +39 -0
- package/src/components/Form/SetField/SetField.tsx +37 -0
- package/src/components/Form/SetField/SetFieldListbox.tsx +45 -0
- package/src/components/Form/SetField/SetFieldSelect.tsx +64 -0
- package/src/components/Form/StaticField.tsx +83 -0
- package/src/components/Form/StringField/StringField.tsx +25 -0
- package/src/components/Form/StringField/StringFieldInput.tsx +24 -0
- package/src/components/Form/StringField/StringFieldPassword.tsx +42 -0
- package/src/components/Form/StringField/StringFieldRadio.tsx +16 -0
- package/src/components/Form/StringField/StringFieldSelect.tsx +45 -0
- package/src/components/Form/StringField/StringFieldTextArea.tsx +24 -0
- package/src/components/Form/types.ts +26 -0
- package/src/components/Form/utils.ts +53 -0
- package/src/components/Heading/Heading.tsx +26 -0
- package/src/components/HoverCard/HoverCard.tsx +8 -0
- package/src/components/HoverCard/HoverCardContent.tsx +23 -0
- package/src/components/Input/Input.tsx +21 -0
- package/src/components/Label/Label.tsx +17 -0
- package/src/components/LanguageToggle/LanguageToggle.tsx +41 -0
- package/src/components/LegacyDropdown/LegacyDropdown.tsx +79 -0
- package/src/components/LegacyModal/LegacyModal.tsx +77 -0
- package/src/components/LegacySelectDropdown/LegacySelectDropdown.tsx +87 -0
- package/src/components/LegacySlider/LegacySlider.tsx +67 -0
- package/src/components/LegacyStepper/LegacyStepper.tsx +91 -0
- package/src/components/LegacyTable/LegacyClientTable.tsx +55 -0
- package/src/components/LegacyTable/LegacyTable.tsx +118 -0
- package/src/components/LegacyTable/LegacyTableColumnHeader.tsx +71 -0
- package/src/components/LineGraph/LineGraph.tsx +133 -0
- package/src/components/MenuBar/MenuBar.tsx +31 -0
- package/src/components/MenuBar/MenuBarCheckboxItem.tsx +30 -0
- package/src/components/MenuBar/MenuBarContent.tsx +25 -0
- package/src/components/MenuBar/MenuBarItem.tsx +24 -0
- package/src/components/MenuBar/MenuBarLabel.tsx +14 -0
- package/src/components/MenuBar/MenuBarRadioItem.tsx +29 -0
- package/src/components/MenuBar/MenuBarRoot.tsx +17 -0
- package/src/components/MenuBar/MenuBarSeparator.tsx +12 -0
- package/src/components/MenuBar/MenuBarShortcut.tsx +7 -0
- package/src/components/MenuBar/MenuBarSubContent.tsx +21 -0
- package/src/components/MenuBar/MenuBarSubTrigger.tsx +28 -0
- package/src/components/MenuBar/MenuBarTrigger.tsx +20 -0
- package/src/components/NotificationHub/NotificationHub.tsx +70 -0
- package/src/components/NotificationHub/NotificationIcon.tsx +22 -0
- package/src/components/Pagination/Pagination.tsx +16 -0
- package/src/components/Pagination/PaginationContent.tsx +7 -0
- package/src/components/Pagination/PaginationEllipsis.tsx +12 -0
- package/src/components/Pagination/PaginationItem.tsx +5 -0
- package/src/components/Pagination/PaginationLink.tsx +29 -0
- package/src/components/Pagination/PaginationNext.tsx +17 -0
- package/src/components/Pagination/PaginationPrevious.tsx +17 -0
- package/src/components/Pagination/PaginationRoot.tsx +12 -0
- package/src/components/Popover/Popover.tsx +8 -0
- package/src/components/Popover/PopoverContent.tsx +47 -0
- package/src/components/Progress/Progress.tsx +23 -0
- package/src/components/RadioGroup/RadioGroup.tsx +23 -0
- package/src/components/RadioGroup/RadioGroupItem.tsx +29 -0
- package/src/components/Resizable/Resizable.tsx +22 -0
- package/src/components/Resizable/ResizableHandle.tsx +26 -0
- package/src/components/Resizable/ResizablePanelGroup.tsx +14 -0
- package/src/components/ScrollArea/ScrollArea.tsx +18 -0
- package/src/components/ScrollArea/ScrollBar.tsx +26 -0
- package/src/components/SearchBar/SearchBar.tsx +49 -0
- package/src/components/Select/Select.tsx +21 -0
- package/src/components/Select/SelectContent.tsx +40 -0
- package/src/components/Select/SelectItem.tsx +29 -0
- package/src/components/Select/SelectLabel.tsx +12 -0
- package/src/components/Select/SelectScrollDownButton.tsx +21 -0
- package/src/components/Select/SelectScrollUpButton.tsx +21 -0
- package/src/components/Select/SelectSeparator.tsx +12 -0
- package/src/components/Select/SelectTrigger.tsx +16 -0
- package/src/components/Separator/Separator.tsx +25 -0
- package/src/components/Sheet/Sheet.tsx +20 -0
- package/src/components/Sheet/SheetContent.tsx +46 -0
- package/src/components/Sheet/SheetDescription.tsx +12 -0
- package/src/components/Sheet/SheetFooter.tsx +7 -0
- package/src/components/Sheet/SheetHeader.tsx +7 -0
- package/src/components/Sheet/SheetOverlay.tsx +21 -0
- package/src/components/Sheet/SheetTitle.tsx +12 -0
- package/src/components/Slider/Slider.tsx +22 -0
- package/src/components/Spinner/Spinner.tsx +22 -0
- package/src/components/SpinnerIcon/SpinnerIcon.tsx +21 -0
- package/src/components/Switch/Switch.tsx +27 -0
- package/src/components/Table/Table.tsx +18 -0
- package/src/components/Table/TableBody.tsx +9 -0
- package/src/components/Table/TableCaption.tsx +9 -0
- package/src/components/Table/TableCell.tsx +9 -0
- package/src/components/Table/TableFooter.tsx +15 -0
- package/src/components/Table/TableHead.tsx +18 -0
- package/src/components/Table/TableHeader.tsx +9 -0
- package/src/components/Table/TableRoot.tsx +14 -0
- package/src/components/Table/TableRow.tsx +15 -0
- package/src/components/Tabs/Tabs.tsx +10 -0
- package/src/components/Tabs/TabsContent.tsx +21 -0
- package/src/components/Tabs/TabsList.tsx +21 -0
- package/src/components/Tabs/TabsRoot.tsx +9 -0
- package/src/components/Tabs/TabsTrigger.tsx +21 -0
- package/src/components/TextArea/TextArea.tsx +23 -0
- package/src/components/ThemeToggle/ThemeToggle.tsx +31 -0
- package/src/components/Tooltip/Tooltip.tsx +8 -0
- package/src/components/Tooltip/TooltipContent.tsx +35 -0
- package/src/components/Tooltip/TooltipRoot.tsx +20 -0
- package/src/components/Tooltip/TooltipTrigger.tsx +17 -0
- package/src/components.ts +54 -0
- package/src/context/LegacyStepperContext.tsx +7 -0
- package/src/hooks/useDownload.ts +61 -0
- package/src/hooks/useEventCallback.ts +15 -0
- package/src/hooks/useEventListener.ts +73 -0
- package/src/hooks/useInterval.ts +25 -0
- package/src/hooks/useIsomorphicLayoutEffect.ts +5 -0
- package/src/hooks/useLegacyStepper.ts +8 -0
- package/src/hooks/useMediaQuery.ts +43 -0
- package/src/hooks/useNotificationsStore.ts +29 -0
- package/src/hooks/useOnClickOutside.ts +22 -0
- package/src/hooks/useSessionStorage.ts +155 -0
- package/src/hooks/useTheme.ts +75 -0
- package/src/hooks/useWindowSize.ts +32 -0
- package/src/hooks.ts +12 -0
- package/src/i18n.ts +78 -0
- package/src/styles/globals.css +86 -0
- package/src/testing/mocks.ts +53 -0
- package/src/testing/setup-tests.ts +11 -0
- package/src/translations/libui.json +154 -0
- package/src/typings/i18next.d.ts +21 -0
- package/src/utils.ts +10 -0
- package/dist/chunk-IP3LSCUG.js +0 -129
- package/dist/chunk-IP3LSCUG.js.map +0 -1
- package/dist/chunk-PAAJ5AH3.js +0 -15
- package/dist/chunk-PAAJ5AH3.js.map +0 -1
- package/dist/components/index.d.ts +0 -2043
- package/dist/components/index.js +0 -4141
- package/dist/components/index.js.map +0 -1
- package/dist/hooks/index.d.ts +0 -122
- package/dist/hooks/index.js +0 -219
- package/dist/hooks/index.js.map +0 -1
- package/dist/i18n.js.map +0 -1
- package/dist/utils.js.map +0 -1
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { toBasicISOString } from '@douglasneuroinformatics/libjs';
|
|
3
|
+
import { DatePicker } from '../../DatePicker/DatePicker.js';
|
|
4
|
+
import { Input } from '../../Input/Input.js';
|
|
5
|
+
import { Label } from '../../Label/Label.js';
|
|
6
|
+
import { Popover } from '../../Popover/Popover.js';
|
|
7
|
+
import { FieldGroup } from '../FieldGroup/FieldGroup.js';
|
|
8
|
+
import {} from '../types.js';
|
|
9
|
+
const isValidDateString = (s) => /^(\d{4})-((0[1-9])|(1[0-2]))-((0[1-9])|([12])[0-9]|3[01])$/.test(s);
|
|
10
|
+
export const DateField = ({ error, label, name, setValue, value }) => {
|
|
11
|
+
const [isDatePickerOpen, setIsDatePickerOpen] = useState(false);
|
|
12
|
+
const [isInputFocused, setIsInputFocused] = useState(false);
|
|
13
|
+
const [inputValue, setInputValue] = useState('');
|
|
14
|
+
useEffect(() => {
|
|
15
|
+
const isSelecting = isDatePickerOpen || isInputFocused;
|
|
16
|
+
if (isSelecting) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
else if (isValidDateString(inputValue)) {
|
|
20
|
+
setValue(new Date(inputValue));
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
setInputValue('');
|
|
24
|
+
}
|
|
25
|
+
}, [isDatePickerOpen, isInputFocused]);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
setInputValue(value ? toBasicISOString(value) : '');
|
|
28
|
+
}, [value]);
|
|
29
|
+
return (React.createElement(FieldGroup, null,
|
|
30
|
+
React.createElement(Label, { htmlFor: name }, label),
|
|
31
|
+
React.createElement(Popover, { open: isDatePickerOpen, onOpenChange: setIsDatePickerOpen },
|
|
32
|
+
React.createElement(Popover.Trigger, null,
|
|
33
|
+
React.createElement(Input, { autoComplete: "off", "data-cy": "date-input", "data-testid": "date-input", name: name, placeholder: "YYYY-MM-DD", type: "text", value: inputValue, onBlur: () => setIsInputFocused(false), onChange: (event) => setInputValue(event.target.value), onFocus: () => setIsInputFocused(true) })),
|
|
34
|
+
React.createElement(Popover.Content, { asChild: true, align: "start", autofocus: false, className: "w-auto" },
|
|
35
|
+
React.createElement(DatePicker, { onSelection: (value) => {
|
|
36
|
+
setInputValue(toBasicISOString(value));
|
|
37
|
+
setIsDatePickerOpen(false);
|
|
38
|
+
} }))),
|
|
39
|
+
React.createElement(FieldGroup.Error, { error: error })));
|
|
40
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { DynamicFormField, FormDataType, PartialFormDataType } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { FormErrors } from './types.js';
|
|
4
|
+
export type DynamicFieldProps<TData extends FormDataType> = {
|
|
5
|
+
errors: FormErrors<TData>;
|
|
6
|
+
field: DynamicFormField<TData>;
|
|
7
|
+
name: string;
|
|
8
|
+
setErrors: React.Dispatch<React.SetStateAction<FormErrors<TData>>>;
|
|
9
|
+
setValues: React.Dispatch<React.SetStateAction<PartialFormDataType<TData>>>;
|
|
10
|
+
values: PartialFormDataType<TData>;
|
|
11
|
+
};
|
|
12
|
+
export declare const DynamicField: <TData extends FormDataType>({ field, name, values, ...props }: DynamicFieldProps<TData>) => React.JSX.Element | null;
|
|
13
|
+
//# sourceMappingURL=DynamicField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DynamicField.d.ts","sourceRoot":"","sources":["../../../src/components/Form/DynamicField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAuC,MAAM,OAAO,CAAC;AAE5D,OAAO,KAAK,EAAE,gBAAgB,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAKrH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,MAAM,MAAM,iBAAiB,CAAC,KAAK,SAAS,YAAY,IAAI;IAC1D,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IAC1B,KAAK,EAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACnE,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC5E,MAAM,EAAE,mBAAmB,CAAC,KAAK,CAAC,CAAC;CACpC,CAAC;AAEF,eAAO,MAAM,YAAY,kEAKtB,kBAAkB,KAAK,CAAC,6BAqB1B,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
2
|
+
import { pick } from 'lodash-es';
|
|
3
|
+
import { StaticField } from './StaticField.js';
|
|
4
|
+
export const DynamicField = ({ field, name, values, ...props }) => {
|
|
5
|
+
const [dependentValues, setDependentValues] = useState(pick(values, field.deps));
|
|
6
|
+
const staticField = useMemo(() => {
|
|
7
|
+
return field.render(values);
|
|
8
|
+
}, [dependentValues, field.render]);
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
for (const key of field.deps) {
|
|
11
|
+
if (dependentValues[key] !== values[key]) {
|
|
12
|
+
setDependentValues(pick(values, field.deps));
|
|
13
|
+
break;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}, [field.deps, values]);
|
|
17
|
+
if (!staticField) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
return React.createElement(StaticField, { ...props, field: staticField, name: name, values: values });
|
|
21
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorMessage.d.ts","sourceRoot":"","sources":["../../../src/components/Form/ErrorMessage.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,KAAK,CAAC,EAAE,IAAI,GAAG,MAAM,CAAA;CAAE,CAMnD,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { CircleAlertIcon } from 'lucide-react';
|
|
3
|
+
export const ErrorMessage = ({ error }) => error ? (React.createElement("div", { className: "flex w-full items-center text-sm font-medium text-destructive" },
|
|
4
|
+
React.createElement(CircleAlertIcon, { className: "mr-1", style: { strokeWidth: '2px' } }),
|
|
5
|
+
React.createElement("span", null, error))) : null;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" resolution-mode="require"/>
|
|
2
|
+
export declare const FieldGroup: import("react").FC<{
|
|
3
|
+
children: import("react").ReactNode;
|
|
4
|
+
}> & {
|
|
5
|
+
Description: import("react").FC<{
|
|
6
|
+
description?: string | null | undefined;
|
|
7
|
+
}>;
|
|
8
|
+
Error: import("react").FC<{
|
|
9
|
+
error?: string | null | undefined;
|
|
10
|
+
}>;
|
|
11
|
+
Row: import("react").FC<{
|
|
12
|
+
children: import("react").ReactNode;
|
|
13
|
+
}>;
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=FieldGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldGroup.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/FieldGroup/FieldGroup.tsx"],"names":[],"mappings":";AAKA,eAAO,MAAM,UAAU;;;;;;;;;;;;CAIrB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ErrorMessage } from '../ErrorMessage.js';
|
|
2
|
+
import { FieldGroupDescription } from './FieldGroupDescription.js';
|
|
3
|
+
import { FieldGroupRoot } from './FieldGroupRoot.js';
|
|
4
|
+
import { FieldGroupRow } from './FieldGroupRow.js';
|
|
5
|
+
export const FieldGroup = Object.assign(FieldGroupRoot, {
|
|
6
|
+
Description: FieldGroupDescription,
|
|
7
|
+
Error: ErrorMessage,
|
|
8
|
+
Row: FieldGroupRow
|
|
9
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldGroupDescription.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/FieldGroup/FieldGroupDescription.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,WAAW,CAAC,EAAE,IAAI,GAAG,MAAM,CAAA;CAAE,CAUlE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { CircleHelpIcon } from 'lucide-react';
|
|
3
|
+
import { Popover } from '../../Popover/Popover.js';
|
|
4
|
+
export const FieldGroupDescription = ({ description }) => description ? (React.createElement(Popover, null,
|
|
5
|
+
React.createElement(Popover.Trigger, null,
|
|
6
|
+
React.createElement(CircleHelpIcon, { className: "text-muted-foreground" })),
|
|
7
|
+
React.createElement(Popover.Content, { className: "text-sm text-muted-foreground" },
|
|
8
|
+
React.createElement("p", null, description)))) : null;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldGroupRoot.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/FieldGroup/FieldGroupRoot.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAElE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldGroupRow.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/FieldGroup/FieldGroupRow.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAEjE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { FormDataType, FormFields, PartialFormDataType } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { FormErrors } from './types.js';
|
|
4
|
+
export type FieldsComponentProps<T extends FormDataType> = {
|
|
5
|
+
errors: FormErrors<T>;
|
|
6
|
+
fields: FormFields<T>;
|
|
7
|
+
setErrors: React.Dispatch<React.SetStateAction<FormErrors<T>>>;
|
|
8
|
+
setValues: React.Dispatch<React.SetStateAction<PartialFormDataType<T>>>;
|
|
9
|
+
values: PartialFormDataType<T>;
|
|
10
|
+
};
|
|
11
|
+
/** Renders an object containing key value pairs, where the value is a FormField of some kind */
|
|
12
|
+
export declare const FieldsComponent: <T extends FormDataType>({ fields, ...props }: FieldsComponentProps<T>) => React.JSX.Element[];
|
|
13
|
+
//# sourceMappingURL=FieldsComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldsComponent.d.ts","sourceRoot":"","sources":["../../../src/components/Form/FieldsComponent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAK/G,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,MAAM,MAAM,oBAAoB,CAAC,CAAC,SAAS,YAAY,IAAI;IACzD,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;IACtB,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;IACtB,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/D,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACxE,MAAM,EAAE,mBAAmB,CAAC,CAAC,CAAC,CAAC;CAChC,CAAC;AAEF,gGAAgG;AAChG,eAAO,MAAM,eAAe,iDAAkD,qBAAqB,CAAC,CAAC,wBAQpG,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { DynamicField } from './DynamicField.js';
|
|
3
|
+
import { StaticField } from './StaticField.js';
|
|
4
|
+
/** Renders an object containing key value pairs, where the value is a FormField of some kind */
|
|
5
|
+
export const FieldsComponent = ({ fields, ...props }) => {
|
|
6
|
+
return Object.keys(fields).map((name) => {
|
|
7
|
+
const field = fields[name];
|
|
8
|
+
if (field.kind === 'dynamic') {
|
|
9
|
+
return React.createElement(DynamicField, { ...props, field: field, key: name, name: name });
|
|
10
|
+
}
|
|
11
|
+
return React.createElement(StaticField, { ...props, field: field, key: name, name: name });
|
|
12
|
+
});
|
|
13
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { FormContent, FormDataType, PartialNullableFormDataType } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
type FormProps<TSchema extends z.ZodType<FormDataType>, TData extends z.infer<TSchema> = z.infer<TSchema>> = {
|
|
5
|
+
[key: `data-${string}`]: unknown;
|
|
6
|
+
className?: string;
|
|
7
|
+
content: FormContent<TData>;
|
|
8
|
+
id?: string;
|
|
9
|
+
initialValues?: PartialNullableFormDataType<TData>;
|
|
10
|
+
onError?: (error: z.ZodError<TData>) => void;
|
|
11
|
+
onSubmit: (data: TData) => void;
|
|
12
|
+
resetBtn?: boolean;
|
|
13
|
+
submitBtnLabel?: string;
|
|
14
|
+
validationSchema: z.ZodType<TData>;
|
|
15
|
+
};
|
|
16
|
+
declare const Form: <TSchema extends z.ZodType<FormDataType, z.ZodTypeDef, FormDataType>, TData extends z.TypeOf<TSchema> = z.TypeOf<TSchema>>({ className, content, id, initialValues, onError, onSubmit, resetBtn, submitBtnLabel, validationSchema, ...props }: FormProps<TSchema, TData>) => React.JSX.Element;
|
|
17
|
+
export { Form, type FormProps };
|
|
18
|
+
//# sourceMappingURL=Form.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Form.d.ts","sourceRoot":"","sources":["../../../src/components/Form/Form.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAExC,OAAO,KAAK,EACV,WAAW,EACX,YAAY,EAGZ,2BAA2B,EAC5B,MAAM,2CAA2C,CAAC;AAInD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAUxB,KAAK,SAAS,CAAC,OAAO,SAAS,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI;IAC3G,CAAC,GAAG,EAAE,QAAQ,MAAM,EAAE,GAAG,OAAO,CAAC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,aAAa,CAAC,EAAE,2BAA2B,CAAC,KAAK,CAAC,CAAC;IACnD,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC;IAC7C,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,KAAK,IAAI,CAAC;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;CACpC,CAAC;AAEF,QAAA,MAAM,IAAI,iPAWP,UAAU,OAAO,EAAE,KAAK,CAAC,sBAgG3B,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,KAAK,SAAS,EAAE,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { set } from 'lodash-es';
|
|
3
|
+
import { useTranslation } from 'react-i18next';
|
|
4
|
+
import { twMerge } from 'tailwind-merge';
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import { Button } from '../Button/Button.js';
|
|
7
|
+
import { Heading } from '../Heading/Heading.js';
|
|
8
|
+
import { ErrorMessage } from './ErrorMessage.js';
|
|
9
|
+
import { FieldsComponent } from './FieldsComponent.js';
|
|
10
|
+
import { getInitialValues } from './utils.js';
|
|
11
|
+
const Form = ({ className, content, id, initialValues, onError, onSubmit, resetBtn, submitBtnLabel, validationSchema, ...props }) => {
|
|
12
|
+
const { t } = useTranslation('libui');
|
|
13
|
+
const [rootError, setRootError] = useState(null);
|
|
14
|
+
const [errors, setErrors] = useState({});
|
|
15
|
+
const [values, setValues] = useState(initialValues ? getInitialValues(initialValues) : {});
|
|
16
|
+
const handleError = (error) => {
|
|
17
|
+
const fieldErrors = {};
|
|
18
|
+
const rootErrors = [];
|
|
19
|
+
for (const issue of error.issues) {
|
|
20
|
+
if (issue.path.length > 0) {
|
|
21
|
+
set(fieldErrors, issue.path, issue.message);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
rootErrors.push(issue.message);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
setRootError(rootErrors.join('\n'));
|
|
28
|
+
setErrors(fieldErrors);
|
|
29
|
+
if (onError) {
|
|
30
|
+
onError(error);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const reset = () => {
|
|
34
|
+
setRootError(null);
|
|
35
|
+
setErrors({});
|
|
36
|
+
setValues({});
|
|
37
|
+
};
|
|
38
|
+
const handleSubmit = (event) => {
|
|
39
|
+
event.preventDefault();
|
|
40
|
+
const result = validationSchema.safeParse(values);
|
|
41
|
+
if (result.success) {
|
|
42
|
+
reset();
|
|
43
|
+
onSubmit(result.data);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
console.error(result.error.issues);
|
|
47
|
+
handleError(result.error);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
const isGrouped = Array.isArray(content);
|
|
51
|
+
return (React.createElement("form", { autoComplete: "off", className: twMerge('w-full', isGrouped ? 'space-y-8 divide-y' : 'space-y-6', className), id: id, onSubmit: handleSubmit, ...props },
|
|
52
|
+
isGrouped ? (content.map((fieldGroup, i) => {
|
|
53
|
+
return (React.createElement("div", { className: "space-y-6 [&:not(:first-child)]:pt-8", key: i },
|
|
54
|
+
React.createElement("div", { className: "space-y-1" },
|
|
55
|
+
React.createElement(Heading, { variant: "h4" }, fieldGroup.title),
|
|
56
|
+
fieldGroup.description && (React.createElement("p", { className: "text-sm italic leading-tight text-muted-foreground" }, fieldGroup.description))),
|
|
57
|
+
React.createElement(FieldsComponent, { errors: errors, fields: fieldGroup.fields, setErrors: setErrors, setValues: setValues, values: values })));
|
|
58
|
+
})) : (React.createElement(FieldsComponent, { errors: errors, fields: content, setErrors: setErrors, setValues: setValues, values: values })),
|
|
59
|
+
React.createElement("div", { className: "flex w-full gap-3" },
|
|
60
|
+
React.createElement(Button, { "aria-label": "Submit Button", className: "block w-full", "data-cy": "submit-form", type: "submit", variant: "primary" }, submitBtnLabel ?? t('form.submit')),
|
|
61
|
+
resetBtn && (React.createElement(Button, { "aria-label": "Reset Button", className: "block w-full", type: "button", variant: "secondary", onClick: reset }, t('form.reset')))),
|
|
62
|
+
rootError && React.createElement(ErrorMessage, { error: rootError })));
|
|
63
|
+
};
|
|
64
|
+
export { Form };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { type NumberFieldInputProps } from './NumberFieldInput.js';
|
|
3
|
+
import { type NumberFieldRadioProps } from './NumberFieldRadio.js';
|
|
4
|
+
import { type NumberFieldSliderProps } from './NumberFieldSlider.js';
|
|
5
|
+
export type NumberFieldProps = NumberFieldInputProps | NumberFieldRadioProps | NumberFieldSliderProps;
|
|
6
|
+
export declare const NumberField: (props: NumberFieldProps) => React.JSX.Element;
|
|
7
|
+
//# sourceMappingURL=NumberField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberField.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/NumberField/NumberField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,EAAoB,KAAK,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AACrF,OAAO,EAAoB,KAAK,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AACrF,OAAO,EAAqB,KAAK,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAExF,MAAM,MAAM,gBAAgB,GAAG,qBAAqB,GAAG,qBAAqB,GAAG,sBAAsB,CAAC;AAEtG,eAAO,MAAM,WAAW,UAAW,gBAAgB,sBAMlD,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { match } from 'ts-pattern';
|
|
3
|
+
import { NumberFieldInput } from './NumberFieldInput.js';
|
|
4
|
+
import { NumberFieldRadio } from './NumberFieldRadio.js';
|
|
5
|
+
import { NumberFieldSlider } from './NumberFieldSlider.js';
|
|
6
|
+
export const NumberField = (props) => {
|
|
7
|
+
return match(props)
|
|
8
|
+
.with({ variant: 'input' }, (props) => React.createElement(NumberFieldInput, { ...props }))
|
|
9
|
+
.with({ variant: 'slider' }, (props) => React.createElement(NumberFieldSlider, { ...props }))
|
|
10
|
+
.with({ variant: 'radio' }, (props) => React.createElement(NumberFieldRadio, { ...props }))
|
|
11
|
+
.exhaustive();
|
|
12
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NumberFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from '../types.js';
|
|
5
|
+
export type NumberFieldInputProps = Simplify<BaseFieldComponentProps<number> & Extract<NumberFormField, {
|
|
6
|
+
variant: 'input';
|
|
7
|
+
}>>;
|
|
8
|
+
export declare const NumberFieldInput: ({ description, error, label, max, min, name, setValue, value }: NumberFieldInputProps) => React.JSX.Element;
|
|
9
|
+
//# sourceMappingURL=NumberFieldInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberFieldInput.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/NumberField/NumberFieldInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAM1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AAE3D,MAAM,MAAM,qBAAqB,GAAG,QAAQ,CAC1C,uBAAuB,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,eAAe,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,CAAC,CACjF,CAAC;AAEF,eAAO,MAAM,gBAAgB,mEAS1B,qBAAqB,sBAmBvB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Input } from '../../Input/Input.js';
|
|
3
|
+
import { Label } from '../../Label/Label.js';
|
|
4
|
+
import { FieldGroup } from '../FieldGroup/FieldGroup.js';
|
|
5
|
+
export const NumberFieldInput = ({ description, error, label, max, min, name, setValue, value }) => {
|
|
6
|
+
const handleChange = (event) => {
|
|
7
|
+
const newValue = parseFloat(event.target.value);
|
|
8
|
+
if (Number.isNaN(newValue)) {
|
|
9
|
+
setValue(undefined);
|
|
10
|
+
}
|
|
11
|
+
else if (newValue >= (min ?? -Infinity) && newValue <= (max ?? Infinity)) {
|
|
12
|
+
setValue(newValue);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
return (React.createElement(FieldGroup, null,
|
|
16
|
+
React.createElement(FieldGroup.Row, null,
|
|
17
|
+
React.createElement(Label, null, label),
|
|
18
|
+
React.createElement(FieldGroup.Description, { description: description })),
|
|
19
|
+
React.createElement(Input, { max: max, min: min, name: name, type: "text", value: value ?? '', onChange: handleChange }),
|
|
20
|
+
React.createElement(FieldGroup.Error, { error: error })));
|
|
21
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NumberFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from '../types.js';
|
|
5
|
+
export type NumberFieldRadioProps = Simplify<BaseFieldComponentProps<number> & Extract<NumberFormField, {
|
|
6
|
+
variant: 'radio';
|
|
7
|
+
}>>;
|
|
8
|
+
export declare const NumberFieldRadio: ({ description, error, label, name, options, setValue, value }: NumberFieldRadioProps) => React.JSX.Element;
|
|
9
|
+
//# sourceMappingURL=NumberFieldRadio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberFieldRadio.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/NumberField/NumberFieldRadio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAO1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AAE3D,MAAM,MAAM,qBAAqB,GAAG,QAAQ,CAC1C,uBAAuB,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,eAAe,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,CAAC,CACjF,CAAC;AAEF,eAAO,MAAM,gBAAgB,kEAQ1B,qBAAqB,sBAiCvB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { cn } from '../../../utils.js';
|
|
3
|
+
import { Label } from '../../Label/Label.js';
|
|
4
|
+
import { RadioGroup } from '../../RadioGroup/RadioGroup.js';
|
|
5
|
+
import { FieldGroup } from '../FieldGroup/FieldGroup.js';
|
|
6
|
+
export const NumberFieldRadio = ({ description, error, label, name, options, setValue, value }) => {
|
|
7
|
+
const optionsCount = Object.keys(options).length;
|
|
8
|
+
return (React.createElement(FieldGroup, null,
|
|
9
|
+
React.createElement(FieldGroup.Row, null,
|
|
10
|
+
React.createElement(Label, null, label),
|
|
11
|
+
React.createElement(FieldGroup.Description, { description: description })),
|
|
12
|
+
React.createElement(RadioGroup, { className: cn('flex', optionsCount > 5 ? 'flex-col' : 'flex-col @3xl:flex-row @3xl:items-center @3xl:justify-between'), name: name, value: value?.toString() ?? '', onValueChange: (value) => setValue(parseInt(value)) }, Object.keys(options)
|
|
13
|
+
.map((val) => parseInt(val))
|
|
14
|
+
.toSorted((a, b) => a - b)
|
|
15
|
+
.map((key) => (React.createElement("div", { className: "flex items-center gap-2", key: key },
|
|
16
|
+
React.createElement(RadioGroup.Item, { id: `${name}-${key}`, value: key.toString() }),
|
|
17
|
+
React.createElement(Label, { className: "font-normal", htmlFor: `${name}-${key}` }, options[key]))))),
|
|
18
|
+
React.createElement(FieldGroup.Error, { error: error })));
|
|
19
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NumberFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from '../types.js';
|
|
5
|
+
export type NumberFieldSliderProps = Simplify<BaseFieldComponentProps<number> & Extract<NumberFormField, {
|
|
6
|
+
variant: 'slider';
|
|
7
|
+
}>>;
|
|
8
|
+
export declare const NumberFieldSlider: ({ description, error, label, max, min, name, setValue, value }: NumberFieldSliderProps) => React.JSX.Element;
|
|
9
|
+
//# sourceMappingURL=NumberFieldSlider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberFieldSlider.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/NumberField/NumberFieldSlider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAM1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AAE3D,MAAM,MAAM,sBAAsB,GAAG,QAAQ,CAC3C,uBAAuB,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,eAAe,EAAE;IAAE,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC,CAClF,CAAC;AAEF,eAAO,MAAM,iBAAiB,mEAS3B,sBAAsB,sBAgBxB,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Label } from '../../Label/Label.js';
|
|
3
|
+
import { Slider } from '../../Slider/Slider.js';
|
|
4
|
+
import { FieldGroup } from '../FieldGroup/FieldGroup.js';
|
|
5
|
+
export const NumberFieldSlider = ({ description, error, label, max, min, name, setValue, value }) => {
|
|
6
|
+
return (React.createElement(FieldGroup, null,
|
|
7
|
+
React.createElement(FieldGroup.Row, null,
|
|
8
|
+
React.createElement(Label, null, label),
|
|
9
|
+
React.createElement(FieldGroup.Description, { description: description })),
|
|
10
|
+
React.createElement(FieldGroup.Row, null,
|
|
11
|
+
React.createElement(Slider, { max: max, min: min, name: name, value: [value ?? 0], onValueChange: ([value]) => setValue(value) }),
|
|
12
|
+
React.createElement("span", { className: "flex h-full w-8 items-center justify-center text-sm text-muted-foreground" }, value ?? 'NA')),
|
|
13
|
+
React.createElement(FieldGroup.Error, { error: error })));
|
|
14
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NumberRecordFieldValue, NumberRecordFormField, RequiredFieldValue } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from './types.js';
|
|
5
|
+
export type NumberRecordFieldProps<T extends NumberRecordFieldValue = NumberRecordFieldValue> = Simplify<BaseFieldComponentProps<NumberRecordFieldValue> & NumberRecordFormField<RequiredFieldValue<T>>>;
|
|
6
|
+
export declare const NumberRecordField: <T extends NumberRecordFieldValue = NumberRecordFieldValue>({ error: recordError, items, label, options, setError: setRecordError, setValue: setRecordValue, value: recordValue }: NumberRecordFieldProps<T>) => React.JSX.Element | null;
|
|
7
|
+
//# sourceMappingURL=NumberRecordField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberRecordField.d.ts","sourceRoot":"","sources":["../../../src/components/Form/NumberRecordField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAEzC,OAAO,KAAK,EACV,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,2CAA2C,CAAC;AACnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAK1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,MAAM,sBAAsB,CAAC,CAAC,SAAS,sBAAsB,GAAG,sBAAsB,IAAI,QAAQ,CACtG,uBAAuB,CAAC,sBAAsB,CAAC,GAAG,qBAAqB,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAC/F,CAAC;AAEF,eAAO,MAAM,iBAAiB,qLAQ3B,uBAAuB,CAAC,CAAC,6BAiC3B,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React, { useEffect } from 'react';
|
|
2
|
+
import { Heading } from '../Heading/Heading.js';
|
|
3
|
+
import { NumberField } from './NumberField/NumberField.js';
|
|
4
|
+
export const NumberRecordField = ({ error: recordError, items, label, options, setError: setRecordError, setValue: setRecordValue, value: recordValue }) => {
|
|
5
|
+
useEffect(() => {
|
|
6
|
+
setRecordValue({});
|
|
7
|
+
}, [options]);
|
|
8
|
+
if (!recordValue) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
return (React.createElement("div", { className: "space-y-4" },
|
|
12
|
+
React.createElement(Heading, { variant: "h5" }, label),
|
|
13
|
+
React.createElement("div", { className: "space-y-6" }, Object.keys(items).map((name) => {
|
|
14
|
+
const item = items[name];
|
|
15
|
+
return (React.createElement(NumberField, { error: recordError?.[name], key: name, kind: "number", name: name, options: options, setError: (error) => setRecordError({ ...recordError, [name]: error }), setValue: (value) => setRecordValue({ ...recordValue, [name]: value }), value: recordValue?.[name], variant: "radio", ...item }));
|
|
16
|
+
}))));
|
|
17
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { RecordArrayFieldValue, RecordArrayFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from './types.js';
|
|
5
|
+
export type RecordArrayFieldProps = Simplify<BaseFieldComponentProps<RecordArrayFieldValue> & RecordArrayFormField>;
|
|
6
|
+
export declare const RecordArrayField: React.NamedExoticComponent<{
|
|
7
|
+
error?: {
|
|
8
|
+
[key: string]: string;
|
|
9
|
+
}[] | undefined;
|
|
10
|
+
name: string;
|
|
11
|
+
setError: (error: {
|
|
12
|
+
[key: string]: string;
|
|
13
|
+
}[]) => void;
|
|
14
|
+
setValue: (value: RecordArrayFieldValue) => void;
|
|
15
|
+
value: RecordArrayFieldValue;
|
|
16
|
+
description?: string | undefined;
|
|
17
|
+
kind: "record-array";
|
|
18
|
+
label: string;
|
|
19
|
+
fieldset: import("@douglasneuroinformatics/libui-form-types").Fieldset<{
|
|
20
|
+
[x: string]: NonNullable<import("@douglasneuroinformatics/libui-form-types").ScalarFieldValue>;
|
|
21
|
+
}>;
|
|
22
|
+
}>;
|
|
23
|
+
//# sourceMappingURL=RecordArrayField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RecordArrayField.d.ts","sourceRoot":"","sources":["../../../src/components/Form/RecordArrayField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA0B,MAAM,OAAO,CAAC;AAE/C,OAAO,KAAK,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AAG7G,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAO1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,MAAM,qBAAqB,GAAG,QAAQ,CAAC,uBAAuB,CAAC,qBAAqB,CAAC,GAAG,oBAAoB,CAAC,CAAC;AAEpH,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;EAkF3B,CAAC"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import React, { memo, useEffect } from 'react';
|
|
2
|
+
import { MinusCircleIcon, PlusCircleIcon } from 'lucide-react';
|
|
3
|
+
import { useTranslation } from 'react-i18next';
|
|
4
|
+
import { Button } from '../Button/Button.js';
|
|
5
|
+
import { Heading } from '../Heading/Heading.js';
|
|
6
|
+
import { Label } from '../Label/Label.js';
|
|
7
|
+
import { ScalarField } from './ScalarField.js';
|
|
8
|
+
export const RecordArrayField = memo(function RecordArrayField({ error: arrayError, fieldset, label, setError: setArrayError, setValue: setArrayValue, value: arrayValue }) {
|
|
9
|
+
const { t } = useTranslation('libui');
|
|
10
|
+
const createNewRecord = () => Object.fromEntries(Object.keys(fieldset).map((fieldName) => [fieldName, undefined]));
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
setArrayValue([createNewRecord()]);
|
|
13
|
+
}, [fieldset]);
|
|
14
|
+
if (!arrayValue) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
// Creates a new object with all values mapped to null and appends it to the previous arrayValue
|
|
18
|
+
const appendField = () => {
|
|
19
|
+
setArrayValue([...arrayValue, createNewRecord()]);
|
|
20
|
+
};
|
|
21
|
+
const removeField = () => {
|
|
22
|
+
if (arrayValue.length > 1) {
|
|
23
|
+
setArrayValue(arrayValue.slice(0, arrayValue.length - 1));
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
return (React.createElement("div", { className: "space-y-4" },
|
|
27
|
+
React.createElement(Heading, { variant: "h5" }, label),
|
|
28
|
+
React.createElement("div", { className: "space-y-6" }, arrayValue.map((fields, i) => (React.createElement("div", { className: "space-y-4", key: i },
|
|
29
|
+
React.createElement(Label, { className: "font-semibold italic" }, label + ' ' + (i + 1)),
|
|
30
|
+
Object.keys(fields).map((name) => {
|
|
31
|
+
const field = fieldset[name];
|
|
32
|
+
const fieldProps = field?.kind === 'dynamic' ? field.render(fields) : field;
|
|
33
|
+
if (!fieldProps) {
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
36
|
+
return (React.createElement(ScalarField, { error: arrayError?.[i]?.[name], field: fieldProps, key: name, name: name, setError: (error) => {
|
|
37
|
+
const newArrayError = arrayError ? [...arrayError] : [];
|
|
38
|
+
if (!newArrayError[i]) {
|
|
39
|
+
newArrayError[i] = {};
|
|
40
|
+
}
|
|
41
|
+
newArrayError[i][name] = error;
|
|
42
|
+
setArrayError(newArrayError);
|
|
43
|
+
}, setValue: (value) => {
|
|
44
|
+
const newArrayValue = [...arrayValue];
|
|
45
|
+
newArrayValue[i][name] = value;
|
|
46
|
+
setArrayValue(newArrayValue);
|
|
47
|
+
}, value: arrayValue?.[i]?.[name] }));
|
|
48
|
+
}))))),
|
|
49
|
+
React.createElement("div", { className: "flex gap-3" },
|
|
50
|
+
React.createElement(Button, { type: "button", variant: "outline", onClick: appendField },
|
|
51
|
+
t('form.append'),
|
|
52
|
+
React.createElement(PlusCircleIcon, { className: "ml-2" })),
|
|
53
|
+
React.createElement(Button, { type: "button", variant: "outline", onClick: removeField },
|
|
54
|
+
t('form.remove'),
|
|
55
|
+
React.createElement(MinusCircleIcon, { className: "ml-2" })))));
|
|
56
|
+
});
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { BooleanFormField, DateFormField, NumberFormField, ScalarFieldValue, SetFormField, StringFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { BaseFieldComponentProps } from './types.js';
|
|
4
|
+
export type ScalarFieldProps = BaseFieldComponentProps<ScalarFieldValue> & {
|
|
5
|
+
field: BooleanFormField | DateFormField | NumberFormField | SetFormField | StringFormField;
|
|
6
|
+
};
|
|
7
|
+
export declare const ScalarField: ({ field, ...props }: ScalarFieldProps) => React.JSX.Element;
|
|
8
|
+
//# sourceMappingURL=ScalarField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScalarField.d.ts","sourceRoot":"","sources":["../../../src/components/Form/ScalarField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EACV,gBAAgB,EAChB,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,eAAe,EAChB,MAAM,2CAA2C,CAAC;AAQnD,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,MAAM,gBAAgB,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,GAAG;IACzE,KAAK,EAAE,gBAAgB,GAAG,aAAa,GAAG,eAAe,GAAG,YAAY,GAAG,eAAe,CAAC;CAC5F,CAAC;AAEF,eAAO,MAAM,WAAW,wBAAyB,gBAAgB,sBAehE,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { BooleanField } from './BooleanField/BooleanField.js';
|
|
3
|
+
import { DateField } from './DateField/DateField.js';
|
|
4
|
+
import { NumberField } from './NumberField/NumberField.js';
|
|
5
|
+
import { SetField } from './SetField/SetField.js';
|
|
6
|
+
import { StringField } from './StringField/StringField.js';
|
|
7
|
+
export const ScalarField = ({ field, ...props }) => {
|
|
8
|
+
switch (field.kind) {
|
|
9
|
+
case 'string':
|
|
10
|
+
return React.createElement(StringField, { ...field, ...props });
|
|
11
|
+
case 'number':
|
|
12
|
+
return React.createElement(NumberField, { ...field, ...props });
|
|
13
|
+
case 'date':
|
|
14
|
+
return React.createElement(DateField, { ...field, ...props });
|
|
15
|
+
case 'boolean':
|
|
16
|
+
return React.createElement(BooleanField, { ...field, ...props });
|
|
17
|
+
case 'set':
|
|
18
|
+
return React.createElement(SetField, { ...field, ...props });
|
|
19
|
+
default:
|
|
20
|
+
throw new Error(`Unexpected value for kind: ${Reflect.get(field, 'kind')}`);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { SetFormField } from '@douglasneuroinformatics/libui-form-types';
|
|
3
|
+
import type { Simplify } from 'type-fest';
|
|
4
|
+
import type { BaseFieldComponentProps } from '../types.js';
|
|
5
|
+
export type SetFieldProps<T extends string = string> = Simplify<BaseFieldComponentProps<Set<T>> & SetFormField<Set<T>>>;
|
|
6
|
+
export declare const SetField: <T extends string = string>(props: SetFieldProps<T>) => React.JSX.Element;
|
|
7
|
+
//# sourceMappingURL=SetField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SetField.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/SetField/SetField.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAEzC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AAE9E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAK1C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AAE3D,MAAM,MAAM,aAAa,CAAC,CAAC,SAAS,MAAM,GAAG,MAAM,IAAI,QAAQ,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAExH,eAAO,MAAM,QAAQ,qCAAsC,cAAc,CAAC,CAAC,sBAuB1E,CAAC"}
|