@verbb/plugin-kit-react 1.0.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/CHANGELOG.md +5 -0
- package/LICENSE.md +21 -0
- package/README.md +31 -0
- package/dist/_virtual/_rolldown/runtime.js +34 -0
- package/dist/components/Button.d.ts +26 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +148 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/ButtonGroup.d.ts +11 -0
- package/dist/components/ButtonGroup.d.ts.map +1 -0
- package/dist/components/ButtonGroup.js +59 -0
- package/dist/components/ButtonGroup.js.map +1 -0
- package/dist/components/Calendar.d.ts +11 -0
- package/dist/components/Calendar.d.ts.map +1 -0
- package/dist/components/Calendar.js +133 -0
- package/dist/components/Calendar.js.map +1 -0
- package/dist/components/Checkbox.d.ts +5 -0
- package/dist/components/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox.js +41 -0
- package/dist/components/Checkbox.js.map +1 -0
- package/dist/components/CheckboxInput.d.ts +14 -0
- package/dist/components/CheckboxInput.d.ts.map +1 -0
- package/dist/components/CheckboxInput.js +31 -0
- package/dist/components/CheckboxInput.js.map +1 -0
- package/dist/components/CheckboxSelect.d.ts +19 -0
- package/dist/components/CheckboxSelect.d.ts.map +1 -0
- package/dist/components/CheckboxSelect.js +63 -0
- package/dist/components/CheckboxSelect.js.map +1 -0
- package/dist/components/ColorInput.d.ts +14 -0
- package/dist/components/ColorInput.d.ts.map +1 -0
- package/dist/components/ColorInput.js +148 -0
- package/dist/components/ColorInput.js.map +1 -0
- package/dist/components/Combobox.d.ts +40 -0
- package/dist/components/Combobox.d.ts.map +1 -0
- package/dist/components/Combobox.js +393 -0
- package/dist/components/Combobox.js.map +1 -0
- package/dist/components/ComboboxInput.d.ts +28 -0
- package/dist/components/ComboboxInput.d.ts.map +1 -0
- package/dist/components/ComboboxInput.js +165 -0
- package/dist/components/ComboboxInput.js.map +1 -0
- package/dist/components/Command.d.ts +26 -0
- package/dist/components/Command.d.ts.map +1 -0
- package/dist/components/Command.js +94 -0
- package/dist/components/Command.js.map +1 -0
- package/dist/components/CopyButton.d.ts +9 -0
- package/dist/components/CopyButton.d.ts.map +1 -0
- package/dist/components/CopyButton.js +40 -0
- package/dist/components/CopyButton.js.map +1 -0
- package/dist/components/DatePicker.d.ts +9 -0
- package/dist/components/DatePicker.d.ts.map +1 -0
- package/dist/components/DatePicker.js +46 -0
- package/dist/components/DatePicker.js.map +1 -0
- package/dist/components/Dialog.d.ts +21 -0
- package/dist/components/Dialog.d.ts.map +1 -0
- package/dist/components/Dialog.js +179 -0
- package/dist/components/Dialog.js.map +1 -0
- package/dist/components/DropdownMenu.d.ts +47 -0
- package/dist/components/DropdownMenu.d.ts.map +1 -0
- package/dist/components/DropdownMenu.js +240 -0
- package/dist/components/DropdownMenu.js.map +1 -0
- package/dist/components/EditableTable.d.ts +28 -0
- package/dist/components/EditableTable.d.ts.map +1 -0
- package/dist/components/EditableTable.js +145 -0
- package/dist/components/EditableTable.js.map +1 -0
- package/dist/components/FadeIn.d.ts +12 -0
- package/dist/components/FadeIn.d.ts.map +1 -0
- package/dist/components/FadeIn.js +24 -0
- package/dist/components/FadeIn.js.map +1 -0
- package/dist/components/Input.d.ts +9 -0
- package/dist/components/Input.d.ts.map +1 -0
- package/dist/components/Input.js +43 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/InputGroup.d.ts +20 -0
- package/dist/components/InputGroup.d.ts.map +1 -0
- package/dist/components/InputGroup.js +111 -0
- package/dist/components/InputGroup.js.map +1 -0
- package/dist/components/Label.d.ts +4 -0
- package/dist/components/Label.d.ts.map +1 -0
- package/dist/components/Label.js +15 -0
- package/dist/components/Label.js.map +1 -0
- package/dist/components/Lightswitch.d.ts +9 -0
- package/dist/components/Lightswitch.d.ts.map +1 -0
- package/dist/components/Lightswitch.js +56 -0
- package/dist/components/Lightswitch.js.map +1 -0
- package/dist/components/Markdown.d.ts +11 -0
- package/dist/components/Markdown.d.ts.map +1 -0
- package/dist/components/Markdown.js +46 -0
- package/dist/components/Markdown.js.map +1 -0
- package/dist/components/MenuButton.d.ts +40 -0
- package/dist/components/MenuButton.d.ts.map +1 -0
- package/dist/components/MenuButton.js +122 -0
- package/dist/components/MenuButton.js.map +1 -0
- package/dist/components/ModalTabs.d.ts +8 -0
- package/dist/components/ModalTabs.d.ts.map +1 -0
- package/dist/components/ModalTabs.js +37 -0
- package/dist/components/ModalTabs.js.map +1 -0
- package/dist/components/PaneTabs.d.ts +8 -0
- package/dist/components/PaneTabs.d.ts.map +1 -0
- package/dist/components/PaneTabs.js +37 -0
- package/dist/components/PaneTabs.js.map +1 -0
- package/dist/components/Popover.d.ts +12 -0
- package/dist/components/Popover.d.ts.map +1 -0
- package/dist/components/Popover.js +70 -0
- package/dist/components/Popover.js.map +1 -0
- package/dist/components/RadioGroup.d.ts +6 -0
- package/dist/components/RadioGroup.d.ts.map +1 -0
- package/dist/components/RadioGroup.js +34 -0
- package/dist/components/RadioGroup.js.map +1 -0
- package/dist/components/ScrollArea.d.ts +16 -0
- package/dist/components/ScrollArea.d.ts.map +1 -0
- package/dist/components/ScrollArea.js +47 -0
- package/dist/components/ScrollArea.js.map +1 -0
- package/dist/components/Select.d.ts +23 -0
- package/dist/components/Select.d.ts.map +1 -0
- package/dist/components/Select.js +205 -0
- package/dist/components/Select.js.map +1 -0
- package/dist/components/SelectInput.d.ts +33 -0
- package/dist/components/SelectInput.d.ts.map +1 -0
- package/dist/components/SelectInput.js +85 -0
- package/dist/components/SelectInput.js.map +1 -0
- package/dist/components/Separator.d.ts +4 -0
- package/dist/components/Separator.d.ts.map +1 -0
- package/dist/components/Separator.js +17 -0
- package/dist/components/Separator.js.map +1 -0
- package/dist/components/SlideUp.d.ts +12 -0
- package/dist/components/SlideUp.d.ts.map +1 -0
- package/dist/components/SlideUp.js +36 -0
- package/dist/components/SlideUp.js.map +1 -0
- package/dist/components/Slot.d.ts +6 -0
- package/dist/components/Slot.d.ts.map +1 -0
- package/dist/components/Slot.js +52 -0
- package/dist/components/Slot.js.map +1 -0
- package/dist/components/Spinner.d.ts +9 -0
- package/dist/components/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner.js +43 -0
- package/dist/components/Spinner.js.map +1 -0
- package/dist/components/Status.d.ts +8 -0
- package/dist/components/Status.d.ts.map +1 -0
- package/dist/components/Status.js +55 -0
- package/dist/components/Status.js.map +1 -0
- package/dist/components/Table.d.ts +10 -0
- package/dist/components/Table.d.ts.map +1 -0
- package/dist/components/Table.js +64 -0
- package/dist/components/Table.js.map +1 -0
- package/dist/components/Tabs.d.ts +8 -0
- package/dist/components/Tabs.d.ts.map +1 -0
- package/dist/components/Tabs.js +37 -0
- package/dist/components/Tabs.js.map +1 -0
- package/dist/components/Textarea.d.ts +8 -0
- package/dist/components/Textarea.d.ts.map +1 -0
- package/dist/components/Textarea.js +26 -0
- package/dist/components/Textarea.js.map +1 -0
- package/dist/components/TimePicker.d.ts +9 -0
- package/dist/components/TimePicker.d.ts.map +1 -0
- package/dist/components/TimePicker.js +40 -0
- package/dist/components/TimePicker.js.map +1 -0
- package/dist/components/TiptapContent.d.ts +9 -0
- package/dist/components/TiptapContent.d.ts.map +1 -0
- package/dist/components/TiptapContent.js +24 -0
- package/dist/components/TiptapContent.js.map +1 -0
- package/dist/components/TiptapEditor.d.ts +41 -0
- package/dist/components/TiptapEditor.d.ts.map +1 -0
- package/dist/components/TiptapEditor.js +555 -0
- package/dist/components/TiptapEditor.js.map +1 -0
- package/dist/components/TiptapInput.d.ts +15 -0
- package/dist/components/TiptapInput.d.ts.map +1 -0
- package/dist/components/TiptapInput.js +138 -0
- package/dist/components/TiptapInput.js.map +1 -0
- package/dist/components/Toggle.d.ts +9 -0
- package/dist/components/Toggle.d.ts.map +1 -0
- package/dist/components/Toggle.js +48 -0
- package/dist/components/Toggle.js.map +1 -0
- package/dist/components/ToggleGroup.d.ts +11 -0
- package/dist/components/ToggleGroup.d.ts.map +1 -0
- package/dist/components/ToggleGroup.js +70 -0
- package/dist/components/ToggleGroup.js.map +1 -0
- package/dist/components/Tooltip.d.ts +9 -0
- package/dist/components/Tooltip.d.ts.map +1 -0
- package/dist/components/Tooltip.js +51 -0
- package/dist/components/Tooltip.js.map +1 -0
- package/dist/components/VirtualizedScrollArea.d.ts +25 -0
- package/dist/components/VirtualizedScrollArea.d.ts.map +1 -0
- package/dist/components/VirtualizedScrollArea.js +80 -0
- package/dist/components/VirtualizedScrollArea.js.map +1 -0
- package/dist/components/editable-table/RowDataCells.d.ts +3 -0
- package/dist/components/editable-table/RowDataCells.d.ts.map +1 -0
- package/dist/components/editable-table/RowDataCells.js +33 -0
- package/dist/components/editable-table/RowDataCells.js.map +1 -0
- package/dist/components/editable-table/TableCell.d.ts +13 -0
- package/dist/components/editable-table/TableCell.d.ts.map +1 -0
- package/dist/components/editable-table/TableCell.js +415 -0
- package/dist/components/editable-table/TableCell.js.map +1 -0
- package/dist/components/editable-table/TableRow.d.ts +3 -0
- package/dist/components/editable-table/TableRow.d.ts.map +1 -0
- package/dist/components/editable-table/TableRow.js +163 -0
- package/dist/components/editable-table/TableRow.js.map +1 -0
- package/dist/components/editable-table/helpers.d.ts +12 -0
- package/dist/components/editable-table/helpers.d.ts.map +1 -0
- package/dist/components/editable-table/helpers.js +23 -0
- package/dist/components/editable-table/helpers.js.map +1 -0
- package/dist/components/editable-table/index.d.ts +4 -0
- package/dist/components/editable-table/index.d.ts.map +1 -0
- package/dist/components/editable-table/index.js +4 -0
- package/dist/components/editable-table/types.d.ts +43 -0
- package/dist/components/editable-table/types.d.ts.map +1 -0
- package/dist/components/editable-table/types.js +0 -0
- package/dist/components/editable-table/useEditableTableCellChange.d.ts +17 -0
- package/dist/components/editable-table/useEditableTableCellChange.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableCellChange.js +152 -0
- package/dist/components/editable-table/useEditableTableCellChange.js.map +1 -0
- package/dist/components/editable-table/useEditableTableDnd.d.ts +18 -0
- package/dist/components/editable-table/useEditableTableDnd.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableDnd.js +55 -0
- package/dist/components/editable-table/useEditableTableDnd.js.map +1 -0
- package/dist/components/editable-table/useEditableTableRows.d.ts +17 -0
- package/dist/components/editable-table/useEditableTableRows.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableRows.js +108 -0
- package/dist/components/editable-table/useEditableTableRows.js.map +1 -0
- package/dist/components/index.d.ts +45 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +45 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.d.ts +24 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.d.ts.map +1 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.js +63 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.js.map +1 -0
- package/dist/components/tiptap/InsertLinkDialog.d.ts +14 -0
- package/dist/components/tiptap/InsertLinkDialog.d.ts.map +1 -0
- package/dist/components/tiptap/InsertLinkDialog.js +145 -0
- package/dist/components/tiptap/InsertLinkDialog.js.map +1 -0
- package/dist/components/tiptap/LinkBubbleMenu.d.ts +10 -0
- package/dist/components/tiptap/LinkBubbleMenu.d.ts.map +1 -0
- package/dist/components/tiptap/LinkBubbleMenu.js +106 -0
- package/dist/components/tiptap/LinkBubbleMenu.js.map +1 -0
- package/dist/components/tiptap/LinkDropdown.d.ts +53 -0
- package/dist/components/tiptap/LinkDropdown.d.ts.map +1 -0
- package/dist/components/tiptap/LinkDropdown.js +155 -0
- package/dist/components/tiptap/LinkDropdown.js.map +1 -0
- package/dist/components/tiptap/VariableCommandList.d.ts +37 -0
- package/dist/components/tiptap/VariableCommandList.d.ts.map +1 -0
- package/dist/components/tiptap/VariableCommandList.js +166 -0
- package/dist/components/tiptap/VariableCommandList.js.map +1 -0
- package/dist/components/tiptap/VariableDropdown.d.ts +33 -0
- package/dist/components/tiptap/VariableDropdown.d.ts.map +1 -0
- package/dist/components/tiptap/VariableDropdown.js +121 -0
- package/dist/components/tiptap/VariableDropdown.js.map +1 -0
- package/dist/components/tiptap/VariablePickerContext.d.ts +38 -0
- package/dist/components/tiptap/VariablePickerContext.d.ts.map +1 -0
- package/dist/components/tiptap/VariablePickerContext.js +30 -0
- package/dist/components/tiptap/VariablePickerContext.js.map +1 -0
- package/dist/components/tiptap/VariableTag.d.ts +6 -0
- package/dist/components/tiptap/VariableTag.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTag.js +153 -0
- package/dist/components/tiptap/VariableTag.js.map +1 -0
- package/dist/components/tiptap/VariableTagView.d.ts +3 -0
- package/dist/components/tiptap/VariableTagView.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTagView.js +445 -0
- package/dist/components/tiptap/VariableTagView.js.map +1 -0
- package/dist/components/tiptap/VariableTransformControls.d.ts +37 -0
- package/dist/components/tiptap/VariableTransformControls.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTransformControls.js +157 -0
- package/dist/components/tiptap/VariableTransformControls.js.map +1 -0
- package/dist/components/tiptap/editorConfig.d.ts +15 -0
- package/dist/components/tiptap/editorConfig.d.ts.map +1 -0
- package/dist/components/tiptap/editorConfig.js +191 -0
- package/dist/components/tiptap/editorConfig.js.map +1 -0
- package/dist/components/tiptap/useInlineVariablePicker.d.ts +34 -0
- package/dist/components/tiptap/useInlineVariablePicker.d.ts.map +1 -0
- package/dist/components/tiptap/useInlineVariablePicker.js +240 -0
- package/dist/components/tiptap/useInlineVariablePicker.js.map +1 -0
- package/dist/components/tiptap/useVariablePicker.d.ts +28 -0
- package/dist/components/tiptap/useVariablePicker.d.ts.map +1 -0
- package/dist/components/tiptap/useVariablePicker.js +122 -0
- package/dist/components/tiptap/useVariablePicker.js.map +1 -0
- package/dist/components/tiptap/variablePickerUtils.d.ts +11 -0
- package/dist/components/tiptap/variablePickerUtils.d.ts.map +1 -0
- package/dist/components/tiptap/variablePickerUtils.js +63 -0
- package/dist/components/tiptap/variablePickerUtils.js.map +1 -0
- package/dist/components/tiptap/variableSerialization.d.ts +49 -0
- package/dist/components/tiptap/variableSerialization.d.ts.map +1 -0
- package/dist/components/tiptap/variableSerialization.js +250 -0
- package/dist/components/tiptap/variableSerialization.js.map +1 -0
- package/dist/css/core.css +288 -0
- package/dist/css/style.css +295 -0
- package/dist/forms/Field.d.ts +37 -0
- package/dist/forms/Field.d.ts.map +1 -0
- package/dist/forms/Field.js +159 -0
- package/dist/forms/Field.js.map +1 -0
- package/dist/forms/SchemaFormEngine.d.ts +23 -0
- package/dist/forms/SchemaFormEngine.d.ts.map +1 -0
- package/dist/forms/SchemaFormEngine.js +444 -0
- package/dist/forms/SchemaFormEngine.js.map +1 -0
- package/dist/forms/components/FieldWrap.d.ts +11 -0
- package/dist/forms/components/FieldWrap.d.ts.map +1 -0
- package/dist/forms/components/FieldWrap.js +84 -0
- package/dist/forms/components/FieldWrap.js.map +1 -0
- package/dist/forms/components/ModalTabs.d.ts +21 -0
- package/dist/forms/components/ModalTabs.d.ts.map +1 -0
- package/dist/forms/components/ModalTabs.js +84 -0
- package/dist/forms/components/ModalTabs.js.map +1 -0
- package/dist/forms/components/index.d.ts +3 -0
- package/dist/forms/components/index.d.ts.map +1 -0
- package/dist/forms/components/index.js +3 -0
- package/dist/forms/contexts/VariableCategoriesContext.d.ts +17 -0
- package/dist/forms/contexts/VariableCategoriesContext.d.ts.map +1 -0
- package/dist/forms/contexts/VariableCategoriesContext.js +18 -0
- package/dist/forms/contexts/VariableCategoriesContext.js.map +1 -0
- package/dist/forms/engine/FormStateStore.d.ts +24 -0
- package/dist/forms/engine/FormStateStore.d.ts.map +1 -0
- package/dist/forms/engine/FormStateStore.js +97 -0
- package/dist/forms/engine/FormStateStore.js.map +1 -0
- package/dist/forms/engine/SchemaIndex.d.ts +33 -0
- package/dist/forms/engine/SchemaIndex.d.ts.map +1 -0
- package/dist/forms/engine/SchemaIndex.js +21 -0
- package/dist/forms/engine/SchemaIndex.js.map +1 -0
- package/dist/forms/engine/ValidationEngine.d.ts +13 -0
- package/dist/forms/engine/ValidationEngine.d.ts.map +1 -0
- package/dist/forms/engine/ValidationEngine.js +155 -0
- package/dist/forms/engine/ValidationEngine.js.map +1 -0
- package/dist/forms/engine/buildGroupedMessage.d.ts +2 -0
- package/dist/forms/engine/buildGroupedMessage.d.ts.map +1 -0
- package/dist/forms/engine/buildGroupedMessage.js +20 -0
- package/dist/forms/engine/buildGroupedMessage.js.map +1 -0
- package/dist/forms/engine/context.d.ts +60 -0
- package/dist/forms/engine/context.d.ts.map +1 -0
- package/dist/forms/engine/context.js +12 -0
- package/dist/forms/engine/context.js.map +1 -0
- package/dist/forms/engine/rules/email.d.ts +2 -0
- package/dist/forms/engine/rules/email.d.ts.map +1 -0
- package/dist/forms/engine/rules/email.js +11 -0
- package/dist/forms/engine/rules/email.js.map +1 -0
- package/dist/forms/engine/rules/emailOrVariable.d.ts +2 -0
- package/dist/forms/engine/rules/emailOrVariable.d.ts.map +1 -0
- package/dist/forms/engine/rules/emailOrVariable.js +13 -0
- package/dist/forms/engine/rules/emailOrVariable.js.map +1 -0
- package/dist/forms/engine/rules/handle.d.ts +2 -0
- package/dist/forms/engine/rules/handle.d.ts.map +1 -0
- package/dist/forms/engine/rules/handle.js +12 -0
- package/dist/forms/engine/rules/handle.js.map +1 -0
- package/dist/forms/engine/rules/index.d.ts +9 -0
- package/dist/forms/engine/rules/index.d.ts.map +1 -0
- package/dist/forms/engine/rules/index.js +35 -0
- package/dist/forms/engine/rules/index.js.map +1 -0
- package/dist/forms/engine/rules/max.d.ts +2 -0
- package/dist/forms/engine/rules/max.d.ts.map +1 -0
- package/dist/forms/engine/rules/max.js +16 -0
- package/dist/forms/engine/rules/max.js.map +1 -0
- package/dist/forms/engine/rules/min.d.ts +2 -0
- package/dist/forms/engine/rules/min.d.ts.map +1 -0
- package/dist/forms/engine/rules/min.js +16 -0
- package/dist/forms/engine/rules/min.js.map +1 -0
- package/dist/forms/engine/rules/required.d.ts +2 -0
- package/dist/forms/engine/rules/required.d.ts.map +1 -0
- package/dist/forms/engine/rules/required.js +11 -0
- package/dist/forms/engine/rules/required.js.map +1 -0
- package/dist/forms/engine/rules/uniqueHandle.d.ts +9 -0
- package/dist/forms/engine/rules/uniqueHandle.d.ts.map +1 -0
- package/dist/forms/engine/rules/uniqueHandle.js +95 -0
- package/dist/forms/engine/rules/uniqueHandle.js.map +1 -0
- package/dist/forms/engine/rules/utils.d.ts +3 -0
- package/dist/forms/engine/rules/utils.d.ts.map +1 -0
- package/dist/forms/engine/rules/utils.js +21 -0
- package/dist/forms/engine/rules/utils.js.map +1 -0
- package/dist/forms/fields/CalculationsField.d.ts +24 -0
- package/dist/forms/fields/CalculationsField.d.ts.map +1 -0
- package/dist/forms/fields/CalculationsField.js +215 -0
- package/dist/forms/fields/CalculationsField.js.map +1 -0
- package/dist/forms/fields/CalculationsToolbar.d.ts +17 -0
- package/dist/forms/fields/CalculationsToolbar.d.ts.map +1 -0
- package/dist/forms/fields/CalculationsToolbar.js +130 -0
- package/dist/forms/fields/CalculationsToolbar.js.map +1 -0
- package/dist/forms/fields/CheckboxSelectField.d.ts +19 -0
- package/dist/forms/fields/CheckboxSelectField.d.ts.map +1 -0
- package/dist/forms/fields/CheckboxSelectField.js +30 -0
- package/dist/forms/fields/CheckboxSelectField.js.map +1 -0
- package/dist/forms/fields/ColorField.d.ts +15 -0
- package/dist/forms/fields/ColorField.d.ts.map +1 -0
- package/dist/forms/fields/ColorField.js +30 -0
- package/dist/forms/fields/ColorField.js.map +1 -0
- package/dist/forms/fields/ComboboxField.d.ts +23 -0
- package/dist/forms/fields/ComboboxField.d.ts.map +1 -0
- package/dist/forms/fields/ComboboxField.js +38 -0
- package/dist/forms/fields/ComboboxField.js.map +1 -0
- package/dist/forms/fields/DateTimeField.d.ts +14 -0
- package/dist/forms/fields/DateTimeField.d.ts.map +1 -0
- package/dist/forms/fields/DateTimeField.js +53 -0
- package/dist/forms/fields/DateTimeField.js.map +1 -0
- package/dist/forms/fields/EditableTableField.d.ts +22 -0
- package/dist/forms/fields/EditableTableField.d.ts.map +1 -0
- package/dist/forms/fields/EditableTableField.js +37 -0
- package/dist/forms/fields/EditableTableField.js.map +1 -0
- package/dist/forms/fields/ElementSelectField.d.ts +20 -0
- package/dist/forms/fields/ElementSelectField.d.ts.map +1 -0
- package/dist/forms/fields/ElementSelectField.js +215 -0
- package/dist/forms/fields/ElementSelectField.js.map +1 -0
- package/dist/forms/fields/GroupField.d.ts +19 -0
- package/dist/forms/fields/GroupField.d.ts.map +1 -0
- package/dist/forms/fields/GroupField.js +50 -0
- package/dist/forms/fields/GroupField.js.map +1 -0
- package/dist/forms/fields/HandleField.d.ts +20 -0
- package/dist/forms/fields/HandleField.d.ts.map +1 -0
- package/dist/forms/fields/HandleField.js +70 -0
- package/dist/forms/fields/HandleField.js.map +1 -0
- package/dist/forms/fields/LightswitchField.d.ts +14 -0
- package/dist/forms/fields/LightswitchField.d.ts.map +1 -0
- package/dist/forms/fields/LightswitchField.js +29 -0
- package/dist/forms/fields/LightswitchField.js.map +1 -0
- package/dist/forms/fields/ListField.d.ts +17 -0
- package/dist/forms/fields/ListField.d.ts.map +1 -0
- package/dist/forms/fields/ListField.js +51 -0
- package/dist/forms/fields/ListField.js.map +1 -0
- package/dist/forms/fields/NumberField.d.ts +17 -0
- package/dist/forms/fields/NumberField.d.ts.map +1 -0
- package/dist/forms/fields/NumberField.js +33 -0
- package/dist/forms/fields/NumberField.js.map +1 -0
- package/dist/forms/fields/RadioGroupField.d.ts +25 -0
- package/dist/forms/fields/RadioGroupField.d.ts.map +1 -0
- package/dist/forms/fields/RadioGroupField.js +102 -0
- package/dist/forms/fields/RadioGroupField.js.map +1 -0
- package/dist/forms/fields/RichTextField.d.ts +23 -0
- package/dist/forms/fields/RichTextField.d.ts.map +1 -0
- package/dist/forms/fields/RichTextField.js +50 -0
- package/dist/forms/fields/RichTextField.js.map +1 -0
- package/dist/forms/fields/SelectField.d.ts +25 -0
- package/dist/forms/fields/SelectField.d.ts.map +1 -0
- package/dist/forms/fields/SelectField.js +73 -0
- package/dist/forms/fields/SelectField.js.map +1 -0
- package/dist/forms/fields/StaticTableField.d.ts +34 -0
- package/dist/forms/fields/StaticTableField.d.ts.map +1 -0
- package/dist/forms/fields/StaticTableField.js +128 -0
- package/dist/forms/fields/StaticTableField.js.map +1 -0
- package/dist/forms/fields/TextField.d.ts +16 -0
- package/dist/forms/fields/TextField.d.ts.map +1 -0
- package/dist/forms/fields/TextField.js +31 -0
- package/dist/forms/fields/TextField.js.map +1 -0
- package/dist/forms/fields/TextareaField.d.ts +17 -0
- package/dist/forms/fields/TextareaField.d.ts.map +1 -0
- package/dist/forms/fields/TextareaField.js +32 -0
- package/dist/forms/fields/TextareaField.js.map +1 -0
- package/dist/forms/fields/VariablePickerField.d.ts +21 -0
- package/dist/forms/fields/VariablePickerField.d.ts.map +1 -0
- package/dist/forms/fields/VariablePickerField.js +49 -0
- package/dist/forms/fields/VariablePickerField.js.map +1 -0
- package/dist/forms/index.d.ts +8 -0
- package/dist/forms/index.d.ts.map +1 -0
- package/dist/forms/index.js +10 -0
- package/dist/forms/registry.d.ts +8 -0
- package/dist/forms/registry.d.ts.map +1 -0
- package/dist/forms/registry.js +76 -0
- package/dist/forms/registry.js.map +1 -0
- package/dist/forms/store/element-store.d.ts +11 -0
- package/dist/forms/store/element-store.d.ts.map +1 -0
- package/dist/forms/store/element-store.js +41 -0
- package/dist/forms/store/element-store.js.map +1 -0
- package/dist/forms/useEditableTableFieldBinding.d.ts +13 -0
- package/dist/forms/useEditableTableFieldBinding.d.ts.map +1 -0
- package/dist/forms/useEditableTableFieldBinding.js +91 -0
- package/dist/forms/useEditableTableFieldBinding.js.map +1 -0
- package/dist/forms/useEngineField.d.ts +9 -0
- package/dist/forms/useEngineField.d.ts.map +1 -0
- package/dist/forms/useEngineField.js +32 -0
- package/dist/forms/useEngineField.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts +14 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
- package/dist/hooks/useKeyboardShortcuts.js +67 -0
- package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
- package/dist/hooks/useTranslation.d.ts +3 -0
- package/dist/hooks/useTranslation.d.ts.map +1 -0
- package/dist/hooks/useTranslation.js +12 -0
- package/dist/hooks/useTranslation.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js +15 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js +15 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/createClass.js +21 -0
- package/dist/node_modules/@babel/runtime/helpers/createClass.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/defineProperty.js +20 -0
- package/dist/node_modules/@babel/runtime/helpers/defineProperty.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js +21 -0
- package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js +22 -0
- package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js +18 -0
- package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/typeof.js +18 -0
- package/dist/node_modules/@babel/runtime/helpers/typeof.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js +19 -0
- package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js.map +1 -0
- package/dist/node_modules/jexl/dist/Expression.js +84 -0
- package/dist/node_modules/jexl/dist/Expression.js.map +1 -0
- package/dist/node_modules/jexl/dist/Jexl.js +165 -0
- package/dist/node_modules/jexl/dist/Jexl.js.map +1 -0
- package/dist/node_modules/jexl/dist/Lexer.js +152 -0
- package/dist/node_modules/jexl/dist/Lexer.js.map +1 -0
- package/dist/node_modules/jexl/dist/PromiseSync.js +87 -0
- package/dist/node_modules/jexl/dist/PromiseSync.js.map +1 -0
- package/dist/node_modules/jexl/dist/evaluator/Evaluator.js +98 -0
- package/dist/node_modules/jexl/dist/evaluator/Evaluator.js.map +1 -0
- package/dist/node_modules/jexl/dist/evaluator/handlers.js +162 -0
- package/dist/node_modules/jexl/dist/evaluator/handlers.js.map +1 -0
- package/dist/node_modules/jexl/dist/grammar.js +195 -0
- package/dist/node_modules/jexl/dist/grammar.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/Parser.js +135 -0
- package/dist/node_modules/jexl/dist/parser/Parser.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/handlers.js +205 -0
- package/dist/node_modules/jexl/dist/parser/handlers.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/states.js +158 -0
- package/dist/node_modules/jexl/dist/parser/states.js.map +1 -0
- package/dist/types/global.d.d.ts +1 -0
- package/dist/types/global.d.js +0 -0
- package/dist/utils/classes.d.ts +18 -0
- package/dist/utils/classes.d.ts.map +1 -0
- package/dist/utils/classes.js +25 -0
- package/dist/utils/classes.js.map +1 -0
- package/dist/utils/config.d.ts +14 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +16 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/craftHostBridge.d.ts +16 -0
- package/dist/utils/craftHostBridge.d.ts.map +1 -0
- package/dist/utils/craftHostBridge.js +28 -0
- package/dist/utils/craftHostBridge.js.map +1 -0
- package/dist/utils/handle.d.ts +10 -0
- package/dist/utils/handle.d.ts.map +1 -0
- package/dist/utils/handle.js +51 -0
- package/dist/utils/handle.js.map +1 -0
- package/dist/utils/hostBridge.d.ts +40 -0
- package/dist/utils/hostBridge.d.ts.map +1 -0
- package/dist/utils/hostBridge.js +35 -0
- package/dist/utils/hostBridge.js.map +1 -0
- package/dist/utils/index.d.ts +18 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +66 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/portal.d.ts +17 -0
- package/dist/utils/portal.d.ts.map +1 -0
- package/dist/utils/portal.js +51 -0
- package/dist/utils/portal.js.map +1 -0
- package/dist/utils/schema.d.ts +17 -0
- package/dist/utils/schema.d.ts.map +1 -0
- package/dist/utils/schema.js +56 -0
- package/dist/utils/schema.js.map +1 -0
- package/dist/utils/schemaFieldNames.d.ts +2 -0
- package/dist/utils/schemaFieldNames.d.ts.map +1 -0
- package/dist/utils/schemaFieldNames.js +16 -0
- package/dist/utils/schemaFieldNames.js.map +1 -0
- package/dist/utils/schemaIndex.d.ts +6 -0
- package/dist/utils/schemaIndex.d.ts.map +1 -0
- package/dist/utils/schemaIndex.js +31 -0
- package/dist/utils/schemaIndex.js.map +1 -0
- package/dist/utils/schemaIndexCache.d.ts +6 -0
- package/dist/utils/schemaIndexCache.d.ts.map +1 -0
- package/dist/utils/schemaIndexCache.js +32 -0
- package/dist/utils/schemaIndexCache.js.map +1 -0
- package/dist/utils/schemaNormalize.d.ts +13 -0
- package/dist/utils/schemaNormalize.d.ts.map +1 -0
- package/dist/utils/schemaNormalize.js +17 -0
- package/dist/utils/schemaNormalize.js.map +1 -0
- package/dist/utils/store.d.ts +7 -0
- package/dist/utils/store.d.ts.map +1 -0
- package/dist/utils/store.js +6 -0
- package/dist/utils/store.js.map +1 -0
- package/dist/utils/timeOptions.d.ts +6 -0
- package/dist/utils/timeOptions.d.ts.map +1 -0
- package/dist/utils/timeOptions.js +42 -0
- package/dist/utils/timeOptions.js.map +1 -0
- package/dist/utils/tiptap.d.ts +13 -0
- package/dist/utils/tiptap.d.ts.map +1 -0
- package/dist/utils/tiptap.js +39 -0
- package/dist/utils/tiptap.js.map +1 -0
- package/dist/utils/translation.d.ts +5 -0
- package/dist/utils/translation.d.ts.map +1 -0
- package/dist/utils/translation.js +21 -0
- package/dist/utils/translation.js.map +1 -0
- package/dist/utils/validation.d.ts +4 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +253 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +167 -0
- package/vite-dev.mjs +56 -0
package/CHANGELOG.md
ADDED
package/LICENSE.md
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) Verbb
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# @verbb/plugin-kit-react
|
|
2
|
+
|
|
3
|
+
React UI and form primitives for Craft CMS plugin development.
|
|
4
|
+
|
|
5
|
+
## Install
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install @verbb/plugin-kit-react @verbb/plugin-kit react react-dom
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Usage
|
|
12
|
+
|
|
13
|
+
Import only from the published package entrypoints:
|
|
14
|
+
|
|
15
|
+
```tsx
|
|
16
|
+
import { useTranslation } from '@verbb/plugin-kit-react/hooks';
|
|
17
|
+
import { Button } from '@verbb/plugin-kit-react/components';
|
|
18
|
+
import { cn } from '@verbb/plugin-kit-react/utils';
|
|
19
|
+
import '@verbb/plugin-kit-react/style.css';
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Public Surface
|
|
23
|
+
|
|
24
|
+
- `@verbb/plugin-kit-react` (`useTranslation`)
|
|
25
|
+
- `@verbb/plugin-kit-react/components`
|
|
26
|
+
- `@verbb/plugin-kit-react/forms`
|
|
27
|
+
- `@verbb/plugin-kit-react/hooks`
|
|
28
|
+
- `@verbb/plugin-kit-react/utils`
|
|
29
|
+
- `@verbb/plugin-kit-react/style.css`
|
|
30
|
+
|
|
31
|
+
Avoid importing from internal source paths. Anything outside the exported subpaths is private and may change without notice.
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
//#region \0rolldown/runtime.js
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __commonJSMin = (cb, mod) => () => (mod || (cb((mod = { exports: {} }).exports, mod), cb = null), mod.exports);
|
|
9
|
+
var __exportAll = (all, no_symbols) => {
|
|
10
|
+
let target = {};
|
|
11
|
+
for (var name in all) __defProp(target, name, {
|
|
12
|
+
get: all[name],
|
|
13
|
+
enumerable: true
|
|
14
|
+
});
|
|
15
|
+
if (!no_symbols) __defProp(target, Symbol.toStringTag, { value: "Module" });
|
|
16
|
+
return target;
|
|
17
|
+
};
|
|
18
|
+
var __copyProps = (to, from, except, desc) => {
|
|
19
|
+
if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
|
|
20
|
+
key = keys[i];
|
|
21
|
+
if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
|
|
22
|
+
get: ((k) => from[k]).bind(null, key),
|
|
23
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
return to;
|
|
27
|
+
};
|
|
28
|
+
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
29
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
30
|
+
value: mod,
|
|
31
|
+
enumerable: true
|
|
32
|
+
}) : target, mod));
|
|
33
|
+
//#endregion
|
|
34
|
+
export { __commonJSMin, __exportAll, __reExport, __toESM };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ButtonHTMLAttributes, ReactElement } from 'react';
|
|
2
|
+
import { VariantProps } from 'class-variance-authority';
|
|
3
|
+
declare const buttonVariants: (props?: ({
|
|
4
|
+
variant?: "link" | "default" | "none" | "primary" | "secondary" | "dashed" | "outline" | "transparent" | "ghost" | null | undefined;
|
|
5
|
+
size?: "default" | "none" | "xxs" | "xs" | "sm" | "icon" | "lg" | "xl" | null | undefined;
|
|
6
|
+
loading?: boolean | null | undefined;
|
|
7
|
+
} & import('class-variance-authority/types').ClassProp) | undefined) => string;
|
|
8
|
+
type SpinnerVariant = 'default' | 'primary' | 'secondary' | 'dashed' | 'outline' | 'transparent';
|
|
9
|
+
type SpinnerSize = 'xxs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | null;
|
|
10
|
+
declare const Button: import('react').ForwardRefExoticComponent<Omit<ButtonHTMLAttributes<HTMLButtonElement>, "size"> & VariantProps<(props?: ({
|
|
11
|
+
variant?: "link" | "default" | "none" | "primary" | "secondary" | "dashed" | "outline" | "transparent" | "ghost" | null | undefined;
|
|
12
|
+
size?: "default" | "none" | "xxs" | "xs" | "sm" | "icon" | "lg" | "xl" | null | undefined;
|
|
13
|
+
loading?: boolean | null | undefined;
|
|
14
|
+
} & import('class-variance-authority/types').ClassProp) | undefined) => string> & {
|
|
15
|
+
asChild?: boolean;
|
|
16
|
+
render?: ReactElement;
|
|
17
|
+
href?: string;
|
|
18
|
+
target?: string;
|
|
19
|
+
rel?: string;
|
|
20
|
+
download?: string | boolean;
|
|
21
|
+
spinnerSize?: SpinnerSize;
|
|
22
|
+
spinnerVariant?: SpinnerVariant;
|
|
23
|
+
spinnerClassName?: string;
|
|
24
|
+
} & import('react').RefAttributes<HTMLAnchorElement | HTMLButtonElement>>;
|
|
25
|
+
export { Button, buttonVariants };
|
|
26
|
+
//# sourceMappingURL=Button.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../src/components/Button.tsx"],"names":[],"mappings":"AAAA,OAAO,EAGH,KAAK,oBAAoB,EAMzB,KAAK,YAAY,EACpB,MAAM,OAAO,CAAC;AACf,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAOlE,QAAA,MAAM,cAAc;;;;8EA6ElB,CAAC;AAEH,KAAK,cAAc,GAAG,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,SAAS,GAAG,aAAa,CAAC;AACjG,KAAK,WAAW,GAAG,KAAK,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAenE,QAAA,MAAM,MAAM;;;;;cAXM,OAAO;aACR,YAAY;WACd,MAAM;aACJ,MAAM;UACT,MAAM;eACD,MAAM,GAAG,OAAO;kBACb,WAAW;qBACR,cAAc;uBACZ,MAAM;yEAyH/B,CAAC;AAEH,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { cn } from "../utils/classes.js";
|
|
2
|
+
import "../utils/index.js";
|
|
3
|
+
import { Spinner } from "./Spinner.js";
|
|
4
|
+
import "./index.js";
|
|
5
|
+
import { Slot } from "./Slot.js";
|
|
6
|
+
import { forwardRef } from "react";
|
|
7
|
+
import { cva } from "class-variance-authority";
|
|
8
|
+
import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
//#region src/components/Button.tsx
|
|
10
|
+
var buttonVariants = cva("", {
|
|
11
|
+
variants: {
|
|
12
|
+
variant: {
|
|
13
|
+
default: [
|
|
14
|
+
"bg-slate-250 text-gray-700",
|
|
15
|
+
"hover:not-disabled:bg-slate-300",
|
|
16
|
+
"active:not-disabled:bg-slate-400",
|
|
17
|
+
"focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
18
|
+
"data-[popup-open]:bg-slate-300"
|
|
19
|
+
],
|
|
20
|
+
primary: [
|
|
21
|
+
"antialiased",
|
|
22
|
+
"bg-red-600 text-white border-primary-500",
|
|
23
|
+
"hover:not-disabled:bg-red-700",
|
|
24
|
+
"active:not-disabled:bg-red-800",
|
|
25
|
+
"focus-visible:shadow-[0_0_0_1px_#ffffff,0_0_0_3px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
26
|
+
"data-[popup-open]:bg-red-700"
|
|
27
|
+
],
|
|
28
|
+
secondary: [
|
|
29
|
+
"antialiased",
|
|
30
|
+
"bg-gray-500 text-white",
|
|
31
|
+
"hover:not-disabled:bg-gray-550",
|
|
32
|
+
"active:not-disabled:bg-gray-600",
|
|
33
|
+
"focus-visible:shadow-[0_0_0_1px_#ffffff,0_0_0_3px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
34
|
+
"data-[popup-open]:bg-gray-550"
|
|
35
|
+
],
|
|
36
|
+
dashed: [
|
|
37
|
+
"bg-transparent border-dashed border border-slate-500",
|
|
38
|
+
"hover:not-disabled:bg-slate-150",
|
|
39
|
+
"active:not-disabled:bg-slate-250",
|
|
40
|
+
"focus-visible:border-solid focus-visible:border-sky-600 focus-visible:shadow-[0_0_0_1px_var(--color-sky-600),0_0_4px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
41
|
+
"data-[popup-open]:bg-slate-250"
|
|
42
|
+
],
|
|
43
|
+
outline: [
|
|
44
|
+
"bg-transparent border border-slate-400",
|
|
45
|
+
"hover:not-disabled:bg-slate-150",
|
|
46
|
+
"active:not-disabled:bg-slate-250",
|
|
47
|
+
"focus-visible:border-solid focus-visible:border-sky-600 focus-visible:shadow-[0_0_0_1px_var(--color-sky-600),0_0_4px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
48
|
+
"data-[popup-open]:bg-slate-250"
|
|
49
|
+
],
|
|
50
|
+
transparent: [
|
|
51
|
+
"hover:not-disabled:bg-slate-150",
|
|
52
|
+
"active:not-disabled:bg-slate-250",
|
|
53
|
+
"focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]",
|
|
54
|
+
"data-[popup-open]:bg-slate-250"
|
|
55
|
+
],
|
|
56
|
+
ghost: [
|
|
57
|
+
"hover:not-disabled:bg-slate-150",
|
|
58
|
+
"active:not-disabled:bg-slate-250",
|
|
59
|
+
"focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]"
|
|
60
|
+
],
|
|
61
|
+
link: [
|
|
62
|
+
"rounded-none px-0 py-0 text-sky-700 underline-offset-2",
|
|
63
|
+
"hover:not-disabled:underline",
|
|
64
|
+
"focus-visible:shadow-none focus-visible:underline"
|
|
65
|
+
],
|
|
66
|
+
none: []
|
|
67
|
+
},
|
|
68
|
+
size: {
|
|
69
|
+
default: "px-[10px] py-[7px]",
|
|
70
|
+
none: "p-0",
|
|
71
|
+
xxs: "px-[5px] py-[1px] text-[11px] rounded-sm",
|
|
72
|
+
xs: "px-[8px] py-[3px] text-[12px] rounded-sm",
|
|
73
|
+
sm: "px-[9px] py-[5px] text-[13px] rounded-md",
|
|
74
|
+
icon: "size-8 p-0 justify-center",
|
|
75
|
+
lg: "px-[12px] py-[9px]",
|
|
76
|
+
xl: "px-[16px] py-[10px] text-base"
|
|
77
|
+
},
|
|
78
|
+
loading: { true: "cursor-default" }
|
|
79
|
+
},
|
|
80
|
+
defaultVariants: {
|
|
81
|
+
variant: "default",
|
|
82
|
+
size: "default",
|
|
83
|
+
loading: false
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
var Button = forwardRef(({ className, variant, size, spinnerSize = null, spinnerVariant, spinnerClassName = "", loading = false, children, asChild = false, render, href, type, ...props }, ref) => {
|
|
87
|
+
if (spinnerSize === null) if (size === "xxs" || size === "xs") spinnerSize = "xxs";
|
|
88
|
+
else if (size === "lg" || size === "xl") spinnerSize = "sm";
|
|
89
|
+
else spinnerSize = "xs";
|
|
90
|
+
const resolvedVariant = variant === "ghost" ? "transparent" : variant;
|
|
91
|
+
const resolvedSpinnerVariant = spinnerVariant || (resolvedVariant === "primary" || resolvedVariant === "secondary" || resolvedVariant === "dashed" || resolvedVariant === "outline" || resolvedVariant === "transparent" ? resolvedVariant : "default");
|
|
92
|
+
const sharedProps = {
|
|
93
|
+
"data-slot": "button",
|
|
94
|
+
"data-size": size || "default",
|
|
95
|
+
className: cn("no-underline hover:no-underline", "inline-flex cursor-pointer outline-none gap-1 items-center justify-center whitespace-nowrap transition-colors", "rounded-lg", "disabled:opacity-50 disabled:cursor-[not-allowed]! disabled:select-none", loading && ["relative pointer-events-none text-transparent!", "select-none!"], "[&[data-size='xxs']_svg:not([class*='size-'])]:size-3", "[&[data-size='xs']_svg:not([class*='size-'])]:size-3.5", "[&[data-size='sm']_svg:not([class*='size-'])]:size-3.5", "[&:not([data-size='xxs']):not([data-size='xs']):not([data-size='sm'])_svg:not([class*='size-'])]:size-4", "[&_svg]:pointer-events-none [&_svg]:shrink-0", buttonVariants({
|
|
96
|
+
variant: resolvedVariant,
|
|
97
|
+
size,
|
|
98
|
+
loading,
|
|
99
|
+
className
|
|
100
|
+
}))
|
|
101
|
+
};
|
|
102
|
+
const content = /* @__PURE__ */ jsxs(Fragment$1, { children: [loading && /* @__PURE__ */ jsx(Spinner, {
|
|
103
|
+
variant: resolvedSpinnerVariant,
|
|
104
|
+
size: spinnerSize,
|
|
105
|
+
className: cn("absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2", spinnerClassName)
|
|
106
|
+
}), children] });
|
|
107
|
+
if (render) return /* @__PURE__ */ jsx(Slot, {
|
|
108
|
+
...sharedProps,
|
|
109
|
+
children: render
|
|
110
|
+
});
|
|
111
|
+
if (asChild) return /* @__PURE__ */ jsx(Slot, {
|
|
112
|
+
...sharedProps,
|
|
113
|
+
children
|
|
114
|
+
});
|
|
115
|
+
if (href) {
|
|
116
|
+
const anchorProps = {
|
|
117
|
+
target: props.target,
|
|
118
|
+
rel: props.rel,
|
|
119
|
+
download: props.download,
|
|
120
|
+
onClick: props.onClick,
|
|
121
|
+
onFocus: props.onFocus,
|
|
122
|
+
onBlur: props.onBlur,
|
|
123
|
+
onMouseEnter: props.onMouseEnter,
|
|
124
|
+
onMouseLeave: props.onMouseLeave,
|
|
125
|
+
onKeyDown: props.onKeyDown,
|
|
126
|
+
onKeyUp: props.onKeyUp,
|
|
127
|
+
onCopy: props.onCopy
|
|
128
|
+
};
|
|
129
|
+
return /* @__PURE__ */ jsx("a", {
|
|
130
|
+
ref,
|
|
131
|
+
href,
|
|
132
|
+
...sharedProps,
|
|
133
|
+
...anchorProps,
|
|
134
|
+
children: content
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
return /* @__PURE__ */ jsx("button", {
|
|
138
|
+
ref,
|
|
139
|
+
type: type || "button",
|
|
140
|
+
...sharedProps,
|
|
141
|
+
...props,
|
|
142
|
+
children: content
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
//#endregion
|
|
146
|
+
export { Button, buttonVariants };
|
|
147
|
+
|
|
148
|
+
//# sourceMappingURL=Button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Button.js","names":[],"sources":["../../src/components/Button.tsx"],"sourcesContent":["import {\n forwardRef,\n type AnchorHTMLAttributes,\n type ButtonHTMLAttributes,\n type ClipboardEventHandler,\n type FocusEventHandler,\n type KeyboardEventHandler,\n type MouseEventHandler,\n type Ref,\n type ReactElement,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\n\nimport { cn } from '@verbb/plugin-kit-react/utils';\n\nimport { Spinner } from '@verbb/plugin-kit-react/components';\nimport { Slot } from '@verbb/plugin-kit-react/components/Slot';\n\nconst buttonVariants = cva('', {\n variants: {\n variant: {\n default: [\n 'bg-slate-250 text-gray-700',\n 'hover:not-disabled:bg-slate-300',\n 'active:not-disabled:bg-slate-400',\n 'focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-slate-300',\n ],\n primary: [\n 'antialiased',\n 'bg-red-600 text-white border-primary-500',\n 'hover:not-disabled:bg-red-700',\n 'active:not-disabled:bg-red-800',\n 'focus-visible:shadow-[0_0_0_1px_#ffffff,0_0_0_3px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-red-700',\n ],\n secondary: [\n 'antialiased',\n 'bg-gray-500 text-white',\n 'hover:not-disabled:bg-gray-550',\n 'active:not-disabled:bg-gray-600',\n 'focus-visible:shadow-[0_0_0_1px_#ffffff,0_0_0_3px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-gray-550',\n ],\n dashed: [\n 'bg-transparent border-dashed border border-slate-500',\n 'hover:not-disabled:bg-slate-150',\n 'active:not-disabled:bg-slate-250',\n 'focus-visible:border-solid focus-visible:border-sky-600 focus-visible:shadow-[0_0_0_1px_var(--color-sky-600),0_0_4px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-slate-250',\n ],\n outline: [\n 'bg-transparent border border-slate-400',\n 'hover:not-disabled:bg-slate-150',\n 'active:not-disabled:bg-slate-250',\n 'focus-visible:border-solid focus-visible:border-sky-600 focus-visible:shadow-[0_0_0_1px_var(--color-sky-600),0_0_4px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-slate-250',\n ],\n transparent: [\n 'hover:not-disabled:bg-slate-150',\n 'active:not-disabled:bg-slate-250',\n 'focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n 'data-[popup-open]:bg-slate-250',\n ],\n ghost: [\n 'hover:not-disabled:bg-slate-150',\n 'active:not-disabled:bg-slate-250',\n 'focus-visible:shadow-[0_0_0_2px_var(--color-sky-600),0_0_5px_1px_hsl(from_var(--color-sky-600)_h_s_l/0.7)]',\n ],\n link: [\n 'rounded-none px-0 py-0 text-sky-700 underline-offset-2',\n 'hover:not-disabled:underline',\n 'focus-visible:shadow-none focus-visible:underline',\n ],\n none: [],\n },\n size: {\n default: 'px-[10px] py-[7px]',\n none: 'p-0',\n xxs: 'px-[5px] py-[1px] text-[11px] rounded-sm',\n xs: 'px-[8px] py-[3px] text-[12px] rounded-sm',\n sm: 'px-[9px] py-[5px] text-[13px] rounded-md',\n icon: 'size-8 p-0 justify-center',\n lg: 'px-[12px] py-[9px]',\n xl: 'px-[16px] py-[10px] text-base',\n },\n loading: {\n true: 'cursor-default',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n loading: false,\n },\n});\n\ntype SpinnerVariant = 'default' | 'primary' | 'secondary' | 'dashed' | 'outline' | 'transparent';\ntype SpinnerSize = 'xxs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | null;\n\ntype ButtonProps = Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'size'> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean\n render?: ReactElement\n href?: string\n target?: string\n rel?: string\n download?: string | boolean\n spinnerSize?: SpinnerSize\n spinnerVariant?: SpinnerVariant\n spinnerClassName?: string\n };\n\nconst Button = forwardRef<HTMLButtonElement | HTMLAnchorElement, ButtonProps>(({\n className,\n variant,\n size,\n spinnerSize = null,\n spinnerVariant,\n spinnerClassName = '',\n loading = false,\n children,\n asChild = false,\n render,\n href,\n type,\n ...props\n}, ref) => {\n if (spinnerSize === null) {\n if (size === 'xxs' || size === 'xs') {\n spinnerSize = 'xxs';\n } else if (size === 'lg' || size === 'xl') {\n spinnerSize = 'sm';\n } else {\n spinnerSize = 'xs';\n }\n }\n\n const resolvedVariant = variant === 'ghost' ? 'transparent' : variant;\n const resolvedSpinnerVariant = spinnerVariant || (resolvedVariant === 'primary' || resolvedVariant === 'secondary' || resolvedVariant === 'dashed' || resolvedVariant === 'outline' || resolvedVariant === 'transparent'\n ? resolvedVariant\n : 'default');\n const sharedProps = {\n 'data-slot': 'button',\n 'data-size': size || 'default',\n className: cn(\n 'no-underline hover:no-underline',\n 'inline-flex cursor-pointer outline-none gap-1 items-center justify-center whitespace-nowrap transition-colors',\n 'rounded-lg',\n 'disabled:opacity-50 disabled:cursor-[not-allowed]! disabled:select-none',\n loading && [\n 'relative pointer-events-none text-transparent!',\n 'select-none!',\n ],\n \"[&[data-size='xxs']_svg:not([class*='size-'])]:size-3\",\n \"[&[data-size='xs']_svg:not([class*='size-'])]:size-3.5\",\n \"[&[data-size='sm']_svg:not([class*='size-'])]:size-3.5\",\n \"[&:not([data-size='xxs']):not([data-size='xs']):not([data-size='sm'])_svg:not([class*='size-'])]:size-4\",\n '[&_svg]:pointer-events-none [&_svg]:shrink-0',\n buttonVariants({\n variant: resolvedVariant,\n size,\n loading,\n className,\n }),\n ),\n } as const;\n\n const content = (\n <>\n {loading && <Spinner variant={resolvedSpinnerVariant} size={spinnerSize} className={cn(\n 'absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2',\n spinnerClassName,\n )} />}\n {children}\n </>\n );\n\n if (render) {\n return (\n <Slot {...sharedProps}>\n {render}\n </Slot>\n );\n }\n\n if (asChild) {\n return (\n <Slot {...sharedProps}>\n {children as ReactElement}\n </Slot>\n );\n }\n\n if (href) {\n const anchorProps: AnchorHTMLAttributes<HTMLAnchorElement> = {\n target: props.target,\n rel: props.rel,\n download: props.download,\n onClick: props.onClick as MouseEventHandler<HTMLAnchorElement> | undefined,\n onFocus: props.onFocus as FocusEventHandler<HTMLAnchorElement> | undefined,\n onBlur: props.onBlur as FocusEventHandler<HTMLAnchorElement> | undefined,\n onMouseEnter: props.onMouseEnter as MouseEventHandler<HTMLAnchorElement> | undefined,\n onMouseLeave: props.onMouseLeave as MouseEventHandler<HTMLAnchorElement> | undefined,\n onKeyDown: props.onKeyDown as KeyboardEventHandler<HTMLAnchorElement> | undefined,\n onKeyUp: props.onKeyUp as KeyboardEventHandler<HTMLAnchorElement> | undefined,\n onCopy: props.onCopy as ClipboardEventHandler<HTMLAnchorElement> | undefined,\n };\n\n return (\n <a\n ref={ref as Ref<HTMLAnchorElement>}\n href={href}\n {...sharedProps}\n {...anchorProps}\n >\n {content}\n </a>\n );\n }\n\n return (\n <button\n ref={ref as Ref<HTMLButtonElement>}\n type={type || 'button'}\n {...sharedProps}\n {...props}\n >\n {content}\n </button>\n );\n});\n\nexport { Button, buttonVariants };\n"],"mappings":";;;;;;;;;AAkBA,IAAM,iBAAiB,IAAI,IAAI;CAC3B,UAAU;EACN,SAAS;GACL,SAAS;IACL;IACA;IACA;IACA;IACA;IACH;GACD,SAAS;IACL;IACA;IACA;IACA;IACA;IACA;IACH;GACD,WAAW;IACP;IACA;IACA;IACA;IACA;IACA;IACH;GACD,QAAQ;IACJ;IACA;IACA;IACA;IACA;IACH;GACD,SAAS;IACL;IACA;IACA;IACA;IACA;IACH;GACD,aAAa;IACT;IACA;IACA;IACA;IACH;GACD,OAAO;IACH;IACA;IACA;IACH;GACD,MAAM;IACF;IACA;IACA;IACH;GACD,MAAM,EAAE;GACX;EACD,MAAM;GACF,SAAS;GACT,MAAM;GACN,KAAK;GACL,IAAI;GACJ,IAAI;GACJ,MAAM;GACN,IAAI;GACJ,IAAI;GACP;EACD,SAAS,EACL,MAAM,kBACT;EACJ;CACD,iBAAiB;EACb,SAAS;EACT,MAAM;EACN,SAAS;EACZ;CACJ,CAAC;AAkBF,IAAM,SAAS,YAAgE,EAC3E,WACA,SACA,MACA,cAAc,MACd,gBACA,mBAAmB,IACnB,UAAU,OACV,UACA,UAAU,OACV,QACA,MACA,MACA,GAAG,SACJ,QAAQ;AACP,KAAI,gBAAgB,KAChB,KAAI,SAAS,SAAS,SAAS,KAC3B,eAAc;UACP,SAAS,QAAQ,SAAS,KACjC,eAAc;KAEd,eAAc;CAItB,MAAM,kBAAkB,YAAY,UAAU,gBAAgB;CAC9D,MAAM,yBAAyB,mBAAmB,oBAAoB,aAAa,oBAAoB,eAAe,oBAAoB,YAAY,oBAAoB,aAAa,oBAAoB,gBACrM,kBACA;CACN,MAAM,cAAc;EAChB,aAAa;EACb,aAAa,QAAQ;EACrB,WAAW,GACP,mCACA,iHACA,cACA,2EACA,WAAW,CACP,kDACA,eACH,EACD,yDACA,0DACA,0DACA,2GACA,gDACA,eAAe;GACX,SAAS;GACT;GACA;GACA;GACH,CAAC,CACL;EACJ;CAED,MAAM,UACF,qBAAA,YAAA,EAAA,UAAA,CACK,WAAW,oBAAC,SAAD;EAAS,SAAS;EAAwB,MAAM;EAAa,WAAW,GAChF,yEACA,iBACH;EAAI,CAAA,EACJ,SACF,EAAA,CAAA;AAGP,KAAI,OACA,QACI,oBAAC,MAAD;EAAM,GAAI;YACL;EACE,CAAA;AAIf,KAAI,QACA,QACI,oBAAC,MAAD;EAAM,GAAI;EACL;EACE,CAAA;AAIf,KAAI,MAAM;EACN,MAAM,cAAuD;GACzD,QAAQ,MAAM;GACd,KAAK,MAAM;GACX,UAAU,MAAM;GAChB,SAAS,MAAM;GACf,SAAS,MAAM;GACf,QAAQ,MAAM;GACd,cAAc,MAAM;GACpB,cAAc,MAAM;GACpB,WAAW,MAAM;GACjB,SAAS,MAAM;GACf,QAAQ,MAAM;GACjB;AAED,SACI,oBAAC,KAAD;GACS;GACC;GACN,GAAI;GACJ,GAAI;aAEH;GACD,CAAA;;AAIZ,QACI,oBAAC,UAAD;EACS;EACL,MAAM,QAAQ;EACd,GAAI;EACJ,GAAI;YAEH;EACI,CAAA;EAEf"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { useRender } from '@base-ui/react/use-render';
|
|
2
|
+
import { VariantProps } from 'class-variance-authority';
|
|
3
|
+
import { Separator } from './Separator';
|
|
4
|
+
declare const buttonGroupVariants: (props?: ({
|
|
5
|
+
orientation?: "horizontal" | "vertical" | null | undefined;
|
|
6
|
+
} & import('class-variance-authority/types').ClassProp) | undefined) => string;
|
|
7
|
+
declare function ButtonGroup({ className, orientation, ...props }: React.ComponentProps<'div'> & VariantProps<typeof buttonGroupVariants>): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
declare function ButtonGroupText({ className, render, ...props }: useRender.ComponentProps<'div'>): import('react').ReactElement<unknown, string | import('react').JSXElementConstructor<any>>;
|
|
9
|
+
declare function ButtonGroupSeparator({ className, orientation, ...props }: React.ComponentProps<typeof Separator>): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText, buttonGroupVariants, };
|
|
11
|
+
//# sourceMappingURL=ButtonGroup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonGroup.d.ts","sourceRoot":"","sources":["../../src/components/ButtonGroup.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAGlE,OAAO,EAAE,SAAS,EAAE,MAAM,8CAA8C,CAAC;AAEzE,QAAA,MAAM,mBAAmB;;8EA+CnB,CAAC;AAEP,iBAAS,WAAW,CAAC,EACjB,SAAS,EACT,WAAW,EACX,GAAG,KAAK,EACX,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,YAAY,CAAC,OAAO,mBAAmB,CAAC,2CAUxE;AAED,iBAAS,eAAe,CAAC,EACrB,SAAS,EACT,MAAM,EACN,GAAG,KAAK,EACX,EAAE,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,8FA0BjC;AAED,iBAAS,oBAAoB,CAAC,EAC1B,SAAS,EACT,WAAwB,EACxB,GAAG,KAAK,EACX,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,SAAS,CAAC,2CAqBxC;AAED,OAAO,EACH,WAAW,EACX,oBAAoB,EACpB,eAAe,EACf,mBAAmB,GACtB,CAAC"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { cn } from "../utils/classes.js";
|
|
2
|
+
import "../utils/index.js";
|
|
3
|
+
import { Separator } from "./Separator.js";
|
|
4
|
+
import { cva } from "class-variance-authority";
|
|
5
|
+
import { mergeProps } from "@base-ui/react/merge-props";
|
|
6
|
+
import { useRender } from "@base-ui/react/use-render";
|
|
7
|
+
import { jsx } from "react/jsx-runtime";
|
|
8
|
+
//#region src/components/ButtonGroup.tsx
|
|
9
|
+
var buttonGroupVariants = cva([
|
|
10
|
+
"flex w-fit items-stretch",
|
|
11
|
+
"[&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1",
|
|
12
|
+
"*:focus-visible:z-10 *:focus-visible:relative",
|
|
13
|
+
"has-[>[data-slot=button-group]]:gap-2",
|
|
14
|
+
"has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-lg"
|
|
15
|
+
], {
|
|
16
|
+
variants: { orientation: {
|
|
17
|
+
horizontal: [
|
|
18
|
+
"[&>[data-slot]:not(:has(~[data-slot]))]:rounded-r-lg!",
|
|
19
|
+
"[&>[data-slot]~[data-slot]]:rounded-l-none [&>[data-slot]~[data-slot]]:border-l-0",
|
|
20
|
+
"*:data-slot:rounded-r-none"
|
|
21
|
+
],
|
|
22
|
+
vertical: [
|
|
23
|
+
"flex-col",
|
|
24
|
+
"[&>[data-slot]:not(:has(~[data-slot]))]:rounded-b-lg!",
|
|
25
|
+
"[&>[data-slot]~[data-slot]]:rounded-t-none [&>[data-slot]~[data-slot]]:border-t-0",
|
|
26
|
+
"*:data-slot:rounded-b-none"
|
|
27
|
+
]
|
|
28
|
+
} },
|
|
29
|
+
defaultVariants: { orientation: "horizontal" }
|
|
30
|
+
});
|
|
31
|
+
function ButtonGroup({ className, orientation, ...props }) {
|
|
32
|
+
return /* @__PURE__ */ jsx("div", {
|
|
33
|
+
role: "group",
|
|
34
|
+
"data-slot": "button-group",
|
|
35
|
+
"data-orientation": orientation,
|
|
36
|
+
className: cn(buttonGroupVariants({ orientation }), className),
|
|
37
|
+
...props
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
function ButtonGroupText({ className, render, ...props }) {
|
|
41
|
+
return useRender({
|
|
42
|
+
defaultTagName: "div",
|
|
43
|
+
props: mergeProps({ className: cn("flex items-center gap-2 rounded-lg border px-2.5", "text-sm font-medium", "border-slate-300 bg-slate-200 text-gray-700", "[&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none", className) }, props),
|
|
44
|
+
render,
|
|
45
|
+
state: { slot: "button-group-text" }
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
function ButtonGroupSeparator({ className, orientation = "vertical", ...props }) {
|
|
49
|
+
return /* @__PURE__ */ jsx(Separator, {
|
|
50
|
+
"data-slot": "button-group-separator",
|
|
51
|
+
orientation,
|
|
52
|
+
className: cn("relative self-stretch", "bg-white", "data-[orientation=horizontal]:mx-px data-[orientation=horizontal]:w-auto", "data-[orientation=vertical]:my-px data-[orientation=vertical]:h-auto", className),
|
|
53
|
+
...props
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
//#endregion
|
|
57
|
+
export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText, buttonGroupVariants };
|
|
58
|
+
|
|
59
|
+
//# sourceMappingURL=ButtonGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ButtonGroup.js","names":[],"sources":["../../src/components/ButtonGroup.tsx"],"sourcesContent":["import { mergeProps } from '@base-ui/react/merge-props';\nimport { useRender } from '@base-ui/react/use-render';\nimport { cva, type VariantProps } from 'class-variance-authority';\n\nimport { cn } from '@verbb/plugin-kit-react/utils';\nimport { Separator } from '@verbb/plugin-kit-react/components/Separator';\n\nconst buttonGroupVariants = cva([\n // Layout\n 'flex w-fit items-stretch',\n\n // Child sizing\n \"[&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1\",\n\n // Focus layering\n '*:focus-visible:z-10 *:focus-visible:relative',\n\n // Nested group spacing\n 'has-[>[data-slot=button-group]]:gap-2',\n\n // Select edge-case rounding\n 'has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-lg',\n],\n {\n variants: {\n orientation: {\n horizontal: [\n // Last item keeps the right edge radius\n '[&>[data-slot]:not(:has(~[data-slot]))]:rounded-r-lg!',\n\n // Remove interior seams\n '[&>[data-slot]~[data-slot]]:rounded-l-none [&>[data-slot]~[data-slot]]:border-l-0',\n\n // Ensure non-last items are flush on the right\n '*:data-slot:rounded-r-none',\n ],\n vertical: [\n // Stack children vertically\n 'flex-col',\n\n // Last item keeps the bottom edge radius\n '[&>[data-slot]:not(:has(~[data-slot]))]:rounded-b-lg!',\n\n // Remove interior seams\n '[&>[data-slot]~[data-slot]]:rounded-t-none [&>[data-slot]~[data-slot]]:border-t-0',\n\n // Ensure non-last items are flush on the bottom\n '*:data-slot:rounded-b-none',\n ],\n },\n },\n defaultVariants: {\n orientation: 'horizontal',\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 render,\n ...props\n}: useRender.ComponentProps<'div'>) {\n return useRender({\n defaultTagName: 'div',\n props: mergeProps<'div'>({\n className: cn(\n // Layout\n 'flex items-center gap-2 rounded-lg border px-2.5',\n\n // Typography\n 'text-sm font-medium',\n\n // Theme\n 'border-slate-300 bg-slate-200 text-gray-700',\n\n // Icons\n \"[&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none\",\n\n className,\n ),\n },\n props),\n render,\n state: {\n slot: 'button-group-text',\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 // Layout\n 'relative self-stretch',\n\n // Theme\n 'bg-white',\n\n // Orientation tweaks\n 'data-[orientation=horizontal]:mx-px data-[orientation=horizontal]:w-auto',\n 'data-[orientation=vertical]:my-px data-[orientation=vertical]:h-auto',\n\n className,\n )}\n {...props}\n />\n );\n}\n\nexport {\n ButtonGroup,\n ButtonGroupSeparator,\n ButtonGroupText,\n buttonGroupVariants,\n};\n"],"mappings":";;;;;;;;AAOA,IAAM,sBAAsB,IAAI;CAE5B;CAGA;CAGA;CAGA;CAGA;CACH,EACG;CACI,UAAU,EACN,aAAa;EACT,YAAY;GAER;GAGA;GAGA;GACH;EACD,UAAU;GAEN;GAGA;GAGA;GAGA;GACH;EACJ,EACJ;CACD,iBAAiB,EACb,aAAa,cAChB;CACJ,CAAC;AAEN,SAAS,YAAY,EACjB,WACA,aACA,GAAG,SACoE;AACvE,QACI,oBAAC,OAAD;EACI,MAAK;EACL,aAAU;EACV,oBAAkB;EAClB,WAAW,GAAG,oBAAoB,EAAE,aAAa,CAAC,EAAE,UAAU;EAC9D,GAAI;EACN,CAAA;;AAIV,SAAS,gBAAgB,EACrB,WACA,QACA,GAAG,SAC6B;AAChC,QAAO,UAAU;EACb,gBAAgB;EAChB,OAAO,WAAkB,EACrB,WAAW,GAEP,oDAGA,uBAGA,+CAGA,oEAEA,UACH,EACJ,EACG,MAAM;EACV;EACA,OAAO,EACH,MAAM,qBACT;EACJ,CAAC;;AAGN,SAAS,qBAAqB,EAC1B,WACA,cAAc,YACd,GAAG,SACoC;AACvC,QACI,oBAAC,WAAD;EACI,aAAU;EACG;EACb,WAAW,GAEP,yBAGA,YAGA,4EACA,wEAEA,UACH;EACD,GAAI;EACN,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ComponentProps } from 'react';
|
|
2
|
+
import { DayPicker, DayButton, Locale } from 'react-day-picker';
|
|
3
|
+
import { Button } from '.';
|
|
4
|
+
declare function Calendar({ className, classNames, showOutsideDays, captionLayout, buttonVariant, locale, formatters, components, ...props }: ComponentProps<typeof DayPicker> & {
|
|
5
|
+
buttonVariant?: ComponentProps<typeof Button>['variant'];
|
|
6
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
declare function CalendarDayButton({ className, day, modifiers, locale, ...props }: ComponentProps<typeof DayButton> & {
|
|
8
|
+
locale?: Partial<Locale>;
|
|
9
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export { Calendar, CalendarDayButton };
|
|
11
|
+
//# sourceMappingURL=Calendar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Calendar.d.ts","sourceRoot":"","sources":["../../src/components/Calendar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAqB,cAAc,EAAE,MAAM,OAAO,CAAC;AAE1D,OAAO,EACH,SAAS,EAET,KAAK,SAAS,EACd,KAAK,MAAM,EACd,MAAM,kBAAkB,CAAC;AAM1B,OAAO,EAAE,MAAM,EAAkB,MAAM,oCAAoC,CAAC;AAE5E,iBAAS,QAAQ,CAAC,EACd,SAAS,EACT,UAAU,EACV,eAAsB,EACtB,aAAuB,EACvB,aAAsB,EACtB,MAAM,EACN,UAAU,EACV,UAAU,EACV,GAAG,KAAK,EACX,EAAE,cAAc,CAAC,OAAO,SAAS,CAAC,GAAG;IAClC,aAAa,CAAC,EAAE,cAAc,CAAC,OAAO,MAAM,CAAC,CAAC,SAAS,CAAC,CAAA;CAC3D,2CAoLA;AAED,iBAAS,iBAAiB,CAAC,EACvB,SAAS,EACT,GAAG,EACH,SAAS,EACT,MAAM,EACN,GAAG,KAAK,EACX,EAAE,cAAc,CAAC,OAAO,SAAS,CAAC,GAAG;IAAE,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;CAAE,2CA0DjE;AAED,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { cn } from "../utils/classes.js";
|
|
2
|
+
import "../utils/index.js";
|
|
3
|
+
import "./index.js";
|
|
4
|
+
import { Button, buttonVariants } from "./Button.js";
|
|
5
|
+
import { useEffect, useRef } from "react";
|
|
6
|
+
import { jsx } from "react/jsx-runtime";
|
|
7
|
+
import { DayPicker, getDefaultClassNames } from "react-day-picker";
|
|
8
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
9
|
+
import { faChevronDown, faChevronLeft, faChevronRight } from "@fortawesome/pro-solid-svg-icons";
|
|
10
|
+
//#region src/components/Calendar.tsx
|
|
11
|
+
function Calendar({ className, classNames, showOutsideDays = true, captionLayout = "label", buttonVariant = "none", locale, formatters, components, ...props }) {
|
|
12
|
+
const defaultClassNames = getDefaultClassNames();
|
|
13
|
+
return /* @__PURE__ */ jsx(DayPicker, {
|
|
14
|
+
showOutsideDays,
|
|
15
|
+
className: cn("bg-background group/calendar", "p-2", "[--cell-radius:100%] [--cell-size:--spacing(7)]", "[[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent", String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`, String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`, className),
|
|
16
|
+
captionLayout,
|
|
17
|
+
locale,
|
|
18
|
+
formatters: {
|
|
19
|
+
formatMonthDropdown: (date) => {
|
|
20
|
+
return date.toLocaleString(locale?.code, { month: "short" });
|
|
21
|
+
},
|
|
22
|
+
...formatters
|
|
23
|
+
},
|
|
24
|
+
classNames: {
|
|
25
|
+
root: cn("w-fit", defaultClassNames.root),
|
|
26
|
+
months: cn("flex gap-4 flex-col md:flex-row relative", defaultClassNames.months),
|
|
27
|
+
month: cn("flex flex-col w-full gap-2", defaultClassNames.month),
|
|
28
|
+
nav: cn("flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between", defaultClassNames.nav),
|
|
29
|
+
"button_previous": cn(buttonVariants({
|
|
30
|
+
variant: buttonVariant,
|
|
31
|
+
size: "none"
|
|
32
|
+
}), "cursor-pointer rounded-sm", "p-2!", "[&>svg]:size-3", defaultClassNames.button_previous),
|
|
33
|
+
"button_next": cn(buttonVariants({
|
|
34
|
+
variant: buttonVariant,
|
|
35
|
+
size: "none"
|
|
36
|
+
}), "cursor-pointer rounded-sm", "p-2!", "[&>svg]:size-3", defaultClassNames.button_next),
|
|
37
|
+
"month_caption": cn("flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)", defaultClassNames.month_caption),
|
|
38
|
+
dropdowns: cn("w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5", defaultClassNames.dropdowns),
|
|
39
|
+
"dropdown_root": cn("relative cn-calendar-dropdown-root rounded-(--cell-radius)", defaultClassNames.dropdown_root),
|
|
40
|
+
dropdown: cn("absolute bg-white inset-0 opacity-0", defaultClassNames.dropdown),
|
|
41
|
+
"caption_label": cn("select-none font-medium", captionLayout === "label" ? "text-[13px]" : [
|
|
42
|
+
"cn-calendar-caption-label",
|
|
43
|
+
"rounded-(--cell-radius)",
|
|
44
|
+
"flex items-center gap-1 text-[13px]",
|
|
45
|
+
"[&>svg]:text-slate-800",
|
|
46
|
+
"[&>svg]:size-2.5"
|
|
47
|
+
].join(" "), defaultClassNames.caption_label),
|
|
48
|
+
table: "w-full border-collapse",
|
|
49
|
+
weekdays: cn("flex", defaultClassNames.weekdays),
|
|
50
|
+
weekday: cn("text-gray-500 rounded-(--cell-radius) flex-1 font-normal text-[0.8rem] select-none", defaultClassNames.weekday),
|
|
51
|
+
week: cn("flex w-full mt-2", defaultClassNames.week),
|
|
52
|
+
"week_number_header": cn("select-none w-(--cell-size)", defaultClassNames.week_number_header),
|
|
53
|
+
"week_number": cn("text-[0.8rem]", "select-none", "text-gray-500", defaultClassNames.week_number),
|
|
54
|
+
day: cn("relative w-full h-full p-0 text-center group/day aspect-square select-none", defaultClassNames.day),
|
|
55
|
+
"range_start": cn(defaultClassNames.range_start),
|
|
56
|
+
"range_middle": cn(defaultClassNames.range_middle),
|
|
57
|
+
"range_end": cn(defaultClassNames.range_end),
|
|
58
|
+
today: cn(defaultClassNames.today),
|
|
59
|
+
outside: cn("opacity-60", defaultClassNames.outside),
|
|
60
|
+
disabled: cn("opacity-40", defaultClassNames.disabled),
|
|
61
|
+
hidden: cn("invisible", defaultClassNames.hidden),
|
|
62
|
+
...classNames
|
|
63
|
+
},
|
|
64
|
+
components: {
|
|
65
|
+
Root: ({ className, rootRef, ...props }) => {
|
|
66
|
+
return /* @__PURE__ */ jsx("div", {
|
|
67
|
+
"data-slot": "calendar",
|
|
68
|
+
ref: rootRef,
|
|
69
|
+
className: cn(className),
|
|
70
|
+
...props
|
|
71
|
+
});
|
|
72
|
+
},
|
|
73
|
+
Chevron: ({ className, orientation, ...props }) => {
|
|
74
|
+
if (orientation === "left") return /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
75
|
+
icon: faChevronLeft,
|
|
76
|
+
className: cn("cn-rtl-flip size-4", className),
|
|
77
|
+
...props
|
|
78
|
+
});
|
|
79
|
+
if (orientation === "right") return /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
80
|
+
icon: faChevronRight,
|
|
81
|
+
className: cn("cn-rtl-flip size-4", className),
|
|
82
|
+
...props
|
|
83
|
+
});
|
|
84
|
+
return /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
85
|
+
icon: faChevronDown,
|
|
86
|
+
className: cn("size-4", className),
|
|
87
|
+
...props
|
|
88
|
+
});
|
|
89
|
+
},
|
|
90
|
+
DayButton: ({ ...props }) => {
|
|
91
|
+
return /* @__PURE__ */ jsx(CalendarDayButton, {
|
|
92
|
+
locale,
|
|
93
|
+
...props
|
|
94
|
+
});
|
|
95
|
+
},
|
|
96
|
+
WeekNumber: ({ children, ...props }) => {
|
|
97
|
+
return /* @__PURE__ */ jsx("td", {
|
|
98
|
+
...props,
|
|
99
|
+
children: /* @__PURE__ */ jsx("div", {
|
|
100
|
+
className: "flex size-(--cell-size) items-center justify-center text-center",
|
|
101
|
+
children
|
|
102
|
+
})
|
|
103
|
+
});
|
|
104
|
+
},
|
|
105
|
+
...components
|
|
106
|
+
},
|
|
107
|
+
...props
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
function CalendarDayButton({ className, day, modifiers, locale, ...props }) {
|
|
111
|
+
const defaultClassNames = getDefaultClassNames();
|
|
112
|
+
const ref = useRef(null);
|
|
113
|
+
useEffect(() => {
|
|
114
|
+
if (modifiers.focused) ref.current?.focus();
|
|
115
|
+
}, [modifiers.focused]);
|
|
116
|
+
return /* @__PURE__ */ jsx(Button, {
|
|
117
|
+
ref,
|
|
118
|
+
variant: "none",
|
|
119
|
+
size: "none",
|
|
120
|
+
"data-today": modifiers.today,
|
|
121
|
+
"data-day": day.date.toLocaleDateString(locale?.code),
|
|
122
|
+
"data-selected-single": modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle,
|
|
123
|
+
"data-range-start": modifiers.range_start,
|
|
124
|
+
"data-range-end": modifiers.range_end,
|
|
125
|
+
"data-range-middle": modifiers.range_middle,
|
|
126
|
+
className: cn("relative isolate z-10 flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 border-0 leading-none font-normal", "rounded-none transition-none", "data-[selected-single=true]:bg-gray-200", "data-[selected-single=true]:rounded-(--cell-radius)", "data-[range-middle=true]:bg-gray-200", "data-[range-start=true]:bg-gray-200", "data-[range-end=true]:bg-gray-200", "data-[today=true]:after:absolute", "data-[today=true]:after:w-full", "data-[today=true]:after:h-full", "data-[today=true]:after:m-2", "data-[today=true]:after:-z-0", "data-[today=true]:after:isolate", "data-[today=true]:after:border", "data-[today=true]:after:border-blue-500", "data-[today=true]:after:rounded-(--cell-radius)", "data-[range-start=true]:data-[range-end=true]:rounded-(--cell-radius)", "data-[range-start=true]:data-[range-end=false]:rounded-l-(--cell-radius)", "data-[range-middle=true]:rounded-none", "data-[range-start=false]:data-[range-end=true]:rounded-r-(--cell-radius)", "[&>span]:text-xs [&>span]:opacity-70", defaultClassNames.day, className),
|
|
127
|
+
...props
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
//#endregion
|
|
131
|
+
export { Calendar, CalendarDayButton };
|
|
132
|
+
|
|
133
|
+
//# sourceMappingURL=Calendar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Calendar.js","names":[],"sources":["../../src/components/Calendar.tsx"],"sourcesContent":["import { useRef, useEffect, ComponentProps } from 'react';\n\nimport {\n DayPicker,\n getDefaultClassNames,\n type DayButton,\n type Locale,\n} from 'react-day-picker';\n\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faChevronDown, faChevronLeft, faChevronRight } from '@fortawesome/pro-solid-svg-icons';\n\nimport { cn } from '@verbb/plugin-kit-react/utils';\nimport { Button, buttonVariants } from '@verbb/plugin-kit-react/components';\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = 'label',\n buttonVariant = 'none',\n locale,\n formatters,\n components,\n ...props\n}: ComponentProps<typeof DayPicker> & {\n buttonVariant?: ComponentProps<typeof Button>['variant']\n}) {\n const defaultClassNames = getDefaultClassNames();\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n 'bg-background group/calendar',\n 'p-2',\n '[--cell-radius:100%] [--cell-size:--spacing(7)]',\n '[[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',\n\n // RTL support styles\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n\n className,\n )}\n captionLayout={captionLayout}\n locale={locale}\n formatters={{\n formatMonthDropdown: (date) => { return date.toLocaleString(locale?.code, { month: 'short' }); },\n ...formatters,\n }}\n classNames={{\n root: cn(\n 'w-fit',\n defaultClassNames.root,\n ),\n months: cn(\n 'flex gap-4 flex-col md:flex-row relative',\n defaultClassNames.months,\n ),\n month: cn(\n 'flex flex-col w-full gap-2',\n defaultClassNames.month,\n ),\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, size: 'none' }),\n 'cursor-pointer rounded-sm',\n 'p-2!',\n '[&>svg]:size-3',\n defaultClassNames.button_previous,\n ),\n 'button_next': cn(\n buttonVariants({ variant: buttonVariant, size: 'none' }),\n 'cursor-pointer rounded-sm',\n 'p-2!',\n '[&>svg]:size-3',\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 cn-calendar-dropdown-root rounded-(--cell-radius)',\n defaultClassNames.dropdown_root,\n ),\n dropdown: cn(\n 'absolute bg-white inset-0 opacity-0',\n defaultClassNames.dropdown,\n ),\n 'caption_label': cn(\n 'select-none font-medium',\n captionLayout === 'label' ? 'text-[13px]' : [\n 'cn-calendar-caption-label',\n 'rounded-(--cell-radius)',\n 'flex items-center gap-1 text-[13px]',\n '[&>svg]:text-slate-800',\n '[&>svg]:size-2.5',\n ].join(' '),\n defaultClassNames.caption_label,\n ),\n table: 'w-full border-collapse',\n weekdays: cn(\n 'flex',\n defaultClassNames.weekdays,\n ),\n weekday: cn(\n 'text-gray-500 rounded-(--cell-radius) flex-1 font-normal text-[0.8rem] select-none',\n defaultClassNames.weekday,\n ),\n week: cn(\n 'flex w-full mt-2',\n defaultClassNames.week,\n ),\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]',\n 'select-none',\n 'text-gray-500',\n defaultClassNames.week_number,\n ),\n day: cn(\n 'relative w-full h-full p-0 text-center group/day aspect-square select-none',\n defaultClassNames.day,\n ),\n 'range_start': cn(\n defaultClassNames.range_start,\n ),\n 'range_middle': cn(\n defaultClassNames.range_middle,\n ),\n 'range_end': cn(\n defaultClassNames.range_end,\n ),\n today: cn(\n defaultClassNames.today,\n ),\n outside: cn(\n 'opacity-60',\n defaultClassNames.outside,\n ),\n disabled: cn(\n 'opacity-40',\n defaultClassNames.disabled,\n ),\n hidden: cn(\n 'invisible',\n defaultClassNames.hidden,\n ),\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 <FontAwesomeIcon icon={faChevronLeft} className={cn('cn-rtl-flip size-4', className)} {...props} />\n );\n }\n if (orientation === 'right') {\n return (\n <FontAwesomeIcon icon={faChevronRight} className={cn('cn-rtl-flip size-4', className)} {...props} />\n );\n }\n return (\n <FontAwesomeIcon icon={faChevronDown} className={cn('size-4', className)} {...props} />\n );\n },\n DayButton: ({ ...props }) => {\n return (\n // eslint-disable-next-line no-use-before-define\n <CalendarDayButton locale={locale} {...props} />\n );\n },\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 locale,\n ...props\n}: ComponentProps<typeof DayButton> & { locale?: Partial<Locale> }) {\n const defaultClassNames = getDefaultClassNames();\n const ref = useRef<HTMLButtonElement>(null);\n\n useEffect(() => {\n if (modifiers.focused) { ref.current?.focus(); }\n }, [modifiers.focused]);\n\n return (\n <Button\n ref={ref}\n variant=\"none\"\n size=\"none\"\n data-today={modifiers.today}\n data-day={day.date.toLocaleDateString(locale?.code)}\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 'relative isolate z-10 flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 border-0 leading-none font-normal',\n 'rounded-none transition-none',\n\n 'data-[selected-single=true]:bg-gray-200',\n 'data-[selected-single=true]:rounded-(--cell-radius)',\n 'data-[range-middle=true]:bg-gray-200',\n 'data-[range-start=true]:bg-gray-200',\n 'data-[range-end=true]:bg-gray-200',\n\n 'data-[today=true]:after:absolute',\n 'data-[today=true]:after:w-full',\n 'data-[today=true]:after:h-full',\n 'data-[today=true]:after:m-2',\n 'data-[today=true]:after:-z-0',\n 'data-[today=true]:after:isolate',\n 'data-[today=true]:after:border',\n 'data-[today=true]:after:border-blue-500',\n 'data-[today=true]:after:rounded-(--cell-radius)',\n\n 'data-[range-start=true]:data-[range-end=true]:rounded-(--cell-radius)',\n 'data-[range-start=true]:data-[range-end=false]:rounded-l-(--cell-radius)',\n 'data-[range-middle=true]:rounded-none',\n 'data-[range-start=false]:data-[range-end=true]:rounded-r-(--cell-radius)',\n\n '[&>span]:text-xs [&>span]:opacity-70',\n\n defaultClassNames.day,\n\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Calendar, CalendarDayButton };\n"],"mappings":";;;;;;;;;;AAeA,SAAS,SAAS,EACd,WACA,YACA,kBAAkB,MAClB,gBAAgB,SAChB,gBAAgB,QAChB,QACA,YACA,YACA,GAAG,SAGJ;CACC,MAAM,oBAAoB,sBAAsB;AAChD,QACI,oBAAC,WAAD;EACqB;EACjB,WAAW,GACP,gCACA,OACA,mDACA,8FAGA,OAAO,GAAG,6CACV,OAAO,GAAG,iDAEV,UACH;EACc;EACP;EACR,YAAY;GACR,sBAAsB,SAAS;AAAE,WAAO,KAAK,eAAe,QAAQ,MAAM,EAAE,OAAO,SAAS,CAAC;;GAC7F,GAAG;GACN;EACD,YAAY;GACR,MAAM,GACF,SACA,kBAAkB,KACrB;GACD,QAAQ,GACJ,4CACA,kBAAkB,OACrB;GACD,OAAO,GACH,8BACA,kBAAkB,MACrB;GACD,KAAK,GACD,2EACA,kBAAkB,IACrB;GACD,mBAAmB,GACf,eAAe;IAAE,SAAS;IAAe,MAAM;IAAQ,CAAC,EACxD,6BACA,QACA,kBACA,kBAAkB,gBACrB;GACD,eAAe,GACX,eAAe;IAAE,SAAS;IAAe,MAAM;IAAQ,CAAC,EACxD,6BACA,QACA,kBACA,kBAAkB,YACrB;GACD,iBAAiB,GACb,4EACA,kBAAkB,cACrB;GACD,WAAW,GACP,uFACA,kBAAkB,UACrB;GACD,iBAAiB,GACb,8DACA,kBAAkB,cACrB;GACD,UAAU,GACN,uCACA,kBAAkB,SACrB;GACD,iBAAiB,GACb,2BACA,kBAAkB,UAAU,gBAAgB;IACxC;IACA;IACA;IACA;IACA;IACH,CAAC,KAAK,IAAI,EACX,kBAAkB,cACrB;GACD,OAAO;GACP,UAAU,GACN,QACA,kBAAkB,SACrB;GACD,SAAS,GACL,sFACA,kBAAkB,QACrB;GACD,MAAM,GACF,oBACA,kBAAkB,KACrB;GACD,sBAAsB,GAClB,+BACA,kBAAkB,mBACrB;GACD,eAAe,GACX,iBACA,eACA,iBACA,kBAAkB,YACrB;GACD,KAAK,GACD,8EACA,kBAAkB,IACrB;GACD,eAAe,GACX,kBAAkB,YACrB;GACD,gBAAgB,GACZ,kBAAkB,aACrB;GACD,aAAa,GACT,kBAAkB,UACrB;GACD,OAAO,GACH,kBAAkB,MACrB;GACD,SAAS,GACL,cACA,kBAAkB,QACrB;GACD,UAAU,GACN,cACA,kBAAkB,SACrB;GACD,QAAQ,GACJ,aACA,kBAAkB,OACrB;GACD,GAAG;GACN;EACD,YAAY;GACR,OAAO,EAAE,WAAW,SAAS,GAAG,YAAY;AACxC,WACI,oBAAC,OAAD;KACI,aAAU;KACV,KAAK;KACL,WAAW,GAAG,UAAU;KACxB,GAAI;KACN,CAAA;;GAGV,UAAU,EAAE,WAAW,aAAa,GAAG,YAAY;AAC/C,QAAI,gBAAgB,OAChB,QACI,oBAAC,iBAAD;KAAiB,MAAM;KAAe,WAAW,GAAG,sBAAsB,UAAU;KAAE,GAAI;KAAS,CAAA;AAG3G,QAAI,gBAAgB,QAChB,QACI,oBAAC,iBAAD;KAAiB,MAAM;KAAgB,WAAW,GAAG,sBAAsB,UAAU;KAAE,GAAI;KAAS,CAAA;AAG5G,WACI,oBAAC,iBAAD;KAAiB,MAAM;KAAe,WAAW,GAAG,UAAU,UAAU;KAAE,GAAI;KAAS,CAAA;;GAG/F,YAAY,EAAE,GAAG,YAAY;AACzB,WAEI,oBAAC,mBAAD;KAA2B;KAAQ,GAAI;KAAS,CAAA;;GAGxD,aAAa,EAAE,UAAU,GAAG,YAAY;AACpC,WACI,oBAAC,MAAD;KAAI,GAAI;eACJ,oBAAC,OAAD;MAAK,WAAU;MACV;MACC,CAAA;KACL,CAAA;;GAGb,GAAG;GACN;EACD,GAAI;EACN,CAAA;;AAIV,SAAS,kBAAkB,EACvB,WACA,KACA,WACA,QACA,GAAG,SAC6D;CAChE,MAAM,oBAAoB,sBAAsB;CAChD,MAAM,MAAM,OAA0B,KAAK;AAE3C,iBAAgB;AACZ,MAAI,UAAU,QAAW,KAAI,SAAS,OAAO;IAC9C,CAAC,UAAU,QAAQ,CAAC;AAEvB,QACI,oBAAC,QAAD;EACS;EACL,SAAQ;EACR,MAAK;EACL,cAAY,UAAU;EACtB,YAAU,IAAI,KAAK,mBAAmB,QAAQ,KAAK;EACnD,wBACI,UAAU,YACV,CAAC,UAAU,eACX,CAAC,UAAU,aACX,CAAC,UAAU;EAEf,oBAAkB,UAAU;EAC5B,kBAAgB,UAAU;EAC1B,qBAAmB,UAAU;EAC7B,WAAW,GACP,kIACA,gCAEA,2CACA,uDACA,wCACA,uCACA,qCAEA,oCACA,kCACA,kCACA,+BACA,gCACA,mCACA,kCACA,2CACA,mDAEA,yEACA,4EACA,yCACA,4EAEA,wCAEA,kBAAkB,KAElB,UACH;EACD,GAAI;EACN,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ComponentProps } from 'react';
|
|
2
|
+
import { Checkbox as CheckboxPrimitive } from '@base-ui/react/checkbox';
|
|
3
|
+
declare function Checkbox({ className, ...props }: ComponentProps<typeof CheckboxPrimitive.Root>): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export { Checkbox };
|
|
5
|
+
//# sourceMappingURL=Checkbox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkbox.d.ts","sourceRoot":"","sources":["../../src/components/Checkbox.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,EAAE,QAAQ,IAAI,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAIxE,iBAAS,QAAQ,CAAC,EACd,SAAS,EACT,GAAG,KAAK,EACX,EAAE,cAAc,CAAC,OAAO,iBAAiB,CAAC,IAAI,CAAC,2CAqD/C;AAED,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { cn } from "../utils/classes.js";
|
|
2
|
+
import "../utils/index.js";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { Checkbox as Checkbox$1 } from "@base-ui/react/checkbox";
|
|
5
|
+
//#region src/components/Checkbox.tsx
|
|
6
|
+
function Checkbox({ className, ...props }) {
|
|
7
|
+
return /* @__PURE__ */ jsx(Checkbox$1.Root, {
|
|
8
|
+
"data-slot": "checkbox",
|
|
9
|
+
className: cn("peer group/checkbox flex items-center justify-center cursor-pointer shrink-0 rounded-sm outline-none border", "size-4 border-[#c0cbd9]", "focus-visible:border-sky-600 focus-visible:shadow-[0_0_0_1px_var(--color-sky-600),0_0_4px_0_hsl(from_var(--color-sky-600)_h_s_l/0.7)]", "aria-invalid:border-rose-600 aria-invalid:focus-visible:!shadow-[0_0_0_1px_var(--color-rose-600),0_0_4px_0_hsl(from_var(--color-rose-600)_h_s_l/0.7)]", "disabled:cursor-not-allowed disabled:opacity-50 data-disabled:cursor-not-allowed data-disabled:opacity-50", className),
|
|
10
|
+
...props,
|
|
11
|
+
children: /* @__PURE__ */ jsxs(Checkbox$1.Indicator, {
|
|
12
|
+
"data-slot": "checkbox-indicator",
|
|
13
|
+
className: cn("flex items-center justify-center", "size-[14px] text-current"),
|
|
14
|
+
children: [/* @__PURE__ */ jsx("svg", {
|
|
15
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
16
|
+
role: "img",
|
|
17
|
+
"aria-hidden": "true",
|
|
18
|
+
viewBox: "0 0 640 640",
|
|
19
|
+
className: "size-[14px] translate-y-[1px] scale-[1.2] group-data-[indeterminate]/checkbox:hidden",
|
|
20
|
+
children: /* @__PURE__ */ jsx("path", {
|
|
21
|
+
fill: "currentColor",
|
|
22
|
+
d: "M557.5 192L534.9 214.6L278.9 470.6C266.4 483.1 246.1 483.1 233.6 470.6L105.6 342.6L83 320L128.3 274.7C129.6 276 172.3 318.7 256.3 402.7L489.7 169.3L512.3 146.7L557.6 192z"
|
|
23
|
+
})
|
|
24
|
+
}), /* @__PURE__ */ jsx("svg", {
|
|
25
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
26
|
+
role: "img",
|
|
27
|
+
"aria-hidden": "true",
|
|
28
|
+
viewBox: "0 0 640 640",
|
|
29
|
+
className: "hidden size-[12px] group-data-[indeterminate]/checkbox:block",
|
|
30
|
+
children: /* @__PURE__ */ jsx("path", {
|
|
31
|
+
fill: "currentColor",
|
|
32
|
+
d: "M96 352V288H544V352H96z"
|
|
33
|
+
})
|
|
34
|
+
})]
|
|
35
|
+
})
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
//#endregion
|
|
39
|
+
export { Checkbox };
|
|
40
|
+
|
|
41
|
+
//# sourceMappingURL=Checkbox.js.map
|