@jakubmazanec/ui 0.1.0-unstable.0c19abe
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 +40 -0
- package/build/components/Button.d.ts +24 -0
- package/build/components/Button.js +51 -0
- package/build/components/Button.js.map +7 -0
- package/build/components/Card.d.ts +5 -0
- package/build/components/Card.js +7 -0
- package/build/components/Card.js.map +7 -0
- package/build/components/Checkbox.d.ts +24 -0
- package/build/components/Checkbox.js +63 -0
- package/build/components/Checkbox.js.map +7 -0
- package/build/components/CheckboxField.d.ts +11 -0
- package/build/components/CheckboxField.js +14 -0
- package/build/components/CheckboxField.js.map +7 -0
- package/build/components/Combobox.d.ts +33 -0
- package/build/components/Combobox.js +121 -0
- package/build/components/Combobox.js.map +7 -0
- package/build/components/ConfirmDialog.d.ts +23 -0
- package/build/components/ConfirmDialog.js +40 -0
- package/build/components/ConfirmDialog.js.map +7 -0
- package/build/components/Dialog.d.ts +18 -0
- package/build/components/Dialog.js +21 -0
- package/build/components/Dialog.js.map +7 -0
- package/build/components/DialogPanel.d.ts +10 -0
- package/build/components/DialogPanel.js +10 -0
- package/build/components/DialogPanel.js.map +7 -0
- package/build/components/DialogTitle.d.ts +10 -0
- package/build/components/DialogTitle.js +10 -0
- package/build/components/DialogTitle.js.map +7 -0
- package/build/components/Error.d.ts +10 -0
- package/build/components/Error.js +14 -0
- package/build/components/Error.js.map +7 -0
- package/build/components/Field.d.ts +11 -0
- package/build/components/Field.js +14 -0
- package/build/components/Field.js.map +7 -0
- package/build/components/Form.d.ts +13 -0
- package/build/components/Form.js +11 -0
- package/build/components/Form.js.map +7 -0
- package/build/components/Input.d.ts +42 -0
- package/build/components/Input.js +129 -0
- package/build/components/Input.js.map +7 -0
- package/build/components/Label.d.ts +10 -0
- package/build/components/Label.js +10 -0
- package/build/components/Label.js.map +7 -0
- package/build/components/Listbox.d.ts +32 -0
- package/build/components/Listbox.js +75 -0
- package/build/components/Listbox.js.map +7 -0
- package/build/components/Menu.d.ts +10 -0
- package/build/components/Menu.js +10 -0
- package/build/components/Menu.js.map +7 -0
- package/build/components/MenuButton.d.ts +10 -0
- package/build/components/MenuButton.js +10 -0
- package/build/components/MenuButton.js.map +7 -0
- package/build/components/MenuItem.d.ts +10 -0
- package/build/components/MenuItem.js +10 -0
- package/build/components/MenuItem.js.map +7 -0
- package/build/components/MenuItems.d.ts +10 -0
- package/build/components/MenuItems.js +10 -0
- package/build/components/MenuItems.js.map +7 -0
- package/build/components/Popover.d.ts +10 -0
- package/build/components/Popover.js +10 -0
- package/build/components/Popover.js.map +7 -0
- package/build/components/PopoverButton.d.ts +13 -0
- package/build/components/PopoverButton.js +28 -0
- package/build/components/PopoverButton.js.map +7 -0
- package/build/components/PopoverPanel.d.ts +16 -0
- package/build/components/PopoverPanel.js +24 -0
- package/build/components/PopoverPanel.js.map +7 -0
- package/build/components/Radio.d.ts +24 -0
- package/build/components/Radio.js +39 -0
- package/build/components/Radio.js.map +7 -0
- package/build/components/RadioField.d.ts +10 -0
- package/build/components/RadioField.js +14 -0
- package/build/components/RadioField.js.map +7 -0
- package/build/components/RadioGroupField.d.ts +20 -0
- package/build/components/RadioGroupField.js +82 -0
- package/build/components/RadioGroupField.js.map +7 -0
- package/build/components/Spinner.d.ts +7 -0
- package/build/components/Spinner.js +52 -0
- package/build/components/Spinner.js.map +7 -0
- package/build/components/Table.d.ts +16 -0
- package/build/components/Table.js +20 -0
- package/build/components/Table.js.map +7 -0
- package/build/components/TableCell.d.ts +10 -0
- package/build/components/TableCell.js +9 -0
- package/build/components/TableCell.js.map +7 -0
- package/build/components/TableHeader.d.ts +10 -0
- package/build/components/TableHeader.js +8 -0
- package/build/components/TableHeader.js.map +7 -0
- package/build/components/TableHeaderCell.d.ts +10 -0
- package/build/components/TableHeaderCell.js +9 -0
- package/build/components/TableHeaderCell.js.map +7 -0
- package/build/components/TableRow.d.ts +10 -0
- package/build/components/TableRow.js +9 -0
- package/build/components/TableRow.js.map +7 -0
- package/build/components/Textarea.d.ts +39 -0
- package/build/components/Textarea.js +104 -0
- package/build/components/Textarea.js.map +7 -0
- package/build/components/internals/fieldNameContext.d.ts +2 -0
- package/build/components/internals/fieldNameContext.js +4 -0
- package/build/components/internals/fieldNameContext.js.map +7 -0
- package/build/components/internals/formContext.d.ts +3 -0
- package/build/components/internals/formContext.js +4 -0
- package/build/components/internals/formContext.js.map +7 -0
- package/build/components/internals/useField.d.ts +6 -0
- package/build/components/internals/useField.js +18 -0
- package/build/components/internals/useField.js.map +7 -0
- package/build/components/internals/useFieldName.d.ts +1 -0
- package/build/components/internals/useFieldName.js +7 -0
- package/build/components/internals/useFieldName.js.map +7 -0
- package/build/components/internals/useForm.d.ts +1 -0
- package/build/components/internals/useForm.js +7 -0
- package/build/components/internals/useForm.js.map +7 -0
- package/build/components/internals.d.ts +5 -0
- package/build/components/internals.js +7 -0
- package/build/components/internals.js.map +7 -0
- package/build/components.d.ts +32 -0
- package/build/components.js +34 -0
- package/build/components.js.map +7 -0
- package/build/development/createTailwindConfig.d.ts +18 -0
- package/build/development/createTailwindConfig.js +125 -0
- package/build/development/createTailwindConfig.js.map +7 -0
- package/build/development/createTailwindMerge.d.ts +2 -0
- package/build/development/createTailwindMerge.js +74 -0
- package/build/development/createTailwindMerge.js.map +7 -0
- package/build/development/defaultTailwindConfig.d.ts +72 -0
- package/build/development/defaultTailwindConfig.js +45 -0
- package/build/development/defaultTailwindConfig.js.map +7 -0
- package/build/development/internals/PaletteConfig.d.ts +6 -0
- package/build/development/internals/PaletteConfig.js +2 -0
- package/build/development/internals/PaletteConfig.js.map +7 -0
- package/build/development/internals/SwatchValue.d.ts +9 -0
- package/build/development/internals/SwatchValue.js +2 -0
- package/build/development/internals/SwatchValue.js.map +7 -0
- package/build/development/internals/clamp.d.ts +1 -0
- package/build/development/internals/clamp.js +5 -0
- package/build/development/internals/clamp.js.map +7 -0
- package/build/development/internals/constants.d.ts +2 -0
- package/build/development/internals/constants.js +22 -0
- package/build/development/internals/constants.js.map +7 -0
- package/build/development/internals/createDisplayColor.d.ts +1 -0
- package/build/development/internals/createDisplayColor.js +24 -0
- package/build/development/internals/createDisplayColor.js.map +7 -0
- package/build/development/internals/createDistributionValues.d.ts +4 -0
- package/build/development/internals/createDistributionValues.js +32 -0
- package/build/development/internals/createDistributionValues.js.map +7 -0
- package/build/development/internals/createHueScale.d.ts +4 -0
- package/build/development/internals/createHueScale.js +15 -0
- package/build/development/internals/createHueScale.js.map +7 -0
- package/build/development/internals/createPalette.d.ts +16 -0
- package/build/development/internals/createPalette.js +36 -0
- package/build/development/internals/createPalette.js.map +7 -0
- package/build/development/internals/createSaturationScale.d.ts +4 -0
- package/build/development/internals/createSaturationScale.js +18 -0
- package/build/development/internals/createSaturationScale.js.map +7 -0
- package/build/development/internals/createSwatches.d.ts +10 -0
- package/build/development/internals/createSwatches.js +31 -0
- package/build/development/internals/createSwatches.js.map +7 -0
- package/build/development/internals/hexToHsl.d.ts +5 -0
- package/build/development/internals/hexToHsl.js +37 -0
- package/build/development/internals/hexToHsl.js.map +7 -0
- package/build/development/internals/hexToRgb.d.ts +5 -0
- package/build/development/internals/hexToRgb.js +21 -0
- package/build/development/internals/hexToRgb.js.map +7 -0
- package/build/development/internals/hslToHex.d.ts +1 -0
- package/build/development/internals/hslToHex.js +19 -0
- package/build/development/internals/hslToHex.js.map +7 -0
- package/build/development/internals/hslToRgb.d.ts +5 -0
- package/build/development/internals/hslToRgb.js +42 -0
- package/build/development/internals/hslToRgb.js.map +7 -0
- package/build/development/internals/isHex.d.ts +1 -0
- package/build/development/internals/isHex.js +7 -0
- package/build/development/internals/isHex.js.map +7 -0
- package/build/development/internals/resolveModule.d.ts +1 -0
- package/build/development/internals/resolveModule.js +9 -0
- package/build/development/internals/resolveModule.js.map +7 -0
- package/build/development/internals/round.d.ts +1 -0
- package/build/development/internals/round.js +6 -0
- package/build/development/internals/round.js.map +7 -0
- package/build/development/internals/unsignedModulo.d.ts +1 -0
- package/build/development/internals/unsignedModulo.js +5 -0
- package/build/development/internals/unsignedModulo.js.map +7 -0
- package/build/development/internals.d.ts +1 -0
- package/build/development/internals.js +3 -0
- package/build/development/internals.js.map +7 -0
- package/build/development.d.ts +3 -0
- package/build/development.js +5 -0
- package/build/development.js.map +7 -0
- package/build/fonts.css +15 -0
- package/build/fonts.css.map +7 -0
- package/build/inter-variable-75YQYCJN.woff2 +0 -0
- package/build/inter-variable-italic-54HMV74W.woff2 +0 -0
- package/build/inter-variable-italic.js +2 -0
- package/build/inter-variable-italic.js.map +7 -0
- package/build/inter-variable.js +2 -0
- package/build/inter-variable.js.map +7 -0
- package/build/main.d.ts +5 -0
- package/build/main.js +7 -0
- package/build/main.js.map +7 -0
- package/build/theme/Theme.d.ts +40 -0
- package/build/theme/Theme.js +2 -0
- package/build/theme/Theme.js.map +7 -0
- package/build/theme/ThemeProvider.d.ts +6 -0
- package/build/theme/ThemeProvider.js +7 -0
- package/build/theme/ThemeProvider.js.map +7 -0
- package/build/theme/defaultTheme.d.ts +2 -0
- package/build/theme/defaultTheme.js +331 -0
- package/build/theme/defaultTheme.js.map +7 -0
- package/build/theme/internals/ClassName.d.ts +1 -0
- package/build/theme/internals/ClassName.js +2 -0
- package/build/theme/internals/ClassName.js.map +7 -0
- package/build/theme/internals/ComponentProps.d.ts +7 -0
- package/build/theme/internals/ComponentProps.js +2 -0
- package/build/theme/internals/ComponentProps.js.map +7 -0
- package/build/theme/internals/ComponentTheme.d.ts +25 -0
- package/build/theme/internals/ComponentTheme.js +2 -0
- package/build/theme/internals/ComponentTheme.js.map +7 -0
- package/build/theme/internals/ComponentThemeCompoundVariants.d.ts +12 -0
- package/build/theme/internals/ComponentThemeCompoundVariants.js +2 -0
- package/build/theme/internals/ComponentThemeCompoundVariants.js.map +7 -0
- package/build/theme/internals/ComponentThemeDefinition.d.ts +6 -0
- package/build/theme/internals/ComponentThemeDefinition.js +2 -0
- package/build/theme/internals/ComponentThemeDefinition.js.map +7 -0
- package/build/theme/internals/ComponentThemeDefinitionElements.d.ts +1 -0
- package/build/theme/internals/ComponentThemeDefinitionElements.js +2 -0
- package/build/theme/internals/ComponentThemeDefinitionElements.js.map +7 -0
- package/build/theme/internals/ComponentThemeDefinitionVariants.d.ts +3 -0
- package/build/theme/internals/ComponentThemeDefinitionVariants.js +2 -0
- package/build/theme/internals/ComponentThemeDefinitionVariants.js.map +7 -0
- package/build/theme/internals/ComponentThemeProps.d.ts +5 -0
- package/build/theme/internals/ComponentThemeProps.js +2 -0
- package/build/theme/internals/ComponentThemeProps.js.map +7 -0
- package/build/theme/internals/ComponentThemeVariants.d.ts +14 -0
- package/build/theme/internals/ComponentThemeVariants.js +2 -0
- package/build/theme/internals/ComponentThemeVariants.js.map +7 -0
- package/build/theme/internals/UseComponentTheme.d.ts +21 -0
- package/build/theme/internals/UseComponentTheme.js +2 -0
- package/build/theme/internals/UseComponentTheme.js.map +7 -0
- package/build/theme/internals/UseComponentThemeReturn.d.ts +6 -0
- package/build/theme/internals/UseComponentThemeReturn.js +2 -0
- package/build/theme/internals/UseComponentThemeReturn.js.map +7 -0
- package/build/theme/internals/booleanToString.d.ts +1 -0
- package/build/theme/internals/booleanToString.js +5 -0
- package/build/theme/internals/booleanToString.js.map +7 -0
- package/build/theme/internals/createComponentTheme.d.ts +3 -0
- package/build/theme/internals/createComponentTheme.js +36 -0
- package/build/theme/internals/createComponentTheme.js.map +7 -0
- package/build/theme/internals/createUseComponentThemeReturn.d.ts +15 -0
- package/build/theme/internals/createUseComponentThemeReturn.js +51 -0
- package/build/theme/internals/createUseComponentThemeReturn.js.map +7 -0
- package/build/theme/internals/cx.d.ts +2 -0
- package/build/theme/internals/cx.js +6 -0
- package/build/theme/internals/cx.js.map +7 -0
- package/build/theme/internals/pickPropertyIfExists.d.ts +4 -0
- package/build/theme/internals/pickPropertyIfExists.js +11 -0
- package/build/theme/internals/pickPropertyIfExists.js.map +7 -0
- package/build/theme/internals/themeContext.d.ts +217 -0
- package/build/theme/internals/themeContext.js +4 -0
- package/build/theme/internals/themeContext.js.map +7 -0
- package/build/theme/internals/useTheme.d.ts +216 -0
- package/build/theme/internals/useTheme.js +7 -0
- package/build/theme/internals/useTheme.js.map +7 -0
- package/build/theme/internals.d.ts +18 -0
- package/build/theme/internals.js +20 -0
- package/build/theme/internals.js.map +7 -0
- package/build/theme.d.ts +3 -0
- package/build/theme.js +5 -0
- package/build/theme.js.map +7 -0
- package/package.json +93 -0
- package/source/components/Button.ts +74 -0
- package/source/components/Card.tsx +10 -0
- package/source/components/Checkbox.tsx +75 -0
- package/source/components/CheckboxField.tsx +28 -0
- package/source/components/Combobox.tsx +160 -0
- package/source/components/ConfirmDialog.tsx +67 -0
- package/source/components/Dialog.tsx +34 -0
- package/source/components/DialogPanel.tsx +18 -0
- package/source/components/DialogTitle.tsx +18 -0
- package/source/components/Error.tsx +27 -0
- package/source/components/Field.tsx +28 -0
- package/source/components/Form.tsx +30 -0
- package/source/components/Input.tsx +176 -0
- package/source/components/Label.tsx +18 -0
- package/source/components/Listbox.tsx +113 -0
- package/source/components/Menu.tsx +19 -0
- package/source/components/MenuButton.tsx +18 -0
- package/source/components/MenuItem.tsx +19 -0
- package/source/components/MenuItems.tsx +18 -0
- package/source/components/Popover.tsx +18 -0
- package/source/components/PopoverButton.tsx +45 -0
- package/source/components/PopoverPanel.tsx +37 -0
- package/source/components/Radio.tsx +46 -0
- package/source/components/RadioField.tsx +34 -0
- package/source/components/RadioGroupField.tsx +101 -0
- package/source/components/Spinner.tsx +46 -0
- package/source/components/Table.tsx +31 -0
- package/source/components/TableCell.tsx +17 -0
- package/source/components/TableHeader.tsx +19 -0
- package/source/components/TableHeaderCell.tsx +17 -0
- package/source/components/TableRow.tsx +17 -0
- package/source/components/Textarea.tsx +142 -0
- package/source/components/internals/fieldNameContext.ts +3 -0
- package/source/components/internals/formContext.ts +4 -0
- package/source/components/internals/useField.ts +19 -0
- package/source/components/internals/useFieldName.ts +7 -0
- package/source/components/internals/useForm.ts +7 -0
- package/source/components/internals.ts +5 -0
- package/source/components.ts +32 -0
- package/source/development/createTailwindConfig.ts +153 -0
- package/source/development/createTailwindMerge.ts +101 -0
- package/source/development/defaultTailwindConfig.ts +45 -0
- package/source/development/internals/PaletteConfig.ts +6 -0
- package/source/development/internals/SwatchValue.ts +9 -0
- package/source/development/internals/clamp.ts +3 -0
- package/source/development/internals/constants.ts +4 -0
- package/source/development/internals/createDisplayColor.ts +29 -0
- package/source/development/internals/createDistributionValues.ts +38 -0
- package/source/development/internals/createHueScale.ts +17 -0
- package/source/development/internals/createPalette.ts +54 -0
- package/source/development/internals/createSaturationScale.ts +21 -0
- package/source/development/internals/createSwatches.ts +34 -0
- package/source/development/internals/hexToHsl.ts +45 -0
- package/source/development/internals/hexToRgb.ts +23 -0
- package/source/development/internals/hslToHex.ts +23 -0
- package/source/development/internals/hslToRgb.ts +43 -0
- package/source/development/internals/isHex.ts +7 -0
- package/source/development/internals/resolveModule.ts +9 -0
- package/source/development/internals/round.ts +5 -0
- package/source/development/internals/unsignedModulo.ts +3 -0
- package/source/development/internals.ts +1 -0
- package/source/development.ts +3 -0
- package/source/fonts.css +15 -0
- package/source/inter-variable-italic.woff2 +0 -0
- package/source/inter-variable.woff2 +0 -0
- package/source/main.ts +8 -0
- package/source/theme/Theme.ts +72 -0
- package/source/theme/ThemeProvider.tsx +12 -0
- package/source/theme/defaultTheme.ts +370 -0
- package/source/theme/internals/ClassName.ts +1 -0
- package/source/theme/internals/ComponentProps.ts +13 -0
- package/source/theme/internals/ComponentTheme.ts +33 -0
- package/source/theme/internals/ComponentThemeCompoundVariants.ts +20 -0
- package/source/theme/internals/ComponentThemeDefinition.ts +7 -0
- package/source/theme/internals/ComponentThemeDefinitionElements.ts +1 -0
- package/source/theme/internals/ComponentThemeDefinitionVariants.ts +3 -0
- package/source/theme/internals/ComponentThemeProps.ts +11 -0
- package/source/theme/internals/ComponentThemeVariants.ts +24 -0
- package/source/theme/internals/UseComponentTheme.ts +22 -0
- package/source/theme/internals/UseComponentThemeReturn.ts +15 -0
- package/source/theme/internals/booleanToString.ts +6 -0
- package/source/theme/internals/createComponentTheme.ts +67 -0
- package/source/theme/internals/createUseComponentThemeReturn.ts +87 -0
- package/source/theme/internals/cx.ts +10 -0
- package/source/theme/internals/pickPropertyIfExists.ts +24 -0
- package/source/theme/internals/themeContext.ts +5 -0
- package/source/theme/internals/useTheme.ts +7 -0
- package/source/theme/internals.ts +18 -0
- package/source/theme.ts +3 -0
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/* eslint-disable unicorn/consistent-destructuring -- destructuring leads to messy code because of complicated types */
|
|
2
|
+
import {booleanToString} from './booleanToString.js';
|
|
3
|
+
import {type ClassName} from './ClassName.js';
|
|
4
|
+
import {type ComponentTheme} from './ComponentTheme.js';
|
|
5
|
+
import {type ComponentThemeDefinitionElements} from './ComponentThemeDefinitionElements.js';
|
|
6
|
+
import {type ComponentThemeDefinitionVariants} from './ComponentThemeDefinitionVariants.js';
|
|
7
|
+
import {type ComponentThemeProps} from './ComponentThemeProps.js';
|
|
8
|
+
import {cx} from './cx.js';
|
|
9
|
+
import {pickPropertyIfExists} from './pickPropertyIfExists.js';
|
|
10
|
+
|
|
11
|
+
export function createUseComponentThemeReturn(
|
|
12
|
+
componentTheme:
|
|
13
|
+
| ComponentTheme<{
|
|
14
|
+
variants: ComponentThemeDefinitionVariants;
|
|
15
|
+
elements: ComponentThemeDefinitionElements;
|
|
16
|
+
}>
|
|
17
|
+
| ComponentTheme<{elements: ComponentThemeDefinitionElements}>
|
|
18
|
+
| ComponentTheme<{variants: ComponentThemeDefinitionVariants}>
|
|
19
|
+
| ComponentTheme<undefined>,
|
|
20
|
+
themeProps?:
|
|
21
|
+
| ComponentThemeProps<{variants: ComponentThemeDefinitionVariants}>
|
|
22
|
+
| ComponentThemeProps<undefined>,
|
|
23
|
+
elementName?: string,
|
|
24
|
+
) {
|
|
25
|
+
if (!themeProps || !('variants' in componentTheme)) {
|
|
26
|
+
return (baseClassName: ClassName, overrideClassName: ClassName) =>
|
|
27
|
+
cx(
|
|
28
|
+
baseClassName,
|
|
29
|
+
'classNames' in componentTheme ?
|
|
30
|
+
pickPropertyIfExists(componentTheme.classNames, elementName)
|
|
31
|
+
: 'className' in componentTheme ? componentTheme.className
|
|
32
|
+
: undefined,
|
|
33
|
+
overrideClassName,
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
let {variants, compoundVariants} = componentTheme;
|
|
38
|
+
let getVariantClassNames = Object.keys(variants).map((variant) => {
|
|
39
|
+
let variantProp = themeProps[variant as keyof typeof themeProps] as boolean | string;
|
|
40
|
+
let variantKey = booleanToString(variantProp);
|
|
41
|
+
|
|
42
|
+
return pickPropertyIfExists(variants[variant]?.[variantKey as 'false' | 'true'], elementName);
|
|
43
|
+
});
|
|
44
|
+
let getCompoundVariantClassNames: ClassName[] = [];
|
|
45
|
+
|
|
46
|
+
if (compoundVariants) {
|
|
47
|
+
for (let compoundVariant of compoundVariants) {
|
|
48
|
+
let {className, classNames, ...rest} = compoundVariant;
|
|
49
|
+
let matchesAllSelectors = true;
|
|
50
|
+
|
|
51
|
+
for (let [cvKey, cvSelector] of Object.entries(rest)) {
|
|
52
|
+
let selector = themeProps[cvKey as keyof typeof themeProps];
|
|
53
|
+
|
|
54
|
+
if (Array.isArray(cvSelector)) {
|
|
55
|
+
if (!cvSelector.includes(selector as string)) {
|
|
56
|
+
matchesAllSelectors = false;
|
|
57
|
+
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
} else if (selector !== cvSelector) {
|
|
61
|
+
matchesAllSelectors = false;
|
|
62
|
+
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if (matchesAllSelectors) {
|
|
68
|
+
getCompoundVariantClassNames.push(
|
|
69
|
+
('classNames' in compoundVariant ?
|
|
70
|
+
pickPropertyIfExists(classNames as Record<string, ClassName>, elementName)
|
|
71
|
+
: className) as ClassName,
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
return (baseClassName: ClassName, overrideClassName: ClassName) =>
|
|
78
|
+
cx(
|
|
79
|
+
baseClassName,
|
|
80
|
+
'classNames' in componentTheme ? pickPropertyIfExists(componentTheme.classNames, elementName)
|
|
81
|
+
: 'className' in componentTheme ? componentTheme.className
|
|
82
|
+
: undefined,
|
|
83
|
+
getVariantClassNames,
|
|
84
|
+
getCompoundVariantClassNames,
|
|
85
|
+
overrideClassName,
|
|
86
|
+
);
|
|
87
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// import {type ClassValue, clsx} from 'clsx';
|
|
2
|
+
import {twMerge} from 'tailwind-merge';
|
|
3
|
+
|
|
4
|
+
import {type ClassName} from './ClassName.js';
|
|
5
|
+
|
|
6
|
+
// TODO: is the merging done correctly? write some tests
|
|
7
|
+
export function cx(...inputs: ClassName[] /*ClassValue[]*/) {
|
|
8
|
+
// return twMerge(clsx(inputs));
|
|
9
|
+
return twMerge(...inputs);
|
|
10
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import {type ClassName} from './ClassName.js';
|
|
2
|
+
|
|
3
|
+
type PickPropertyIfExistsReturn<
|
|
4
|
+
T extends ClassName | Record<string, ClassName> | undefined,
|
|
5
|
+
U extends string | undefined,
|
|
6
|
+
> =
|
|
7
|
+
U extends undefined ? T
|
|
8
|
+
: T extends Record<string, ClassName> ? null
|
|
9
|
+
: ClassName;
|
|
10
|
+
|
|
11
|
+
export function pickPropertyIfExists<
|
|
12
|
+
T extends ClassName | Record<string, ClassName> | undefined,
|
|
13
|
+
U extends string | undefined,
|
|
14
|
+
>(object: T, property?: U): PickPropertyIfExistsReturn<T, U> {
|
|
15
|
+
if (!property) {
|
|
16
|
+
return object as PickPropertyIfExistsReturn<T, U>;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
if (Array.isArray(object) || !object || typeof object === 'string') {
|
|
20
|
+
return null as PickPropertyIfExistsReturn<T, U>;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return object[property] as PickPropertyIfExistsReturn<T, U>;
|
|
24
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export * from './internals/booleanToString.js';
|
|
2
|
+
export * from './internals/ClassName.js';
|
|
3
|
+
export * from './internals/ComponentProps.js';
|
|
4
|
+
export * from './internals/ComponentTheme.js';
|
|
5
|
+
export * from './internals/ComponentThemeCompoundVariants.js';
|
|
6
|
+
export * from './internals/ComponentThemeDefinition.js';
|
|
7
|
+
export * from './internals/ComponentThemeDefinitionElements.js';
|
|
8
|
+
export * from './internals/ComponentThemeDefinitionVariants.js';
|
|
9
|
+
export * from './internals/ComponentThemeProps.js';
|
|
10
|
+
export * from './internals/ComponentThemeVariants.js';
|
|
11
|
+
export * from './internals/createComponentTheme.js';
|
|
12
|
+
export * from './internals/createUseComponentThemeReturn.js';
|
|
13
|
+
export * from './internals/cx.js';
|
|
14
|
+
export * from './internals/pickPropertyIfExists.js';
|
|
15
|
+
export * from './internals/themeContext.js';
|
|
16
|
+
export * from './internals/UseComponentTheme.js';
|
|
17
|
+
export * from './internals/UseComponentThemeReturn.js';
|
|
18
|
+
export * from './internals/useTheme.js';
|
package/source/theme.ts
ADDED