@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,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { extendTailwindMerge, twMerge } from "tailwind-merge";
|
|
3
|
+
const THEME_SCALES = [
|
|
4
|
+
"colors",
|
|
5
|
+
"spacing",
|
|
6
|
+
"blur",
|
|
7
|
+
"brightness",
|
|
8
|
+
"borderColor",
|
|
9
|
+
"borderRadius",
|
|
10
|
+
"borderSpacing",
|
|
11
|
+
"borderWidth",
|
|
12
|
+
"contrast",
|
|
13
|
+
"grayscale",
|
|
14
|
+
"hueRotate",
|
|
15
|
+
"invert",
|
|
16
|
+
"gap",
|
|
17
|
+
"gradientColorStops",
|
|
18
|
+
"gradientColorStopPositions",
|
|
19
|
+
"inset",
|
|
20
|
+
"margin",
|
|
21
|
+
"opacity",
|
|
22
|
+
"padding",
|
|
23
|
+
"saturate",
|
|
24
|
+
"scale",
|
|
25
|
+
"sepia",
|
|
26
|
+
"skew",
|
|
27
|
+
"space",
|
|
28
|
+
"translate"
|
|
29
|
+
];
|
|
30
|
+
export function createTailwindMerge(tailwindConfig) {
|
|
31
|
+
if (!tailwindConfig.theme) {
|
|
32
|
+
return twMerge;
|
|
33
|
+
}
|
|
34
|
+
let tailwindMergeConfig = {
|
|
35
|
+
override: { theme: {} },
|
|
36
|
+
extend: { theme: {} }
|
|
37
|
+
};
|
|
38
|
+
for (let scale of THEME_SCALES) {
|
|
39
|
+
if (!tailwindMergeConfig.override?.theme || !tailwindMergeConfig.extend?.theme) {
|
|
40
|
+
throw new Error("Creating Tailwind merge failed!");
|
|
41
|
+
}
|
|
42
|
+
if (tailwindConfig.theme[scale]) {
|
|
43
|
+
let tailwindConfigScale = tailwindConfig.theme[scale];
|
|
44
|
+
let keys = Object.keys(tailwindConfigScale);
|
|
45
|
+
let combinedKeys = [];
|
|
46
|
+
for (let key of keys) {
|
|
47
|
+
if (tailwindConfigScale[key] !== void 0 && tailwindConfigScale[key] !== null && typeof tailwindConfigScale[key] === "object") {
|
|
48
|
+
combinedKeys.push(
|
|
49
|
+
...Object.keys(tailwindConfigScale[key]).filter((value) => value !== "DEFAULT").map((value) => `${key}-${value}`)
|
|
50
|
+
);
|
|
51
|
+
} else {
|
|
52
|
+
combinedKeys.push(key);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
tailwindMergeConfig.override.theme[scale] = combinedKeys;
|
|
56
|
+
} else if (tailwindConfig.theme.extend?.[scale]) {
|
|
57
|
+
let tailwindConfigScale = tailwindConfig.theme.extend[scale];
|
|
58
|
+
let keys = Object.keys(tailwindConfigScale);
|
|
59
|
+
let combinedKeys = [];
|
|
60
|
+
for (let key of keys) {
|
|
61
|
+
if (tailwindConfigScale[key] !== void 0 && tailwindConfigScale[key] !== null && typeof tailwindConfigScale[key] === "object") {
|
|
62
|
+
combinedKeys.push(
|
|
63
|
+
...Object.keys(tailwindConfigScale[key]).filter((value) => value !== "DEFAULT").map((value) => `${key}-${value}`)
|
|
64
|
+
);
|
|
65
|
+
} else {
|
|
66
|
+
combinedKeys.push(key);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
tailwindMergeConfig.extend.theme[scale] = combinedKeys;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return extendTailwindMerge(tailwindMergeConfig);
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=createTailwindMerge.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../source/development/createTailwindMerge.ts"],
|
|
4
|
+
"sourcesContent": ["import {extendTailwindMerge, twMerge} from 'tailwind-merge';\nimport {type Config as TailwindConfig} from 'tailwindcss';\n\nconst THEME_SCALES = [\n 'colors',\n 'spacing',\n 'blur',\n 'brightness',\n 'borderColor',\n 'borderRadius',\n 'borderSpacing',\n 'borderWidth',\n 'contrast',\n 'grayscale',\n 'hueRotate',\n 'invert',\n 'gap',\n 'gradientColorStops',\n 'gradientColorStopPositions',\n 'inset',\n 'margin',\n 'opacity',\n 'padding',\n 'saturate',\n 'scale',\n 'sepia',\n 'skew',\n 'space',\n 'translate',\n];\n\nexport function createTailwindMerge(tailwindConfig: TailwindConfig) {\n if (!tailwindConfig.theme) {\n return twMerge;\n }\n\n let tailwindMergeConfig: Parameters<typeof extendTailwindMerge>[0] = {\n override: {theme: {}},\n extend: {theme: {}},\n };\n\n for (let scale of THEME_SCALES) {\n if (!tailwindMergeConfig.override?.theme || !tailwindMergeConfig.extend?.theme) {\n throw new Error('Creating Tailwind merge failed!');\n }\n\n if (tailwindConfig.theme[scale]) {\n let tailwindConfigScale = tailwindConfig.theme[scale] as Record<\n string,\n Record<string, string | unknown> | unknown\n >;\n let keys = Object.keys(tailwindConfigScale);\n let combinedKeys = [];\n\n for (let key of keys) {\n if (\n tailwindConfigScale[key] !== undefined &&\n tailwindConfigScale[key] !== null &&\n typeof tailwindConfigScale[key] === 'object'\n ) {\n combinedKeys.push(\n ...Object.keys(tailwindConfigScale[key] as object)\n .filter((value) => value !== 'DEFAULT')\n .map((value) => `${key}-${value}`),\n );\n } else {\n combinedKeys.push(key);\n }\n }\n\n tailwindMergeConfig.override.theme[scale] = combinedKeys;\n } else if (tailwindConfig.theme.extend?.[scale]) {\n let tailwindConfigScale = tailwindConfig.theme.extend[scale] as Record<\n string,\n Record<string, string | unknown> | unknown\n >;\n let keys = Object.keys(tailwindConfigScale);\n let combinedKeys = [];\n\n for (let key of keys) {\n if (\n tailwindConfigScale[key] !== undefined &&\n tailwindConfigScale[key] !== null &&\n typeof tailwindConfigScale[key] === 'object'\n ) {\n combinedKeys.push(\n ...Object.keys(tailwindConfigScale[key] as object)\n .filter((value) => value !== 'DEFAULT')\n .map((value) => `${key}-${value}`),\n );\n } else {\n combinedKeys.push(key);\n }\n }\n\n tailwindMergeConfig.extend.theme[scale] = combinedKeys;\n }\n }\n\n return extendTailwindMerge(tailwindMergeConfig);\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,qBAAqB,eAAc;AAG3C,MAAM,eAAe;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEO,gBAAS,oBAAoB,gBAAgC;AAClE,MAAI,CAAC,eAAe,OAAO;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,sBAAiE;AAAA,IACnE,UAAU,EAAC,OAAO,CAAC,EAAC;AAAA,IACpB,QAAQ,EAAC,OAAO,CAAC,EAAC;AAAA,EACpB;AAEA,WAAS,SAAS,cAAc;AAC9B,QAAI,CAAC,oBAAoB,UAAU,SAAS,CAAC,oBAAoB,QAAQ,OAAO;AAC9E,YAAM,IAAI,MAAM,iCAAiC;AAAA,IACnD;AAEA,QAAI,eAAe,MAAM,KAAK,GAAG;AAC/B,UAAI,sBAAsB,eAAe,MAAM,KAAK;AAIpD,UAAI,OAAO,OAAO,KAAK,mBAAmB;AAC1C,UAAI,eAAe,CAAC;AAEpB,eAAS,OAAO,MAAM;AACpB,YACE,oBAAoB,GAAG,MAAM,UAC7B,oBAAoB,GAAG,MAAM,QAC7B,OAAO,oBAAoB,GAAG,MAAM,UACpC;AACA,uBAAa;AAAA,YACX,GAAG,OAAO,KAAK,oBAAoB,GAAG,CAAW,EAC9C,OAAO,CAAC,UAAU,UAAU,SAAS,EACrC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,UACrC;AAAA,QACF,OAAO;AACL,uBAAa,KAAK,GAAG;AAAA,QACvB;AAAA,MACF;AAEA,0BAAoB,SAAS,MAAM,KAAK,IAAI;AAAA,IAC9C,WAAW,eAAe,MAAM,SAAS,KAAK,GAAG;AAC/C,UAAI,sBAAsB,eAAe,MAAM,OAAO,KAAK;AAI3D,UAAI,OAAO,OAAO,KAAK,mBAAmB;AAC1C,UAAI,eAAe,CAAC;AAEpB,eAAS,OAAO,MAAM;AACpB,YACE,oBAAoB,GAAG,MAAM,UAC7B,oBAAoB,GAAG,MAAM,QAC7B,OAAO,oBAAoB,GAAG,MAAM,UACpC;AACA,uBAAa;AAAA,YACX,GAAG,OAAO,KAAK,oBAAoB,GAAG,CAAW,EAC9C,OAAO,CAAC,UAAU,UAAU,SAAS,EACrC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,UACrC;AAAA,QACF,OAAO;AACL,uBAAa,KAAK,GAAG;AAAA,QACvB;AAAA,MACF;AAEA,0BAAoB,OAAO,MAAM,KAAK,IAAI;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO,oBAAoB,mBAAmB;AAChD;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
export declare const defaultTailwindConfig: {
|
|
2
|
+
content: string[];
|
|
3
|
+
colors: {
|
|
4
|
+
gray: string;
|
|
5
|
+
red: string;
|
|
6
|
+
orange: {
|
|
7
|
+
hex: string;
|
|
8
|
+
hueShift: number;
|
|
9
|
+
};
|
|
10
|
+
yellow: {
|
|
11
|
+
swatches: ({
|
|
12
|
+
hex: string;
|
|
13
|
+
stop: 10;
|
|
14
|
+
} | {
|
|
15
|
+
hex: string;
|
|
16
|
+
stop: 25;
|
|
17
|
+
} | {
|
|
18
|
+
hex: string;
|
|
19
|
+
stop: 50;
|
|
20
|
+
} | {
|
|
21
|
+
hex: string;
|
|
22
|
+
stop: 100;
|
|
23
|
+
} | {
|
|
24
|
+
hex: string;
|
|
25
|
+
stop: 200;
|
|
26
|
+
} | {
|
|
27
|
+
hex: string;
|
|
28
|
+
stop: 300;
|
|
29
|
+
} | {
|
|
30
|
+
hex: string;
|
|
31
|
+
stop: 400;
|
|
32
|
+
} | {
|
|
33
|
+
hex: string;
|
|
34
|
+
stop: 500;
|
|
35
|
+
} | {
|
|
36
|
+
hex: string;
|
|
37
|
+
stop: 600;
|
|
38
|
+
} | {
|
|
39
|
+
hex: string;
|
|
40
|
+
stop: 700;
|
|
41
|
+
} | {
|
|
42
|
+
hex: string;
|
|
43
|
+
stop: 800;
|
|
44
|
+
} | {
|
|
45
|
+
hex: string;
|
|
46
|
+
stop: 900;
|
|
47
|
+
} | {
|
|
48
|
+
hex: string;
|
|
49
|
+
stop: 950;
|
|
50
|
+
} | {
|
|
51
|
+
hex: string;
|
|
52
|
+
stop: 975;
|
|
53
|
+
} | {
|
|
54
|
+
hex: string;
|
|
55
|
+
stop: 990;
|
|
56
|
+
})[];
|
|
57
|
+
hex: string;
|
|
58
|
+
hueShift: number;
|
|
59
|
+
};
|
|
60
|
+
green: string;
|
|
61
|
+
teal: {
|
|
62
|
+
hex: string;
|
|
63
|
+
hueShift: number;
|
|
64
|
+
};
|
|
65
|
+
blue: string;
|
|
66
|
+
violet: string;
|
|
67
|
+
pink: {
|
|
68
|
+
hex: string;
|
|
69
|
+
hueShift: number;
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
export const defaultTailwindConfig = {
|
|
3
|
+
content: ["./{.storybook,app,source,stories}/**/*.{js,jsx,ts,tsx,mdx}", "@jakubmazanec/ui"],
|
|
4
|
+
colors: {
|
|
5
|
+
gray: "#6c6e79",
|
|
6
|
+
red: "#d1002f",
|
|
7
|
+
orange: {
|
|
8
|
+
hex: "#c33909",
|
|
9
|
+
hueShift: 1
|
|
10
|
+
},
|
|
11
|
+
yellow: {
|
|
12
|
+
swatches: [
|
|
13
|
+
{ hex: "#fffffa", stop: 10 },
|
|
14
|
+
{ hex: "#fffef0", stop: 25 },
|
|
15
|
+
{ hex: "#fffbdb", stop: 50 },
|
|
16
|
+
{ hex: "#fff3b8", stop: 100 },
|
|
17
|
+
{ hex: "#ffe06f", stop: 200 },
|
|
18
|
+
{ hex: "#ffc72d", stop: 300 },
|
|
19
|
+
{ hex: "#e69d00", stop: 400 },
|
|
20
|
+
{ hex: "#9e6300", stop: 500 },
|
|
21
|
+
{ hex: "#805701", stop: 600 },
|
|
22
|
+
{ hex: "#614700", stop: 700 },
|
|
23
|
+
{ hex: "#3d3000", stop: 800 },
|
|
24
|
+
{ hex: "#1f1a00", stop: 900 },
|
|
25
|
+
{ hex: "#0f0e00", stop: 950 },
|
|
26
|
+
{ hex: "#0a0a00", stop: 975 },
|
|
27
|
+
{ hex: "#050500", stop: 990 }
|
|
28
|
+
],
|
|
29
|
+
hex: "#9e6300",
|
|
30
|
+
hueShift: 3
|
|
31
|
+
},
|
|
32
|
+
green: "#0a7e22",
|
|
33
|
+
teal: {
|
|
34
|
+
hex: "#007c65",
|
|
35
|
+
hueShift: 5
|
|
36
|
+
},
|
|
37
|
+
blue: "#006dca",
|
|
38
|
+
violet: "#8649e1",
|
|
39
|
+
pink: {
|
|
40
|
+
hex: "#b229b9",
|
|
41
|
+
hueShift: 10
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=defaultTailwindConfig.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../source/development/defaultTailwindConfig.ts"],
|
|
4
|
+
"sourcesContent": ["import {type CreateTailwindConfigOptions} from './createTailwindConfig.js';\n\nexport const defaultTailwindConfig = {\n content: ['./{.storybook,app,source,stories}/**/*.{js,jsx,ts,tsx,mdx}', '@jakubmazanec/ui'],\n colors: {\n gray: '#6c6e79',\n red: '#d1002f',\n orange: {\n hex: '#c33909',\n hueShift: 1,\n },\n yellow: {\n swatches: [\n {hex: '#fffffa', stop: 10},\n {hex: '#fffef0', stop: 25},\n {hex: '#fffbdb', stop: 50},\n {hex: '#fff3b8', stop: 100},\n {hex: '#ffe06f', stop: 200},\n {hex: '#ffc72d', stop: 300},\n {hex: '#e69d00', stop: 400},\n {hex: '#9e6300', stop: 500},\n {hex: '#805701', stop: 600},\n {hex: '#614700', stop: 700},\n {hex: '#3d3000', stop: 800},\n {hex: '#1f1a00', stop: 900},\n {hex: '#0f0e00', stop: 950},\n {hex: '#0a0a00', stop: 975},\n {hex: '#050500', stop: 990},\n ],\n hex: '#9e6300',\n hueShift: 3,\n },\n green: '#0a7e22',\n teal: {\n hex: '#007c65',\n hueShift: 5,\n },\n blue: '#006dca',\n violet: '#8649e1',\n pink: {\n hex: '#b229b9',\n hueShift: 10,\n },\n },\n} satisfies CreateTailwindConfigOptions;\n"],
|
|
5
|
+
"mappings": ";AAEO,aAAM,wBAAwB;AAAA,EACnC,SAAS,CAAC,8DAA8D,kBAAkB;AAAA,EAC1F,QAAQ;AAAA,IACN,MAAM;AAAA,IACN,KAAK;AAAA,IACL,QAAQ;AAAA,MACN,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,QAAQ;AAAA,MACN,UAAU;AAAA,QACR,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,MAC5B;AAAA,MACA,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,OAAO;AAAA,IACP,MAAM;AAAA,MACJ,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,MAAM;AAAA,MACJ,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,EACF;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function clamp(x: number, min: number, max: number): number;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/clamp.ts"],
|
|
4
|
+
"sourcesContent": ["export function clamp(x: number, min: number, max: number) {\n return Math.min(Math.max(x, min), max);\n}\n"],
|
|
5
|
+
"mappings": ";AAAO,gBAAS,MAAM,GAAW,KAAa,KAAa;AACzD,SAAO,KAAK,IAAI,KAAK,IAAI,GAAG,GAAG,GAAG,GAAG;AACvC;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
export const DEFAULT_STOP = 500;
|
|
3
|
+
export const DEFAULT_STOPS = [
|
|
4
|
+
0,
|
|
5
|
+
10,
|
|
6
|
+
25,
|
|
7
|
+
50,
|
|
8
|
+
100,
|
|
9
|
+
200,
|
|
10
|
+
300,
|
|
11
|
+
400,
|
|
12
|
+
500,
|
|
13
|
+
600,
|
|
14
|
+
700,
|
|
15
|
+
800,
|
|
16
|
+
900,
|
|
17
|
+
950,
|
|
18
|
+
975,
|
|
19
|
+
990,
|
|
20
|
+
1e3
|
|
21
|
+
];
|
|
22
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/constants.ts"],
|
|
4
|
+
"sourcesContent": ["export const DEFAULT_STOP = 500;\nexport const DEFAULT_STOPS = [\n 0, 10, 25, 50, 100, 200, 300, 400, 500, 600, 700, 800, 900, 950, 975, 990, 1000,\n] as const;\n"],
|
|
5
|
+
"mappings": ";AAAO,aAAM,eAAe;AACrB,aAAM,gBAAgB;AAAA,EAC3B;AAAA,EAAG;AAAA,EAAI;AAAA,EAAI;AAAA,EAAI;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAC7E;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createDisplayColor(hexColor: string, alphaPlaceholder?: boolean): string | null;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { oklch } from "culori";
|
|
3
|
+
import { isHex } from "./isHex.js";
|
|
4
|
+
import { round } from "./round.js";
|
|
5
|
+
export function createDisplayColor(hexColor, alphaPlaceholder) {
|
|
6
|
+
if (!hexColor || !isHex(hexColor)) {
|
|
7
|
+
return null;
|
|
8
|
+
}
|
|
9
|
+
let display = null;
|
|
10
|
+
let oklchColor = oklch(hexColor);
|
|
11
|
+
if (!oklchColor) {
|
|
12
|
+
throw new Error(`Couldn't convert "${hexColor}" to OKLCH!`);
|
|
13
|
+
}
|
|
14
|
+
let { l, c, h = 0 } = oklchColor;
|
|
15
|
+
display = `oklch(${[
|
|
16
|
+
`${round(l * 100, 2)}%`,
|
|
17
|
+
round(c, 3),
|
|
18
|
+
round(h, 2),
|
|
19
|
+
`/`,
|
|
20
|
+
alphaPlaceholder ? `<alpha-value>` : 1
|
|
21
|
+
].join(` `)})`;
|
|
22
|
+
return display;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=createDisplayColor.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createDisplayColor.ts"],
|
|
4
|
+
"sourcesContent": ["import {oklch} from 'culori';\n\nimport {isHex} from './isHex.js';\nimport {round} from './round.js';\n\nexport function createDisplayColor(hexColor: string, alphaPlaceholder?: boolean): string | null {\n if (!hexColor || !isHex(hexColor)) {\n return null;\n }\n\n let display = null;\n let oklchColor = oklch(hexColor);\n\n if (!oklchColor) {\n throw new Error(`Couldn't convert \"${hexColor}\" to OKLCH!`);\n }\n\n let {l, c, h = 0} = oklchColor;\n\n display = `oklch(${[\n `${round(l * 100, 2)}%`,\n round(c, 3),\n round(h, 2),\n `/`,\n alphaPlaceholder ? `<alpha-value>` : 1,\n ].join(` `)})`;\n\n return display;\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,aAAY;AAEpB,SAAQ,aAAY;AACpB,SAAQ,aAAY;AAEb,gBAAS,mBAAmB,UAAkB,kBAA2C;AAC9F,MAAI,CAAC,YAAY,CAAC,MAAM,QAAQ,GAAG;AACjC,WAAO;AAAA,EACT;AAEA,MAAI,UAAU;AACd,MAAI,aAAa,MAAM,QAAQ;AAE/B,MAAI,CAAC,YAAY;AACf,UAAM,IAAI,MAAM,qBAAqB,QAAQ,aAAa;AAAA,EAC5D;AAEA,MAAI,EAAC,GAAG,GAAG,IAAI,EAAC,IAAI;AAEpB,YAAU,SAAS;AAAA,IACjB,GAAG,MAAM,IAAI,KAAK,CAAC,CAAC;AAAA,IACpB,MAAM,GAAG,CAAC;AAAA,IACV,MAAM,GAAG,CAAC;AAAA,IACV;AAAA,IACA,mBAAmB,kBAAkB;AAAA,EACvC,EAAE,KAAK,GAAG,CAAC;AAEX,SAAO;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
|
|
3
|
+
const MIN = 0;
|
|
4
|
+
const MAX = 100;
|
|
5
|
+
export function createDistributionValues(lightness, stop = DEFAULT_STOP) {
|
|
6
|
+
let stops = [...DEFAULT_STOPS].sort();
|
|
7
|
+
let newValues = [
|
|
8
|
+
{ stop: 0, value: MAX },
|
|
9
|
+
{ stop, value: lightness },
|
|
10
|
+
{ stop: 1e3, value: MIN }
|
|
11
|
+
];
|
|
12
|
+
let stopIndex = stops.indexOf(stop);
|
|
13
|
+
let firstHalf = stops.slice(0, stopIndex + 1);
|
|
14
|
+
let secondHalf = stops.slice(stopIndex);
|
|
15
|
+
for (let stopValue of firstHalf) {
|
|
16
|
+
if (stopValue !== 0 && stopValue !== stop) {
|
|
17
|
+
let percentage = (stopValue - 0) / (stop - 0);
|
|
18
|
+
let value = MAX - percentage * (MAX - lightness);
|
|
19
|
+
newValues.push({ stop: stopValue, value: Math.round(value) });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
for (let stopValue of secondHalf) {
|
|
23
|
+
if (stopValue !== 1e3 && stopValue !== stop) {
|
|
24
|
+
let percentage = (stopValue - stop) / (1e3 - stop);
|
|
25
|
+
let value = lightness - percentage * (lightness - MIN);
|
|
26
|
+
newValues.push({ stop: stopValue, value: Math.round(value) });
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
newValues.sort((a, b) => a.stop - b.stop);
|
|
30
|
+
return newValues;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=createDistributionValues.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createDistributionValues.ts"],
|
|
4
|
+
"sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nconst MIN = 0;\nconst MAX = 100;\n\nexport function createDistributionValues(lightness: number, stop: number = DEFAULT_STOP) {\n let stops: number[] = [...DEFAULT_STOPS].sort() as unknown as number[];\n let newValues = [\n {stop: 0, value: MAX},\n {stop, value: lightness},\n {stop: 1000, value: MIN},\n ];\n let stopIndex = stops.indexOf(stop);\n let firstHalf = stops.slice(0, stopIndex + 1);\n let secondHalf = stops.slice(stopIndex);\n\n for (let stopValue of firstHalf) {\n if (stopValue !== 0 && stopValue !== stop) {\n let percentage = (stopValue - 0) / (stop - 0);\n let value = MAX - percentage * (MAX - lightness);\n\n newValues.push({stop: stopValue, value: Math.round(value)});\n }\n }\n\n for (let stopValue of secondHalf) {\n if (stopValue !== 1000 && stopValue !== stop) {\n let percentage = (stopValue - stop) / (1000 - stop);\n let value = lightness - percentage * (lightness - MIN);\n\n newValues.push({stop: stopValue, value: Math.round(value)});\n }\n }\n\n newValues.sort((a, b) => a.stop - b.stop);\n\n return newValues;\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAE1C,MAAM,MAAM;AACZ,MAAM,MAAM;AAEL,gBAAS,yBAAyB,WAAmB,OAAe,cAAc;AACvF,MAAI,QAAkB,CAAC,GAAG,aAAa,EAAE,KAAK;AAC9C,MAAI,YAAY;AAAA,IACd,EAAC,MAAM,GAAG,OAAO,IAAG;AAAA,IACpB,EAAC,MAAM,OAAO,UAAS;AAAA,IACvB,EAAC,MAAM,KAAM,OAAO,IAAG;AAAA,EACzB;AACA,MAAI,YAAY,MAAM,QAAQ,IAAI;AAClC,MAAI,YAAY,MAAM,MAAM,GAAG,YAAY,CAAC;AAC5C,MAAI,aAAa,MAAM,MAAM,SAAS;AAEtC,WAAS,aAAa,WAAW;AAC/B,QAAI,cAAc,KAAK,cAAc,MAAM;AACzC,UAAI,cAAc,YAAY,MAAM,OAAO;AAC3C,UAAI,QAAQ,MAAM,cAAc,MAAM;AAEtC,gBAAU,KAAK,EAAC,MAAM,WAAW,OAAO,KAAK,MAAM,KAAK,EAAC,CAAC;AAAA,IAC5D;AAAA,EACF;AAEA,WAAS,aAAa,YAAY;AAChC,QAAI,cAAc,OAAQ,cAAc,MAAM;AAC5C,UAAI,cAAc,YAAY,SAAS,MAAO;AAC9C,UAAI,QAAQ,YAAY,cAAc,YAAY;AAElD,gBAAU,KAAK,EAAC,MAAM,WAAW,OAAO,KAAK,MAAM,KAAK,EAAC,CAAC;AAAA,IAC5D;AAAA,EACF;AAEA,YAAU,KAAK,CAAC,GAAG,MAAM,EAAE,OAAO,EAAE,IAAI;AAExC,SAAO;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
|
|
3
|
+
export function createHueScale(tweak = 0, stop = DEFAULT_STOP) {
|
|
4
|
+
let stops = DEFAULT_STOPS;
|
|
5
|
+
let index = stops.indexOf(stop);
|
|
6
|
+
if (index === -1) {
|
|
7
|
+
throw new Error(`Invalid parameter value: ${stop}`);
|
|
8
|
+
}
|
|
9
|
+
return stops.map((stop2) => {
|
|
10
|
+
let diff = Math.abs(stops.indexOf(stop2) - index);
|
|
11
|
+
let tweakValue = tweak ? diff * tweak : 0;
|
|
12
|
+
return { stop: stop2, tweak: tweakValue };
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=createHueScale.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createHueScale.ts"],
|
|
4
|
+
"sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nexport function createHueScale(tweak = 0, stop: number = DEFAULT_STOP) {\n let stops: number[] = DEFAULT_STOPS as unknown as number[];\n let index = stops.indexOf(stop);\n\n if (index === -1) {\n throw new Error(`Invalid parameter value: ${stop}`);\n }\n\n return stops.map((stop) => {\n let diff = Math.abs(stops.indexOf(stop) - index);\n let tweakValue = tweak ? diff * tweak : 0;\n\n return {stop, tweak: tweakValue};\n });\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAEnC,gBAAS,eAAe,QAAQ,GAAG,OAAe,cAAc;AACrE,MAAI,QAAkB;AACtB,MAAI,QAAQ,MAAM,QAAQ,IAAI;AAE9B,MAAI,UAAU,IAAI;AAChB,UAAM,IAAI,MAAM,4BAA4B,IAAI,EAAE;AAAA,EACpD;AAEA,SAAO,MAAM,IAAI,CAACA,UAAS;AACzB,QAAI,OAAO,KAAK,IAAI,MAAM,QAAQA,KAAI,IAAI,KAAK;AAC/C,QAAI,aAAa,QAAQ,OAAO,QAAQ;AAExC,WAAO,EAAC,MAAAA,OAAM,OAAO,WAAU;AAAA,EACjC,CAAC;AACH;",
|
|
6
|
+
"names": ["stop"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { type DEFAULT_STOPS } from './constants.js';
|
|
2
|
+
export type CreatePaletteOptions<N extends string> = {
|
|
3
|
+
name: N;
|
|
4
|
+
swatches: Array<{
|
|
5
|
+
hex: string;
|
|
6
|
+
stop: number;
|
|
7
|
+
}>;
|
|
8
|
+
hueShift: number;
|
|
9
|
+
saturationShift: number;
|
|
10
|
+
};
|
|
11
|
+
export type CreatePaletteReturn<N extends string> = {
|
|
12
|
+
[K in N]: {
|
|
13
|
+
[J in (typeof DEFAULT_STOPS)[number]]: string;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export declare function createPalette<const N extends string>({ name, swatches, hueShift, saturationShift, }: CreatePaletteOptions<N>): CreatePaletteReturn<N>;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { DEFAULT_STOP } from "./constants.js";
|
|
3
|
+
import { createDisplayColor } from "./createDisplayColor.js";
|
|
4
|
+
import { createSwatches } from "./createSwatches.js";
|
|
5
|
+
export function createPalette({
|
|
6
|
+
name,
|
|
7
|
+
swatches,
|
|
8
|
+
hueShift,
|
|
9
|
+
saturationShift
|
|
10
|
+
}) {
|
|
11
|
+
let defaultSwatch = swatches.find((swatch) => swatch.stop === DEFAULT_STOP);
|
|
12
|
+
if (!defaultSwatch) {
|
|
13
|
+
throw new Error(`Swatches are missing color for stop "${DEFAULT_STOP}"!`);
|
|
14
|
+
}
|
|
15
|
+
let allSwatches = createSwatches({
|
|
16
|
+
value: defaultSwatch.hex,
|
|
17
|
+
valueStop: DEFAULT_STOP,
|
|
18
|
+
h: hueShift,
|
|
19
|
+
s: saturationShift
|
|
20
|
+
});
|
|
21
|
+
let palette = {};
|
|
22
|
+
allSwatches.filter((swatch) => ![0, 1e3].includes(swatch.stop)).forEach((newSwatch) => {
|
|
23
|
+
let existingSwatch = swatches.find((swatch) => swatch.stop === newSwatch.stop);
|
|
24
|
+
if (existingSwatch) {
|
|
25
|
+
Object.assign(palette, {
|
|
26
|
+
[existingSwatch.stop]: createDisplayColor(existingSwatch.hex, true)
|
|
27
|
+
});
|
|
28
|
+
} else {
|
|
29
|
+
Object.assign(palette, { [newSwatch.stop]: createDisplayColor(newSwatch.hex, true) });
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
return {
|
|
33
|
+
[name]: palette
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=createPalette.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createPalette.ts"],
|
|
4
|
+
"sourcesContent": ["import {DEFAULT_STOP, type DEFAULT_STOPS} from './constants.js';\nimport {createDisplayColor} from './createDisplayColor.js';\nimport {createSwatches} from './createSwatches.js';\n\nexport type CreatePaletteOptions<N extends string> = {\n name: N;\n swatches: Array<{hex: string; stop: number}>;\n hueShift: number;\n saturationShift: number;\n};\n\nexport type CreatePaletteReturn<N extends string> = {\n [K in N]: {[J in (typeof DEFAULT_STOPS)[number]]: string};\n};\n\nexport function createPalette<const N extends string>({\n name,\n swatches,\n hueShift,\n saturationShift,\n}: CreatePaletteOptions<N>): CreatePaletteReturn<N> {\n let defaultSwatch = swatches.find((swatch) => swatch.stop === DEFAULT_STOP);\n\n if (!defaultSwatch) {\n throw new Error(`Swatches are missing color for stop \"${DEFAULT_STOP}\"!`);\n }\n\n let allSwatches = createSwatches({\n value: defaultSwatch.hex,\n valueStop: DEFAULT_STOP,\n h: hueShift,\n s: saturationShift,\n });\n let palette = {};\n\n allSwatches\n .filter((swatch) => ![0, 1000].includes(swatch.stop))\n .forEach((newSwatch) => {\n let existingSwatch = swatches.find((swatch) => swatch.stop === newSwatch.stop);\n\n if (existingSwatch) {\n Object.assign(palette, {\n [existingSwatch.stop]: createDisplayColor(existingSwatch.hex, true),\n });\n } else {\n Object.assign(palette, {[newSwatch.stop]: createDisplayColor(newSwatch.hex, true)});\n }\n });\n\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions -- false positive\n return {\n [name]: palette,\n } as CreatePaletteReturn<N>;\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,oBAAuC;AAC/C,SAAQ,0BAAyB;AACjC,SAAQ,sBAAqB;AAatB,gBAAS,cAAsC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAoD;AAClD,MAAI,gBAAgB,SAAS,KAAK,CAAC,WAAW,OAAO,SAAS,YAAY;AAE1E,MAAI,CAAC,eAAe;AAClB,UAAM,IAAI,MAAM,wCAAwC,YAAY,IAAI;AAAA,EAC1E;AAEA,MAAI,cAAc,eAAe;AAAA,IAC/B,OAAO,cAAc;AAAA,IACrB,WAAW;AAAA,IACX,GAAG;AAAA,IACH,GAAG;AAAA,EACL,CAAC;AACD,MAAI,UAAU,CAAC;AAEf,cACG,OAAO,CAAC,WAAW,CAAC,CAAC,GAAG,GAAI,EAAE,SAAS,OAAO,IAAI,CAAC,EACnD,QAAQ,CAAC,cAAc;AACtB,QAAI,iBAAiB,SAAS,KAAK,CAAC,WAAW,OAAO,SAAS,UAAU,IAAI;AAE7E,QAAI,gBAAgB;AAClB,aAAO,OAAO,SAAS;AAAA,QACrB,CAAC,eAAe,IAAI,GAAG,mBAAmB,eAAe,KAAK,IAAI;AAAA,MACpE,CAAC;AAAA,IACH,OAAO;AACL,aAAO,OAAO,SAAS,EAAC,CAAC,UAAU,IAAI,GAAG,mBAAmB,UAAU,KAAK,IAAI,EAAC,CAAC;AAAA,IACpF;AAAA,EACF,CAAC;AAGH,SAAO;AAAA,IACL,CAAC,IAAI,GAAG;AAAA,EACV;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
|
|
3
|
+
export function createSaturationScale(tweak = 0, stop = DEFAULT_STOP) {
|
|
4
|
+
let stops = DEFAULT_STOPS;
|
|
5
|
+
let index = stops.indexOf(stop);
|
|
6
|
+
if (index === -1) {
|
|
7
|
+
throw new Error(`Invalid key value: ${stop}`);
|
|
8
|
+
}
|
|
9
|
+
return stops.map((stop2) => {
|
|
10
|
+
let diff = Math.abs(stops.indexOf(stop2) - index);
|
|
11
|
+
let tweakValue = tweak ? Math.round((diff + 1) * tweak * (1 + diff / 10)) : 0;
|
|
12
|
+
if (tweakValue > 100) {
|
|
13
|
+
return { stop: stop2, tweak: 100 };
|
|
14
|
+
}
|
|
15
|
+
return { stop: stop2, tweak: tweakValue };
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=createSaturationScale.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createSaturationScale.ts"],
|
|
4
|
+
"sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nexport function createSaturationScale(tweak = 0, stop: number = DEFAULT_STOP) {\n let stops: number[] = DEFAULT_STOPS as unknown as number[];\n let index = stops.indexOf(stop);\n\n if (index === -1) {\n throw new Error(`Invalid key value: ${stop}`);\n }\n\n return stops.map((stop) => {\n let diff = Math.abs(stops.indexOf(stop) - index);\n let tweakValue = tweak ? Math.round((diff + 1) * tweak * (1 + diff / 10)) : 0;\n\n if (tweakValue > 100) {\n return {stop, tweak: 100};\n }\n\n return {stop, tweak: tweakValue};\n });\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAEnC,gBAAS,sBAAsB,QAAQ,GAAG,OAAe,cAAc;AAC5E,MAAI,QAAkB;AACtB,MAAI,QAAQ,MAAM,QAAQ,IAAI;AAE9B,MAAI,UAAU,IAAI;AAChB,UAAM,IAAI,MAAM,sBAAsB,IAAI,EAAE;AAAA,EAC9C;AAEA,SAAO,MAAM,IAAI,CAACA,UAAS;AACzB,QAAI,OAAO,KAAK,IAAI,MAAM,QAAQA,KAAI,IAAI,KAAK;AAC/C,QAAI,aAAa,QAAQ,KAAK,OAAO,OAAO,KAAK,SAAS,IAAI,OAAO,GAAG,IAAI;AAE5E,QAAI,aAAa,KAAK;AACpB,aAAO,EAAC,MAAAA,OAAM,OAAO,IAAG;AAAA,IAC1B;AAEA,WAAO,EAAC,MAAAA,OAAM,OAAO,WAAU;AAAA,EACjC,CAAC;AACH;",
|
|
6
|
+
"names": ["stop"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { clamp } from "./clamp.js";
|
|
3
|
+
import { createDistributionValues } from "./createDistributionValues.js";
|
|
4
|
+
import { createHueScale } from "./createHueScale.js";
|
|
5
|
+
import { createSaturationScale } from "./createSaturationScale.js";
|
|
6
|
+
import { hexToHsl } from "./hexToHsl.js";
|
|
7
|
+
import { hslToHex } from "./hslToHex.js";
|
|
8
|
+
import { unsignedModulo } from "./unsignedModulo.js";
|
|
9
|
+
export function createSwatches(palette) {
|
|
10
|
+
let hueScale = createHueScale(palette.h, palette.valueStop);
|
|
11
|
+
let saturationScale = createSaturationScale(palette.s, palette.valueStop);
|
|
12
|
+
let { h, s, l } = hexToHsl(palette.value);
|
|
13
|
+
let distributionScale = createDistributionValues(l, palette.valueStop);
|
|
14
|
+
let swatches = hueScale.map(({ stop }, stopIndex) => {
|
|
15
|
+
let newH = unsignedModulo(h + hueScale[stopIndex].tweak, 360);
|
|
16
|
+
let newS = clamp(s + saturationScale[stopIndex].tweak, 0, 100);
|
|
17
|
+
let newL = clamp(distributionScale[stopIndex].value, 0.1, 99.9);
|
|
18
|
+
let newHex = hslToHex(newH, newS, newL);
|
|
19
|
+
return {
|
|
20
|
+
stop,
|
|
21
|
+
hex: stop === palette.valueStop ? palette.value.toUpperCase() : newHex.toUpperCase(),
|
|
22
|
+
h: newH,
|
|
23
|
+
hScale: (unsignedModulo(hueScale[stopIndex].tweak + 180, 360) - 180) / 180 * 50,
|
|
24
|
+
s: newS,
|
|
25
|
+
sScale: newS - 50,
|
|
26
|
+
l: newL
|
|
27
|
+
};
|
|
28
|
+
});
|
|
29
|
+
return swatches;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=createSwatches.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../source/development/internals/createSwatches.ts"],
|
|
4
|
+
"sourcesContent": ["import {clamp} from './clamp.js';\nimport {createDistributionValues} from './createDistributionValues.js';\nimport {createHueScale} from './createHueScale.js';\nimport {createSaturationScale} from './createSaturationScale.js';\nimport {hexToHsl} from './hexToHsl.js';\nimport {hslToHex} from './hslToHex.js';\nimport {type PaletteConfig} from './PaletteConfig.js';\nimport {unsignedModulo} from './unsignedModulo.js';\n\nexport function createSwatches(palette: PaletteConfig) {\n let hueScale = createHueScale(palette.h, palette.valueStop);\n let saturationScale = createSaturationScale(palette.s, palette.valueStop);\n let {h, s, l} = hexToHsl(palette.value);\n let distributionScale = createDistributionValues(l, palette.valueStop);\n\n let swatches = hueScale.map(({stop}, stopIndex) => {\n let newH = unsignedModulo(h + hueScale[stopIndex]!.tweak, 360);\n let newS = clamp(s + saturationScale[stopIndex]!.tweak, 0, 100);\n let newL = clamp(distributionScale[stopIndex]!.value, 0.1, 99.9); // this is to make sure the first two or last two swatches (the first being total white and the last being total black) aren't the same lightness\n let newHex = hslToHex(newH, newS, newL);\n\n return {\n stop,\n hex: stop === palette.valueStop ? palette.value.toUpperCase() : newHex.toUpperCase(),\n h: newH,\n hScale: ((unsignedModulo(hueScale[stopIndex]!.tweak + 180, 360) - 180) / 180) * 50,\n s: newS,\n sScale: newS - 50,\n l: newL,\n };\n });\n\n return swatches;\n}\n"],
|
|
5
|
+
"mappings": ";AAAA,SAAQ,aAAY;AACpB,SAAQ,gCAA+B;AACvC,SAAQ,sBAAqB;AAC7B,SAAQ,6BAA4B;AACpC,SAAQ,gBAAe;AACvB,SAAQ,gBAAe;AAEvB,SAAQ,sBAAqB;AAEtB,gBAAS,eAAe,SAAwB;AACrD,MAAI,WAAW,eAAe,QAAQ,GAAG,QAAQ,SAAS;AAC1D,MAAI,kBAAkB,sBAAsB,QAAQ,GAAG,QAAQ,SAAS;AACxE,MAAI,EAAC,GAAG,GAAG,EAAC,IAAI,SAAS,QAAQ,KAAK;AACtC,MAAI,oBAAoB,yBAAyB,GAAG,QAAQ,SAAS;AAErE,MAAI,WAAW,SAAS,IAAI,CAAC,EAAC,KAAI,GAAG,cAAc;AACjD,QAAI,OAAO,eAAe,IAAI,SAAS,SAAS,EAAG,OAAO,GAAG;AAC7D,QAAI,OAAO,MAAM,IAAI,gBAAgB,SAAS,EAAG,OAAO,GAAG,GAAG;AAC9D,QAAI,OAAO,MAAM,kBAAkB,SAAS,EAAG,OAAO,KAAK,IAAI;AAC/D,QAAI,SAAS,SAAS,MAAM,MAAM,IAAI;AAEtC,WAAO;AAAA,MACL;AAAA,MACA,KAAK,SAAS,QAAQ,YAAY,QAAQ,MAAM,YAAY,IAAI,OAAO,YAAY;AAAA,MACnF,GAAG;AAAA,MACH,SAAU,eAAe,SAAS,SAAS,EAAG,QAAQ,KAAK,GAAG,IAAI,OAAO,MAAO;AAAA,MAChF,GAAG;AAAA,MACH,QAAQ,OAAO;AAAA,MACf,GAAG;AAAA,IACL;AAAA,EACF,CAAC;AAED,SAAO;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
import { hexToRgb } from "./hexToRgb.js";
|
|
3
|
+
export function hexToHsl(rawHex) {
|
|
4
|
+
let hex = rawHex;
|
|
5
|
+
if (hex.length === 6 && !hex.startsWith(`#`)) {
|
|
6
|
+
hex = `#${hex}`;
|
|
7
|
+
}
|
|
8
|
+
let { r, g, b } = hexToRgb(hex);
|
|
9
|
+
r /= 255;
|
|
10
|
+
g /= 255;
|
|
11
|
+
b /= 255;
|
|
12
|
+
let cmin = Math.min(r, g, b);
|
|
13
|
+
let cmax = Math.max(r, g, b);
|
|
14
|
+
let delta = cmax - cmin;
|
|
15
|
+
let h = 0;
|
|
16
|
+
let s = 0;
|
|
17
|
+
let l = 0;
|
|
18
|
+
if (delta === 0) {
|
|
19
|
+
h = 0;
|
|
20
|
+
} else if (cmax === r) {
|
|
21
|
+
h = (g - b) / delta % 6;
|
|
22
|
+
} else if (cmax === g) {
|
|
23
|
+
h = (b - r) / delta + 2;
|
|
24
|
+
} else {
|
|
25
|
+
h = (r - g) / delta + 4;
|
|
26
|
+
}
|
|
27
|
+
h = Math.round(h * 60);
|
|
28
|
+
if (h < 0) {
|
|
29
|
+
h += 360;
|
|
30
|
+
}
|
|
31
|
+
l = (cmax + cmin) / 2;
|
|
32
|
+
s = delta === 0 ? 0 : delta / (1 - Math.abs(2 * l - 1));
|
|
33
|
+
s = +(s * 100).toFixed(1);
|
|
34
|
+
l = +(l * 100).toFixed(1);
|
|
35
|
+
return { h, s, l };
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=hexToHsl.js.map
|