@jakubmazanec/ui 0.1.0-unstable.0c19abe → 0.1.0-unstable.14b8d65
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/README.md +6 -1
- package/build/components/Button.d.ts +26 -10
- package/build/components/Button.js +112 -24
- package/build/components/Button.js.map +3 -3
- package/build/components/Card.d.ts +18 -4
- package/build/components/Card.js +24 -5
- package/build/components/Card.js.map +3 -3
- package/build/components/Checkbox.d.ts +24 -9
- package/build/components/Checkbox.js +77 -53
- package/build/components/Checkbox.js.map +3 -3
- package/build/components/CheckboxField.d.ts +12 -5
- package/build/components/CheckboxField.js +12 -4
- package/build/components/CheckboxField.js.map +2 -2
- package/build/components/Combobox.d.ts +41 -17
- package/build/components/Combobox.js +167 -110
- package/build/components/Combobox.js.map +3 -3
- package/build/components/ComboboxOption.d.ts +33 -0
- package/build/components/ComboboxOption.js +59 -0
- package/build/components/ComboboxOption.js.map +7 -0
- package/build/components/DataTable.d.ts +55 -0
- package/build/components/DataTable.js +364 -0
- package/build/components/DataTable.js.map +7 -0
- package/build/components/Description.d.ts +19 -0
- package/build/components/Description.js +28 -0
- package/build/components/Description.js.map +7 -0
- package/build/components/Dialog.d.ts +20 -6
- package/build/components/Dialog.js +49 -15
- package/build/components/Dialog.js.map +2 -2
- package/build/components/DialogPanel.d.ts +13 -4
- package/build/components/DialogPanel.js +25 -6
- package/build/components/DialogPanel.js.map +2 -2
- package/build/components/DialogTitle.d.ts +13 -4
- package/build/components/DialogTitle.js +24 -6
- package/build/components/DialogTitle.js.map +2 -2
- package/build/components/Error.d.ts +13 -4
- package/build/components/Error.js +32 -9
- package/build/components/Error.js.map +2 -2
- package/build/components/Field.d.ts +17 -6
- package/build/components/Field.js +26 -8
- package/build/components/Field.js.map +2 -2
- package/build/components/Fieldset.d.ts +27 -0
- package/build/components/Fieldset.js +39 -0
- package/build/components/Fieldset.js.map +7 -0
- package/build/components/Form.d.ts +16 -7
- package/build/components/Form.js +37 -7
- package/build/components/Form.js.map +3 -3
- package/build/components/Icon.d.ts +29 -0
- package/build/components/Icon.js +59 -0
- package/build/components/Icon.js.map +7 -0
- package/build/components/Input.d.ts +15 -20
- package/build/components/Input.js +70 -88
- package/build/components/Input.js.map +2 -2
- package/build/components/Label.d.ts +13 -4
- package/build/components/Label.js +21 -5
- package/build/components/Label.js.map +2 -2
- package/build/components/Legend.d.ts +19 -0
- package/build/components/Legend.js +26 -0
- package/build/components/Legend.js.map +7 -0
- package/build/components/Listbox.d.ts +44 -17
- package/build/components/Listbox.js +246 -67
- package/build/components/Listbox.js.map +3 -3
- package/build/components/ListboxOption.d.ts +33 -0
- package/build/components/ListboxOption.js +59 -0
- package/build/components/ListboxOption.js.map +7 -0
- package/build/components/Menu.d.ts +15 -4
- package/build/components/Menu.js +24 -5
- package/build/components/Menu.js.map +2 -2
- package/build/components/MenuButton.d.ts +23 -6
- package/build/components/MenuButton.js +42 -7
- package/build/components/MenuButton.js.map +2 -2
- package/build/components/MenuHeading.d.ts +19 -0
- package/build/components/MenuHeading.js +28 -0
- package/build/components/MenuHeading.js.map +7 -0
- package/build/components/MenuItem.d.ts +23 -6
- package/build/components/MenuItem.js +36 -7
- package/build/components/MenuItem.js.map +2 -2
- package/build/components/MenuItems.d.ts +16 -4
- package/build/components/MenuItems.js +32 -6
- package/build/components/MenuItems.js.map +2 -2
- package/build/components/MenuSection.d.ts +19 -0
- package/build/components/MenuSection.js +28 -0
- package/build/components/MenuSection.js.map +7 -0
- package/build/components/MenuSeparator.d.ts +19 -0
- package/build/components/MenuSeparator.js +28 -0
- package/build/components/MenuSeparator.js.map +7 -0
- package/build/components/Popover.d.ts +13 -4
- package/build/components/Popover.js +24 -6
- package/build/components/Popover.js.map +2 -2
- package/build/components/PopoverBackdrop.d.ts +19 -0
- package/build/components/PopoverBackdrop.js +28 -0
- package/build/components/PopoverBackdrop.js.map +7 -0
- package/build/components/PopoverButton.d.ts +25 -9
- package/build/components/PopoverButton.js +35 -16
- package/build/components/PopoverButton.js.map +2 -2
- package/build/components/PopoverGroup.d.ts +19 -0
- package/build/components/PopoverGroup.js +28 -0
- package/build/components/PopoverGroup.js.map +7 -0
- package/build/components/PopoverPanel.d.ts +17 -9
- package/build/components/PopoverPanel.js +31 -17
- package/build/components/PopoverPanel.js.map +2 -2
- package/build/components/Radio.d.ts +19 -10
- package/build/components/Radio.js +48 -30
- package/build/components/Radio.js.map +2 -2
- package/build/components/RadioField.d.ts +3 -2
- package/build/components/RadioField.js +8 -7
- package/build/components/RadioField.js.map +2 -2
- package/build/components/RadioGroup.d.ts +34 -0
- package/build/components/RadioGroup.js +87 -0
- package/build/components/RadioGroup.js.map +7 -0
- package/build/components/Spinner.d.ts +20 -6
- package/build/components/Spinner.js +65 -47
- package/build/components/Spinner.js.map +2 -2
- package/build/components/Table.d.ts +16 -13
- package/build/components/Table.js +24 -18
- package/build/components/Table.js.map +3 -3
- package/build/components/TableBody.d.ts +19 -0
- package/build/components/TableBody.js +26 -0
- package/build/components/TableBody.js.map +7 -0
- package/build/components/TableCaption.d.ts +19 -0
- package/build/components/TableCaption.js +31 -0
- package/build/components/TableCaption.js.map +7 -0
- package/build/components/TableCell.d.ts +13 -4
- package/build/components/TableCell.js +23 -6
- package/build/components/TableCell.js.map +3 -3
- package/build/components/TableFoot.d.ts +19 -0
- package/build/components/TableFoot.js +26 -0
- package/build/components/TableFoot.js.map +7 -0
- package/build/components/TableHead.d.ts +19 -0
- package/build/components/TableHead.js +26 -0
- package/build/components/TableHead.js.map +7 -0
- package/build/components/TableHeader.d.ts +13 -4
- package/build/components/TableHeader.js +23 -5
- package/build/components/TableHeader.js.map +3 -3
- package/build/components/TableRow.d.ts +13 -4
- package/build/components/TableRow.js +23 -6
- package/build/components/TableRow.js.map +3 -3
- package/build/components/Text.d.ts +19 -0
- package/build/components/Text.js +26 -0
- package/build/components/Text.js.map +7 -0
- package/build/components/Textarea.d.ts +16 -21
- package/build/components/Textarea.js +48 -74
- package/build/components/Textarea.js.map +2 -2
- package/build/components/data-table/DataTableHeader.d.ts +12 -0
- package/build/components/data-table/DataTableHeader.js +396 -0
- package/build/components/data-table/DataTableHeader.js.map +7 -0
- package/build/components/data-table/DataTablePageButton.d.ts +6 -0
- package/build/components/data-table/DataTablePageButton.js +11 -0
- package/build/components/data-table/DataTablePageButton.js.map +7 -0
- package/build/components/data-table/internals/constants.d.ts +3 -0
- package/build/components/data-table/internals/constants.js +5 -0
- package/build/components/data-table/internals/constants.js.map +7 -0
- package/build/components/data-table/internals/getCommonPinningClasses.d.ts +2 -0
- package/build/components/data-table/internals/getCommonPinningClasses.js +13 -0
- package/build/components/data-table/internals/getCommonPinningClasses.js.map +7 -0
- package/build/components/data-table/internals/getCommonPinningStyles.d.ts +3 -0
- package/build/components/data-table/internals/getCommonPinningStyles.js +10 -0
- package/build/components/data-table/internals/getCommonPinningStyles.js.map +7 -0
- package/build/components/internals/fieldContext.d.ts +3 -0
- package/build/components/internals/fieldContext.js +4 -0
- package/build/components/internals/fieldContext.js.map +7 -0
- package/build/components/internals/fieldNameContext.d.ts +2 -1
- package/build/components/internals/fieldNameContext.js.map +2 -2
- package/build/components/internals/filterProps.d.ts +4 -0
- package/build/components/internals/filterProps.js +9 -0
- package/build/components/internals/filterProps.js.map +7 -0
- package/build/components/internals/formIdContext.d.ts +2 -0
- package/build/components/internals/formIdContext.js +4 -0
- package/build/components/internals/formIdContext.js.map +7 -0
- package/build/components/internals/forwardRef.d.ts +4 -0
- package/build/components/internals/forwardRef.js +6 -0
- package/build/components/internals/forwardRef.js.map +7 -0
- package/build/components/internals/useFormId.d.ts +1 -0
- package/build/components/internals/useFormId.js +7 -0
- package/build/components/internals/useFormId.js.map +7 -0
- package/build/components/internals.d.ts +5 -4
- package/build/components/internals.js +5 -4
- package/build/components/internals.js.map +2 -2
- package/build/components/useField.d.ts +1 -0
- package/build/components/useField.js +7 -0
- package/build/components/useField.js.map +7 -0
- package/build/components/useFieldName.d.ts +1 -0
- package/build/components/{internals/useFieldName.js → useFieldName.js} +1 -1
- package/build/components/useFieldName.js.map +7 -0
- package/build/components/useForm.d.ts +10 -0
- package/build/components/useForm.js +19 -0
- package/build/components/useForm.js.map +7 -0
- package/build/components.d.ts +21 -3
- package/build/components.js +21 -3
- package/build/components.js.map +2 -2
- package/build/development/createTailwindConfig.js +67 -31
- package/build/development/createTailwindConfig.js.map +2 -2
- package/build/development.d.ts +0 -1
- package/build/development.js +0 -1
- package/build/development.js.map +2 -2
- package/build/main.d.ts +2 -2
- package/build/main.js +2 -2
- package/build/main.js.map +2 -2
- package/build/{fonts.css → styles.css} +9 -1
- package/build/{fonts.css.map → styles.css.map} +3 -3
- package/build/theme/Theme.d.ts +115 -12
- package/build/theme/defaultTheme.js +96 -327
- package/build/theme/defaultTheme.js.map +2 -2
- package/build/theme/internals/ComponentTheme.d.ts +11 -1
- package/build/theme/internals/ComponentWithTheme.d.ts +5 -0
- package/build/theme/internals/ComponentWithTheme.js +2 -0
- package/build/theme/internals/createComponentTheme.js +3 -0
- package/build/theme/internals/createComponentTheme.js.map +2 -2
- package/build/theme/internals/createUseComponentThemeReturn.d.ts +1 -1
- package/build/theme/internals/createUseComponentThemeReturn.js +1 -2
- package/build/theme/internals/createUseComponentThemeReturn.js.map +2 -2
- package/build/theme/internals/themeContext.d.ts +165 -52
- package/build/theme/internals/useTheme.d.ts +165 -52
- package/build/theme/internals.d.ts +1 -1
- package/build/theme/internals.js +1 -1
- package/build/theme/internals.js.map +1 -1
- package/build/utilities/WithLocaleOrLocales.d.ts +5 -0
- package/build/utilities/WithLocaleOrLocales.js +2 -0
- package/build/utilities/formatDateTime.d.ts +3 -0
- package/build/utilities/formatDateTime.js +11 -0
- package/build/utilities/formatDateTime.js.map +7 -0
- package/build/utilities/formatNumber.d.ts +3 -0
- package/build/utilities/formatNumber.js +11 -0
- package/build/utilities/formatNumber.js.map +7 -0
- package/build/utilities/internals/cache.d.ts +1 -0
- package/build/utilities/internals/cache.js +3 -0
- package/build/utilities/internals/cache.js.map +7 -0
- package/build/utilities/internals/createCacheKey.d.ts +1 -0
- package/build/utilities/internals/createCacheKey.js +6 -0
- package/build/utilities/internals/createCacheKey.js.map +7 -0
- package/build/utilities/internals/getMemoized.d.ts +1 -0
- package/build/utilities/internals/getMemoized.js +12 -0
- package/build/utilities/internals/getMemoized.js.map +7 -0
- package/build/utilities/internals/normalizeLocales.d.ts +2 -0
- package/build/utilities/internals/normalizeLocales.js +12 -0
- package/build/utilities/internals/normalizeLocales.js.map +7 -0
- package/build/utilities/internals.d.ts +4 -0
- package/build/utilities/internals.js +6 -0
- package/build/utilities/internals.js.map +7 -0
- package/build/utilities.d.ts +3 -0
- package/build/utilities.js +5 -0
- package/build/utilities.js.map +7 -0
- package/package.json +29 -22
- package/source/components/Button.tsx +172 -0
- package/source/components/Card.ts +46 -0
- package/source/components/Checkbox.tsx +111 -61
- package/source/components/CheckboxField.tsx +41 -8
- package/source/components/Combobox.tsx +284 -146
- package/source/components/ComboboxOption.tsx +95 -0
- package/source/components/DataTable.tsx +441 -0
- package/source/components/Description.tsx +52 -0
- package/source/components/Dialog.tsx +76 -25
- package/source/components/DialogPanel.tsx +47 -11
- package/source/components/DialogTitle.tsx +45 -11
- package/source/components/Error.tsx +50 -19
- package/source/components/Field.tsx +71 -20
- package/source/components/Fieldset.tsx +64 -0
- package/source/components/Form.tsx +64 -22
- package/source/components/Icon.tsx +96 -0
- package/source/components/Input.tsx +95 -115
- package/source/components/Label.tsx +42 -11
- package/source/components/Legend.tsx +49 -0
- package/source/components/Listbox.tsx +386 -98
- package/source/components/ListboxOption.tsx +95 -0
- package/source/components/Menu.tsx +43 -12
- package/source/components/MenuButton.tsx +63 -12
- package/source/components/MenuHeading.tsx +52 -0
- package/source/components/MenuItem.tsx +57 -13
- package/source/components/MenuItems.tsx +54 -11
- package/source/components/MenuSection.tsx +52 -0
- package/source/components/MenuSeparator.tsx +52 -0
- package/source/components/Popover.tsx +45 -11
- package/source/components/PopoverBackdrop.tsx +52 -0
- package/source/components/PopoverButton.tsx +53 -26
- package/source/components/PopoverGroup.tsx +52 -0
- package/source/components/PopoverPanel.tsx +54 -26
- package/source/components/Radio.tsx +78 -36
- package/source/components/RadioField.tsx +16 -19
- package/source/components/RadioGroup.tsx +147 -0
- package/source/components/Spinner.tsx +48 -24
- package/source/components/Table.ts +47 -0
- package/source/components/TableBody.ts +47 -0
- package/source/components/TableCaption.ts +52 -0
- package/source/components/TableCell.ts +47 -0
- package/source/components/TableFoot.ts +47 -0
- package/source/components/TableHead.ts +47 -0
- package/source/components/TableHeader.ts +47 -0
- package/source/components/TableRow.ts +47 -0
- package/source/components/Text.ts +47 -0
- package/source/components/Textarea.tsx +65 -103
- package/source/components/data-table/DataTableHeader.tsx +573 -0
- package/source/components/data-table/DataTablePageButton.tsx +21 -0
- package/source/components/data-table/internals/constants.ts +3 -0
- package/source/components/data-table/internals/getCommonPinningClasses.ts +19 -0
- package/source/components/data-table/internals/getCommonPinningStyles.ts +13 -0
- package/source/components/internals/fieldContext.ts +4 -0
- package/source/components/internals/fieldNameContext.ts +3 -1
- package/source/components/internals/filterProps.ts +12 -0
- package/source/components/internals/formIdContext.ts +3 -0
- package/source/components/internals/forwardRef.ts +7 -0
- package/source/components/internals/useFormId.ts +7 -0
- package/source/components/internals.ts +5 -4
- package/source/components/useField.ts +7 -0
- package/source/components/{internals/useFieldName.ts → useFieldName.ts} +1 -1
- package/source/components/useForm.ts +24 -0
- package/source/components.ts +21 -3
- package/source/development/createTailwindConfig.ts +67 -38
- package/source/development.ts +0 -1
- package/source/main.ts +2 -5
- package/source/{fonts.css → styles.css} +10 -0
- package/source/theme/Theme.ts +68 -40
- package/source/theme/defaultTheme.ts +96 -366
- package/source/theme/internals/ComponentTheme.ts +18 -1
- package/source/theme/internals/ComponentWithTheme.ts +6 -0
- package/source/theme/internals/createComponentTheme.ts +3 -0
- package/source/theme/internals/createUseComponentThemeReturn.ts +1 -1
- package/source/theme/internals.ts +1 -1
- package/source/utilities/WithLocaleOrLocales.ts +1 -0
- package/source/utilities/formatDateTime.ts +15 -0
- package/source/utilities/formatNumber.ts +15 -0
- package/source/utilities/internals/cache.ts +1 -0
- package/source/utilities/internals/createCacheKey.ts +9 -0
- package/source/utilities/internals/getMemoized.ts +14 -0
- package/source/utilities/internals/normalizeLocales.ts +15 -0
- package/source/utilities/internals.ts +4 -0
- package/source/utilities.ts +3 -0
- package/build/components/ConfirmDialog.d.ts +0 -23
- package/build/components/ConfirmDialog.js +0 -40
- package/build/components/ConfirmDialog.js.map +0 -7
- package/build/components/RadioGroupField.d.ts +0 -20
- package/build/components/RadioGroupField.js +0 -82
- package/build/components/RadioGroupField.js.map +0 -7
- package/build/components/TableHeaderCell.d.ts +0 -10
- package/build/components/TableHeaderCell.js +0 -9
- package/build/components/TableHeaderCell.js.map +0 -7
- package/build/components/internals/formContext.d.ts +0 -3
- package/build/components/internals/formContext.js +0 -4
- package/build/components/internals/formContext.js.map +0 -7
- package/build/components/internals/useField.d.ts +0 -6
- package/build/components/internals/useField.js +0 -18
- package/build/components/internals/useField.js.map +0 -7
- package/build/components/internals/useFieldName.d.ts +0 -1
- package/build/components/internals/useFieldName.js.map +0 -7
- package/build/components/internals/useForm.d.ts +0 -1
- package/build/components/internals/useForm.js +0 -7
- package/build/components/internals/useForm.js.map +0 -7
- package/build/development/defaultTailwindConfig.d.ts +0 -72
- package/build/development/defaultTailwindConfig.js +0 -45
- package/build/development/defaultTailwindConfig.js.map +0 -7
- package/build/inter-variable-italic.js +0 -2
- package/build/inter-variable.js +0 -2
- package/build/theme/internals/cx.d.ts +0 -2
- package/build/theme/internals/cx.js +0 -6
- package/build/theme/internals/cx.js.map +0 -7
- package/source/components/Button.ts +0 -74
- package/source/components/Card.tsx +0 -10
- package/source/components/ConfirmDialog.tsx +0 -67
- package/source/components/RadioGroupField.tsx +0 -101
- package/source/components/Table.tsx +0 -31
- package/source/components/TableCell.tsx +0 -17
- package/source/components/TableHeader.tsx +0 -19
- package/source/components/TableHeaderCell.tsx +0 -17
- package/source/components/TableRow.tsx +0 -17
- package/source/components/internals/formContext.ts +0 -4
- package/source/components/internals/useField.ts +0 -19
- package/source/components/internals/useForm.ts +0 -7
- package/source/development/defaultTailwindConfig.ts +0 -45
- package/source/theme/internals/cx.ts +0 -10
- /package/build/{inter-variable-italic-54HMV74W.woff2 → inter-variable-italic.woff2} +0 -0
- /package/build/{inter-variable-75YQYCJN.woff2 → inter-variable.woff2} +0 -0
- /package/build/{inter-variable-italic.js.map → theme/internals/ComponentWithTheme.js.map} +0 -0
- /package/build/{inter-variable.js.map → utilities/WithLocaleOrLocales.js.map} +0 -0
package/README.md
CHANGED
|
@@ -24,12 +24,17 @@ It cannot be required from a CommonJS module.
|
|
|
24
24
|
|
|
25
25
|
## Usage
|
|
26
26
|
|
|
27
|
-
|
|
27
|
+
⚠️ This is an incomplete package! Expect a lot of breaking changes before the version 1.0.0 release.
|
|
28
|
+
|
|
29
|
+
Opinionated, pre-styled, but customizable component library based on React, Headless UI, Tailwind
|
|
30
|
+
CSS and Conform, made for very fast UI creation.
|
|
28
31
|
|
|
29
32
|
## Documentation
|
|
30
33
|
|
|
31
34
|
See [API reference](./docs) for auto-generated documentation.
|
|
32
35
|
|
|
36
|
+
See [Storybook](https://www.chromatic.com/library?appId=666f2dc8033dde8c47f6a278) for preview.
|
|
37
|
+
|
|
33
38
|
## Contributing
|
|
34
39
|
|
|
35
40
|
If you want to contribute, see [CONTRIBUTING](./CONTRIBUTING.md) for details.
|
|
@@ -1,24 +1,40 @@
|
|
|
1
|
-
import { type
|
|
2
|
-
import { type
|
|
1
|
+
import { type ButtonProps as HeadlessButtonProps } from '@headlessui/react';
|
|
2
|
+
import { type ComponentPropsWithoutRef, type ElementType, type Ref } from 'react';
|
|
3
|
+
import { type ComponentProps, type ComponentTheme } from '../theme/internals.js';
|
|
3
4
|
export declare const useButtonTheme: ((themeProps: {
|
|
4
|
-
readonly
|
|
5
|
+
readonly variant: "text" | "solid" | "outline" | "invisible";
|
|
5
6
|
readonly size: "small" | "medium" | "large";
|
|
6
7
|
readonly disabled: boolean;
|
|
7
8
|
}) => (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string) & {
|
|
8
9
|
componentThemeName: "Button";
|
|
9
10
|
themeDefinition: {
|
|
10
11
|
readonly variants: {
|
|
11
|
-
readonly
|
|
12
|
+
readonly variant: ["solid", "outline", "text", "invisible"];
|
|
12
13
|
readonly size: ["small", "medium", "large"];
|
|
13
14
|
readonly disabled: [true, false];
|
|
14
15
|
};
|
|
15
16
|
};
|
|
16
17
|
};
|
|
17
|
-
export type ButtonProps<T extends ElementType> = ComponentProps<typeof useButtonTheme> & ComponentPropsWithoutRef<T> & {
|
|
18
|
-
className?: string | undefined;
|
|
19
|
-
submit?: boolean | undefined;
|
|
18
|
+
export type ButtonProps<T extends ElementType> = ComponentProps<typeof useButtonTheme> & Omit<ComponentPropsWithoutRef<T>, 'type'> & {
|
|
20
19
|
as?: T | undefined;
|
|
21
|
-
|
|
22
|
-
|
|
20
|
+
submit?: boolean | undefined;
|
|
21
|
+
idle?: boolean | undefined;
|
|
22
|
+
autoFocus?: boolean | undefined;
|
|
23
|
+
className?: string | undefined;
|
|
24
|
+
children?: HeadlessButtonProps['children'] | undefined;
|
|
23
25
|
};
|
|
24
|
-
export declare const Button:
|
|
26
|
+
export declare const Button: <T extends ElementType = "button">(props: Partial<import("@jakubmazanec/ts-utils").Writable<{
|
|
27
|
+
readonly variant: "text" | "solid" | "outline" | "invisible";
|
|
28
|
+
readonly size: "small" | "medium" | "large";
|
|
29
|
+
readonly disabled: boolean;
|
|
30
|
+
}>> & Omit<import("react").PropsWithoutRef<import("react").ComponentProps<T>>, "type"> & {
|
|
31
|
+
as?: T | undefined;
|
|
32
|
+
submit?: boolean | undefined;
|
|
33
|
+
idle?: boolean | undefined;
|
|
34
|
+
autoFocus?: boolean | undefined;
|
|
35
|
+
className?: string | undefined;
|
|
36
|
+
children?: HeadlessButtonProps['children'] | undefined;
|
|
37
|
+
} & {
|
|
38
|
+
ref?: Ref<HTMLElement> | undefined;
|
|
39
|
+
}) => import("react").ReactNode;
|
|
40
|
+
export declare const buttonTheme: ComponentTheme<typeof useButtonTheme>;
|
|
@@ -1,51 +1,139 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
3
|
import { Button as HeadlessButton } from "@headlessui/react";
|
|
3
4
|
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
Children,
|
|
6
|
+
cloneElement,
|
|
7
|
+
isValidElement
|
|
7
8
|
} from "react";
|
|
8
|
-
import {
|
|
9
|
-
|
|
9
|
+
import {
|
|
10
|
+
createComponentTheme
|
|
11
|
+
} from "../theme/internals.js";
|
|
12
|
+
import { Icon } from "./Icon.js";
|
|
13
|
+
import { forwardRef } from "./internals.js";
|
|
14
|
+
import { Spinner } from "./Spinner.js";
|
|
10
15
|
export const useButtonTheme = createComponentTheme("Button", {
|
|
11
16
|
variants: {
|
|
12
|
-
|
|
17
|
+
variant: ["solid", "outline", "text", "invisible"],
|
|
13
18
|
size: ["small", "medium", "large"],
|
|
14
19
|
disabled: [true, false]
|
|
15
20
|
}
|
|
16
21
|
});
|
|
22
|
+
const BUTTON_ELEMENT = "button";
|
|
17
23
|
export const Button = forwardRef(
|
|
18
24
|
({
|
|
19
|
-
|
|
20
|
-
className,
|
|
21
|
-
type = "solid",
|
|
25
|
+
variant = "solid",
|
|
22
26
|
size = "medium",
|
|
23
27
|
disabled = false,
|
|
28
|
+
as = BUTTON_ELEMENT,
|
|
29
|
+
idle = true,
|
|
30
|
+
autoFocus = false,
|
|
24
31
|
submit = false,
|
|
32
|
+
className,
|
|
25
33
|
children,
|
|
26
|
-
onClick,
|
|
27
34
|
...rest
|
|
28
35
|
}, ref) => {
|
|
29
|
-
let theme = useButtonTheme({
|
|
30
|
-
let form = useForm();
|
|
31
|
-
let handleClick = useCallback(() => {
|
|
32
|
-
onClick?.();
|
|
33
|
-
}, [onClick]);
|
|
36
|
+
let theme = useButtonTheme({ variant, size, disabled });
|
|
34
37
|
let props = {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
disabled,
|
|
38
|
-
|
|
39
|
-
|
|
38
|
+
as,
|
|
39
|
+
ref,
|
|
40
|
+
className: theme(disabled ? "pointer-events-none" : null, className),
|
|
41
|
+
disabled: disabled || submit && !idle,
|
|
42
|
+
autoFocus,
|
|
43
|
+
"data-component": "button",
|
|
44
|
+
...rest
|
|
40
45
|
};
|
|
41
|
-
|
|
42
|
-
if (element === "button") {
|
|
46
|
+
if (as === BUTTON_ELEMENT) {
|
|
43
47
|
props.type = "button";
|
|
44
48
|
}
|
|
45
|
-
if (
|
|
49
|
+
if (submit) {
|
|
46
50
|
props.type = "submit";
|
|
47
51
|
}
|
|
48
|
-
|
|
52
|
+
if (typeof children === "function") {
|
|
53
|
+
return /* @__PURE__ */ jsx(HeadlessButton, { ...props, children });
|
|
54
|
+
}
|
|
55
|
+
let enhancedChildren = Children.map(children, (child) => {
|
|
56
|
+
if (isValidElement(child) && (child.type === Icon || child.type === Spinner)) {
|
|
57
|
+
return cloneElement(child, { "data-icon": "" });
|
|
58
|
+
}
|
|
59
|
+
return child;
|
|
60
|
+
});
|
|
61
|
+
return /* @__PURE__ */ jsxs(HeadlessButton, { ...props, children: [
|
|
62
|
+
submit && !idle ? /* @__PURE__ */ jsx(Spinner, { "data-icon": true }) : null,
|
|
63
|
+
enhancedChildren
|
|
64
|
+
] });
|
|
49
65
|
}
|
|
50
66
|
);
|
|
67
|
+
export const buttonTheme = {
|
|
68
|
+
className: "rounded-2 flex items-center justify-center text-nowrap font-sans font-medium text-sm transition-colors",
|
|
69
|
+
variants: {
|
|
70
|
+
variant: {
|
|
71
|
+
solid: "text-white bg-gray-900 hover:bg-gray-800",
|
|
72
|
+
outline: "text-gray-950 border-2 border-gray-100 hover:border-gray-200",
|
|
73
|
+
text: "text-gray-950 border-2 border-transparent hover:border-gray-200",
|
|
74
|
+
invisible: "cursor-default text-gray-600"
|
|
75
|
+
},
|
|
76
|
+
size: {
|
|
77
|
+
small: "text-sm leading-6 px-2.5 h-8 min-w-8 gap-x-2",
|
|
78
|
+
medium: "leading-6 px-2.5 h-9 min-w-9 gap-x-2",
|
|
79
|
+
large: "text-lg leading-6 px-3 h-10 min-w-10 gap-x-2"
|
|
80
|
+
},
|
|
81
|
+
disabled: {
|
|
82
|
+
true: "",
|
|
83
|
+
false: ""
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
compoundVariants: [
|
|
87
|
+
{
|
|
88
|
+
variant: "solid",
|
|
89
|
+
size: "small",
|
|
90
|
+
className: "px-3"
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
variant: "solid",
|
|
94
|
+
size: "medium",
|
|
95
|
+
className: "px-3"
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
variant: "solid",
|
|
99
|
+
size: "large",
|
|
100
|
+
className: "px-3.5"
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
variant: "invisible",
|
|
104
|
+
size: "small",
|
|
105
|
+
className: "text-xs px-2 h-5 min-w-5"
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
variant: "invisible",
|
|
109
|
+
size: "medium",
|
|
110
|
+
className: "px-2 h-6 min-w-6"
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
variant: "invisible",
|
|
114
|
+
size: "large",
|
|
115
|
+
className: "px-2 h-7 min-w-7"
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
variant: "solid",
|
|
119
|
+
disabled: true,
|
|
120
|
+
className: "text-white bg-gray-200 hover:bg-gray-200"
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
variant: "outline",
|
|
124
|
+
disabled: true,
|
|
125
|
+
className: "text-gray-200 hover:border-gray-100"
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
variant: "text",
|
|
129
|
+
disabled: true,
|
|
130
|
+
className: "text-gray-200 hover:border-transparent"
|
|
131
|
+
},
|
|
132
|
+
{
|
|
133
|
+
variant: "invisible",
|
|
134
|
+
disabled: true,
|
|
135
|
+
className: "text-gray-200 "
|
|
136
|
+
}
|
|
137
|
+
]
|
|
138
|
+
};
|
|
51
139
|
//# sourceMappingURL=Button.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../source/components/Button.
|
|
4
|
-
"sourcesContent": ["import {Button as HeadlessButton} from '@headlessui/react';\nimport {\n
|
|
5
|
-
"mappings": ";
|
|
3
|
+
"sources": ["../../source/components/Button.tsx"],
|
|
4
|
+
"sourcesContent": ["import {Button as HeadlessButton, type ButtonProps as HeadlessButtonProps} from '@headlessui/react';\nimport {\n Children,\n cloneElement,\n type ComponentPropsWithoutRef,\n type ElementType,\n isValidElement,\n type Ref,\n} from 'react';\n\nimport {\n type ComponentProps,\n type ComponentTheme,\n createComponentTheme,\n} from '../theme/internals.js';\nimport {Icon} from './Icon.js';\nimport {forwardRef} from './internals.js';\nimport {Spinner} from './Spinner.js';\n\nexport const useButtonTheme = createComponentTheme('Button', {\n variants: {\n variant: ['solid', 'outline', 'text', 'invisible'],\n size: ['small', 'medium', 'large'],\n disabled: [true, false],\n },\n});\n\nconst BUTTON_ELEMENT = 'button';\n\nexport type ButtonProps<T extends ElementType> = ComponentProps<typeof useButtonTheme> &\n Omit<ComponentPropsWithoutRef<T>, 'type'> & {\n as?: T | undefined;\n submit?: boolean | undefined;\n idle?: boolean | undefined;\n autoFocus?: boolean | undefined;\n className?: string | undefined;\n children?: HeadlessButtonProps['children'] | undefined; // sadly, we cannot use `T`'s children type, because Headless UI always, if `children` is function, calls it with its own render props documented here: https://headlessui.com/react/button#using-render-props\n };\n\nexport const Button = forwardRef(\n <T extends ElementType = typeof BUTTON_ELEMENT>(\n {\n variant = 'solid',\n size = 'medium',\n disabled = false,\n as = BUTTON_ELEMENT as T,\n idle = true,\n autoFocus = false,\n submit = false,\n className,\n children,\n ...rest\n }: ButtonProps<T>,\n ref: Ref<HTMLElement>,\n ) => {\n let theme = useButtonTheme({variant, size, disabled});\n\n let props: Record<string, unknown> = {\n as,\n ref,\n className: theme(disabled ? 'pointer-events-none' : null, className),\n disabled: disabled || (submit && !idle),\n autoFocus,\n 'data-component': 'button',\n ...rest,\n };\n\n if (as === BUTTON_ELEMENT) {\n props.type = 'button';\n }\n\n if (submit) {\n props.type = 'submit';\n }\n\n if (typeof children === 'function') {\n return <HeadlessButton {...props}>{children}</HeadlessButton>;\n }\n\n let enhancedChildren = Children.map(children, (child) => {\n if (isValidElement(child) && (child.type === Icon || child.type === Spinner)) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- needed\n return cloneElement<any>(child, {'data-icon': ''});\n }\n\n return child;\n });\n\n return (\n <HeadlessButton {...props}>\n {submit && !idle ?\n <Spinner data-icon />\n : null}\n {enhancedChildren}\n </HeadlessButton>\n );\n },\n);\n\nexport const buttonTheme: ComponentTheme<typeof useButtonTheme> = {\n className:\n 'rounded-2 flex items-center justify-center text-nowrap font-sans font-medium text-sm transition-colors',\n variants: {\n variant: {\n solid: 'text-white bg-gray-900 hover:bg-gray-800',\n outline: 'text-gray-950 border-2 border-gray-100 hover:border-gray-200',\n text: 'text-gray-950 border-2 border-transparent hover:border-gray-200',\n invisible: 'cursor-default text-gray-600',\n },\n size: {\n small: 'text-sm leading-6 px-2.5 h-8 min-w-8 gap-x-2',\n medium: 'leading-6 px-2.5 h-9 min-w-9 gap-x-2',\n large: 'text-lg leading-6 px-3 h-10 min-w-10 gap-x-2',\n },\n disabled: {\n true: '',\n false: '',\n },\n },\n compoundVariants: [\n {\n variant: 'solid',\n size: 'small',\n className: 'px-3',\n },\n {\n variant: 'solid',\n size: 'medium',\n className: 'px-3',\n },\n {\n variant: 'solid',\n size: 'large',\n className: 'px-3.5',\n },\n {\n variant: 'invisible',\n size: 'small',\n className: 'text-xs px-2 h-5 min-w-5',\n },\n {\n variant: 'invisible',\n size: 'medium',\n className: 'px-2 h-6 min-w-6',\n },\n {\n variant: 'invisible',\n size: 'large',\n className: 'px-2 h-7 min-w-7',\n },\n {\n variant: 'solid',\n disabled: true,\n className: 'text-white bg-gray-200 hover:bg-gray-200',\n },\n {\n variant: 'outline',\n disabled: true,\n className: 'text-gray-200 hover:border-gray-100',\n },\n {\n variant: 'text',\n disabled: true,\n className: 'text-gray-200 hover:border-transparent',\n },\n {\n variant: 'invisible',\n disabled: true,\n className: 'text-gray-200 ',\n },\n ],\n};\n"],
|
|
5
|
+
"mappings": ";AA4Ea,cAaP,YAbO;AA5Eb,SAAQ,UAAU,sBAA8D;AAChF;AAAA,EACE;AAAA,EACA;AAAA,EAGA;AAAA,OAEK;AAEP;AAAA,EAGE;AAAA,OACK;AACP,SAAQ,YAAW;AACnB,SAAQ,kBAAiB;AACzB,SAAQ,eAAc;AAEf,aAAM,iBAAiB,qBAAqB,UAAU;AAAA,EAC3D,UAAU;AAAA,IACR,SAAS,CAAC,SAAS,WAAW,QAAQ,WAAW;AAAA,IACjD,MAAM,CAAC,SAAS,UAAU,OAAO;AAAA,IACjC,UAAU,CAAC,MAAM,KAAK;AAAA,EACxB;AACF,CAAC;AAED,MAAM,iBAAiB;AAYhB,aAAM,SAAS;AAAA,EACpB,CACE;AAAA,IACE,UAAU;AAAA,IACV,OAAO;AAAA,IACP,WAAW;AAAA,IACX,KAAK;AAAA,IACL,OAAO;AAAA,IACP,YAAY;AAAA,IACZ,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACL,GACA,QACG;AACH,QAAI,QAAQ,eAAe,EAAC,SAAS,MAAM,SAAQ,CAAC;AAEpD,QAAI,QAAiC;AAAA,MACnC;AAAA,MACA;AAAA,MACA,WAAW,MAAM,WAAW,wBAAwB,MAAM,SAAS;AAAA,MACnE,UAAU,YAAa,UAAU,CAAC;AAAA,MAClC;AAAA,MACA,kBAAkB;AAAA,MAClB,GAAG;AAAA,IACL;AAEA,QAAI,OAAO,gBAAgB;AACzB,YAAM,OAAO;AAAA,IACf;AAEA,QAAI,QAAQ;AACV,YAAM,OAAO;AAAA,IACf;AAEA,QAAI,OAAO,aAAa,YAAY;AAClC,aAAO,oBAAC,kBAAgB,GAAG,OAAQ,UAAS;AAAA,IAC9C;AAEA,QAAI,mBAAmB,SAAS,IAAI,UAAU,CAAC,UAAU;AACvD,UAAI,eAAe,KAAK,MAAM,MAAM,SAAS,QAAQ,MAAM,SAAS,UAAU;AAE5E,eAAO,aAAkB,OAAO,EAAC,aAAa,GAAE,CAAC;AAAA,MACnD;AAEA,aAAO;AAAA,IACT,CAAC;AAED,WACE,qBAAC,kBAAgB,GAAG,OACjB;AAAA,gBAAU,CAAC,OACV,oBAAC,WAAQ,aAAS,MAAC,IACnB;AAAA,MACD;AAAA,OACH;AAAA,EAEJ;AACF;AAEO,aAAM,cAAqD;AAAA,EAChE,WACE;AAAA,EACF,UAAU;AAAA,IACR,SAAS;AAAA,MACP,OAAO;AAAA,MACP,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA,MAAM;AAAA,MACJ,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,OAAO;AAAA,IACT;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,MACN,OAAO;AAAA,IACT;AAAA,EACF;AAAA,EACA,kBAAkB;AAAA,IAChB;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,MAAM;AAAA,MACN,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,UAAU;AAAA,MACV,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,UAAU;AAAA,MACV,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,UAAU;AAAA,MACV,WAAW;AAAA,IACb;AAAA,IACA;AAAA,MACE,SAAS;AAAA,MACT,UAAU;AAAA,MACV,WAAW;AAAA,IACb;AAAA,EACF;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,5 +1,19 @@
|
|
|
1
|
-
import { type PropsWithChildren } from 'react';
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { type ComponentPropsWithoutRef, type ElementType, type PropsWithChildren, type Ref } from 'react';
|
|
2
|
+
import { type ComponentProps, type ComponentTheme } from '../theme/internals.js';
|
|
3
|
+
export declare const useCardTheme: (() => (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string) & {
|
|
4
|
+
componentThemeName: "Card";
|
|
5
|
+
themeDefinition: undefined;
|
|
4
6
|
};
|
|
5
|
-
export
|
|
7
|
+
export type CardProps<T extends ElementType> = ComponentProps<typeof useCardTheme> & ComponentPropsWithoutRef<T> & PropsWithChildren<{
|
|
8
|
+
as?: T | undefined;
|
|
9
|
+
className?: string;
|
|
10
|
+
}>;
|
|
11
|
+
export declare const Card: <T extends ElementType = "div">(props: import("react").PropsWithoutRef<import("react").ComponentProps<T>> & {
|
|
12
|
+
as?: T | undefined;
|
|
13
|
+
className?: string | undefined;
|
|
14
|
+
} & {
|
|
15
|
+
children?: import("react").ReactNode;
|
|
16
|
+
} & {
|
|
17
|
+
ref?: Ref<HTMLElement> | undefined;
|
|
18
|
+
}) => import("react").ReactNode;
|
|
19
|
+
export declare const cardTheme: ComponentTheme<typeof useCardTheme>;
|
package/build/components/Card.js
CHANGED
|
@@ -1,7 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
import {
|
|
3
|
+
createElement
|
|
4
|
+
} from "react";
|
|
5
|
+
import {
|
|
6
|
+
createComponentTheme
|
|
7
|
+
} from "../theme/internals.js";
|
|
8
|
+
import { forwardRef } from "./internals.js";
|
|
9
|
+
export const useCardTheme = createComponentTheme("Card");
|
|
10
|
+
const CARD_ELEMENT = "div";
|
|
11
|
+
export const Card = forwardRef(
|
|
12
|
+
({ as: Component = CARD_ELEMENT, className, children, ...rest }, ref) => {
|
|
13
|
+
let theme = useCardTheme();
|
|
14
|
+
let props = {
|
|
15
|
+
ref,
|
|
16
|
+
className: theme(null, className),
|
|
17
|
+
"data-component": "card",
|
|
18
|
+
...rest
|
|
19
|
+
};
|
|
20
|
+
return createElement(Component, props, children);
|
|
21
|
+
}
|
|
22
|
+
);
|
|
23
|
+
export const cardTheme = {
|
|
24
|
+
className: "rounded-2 border border-gray-100 p-4"
|
|
25
|
+
};
|
|
7
26
|
//# sourceMappingURL=Card.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../source/components/Card.
|
|
4
|
-
"sourcesContent": ["import {type PropsWithChildren} from 'react';\nimport {
|
|
5
|
-
"mappings": ";
|
|
3
|
+
"sources": ["../../source/components/Card.ts"],
|
|
4
|
+
"sourcesContent": ["import {\n type ComponentPropsWithoutRef,\n createElement,\n type ElementType,\n type PropsWithChildren,\n type Ref,\n} from 'react';\n\nimport {\n type ComponentProps,\n type ComponentTheme,\n createComponentTheme,\n} from '../theme/internals.js';\nimport {forwardRef} from './internals.js';\n\nexport const useCardTheme = createComponentTheme('Card');\n\nconst CARD_ELEMENT = 'div';\n\nexport type CardProps<T extends ElementType> = ComponentProps<typeof useCardTheme> &\n ComponentPropsWithoutRef<T> &\n PropsWithChildren<{\n as?: T | undefined;\n className?: string;\n }>;\n\nexport const Card = forwardRef(\n <T extends ElementType = typeof CARD_ELEMENT>(\n {as: Component = CARD_ELEMENT as T, className, children, ...rest}: CardProps<T>,\n ref: Ref<HTMLElement>,\n ) => {\n let theme = useCardTheme();\n let props = {\n ref,\n className: theme(null, className),\n 'data-component': 'card',\n ...rest,\n };\n\n return createElement(Component, props, children);\n },\n);\n\nexport const cardTheme: ComponentTheme<typeof useCardTheme> = {\n className: 'rounded-2 border border-gray-100 p-4',\n};\n"],
|
|
5
|
+
"mappings": ";AAAA;AAAA,EAEE;AAAA,OAIK;AAEP;AAAA,EAGE;AAAA,OACK;AACP,SAAQ,kBAAiB;AAElB,aAAM,eAAe,qBAAqB,MAAM;AAEvD,MAAM,eAAe;AASd,aAAM,OAAO;AAAA,EAClB,CACE,EAAC,IAAI,YAAY,cAAmB,WAAW,UAAU,GAAG,KAAI,GAChE,QACG;AACH,QAAI,QAAQ,aAAa;AACzB,QAAI,QAAQ;AAAA,MACV;AAAA,MACA,WAAW,MAAM,MAAM,SAAS;AAAA,MAChC,kBAAkB;AAAA,MAClB,GAAG;AAAA,IACL;AAEA,WAAO,cAAc,WAAW,OAAO,QAAQ;AAAA,EACjD;AACF;AAEO,aAAM,YAAiD;AAAA,EAC5D,WAAW;AACb;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,24 +1,39 @@
|
|
|
1
|
-
import { type
|
|
1
|
+
import { type ComponentPropsWithoutRef, type ElementType, type Ref } from 'react';
|
|
2
|
+
import { type ComponentProps, type ComponentTheme } from '../theme/internals.js';
|
|
2
3
|
export declare const useCheckboxTheme: ((themeProps: {
|
|
3
4
|
readonly disabled: boolean;
|
|
4
5
|
}) => {
|
|
5
|
-
root: (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string;
|
|
6
|
-
checked: (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string;
|
|
7
|
-
unchecked: (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string;
|
|
8
6
|
icon: (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string;
|
|
7
|
+
root: (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string;
|
|
9
8
|
}) & {
|
|
10
9
|
componentThemeName: "Checkbox";
|
|
11
10
|
themeDefinition: {
|
|
12
11
|
readonly variants: {
|
|
13
12
|
readonly disabled: [true, false];
|
|
14
13
|
};
|
|
15
|
-
readonly elements: ["root", "
|
|
14
|
+
readonly elements: ["root", "icon"];
|
|
16
15
|
};
|
|
17
16
|
};
|
|
18
|
-
export type CheckboxProps = ComponentProps<typeof useCheckboxTheme> & {
|
|
17
|
+
export type CheckboxProps<T extends ElementType> = ComponentProps<typeof useCheckboxTheme> & Omit<ComponentPropsWithoutRef<T>, 'onChange'> & {
|
|
18
|
+
as?: T | undefined;
|
|
19
|
+
checked?: boolean | undefined;
|
|
20
|
+
indeterminate?: boolean | undefined;
|
|
21
|
+
autoFocus?: boolean | undefined;
|
|
19
22
|
name?: string;
|
|
20
23
|
className?: string;
|
|
21
|
-
|
|
22
|
-
onChange?: ((value: boolean) => void) | undefined;
|
|
24
|
+
onChange?: ((checked: boolean) => void) | undefined;
|
|
23
25
|
};
|
|
24
|
-
export declare
|
|
26
|
+
export declare const Checkbox: <T extends ElementType = "span">(props: Partial<import("@jakubmazanec/ts-utils").Writable<{
|
|
27
|
+
readonly disabled: boolean;
|
|
28
|
+
}>> & Omit<import("react").PropsWithoutRef<import("react").ComponentProps<T>>, "onChange"> & {
|
|
29
|
+
as?: T | undefined;
|
|
30
|
+
checked?: boolean | undefined;
|
|
31
|
+
indeterminate?: boolean | undefined;
|
|
32
|
+
autoFocus?: boolean | undefined;
|
|
33
|
+
name?: string | undefined;
|
|
34
|
+
className?: string | undefined;
|
|
35
|
+
onChange?: ((checked: boolean) => void) | undefined;
|
|
36
|
+
} & {
|
|
37
|
+
ref?: Ref<HTMLElement> | undefined;
|
|
38
|
+
}) => import("react").ReactNode;
|
|
39
|
+
export declare const checkboxTheme: ComponentTheme<typeof useCheckboxTheme>;
|
|
@@ -1,63 +1,87 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
import { jsx
|
|
3
|
-
import {
|
|
4
|
-
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import {
|
|
4
|
+
Checkbox as HeadlessCheckbox
|
|
5
|
+
} from "@headlessui/react";
|
|
5
6
|
import { useCallback } from "react";
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
import {
|
|
8
|
+
createComponentTheme
|
|
9
|
+
} from "../theme/internals.js";
|
|
10
|
+
import { Icon } from "./Icon.js";
|
|
11
|
+
import { forwardRef, useFormId } from "./internals.js";
|
|
12
|
+
import { useField } from "./useField.js";
|
|
13
|
+
import { useFieldName } from "./useFieldName.js";
|
|
9
14
|
export const useCheckboxTheme = createComponentTheme("Checkbox", {
|
|
10
15
|
variants: {
|
|
11
16
|
disabled: [true, false]
|
|
12
17
|
},
|
|
13
|
-
elements: ["root", "
|
|
18
|
+
elements: ["root", "icon"]
|
|
14
19
|
});
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
name
|
|
54
|
-
|
|
20
|
+
const CHECKBOX_ELEMENT = "span";
|
|
21
|
+
export const Checkbox = forwardRef(
|
|
22
|
+
({
|
|
23
|
+
disabled = false,
|
|
24
|
+
as = CHECKBOX_ELEMENT,
|
|
25
|
+
checked,
|
|
26
|
+
indeterminate,
|
|
27
|
+
autoFocus,
|
|
28
|
+
name,
|
|
29
|
+
className,
|
|
30
|
+
onChange,
|
|
31
|
+
...rest
|
|
32
|
+
}, ref) => {
|
|
33
|
+
let theme = useCheckboxTheme({ disabled });
|
|
34
|
+
let fieldName = useFieldName();
|
|
35
|
+
let field = useField();
|
|
36
|
+
let formId = useFormId();
|
|
37
|
+
let handleChange = useCallback(() => {
|
|
38
|
+
onChange?.(!checked);
|
|
39
|
+
}, [checked, onChange]);
|
|
40
|
+
if (field || fieldName) {
|
|
41
|
+
let props2 = {
|
|
42
|
+
as,
|
|
43
|
+
ref,
|
|
44
|
+
form: formId,
|
|
45
|
+
name: field?.name ?? fieldName,
|
|
46
|
+
indeterminate,
|
|
47
|
+
autoFocus,
|
|
48
|
+
className: theme.root("relative", className),
|
|
49
|
+
"data-component": "checkbox",
|
|
50
|
+
...rest
|
|
51
|
+
};
|
|
52
|
+
return /* @__PURE__ */ jsx(HeadlessCheckbox, { ...props2, children: /* @__PURE__ */ jsx("span", { className: theme.icon(), children: /* @__PURE__ */ jsx(Icon, { name: "Check" }) }) });
|
|
53
|
+
}
|
|
54
|
+
let props = {
|
|
55
|
+
as,
|
|
56
|
+
ref,
|
|
57
|
+
checked: Boolean(checked),
|
|
58
|
+
name,
|
|
59
|
+
indeterminate,
|
|
60
|
+
autoFocus,
|
|
61
|
+
className: theme.root("relative", className),
|
|
62
|
+
"data-component": "checkbox",
|
|
55
63
|
onChange: handleChange,
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
64
|
+
...rest
|
|
65
|
+
};
|
|
66
|
+
return /* @__PURE__ */ jsx(HeadlessCheckbox, { ...props, children: /* @__PURE__ */ jsx("span", { className: theme.icon(), children: /* @__PURE__ */ jsx(Icon, { name: "Check" }) }) });
|
|
67
|
+
}
|
|
68
|
+
);
|
|
69
|
+
export const checkboxTheme = {
|
|
70
|
+
classNames: {
|
|
71
|
+
root: "group/checkbox inline-block size-5 cursor-pointer",
|
|
72
|
+
icon: "flex justify-content justify-item size-5 *:rounded-2 *:bg-white *:border-2 *:border-gray-100 *:hover:border-gray-200 *:shadow-inner *:transition-colors *:text-transparent *:hover:text-gray-100 group-data-[checked]/checkbox:*:bg-gray-950 group-data-[checked]/checkbox:*:border-gray-950 group-data-[checked]/checkbox:*:text-white"
|
|
73
|
+
},
|
|
74
|
+
variants: {
|
|
75
|
+
disabled: {
|
|
76
|
+
true: {
|
|
77
|
+
root: "cursor-not-allowed",
|
|
78
|
+
icon: "*:hover:text-transparent *:border-gray-50 *:hover:border-gray-50 group-data-[checked]/checkbox:*:bg-gray-100 group-data-[checked]/checkbox:*:border-gray-100 group-data-[checked]/checkbox:*:text-white"
|
|
79
|
+
},
|
|
80
|
+
false: {
|
|
81
|
+
root: "",
|
|
82
|
+
icon: ""
|
|
83
|
+
}
|
|
60
84
|
}
|
|
61
|
-
|
|
62
|
-
}
|
|
85
|
+
}
|
|
86
|
+
};
|
|
63
87
|
//# sourceMappingURL=Checkbox.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../source/components/Checkbox.tsx"],
|
|
4
|
-
"sourcesContent": ["
|
|
5
|
-
"mappings": ";
|
|
6
|
-
"names": ["
|
|
4
|
+
"sourcesContent": ["import {\n Checkbox as HeadlessCheckbox,\n type CheckboxProps as HeadlessCheckboxProps,\n} from '@headlessui/react';\nimport {type ComponentPropsWithoutRef, type ElementType, type Ref, useCallback} from 'react';\n\nimport {\n type ComponentProps,\n type ComponentTheme,\n createComponentTheme,\n} from '../theme/internals.js';\nimport {Icon} from './Icon.js';\nimport {forwardRef, useFormId} from './internals.js';\nimport {useField} from './useField.js';\nimport {useFieldName} from './useFieldName.js';\n\nexport const useCheckboxTheme = createComponentTheme('Checkbox', {\n variants: {\n disabled: [true, false],\n },\n elements: ['root', 'icon'],\n});\n\nconst CHECKBOX_ELEMENT = 'span';\n\nexport type CheckboxProps<T extends ElementType> = ComponentProps<typeof useCheckboxTheme> &\n Omit<ComponentPropsWithoutRef<T>, 'onChange'> & {\n as?: T | undefined;\n checked?: boolean | undefined;\n indeterminate?: boolean | undefined;\n autoFocus?: boolean | undefined;\n name?: string;\n className?: string;\n onChange?: ((checked: boolean) => void) | undefined;\n };\n\nexport const Checkbox = forwardRef(\n <T extends ElementType = typeof CHECKBOX_ELEMENT>(\n {\n disabled = false,\n as = CHECKBOX_ELEMENT as T,\n checked,\n indeterminate,\n autoFocus,\n name,\n className,\n onChange,\n ...rest\n }: CheckboxProps<T>,\n ref: Ref<HTMLElement>,\n ) => {\n let theme = useCheckboxTheme({disabled});\n let fieldName = useFieldName();\n let field = useField();\n let formId = useFormId();\n\n let handleChange = useCallback(() => {\n onChange?.(!checked);\n }, [checked, onChange]);\n\n if (field || fieldName) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- needed\n let props: HeadlessCheckboxProps<any> = {\n as,\n ref,\n form: formId,\n name: field?.name ?? fieldName,\n indeterminate,\n autoFocus,\n className: theme.root('relative', className),\n 'data-component': 'checkbox',\n ...rest,\n };\n\n return (\n <HeadlessCheckbox {...props}>\n <span className={theme.icon()}>\n <Icon name=\"Check\" />\n </span>\n </HeadlessCheckbox>\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- needed\n let props: HeadlessCheckboxProps<any> = {\n as,\n ref,\n checked: Boolean(checked),\n name,\n indeterminate,\n autoFocus,\n className: theme.root('relative', className),\n 'data-component': 'checkbox',\n onChange: handleChange,\n ...rest,\n };\n\n return (\n <HeadlessCheckbox {...props}>\n <span className={theme.icon()}>\n <Icon name=\"Check\" />\n </span>\n </HeadlessCheckbox>\n );\n },\n);\n\nexport const checkboxTheme: ComponentTheme<typeof useCheckboxTheme> = {\n classNames: {\n root: 'group/checkbox inline-block size-5 cursor-pointer',\n icon: 'flex justify-content justify-item size-5 *:rounded-2 *:bg-white *:border-2 *:border-gray-100 *:hover:border-gray-200 *:shadow-inner *:transition-colors *:text-transparent *:hover:text-gray-100 group-data-[checked]/checkbox:*:bg-gray-950 group-data-[checked]/checkbox:*:border-gray-950 group-data-[checked]/checkbox:*:text-white',\n },\n variants: {\n disabled: {\n true: {\n root: 'cursor-not-allowed',\n icon: '*:hover:text-transparent *:border-gray-50 *:hover:border-gray-50 group-data-[checked]/checkbox:*:bg-gray-100 group-data-[checked]/checkbox:*:border-gray-100 group-data-[checked]/checkbox:*:text-white',\n },\n false: {\n root: '',\n icon: '',\n },\n },\n },\n};\n"],
|
|
5
|
+
"mappings": ";AA6EY;AA7EZ;AAAA,EACE,YAAY;AAAA,OAEP;AACP,SAAmE,mBAAkB;AAErF;AAAA,EAGE;AAAA,OACK;AACP,SAAQ,YAAW;AACnB,SAAQ,YAAY,iBAAgB;AACpC,SAAQ,gBAAe;AACvB,SAAQ,oBAAmB;AAEpB,aAAM,mBAAmB,qBAAqB,YAAY;AAAA,EAC/D,UAAU;AAAA,IACR,UAAU,CAAC,MAAM,KAAK;AAAA,EACxB;AAAA,EACA,UAAU,CAAC,QAAQ,MAAM;AAC3B,CAAC;AAED,MAAM,mBAAmB;AAalB,aAAM,WAAW;AAAA,EACtB,CACE;AAAA,IACE,WAAW;AAAA,IACX,KAAK;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACL,GACA,QACG;AACH,QAAI,QAAQ,iBAAiB,EAAC,SAAQ,CAAC;AACvC,QAAI,YAAY,aAAa;AAC7B,QAAI,QAAQ,SAAS;AACrB,QAAI,SAAS,UAAU;AAEvB,QAAI,eAAe,YAAY,MAAM;AACnC,iBAAW,CAAC,OAAO;AAAA,IACrB,GAAG,CAAC,SAAS,QAAQ,CAAC;AAEtB,QAAI,SAAS,WAAW;AAEtB,UAAIA,SAAoC;AAAA,QACtC;AAAA,QACA;AAAA,QACA,MAAM;AAAA,QACN,MAAM,OAAO,QAAQ;AAAA,QACrB;AAAA,QACA;AAAA,QACA,WAAW,MAAM,KAAK,YAAY,SAAS;AAAA,QAC3C,kBAAkB;AAAA,QAClB,GAAG;AAAA,MACL;AAEA,aACE,oBAAC,oBAAkB,GAAGA,QACpB,8BAAC,UAAK,WAAW,MAAM,KAAK,GAC1B,8BAAC,QAAK,MAAK,SAAQ,GACrB,GACF;AAAA,IAEJ;AAGA,QAAI,QAAoC;AAAA,MACtC;AAAA,MACA;AAAA,MACA,SAAS,QAAQ,OAAO;AAAA,MACxB;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW,MAAM,KAAK,YAAY,SAAS;AAAA,MAC3C,kBAAkB;AAAA,MAClB,UAAU;AAAA,MACV,GAAG;AAAA,IACL;AAEA,WACE,oBAAC,oBAAkB,GAAG,OACpB,8BAAC,UAAK,WAAW,MAAM,KAAK,GAC1B,8BAAC,QAAK,MAAK,SAAQ,GACrB,GACF;AAAA,EAEJ;AACF;AAEO,aAAM,gBAAyD;AAAA,EACpE,YAAY;AAAA,IACV,MAAM;AAAA,IACN,MAAM;AAAA,EACR;AAAA,EACA,UAAU;AAAA,IACR,UAAU;AAAA,MACR,MAAM;AAAA,QACJ,MAAM;AAAA,QACN,MAAM;AAAA,MACR;AAAA,MACA,OAAO;AAAA,QACL,MAAM;AAAA,QACN,MAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;",
|
|
6
|
+
"names": ["props"]
|
|
7
7
|
}
|
|
@@ -1,11 +1,18 @@
|
|
|
1
|
+
import { type FieldMetadata, type FieldName } from '@conform-to/react';
|
|
1
2
|
import { type PropsWithChildren } from 'react';
|
|
2
|
-
import { type ComponentProps } from '../theme/internals.js';
|
|
3
|
+
import { type ComponentProps, type ComponentTheme } from '../theme/internals.js';
|
|
3
4
|
export declare const useCheckboxFieldTheme: (() => (baseClassName?: import("../theme/internals.js").ClassName, overrideClassName?: import("../theme/internals.js").ClassName) => string) & {
|
|
4
5
|
componentThemeName: "CheckboxField";
|
|
5
6
|
themeDefinition: undefined;
|
|
6
7
|
};
|
|
7
|
-
export type CheckboxFieldProps = PropsWithChildren<ComponentProps<typeof useCheckboxFieldTheme> & {
|
|
8
|
+
export type CheckboxFieldProps = PropsWithChildren<ComponentProps<typeof useCheckboxFieldTheme> & ({
|
|
8
9
|
className?: string | undefined;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
field?: FieldMetadata<any, any> | undefined;
|
|
11
|
+
name?: undefined;
|
|
12
|
+
} | {
|
|
13
|
+
className?: string | undefined;
|
|
14
|
+
field?: undefined;
|
|
15
|
+
name?: FieldName<any, any> | string | undefined;
|
|
16
|
+
})>;
|
|
17
|
+
export declare function CheckboxField({ field, name, className, children }: CheckboxFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
export declare const checkboxFieldTheme: ComponentTheme<typeof useCheckboxFieldTheme>;
|