@basic-ui/material 0.1.10 → 0.1.13
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/build/cjs/index.js +36 -31
- package/build/cjs/index.js.map +1 -1
- package/build/esm/Alert/Alert.d.ts +1 -1
- package/build/esm/AppBar/AppBar.d.ts +1 -1
- package/build/esm/AppBar/AppBarButton.d.ts +1 -1
- package/build/esm/Badge/Badge.d.ts +1 -1
- package/build/esm/BottomSheet/BottomSheet.d.ts +1 -1
- package/build/esm/BottomSheet/BottomSheetSurface.d.ts +1 -1
- package/build/esm/Button/BaseButton.d.ts +1 -1
- package/build/esm/Button/Button.d.ts +1 -1
- package/build/esm/Button/FilledButton.d.ts +1 -1
- package/build/esm/Button/FloatingActionButton.d.ts +7 -0
- package/build/esm/Button/FloatingActionButton.js +8 -0
- package/build/esm/Button/FloatingActionButton.js.map +1 -0
- package/build/esm/Button/OutlinedButton.d.ts +1 -3
- package/build/esm/Button/TransparentButton.d.ts +1 -1
- package/build/esm/CheckBox/CheckBox.d.ts +1 -1
- package/build/esm/CheckBox/CheckBoxIcon.d.ts +1 -1
- package/build/esm/Chip/ButtonChip.d.ts +1 -1
- package/build/esm/Chip/ChipBase.d.ts +1 -1
- package/build/esm/Chip/ChoiceChip.d.ts +1 -1
- package/build/esm/ColorMode/ColorModeProvider.js +10 -3
- package/build/esm/ColorMode/ColorModeProvider.js.map +1 -1
- package/build/esm/Combobox/Combobox.d.ts +7 -7
- package/build/esm/Dialog/Dialog.d.ts +1 -1
- package/build/esm/Dialog/DialogBackdrop.d.ts +1 -1
- package/build/esm/Dialog/DialogContainer.d.ts +1 -1
- package/build/esm/Dialog/DialogSurface.d.ts +1 -1
- package/build/esm/Dialog/Scrim.d.ts +1 -1
- package/build/esm/Dialog/useDialogAnimation.js +1 -1
- package/build/esm/Dialog/useDialogAnimation.js.map +1 -1
- package/build/esm/Divider/Divider.d.ts +1 -1
- package/build/esm/LineRipple/LineRipple.d.ts +1 -1
- package/build/esm/Link/Link.d.ts +1 -1
- package/build/esm/List/List.d.ts +1 -1
- package/build/esm/ListItem/ListItem.d.ts +1 -1
- package/build/esm/Menu/Menu.d.ts +4 -4
- package/build/esm/Paper/Paper.d.ts +1 -1
- package/build/esm/ProgressSpinner/ProgressSpinner.d.ts +1 -1
- package/build/esm/RadioButton/RadioGroup.d.ts +1 -1
- package/build/esm/Ripple/keyframes.js +0 -2
- package/build/esm/Ripple/keyframes.js.map +1 -1
- package/build/esm/Ripple/useRipple.js +4 -4
- package/build/esm/Ripple/useRipple.js.map +1 -1
- package/build/esm/Select/SelectIcon.d.ts +1 -1
- package/build/esm/SelectItem/SelectItem.d.ts +1 -1
- package/build/esm/SelectionControl/SelectionControlLabel.d.ts +1 -1
- package/build/esm/SelectionControl/SelectionControlText.d.ts +1 -1
- package/build/esm/Skeleton/DelayAppearance.d.ts +1 -1
- package/build/esm/Skeleton/Skeleton.d.ts +1 -1
- package/build/esm/Snackbar/Snackbar.d.ts +1 -1
- package/build/esm/Snackbar/Stack.d.ts +2 -0
- package/build/esm/Snackbar/Stack.js.map +1 -1
- package/build/esm/Switch/Switch.d.ts +1 -1
- package/build/esm/Tab/Tab.d.ts +1 -1
- package/build/esm/Tab/TabList.d.ts +1 -1
- package/build/esm/Tab/TabPanel.d.ts +1 -1
- package/build/esm/TabIndicator/TabIndicator.d.ts +1 -1
- package/build/esm/Table/Table.d.ts +1 -1
- package/build/esm/Table/TableBody.d.ts +1 -1
- package/build/esm/Table/TableCell.d.ts +1 -1
- package/build/esm/Table/TableHead.d.ts +1 -1
- package/build/esm/Table/TableRow.d.ts +1 -1
- package/build/esm/Text/Text.d.ts +1 -1
- package/build/esm/TextField/FilledContainer.d.ts +1 -1
- package/build/esm/TextField/HelperText.d.ts +1 -1
- package/build/esm/TextField/Input.d.ts +1 -1
- package/build/esm/TextField/OutlinedContainer.d.ts +1 -1
- package/build/esm/TextField/TextField.d.ts +1 -1
- package/build/esm/ThemeExplorer/ColorPicker.d.ts +8 -0
- package/build/esm/ThemeExplorer/ColorPicker.js +76 -0
- package/build/esm/ThemeExplorer/ColorPicker.js.map +1 -0
- package/build/esm/ThemeExplorer/TextFieldColorPicker.d.ts +9 -0
- package/build/esm/ThemeExplorer/TextFieldColorPicker.js +100 -0
- package/build/esm/ThemeExplorer/TextFieldColorPicker.js.map +1 -0
- package/build/esm/ThemeExplorer/ThemeColors.d.ts +5 -0
- package/build/esm/ThemeExplorer/ThemeColors.js +80 -0
- package/build/esm/ThemeExplorer/ThemeColors.js.map +1 -0
- package/build/esm/ThemeExplorer/components.d.ts +31 -0
- package/build/esm/ThemeExplorer/components.js +184 -0
- package/build/esm/ThemeExplorer/components.js.map +1 -0
- package/build/esm/ThemeExplorer/makeColorScheme.d.ts +66 -0
- package/build/esm/ThemeExplorer/makeColorScheme.js +66 -0
- package/build/esm/ThemeExplorer/makeColorScheme.js.map +1 -0
- package/build/esm/ThemeExplorer/useDeferredColor.d.ts +3 -0
- package/build/esm/ThemeExplorer/useDeferredColor.js +11 -0
- package/build/esm/ThemeExplorer/useDeferredColor.js.map +1 -0
- package/build/esm/ThemeExplorer/useLocalStorageCachedState.d.ts +1 -0
- package/build/esm/ThemeExplorer/useLocalStorageCachedState.js +11 -0
- package/build/esm/ThemeExplorer/useLocalStorageCachedState.js.map +1 -0
- package/build/esm/Tooltip/Tooltip.d.ts +1 -1
- package/build/esm/hooks/useAnimation.js +22 -21
- package/build/esm/hooks/useAnimation.js.map +1 -1
- package/build/esm/theme/useTheme.d.ts +1 -425
- package/build/tsconfig.tsbuildinfo +102 -142
- package/package.json +10 -8
- package/src/ColorMode/ColorModeProvider.tsx +9 -3
- package/src/Dialog/useDialogAnimation.tsx +1 -1
- package/src/Ripple/keyframes.ts +0 -2
- package/src/Ripple/useRipple.ts +6 -4
- package/src/Snackbar/Stack.tsx +1 -0
- package/src/hooks/useAnimation.ts +42 -32
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose";
|
|
3
|
+
import { ColorPicker as _BaseColorPicker, Hue as _Hue, HueCursor as _HueCursor, Saturation as _Saturation, SaturationCursor as _SaturationCursor } from '@basic-ui/color-picker';
|
|
4
|
+
import { Box } from '../Box';
|
|
5
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
7
|
+
const BaseColorPicker = _BaseColorPicker;
|
|
8
|
+
const Hue = _Hue;
|
|
9
|
+
const HueCursor = _HueCursor;
|
|
10
|
+
const Saturation = _Saturation;
|
|
11
|
+
const SaturationCursor = _SaturationCursor;
|
|
12
|
+
export const ColorPicker = (_ref) => {
|
|
13
|
+
let {
|
|
14
|
+
color,
|
|
15
|
+
onChange,
|
|
16
|
+
width = 450,
|
|
17
|
+
height = 225
|
|
18
|
+
} = _ref,
|
|
19
|
+
otherProps = _objectWithoutPropertiesLoose(_ref, ["color", "onChange", "width", "height"]);
|
|
20
|
+
|
|
21
|
+
return /*#__PURE__*/_jsxs(BaseColorPicker, _extends({
|
|
22
|
+
as: Box,
|
|
23
|
+
width: width,
|
|
24
|
+
height: height,
|
|
25
|
+
onChange: onChange,
|
|
26
|
+
color: color
|
|
27
|
+
}, otherProps, {
|
|
28
|
+
children: [/*#__PURE__*/_jsx(Saturation, {
|
|
29
|
+
as: Box,
|
|
30
|
+
sx: {
|
|
31
|
+
position: 'relative',
|
|
32
|
+
touchAction: 'none',
|
|
33
|
+
userSelect: 'none',
|
|
34
|
+
width: '100%',
|
|
35
|
+
backgroundImage: 'linear-gradient(transparent, black), linear-gradient(to right, white, transparent)'
|
|
36
|
+
},
|
|
37
|
+
children: /*#__PURE__*/_jsx(SaturationCursor, {
|
|
38
|
+
as: Box,
|
|
39
|
+
sx: {
|
|
40
|
+
position: 'absolute',
|
|
41
|
+
width: '20px',
|
|
42
|
+
height: '20px',
|
|
43
|
+
border: '2px solid #ffffff',
|
|
44
|
+
borderRadius: '50%',
|
|
45
|
+
boxShadow: '0 0 15px 0 rgba(0, 0, 0, 0.15)',
|
|
46
|
+
boxSizing: 'border-box',
|
|
47
|
+
transform: 'translate(-10px, -10px)'
|
|
48
|
+
}
|
|
49
|
+
})
|
|
50
|
+
}), /*#__PURE__*/_jsx(Hue, {
|
|
51
|
+
as: Box,
|
|
52
|
+
sx: {
|
|
53
|
+
position: 'relative',
|
|
54
|
+
touchAction: 'none',
|
|
55
|
+
userSelect: 'none',
|
|
56
|
+
width: '100%',
|
|
57
|
+
height: '12px',
|
|
58
|
+
backgroundImage: "linear-gradient(to right, rgb(255, 0, 0), rgb(255, 255, 0), rgb(0, 255, 0), rgb(0, 255, 255), rgb(0, 0, 255), rgb(255, 0, 255), rgb(255, 0, 0))"
|
|
59
|
+
},
|
|
60
|
+
children: /*#__PURE__*/_jsx(HueCursor, {
|
|
61
|
+
as: Box,
|
|
62
|
+
sx: {
|
|
63
|
+
position: 'absolute',
|
|
64
|
+
width: '20px',
|
|
65
|
+
height: '20px',
|
|
66
|
+
border: '2px solid #ffffff',
|
|
67
|
+
borderRadius: '50%',
|
|
68
|
+
boxShadow: 'rgba(0, 0, 0, 0.2) 0px 0px 0px 0.5px',
|
|
69
|
+
boxSizing: 'border-box',
|
|
70
|
+
transform: 'translate(-10px, -4px)'
|
|
71
|
+
}
|
|
72
|
+
})
|
|
73
|
+
})]
|
|
74
|
+
}));
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=ColorPicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/ThemeExplorer/ColorPicker.tsx"],"names":["ColorPicker","_BaseColorPicker","Hue","_Hue","HueCursor","_HueCursor","Saturation","_Saturation","SaturationCursor","_SaturationCursor","Box","BaseColorPicker","color","onChange","width","height","otherProps","position","touchAction","userSelect","backgroundImage","border","borderRadius","boxShadow","boxSizing","transform"],"mappings":";;AAAA,SAEEA,WAAW,IAAIC,gBAFjB,EAGEC,GAAG,IAAIC,IAHT,EAIEC,SAAS,IAAIC,UAJf,EAKEC,UAAU,IAAIC,WALhB,EAMEC,gBAAgB,IAAIC,iBANtB,QAYO,wBAZP;AAaA,SAASC,GAAT,QAA8B,QAA9B;;;AASA,MAAMC,eAEL,GAAGV,gBAFJ;AAGA,MAAMC,GAA6B,GAAGC,IAAtC;AACA,MAAMC,SAAyC,GAAGC,UAAlD;AACA,MAAMC,UAA2C,GAAGC,WAApD;AACA,MAAMC,gBAEL,GAAGC,iBAFJ;AAIA,OAAO,MAAMT,WAAkC,GAAG,UAM5C;AAAA,MAN6C;AACjDY,IAAAA,KADiD;AAEjDC,IAAAA,QAFiD;AAGjDC,IAAAA,KAAK,GAAG,GAHyC;AAIjDC,IAAAA,MAAM,GAAG;AAJwC,GAM7C;AAAA,MADDC,UACC;;AACJ,sBACE,MAAC,eAAD;AACE,IAAA,EAAE,EAAEN,GADN;AAEE,IAAA,KAAK,EAAEI,KAFT;AAGE,IAAA,MAAM,EAAEC,MAHV;AAIE,IAAA,QAAQ,EAAEF,QAJZ;AAKE,IAAA,KAAK,EAAED;AALT,KAMMI,UANN;AAAA,4BAQE,KAAC,UAAD;AACE,MAAA,EAAE,EAAEN,GADN;AAEE,MAAA,EAAE,EAAE;AACFO,QAAAA,QAAQ,EAAE,UADR;AAEFC,QAAAA,WAAW,EAAE,MAFX;AAGFC,QAAAA,UAAU,EAAE,MAHV;AAIFL,QAAAA,KAAK,EAAE,MAJL;AAKFM,QAAAA,eAAe,EACb;AANA,OAFN;AAAA,6BAWE,KAAC,gBAAD;AACE,QAAA,EAAE,EAAEV,GADN;AAEE,QAAA,EAAE,EAAE;AACFO,UAAAA,QAAQ,EAAE,UADR;AAEFH,UAAAA,KAAK,EAAE,MAFL;AAGFC,UAAAA,MAAM,EAAE,MAHN;AAIFM,UAAAA,MAAM,EAAE,mBAJN;AAKFC,UAAAA,YAAY,EAAE,KALZ;AAMFC,UAAAA,SAAS,EAAE,gCANT;AAOFC,UAAAA,SAAS,EAAE,YAPT;AAQFC,UAAAA,SAAS,EAAE;AART;AAFN;AAXF,MARF,eAiCE,KAAC,GAAD;AACE,MAAA,EAAE,EAAEf,GADN;AAEE,MAAA,EAAE,EAAE;AACFO,QAAAA,QAAQ,EAAE,UADR;AAEFC,QAAAA,WAAW,EAAE,MAFX;AAGFC,QAAAA,UAAU,EAAE,MAHV;AAIFL,QAAAA,KAAK,EAAE,MAJL;AAKFC,QAAAA,MAAM,EAAE,MALN;AAMFK,QAAAA,eAAe;AANb,OAFN;AAAA,6BAWE,KAAC,SAAD;AACE,QAAA,EAAE,EAAEV,GADN;AAEE,QAAA,EAAE,EAAE;AACFO,UAAAA,QAAQ,EAAE,UADR;AAEFH,UAAAA,KAAK,EAAE,MAFL;AAGFC,UAAAA,MAAM,EAAE,MAHN;AAIFM,UAAAA,MAAM,EAAE,mBAJN;AAKFC,UAAAA,YAAY,EAAE,KALZ;AAMFC,UAAAA,SAAS,EAAE,sCANT;AAOFC,UAAAA,SAAS,EAAE,YAPT;AAQFC,UAAAA,SAAS,EAAE;AART;AAFN;AAXF,MAjCF;AAAA,KADF;AA6DD,CApEM","sourcesContent":["import {\n Color,\n ColorPicker as _BaseColorPicker,\n Hue as _Hue,\n HueCursor as _HueCursor,\n Saturation as _Saturation,\n SaturationCursor as _SaturationCursor,\n ColorPickerProps as BaseColorPickerProps,\n HueProps,\n HueCursorProps,\n SaturationProps,\n SaturationCursorProps,\n} from '@basic-ui/color-picker';\nimport { Box, BoxProps } from '../Box';\nimport { VFC } from 'react';\n\nexport type ColorPickerProps = (Omit<BoxProps, 'color' | 'onChange'> &\n BaseColorPickerProps) & {\n color: Color;\n onChange: (color: Color) => void;\n};\n\nconst BaseColorPicker: VFC<\n Omit<BoxProps, 'color' | 'onChange'> & BaseColorPickerProps\n> = _BaseColorPicker as any;\nconst Hue: VFC<BoxProps & HueProps> = _Hue as any;\nconst HueCursor: VFC<BoxProps & HueCursorProps> = _HueCursor as any;\nconst Saturation: VFC<BoxProps & SaturationProps> = _Saturation as any;\nconst SaturationCursor: VFC<\n BoxProps & SaturationCursorProps\n> = _SaturationCursor as any;\n\nexport const ColorPicker: VFC<ColorPickerProps> = ({\n color,\n onChange,\n width = 450,\n height = 225,\n ...otherProps\n}) => {\n return (\n <BaseColorPicker\n as={Box}\n width={width}\n height={height}\n onChange={onChange}\n color={color}\n {...otherProps}\n >\n <Saturation\n as={Box}\n sx={{\n position: 'relative',\n touchAction: 'none',\n userSelect: 'none',\n width: '100%',\n backgroundImage:\n 'linear-gradient(transparent, black), linear-gradient(to right, white, transparent)',\n }}\n >\n <SaturationCursor\n as={Box}\n sx={{\n position: 'absolute',\n width: '20px',\n height: '20px',\n border: '2px solid #ffffff',\n borderRadius: '50%',\n boxShadow: '0 0 15px 0 rgba(0, 0, 0, 0.15)',\n boxSizing: 'border-box',\n transform: 'translate(-10px, -10px)',\n }}\n />\n </Saturation>\n <Hue\n as={Box}\n sx={{\n position: 'relative',\n touchAction: 'none',\n userSelect: 'none',\n width: '100%',\n height: '12px',\n backgroundImage: `linear-gradient(to right, rgb(255, 0, 0), rgb(255, 255, 0), rgb(0, 255, 0), rgb(0, 255, 255), rgb(0, 0, 255), rgb(255, 0, 255), rgb(255, 0, 0))`,\n }}\n >\n <HueCursor\n as={Box}\n sx={{\n position: 'absolute',\n width: '20px',\n height: '20px',\n border: '2px solid #ffffff',\n borderRadius: '50%',\n boxShadow: 'rgba(0, 0, 0, 0.2) 0px 0px 0px 0.5px',\n boxSizing: 'border-box',\n transform: 'translate(-10px, -4px)',\n }}\n />\n </Hue>\n </BaseColorPicker>\n );\n};\n"],"file":"ColorPicker.js"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Color } from '@basic-ui/color-picker';
|
|
3
|
+
import { TextFieldProps } from '../';
|
|
4
|
+
export interface TextFieldColorPickerProps extends Omit<TextFieldProps, 'value' | 'defaultValue' | 'onChange'> {
|
|
5
|
+
value?: Color;
|
|
6
|
+
defaultValue?: Color;
|
|
7
|
+
onChange?: (color: Color) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const TextFieldColorPicker: import("react").NamedExoticComponent<TextFieldColorPickerProps>;
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
|
2
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose";
|
|
3
|
+
import { toColor } from '@basic-ui/color-picker';
|
|
4
|
+
import { Popper, useControlledState, useOnClickOutside } from '@basic-ui/core';
|
|
5
|
+
import { alpha, Box, TextField, Button } from '../';
|
|
6
|
+
import { useRef, useState, memo, useCallback } from 'react';
|
|
7
|
+
import { ColorPicker } from './ColorPicker';
|
|
8
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
11
|
+
export const TextFieldColorPicker = /*#__PURE__*/memo(props => {
|
|
12
|
+
const {
|
|
13
|
+
value: valueProp,
|
|
14
|
+
defaultValue = toColor('hex', '#33ff33'),
|
|
15
|
+
onChange: onChangeProp,
|
|
16
|
+
disabled
|
|
17
|
+
} = props,
|
|
18
|
+
otherProps = _objectWithoutPropertiesLoose(props, ["value", "defaultValue", "onChange", "disabled"]);
|
|
19
|
+
|
|
20
|
+
const [popoverOpen, setPopoverOpen] = useState(false);
|
|
21
|
+
const [text, setText] = useState((valueProp == null ? void 0 : valueProp.hex) || defaultValue.hex);
|
|
22
|
+
const [value, _onChange] = useControlledState(valueProp, onChangeProp, defaultValue, setState => v => {
|
|
23
|
+
setState(v);
|
|
24
|
+
setText(v.hex);
|
|
25
|
+
});
|
|
26
|
+
const onChange = useCallback(color => {
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
28
|
+
_onChange(color);
|
|
29
|
+
|
|
30
|
+
setText(color.hex.replace('#', ''));
|
|
31
|
+
}, [_onChange]);
|
|
32
|
+
const popoverRef = useRef(null);
|
|
33
|
+
const buttonRef = useRef(null);
|
|
34
|
+
useOnClickOutside(popoverRef, e => {
|
|
35
|
+
if (e.target === (buttonRef == null ? void 0 : buttonRef.current)) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
setPopoverOpen(false);
|
|
40
|
+
});
|
|
41
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
42
|
+
children: [/*#__PURE__*/_jsx(TextField, _extends({
|
|
43
|
+
disabled: disabled,
|
|
44
|
+
value: text.replace('#', ''),
|
|
45
|
+
leadingIcon: '#',
|
|
46
|
+
trailingIcon: /*#__PURE__*/_jsx(Button, {
|
|
47
|
+
style: {
|
|
48
|
+
backgroundColor: value.hex
|
|
49
|
+
},
|
|
50
|
+
color: "on.surface",
|
|
51
|
+
ref: buttonRef,
|
|
52
|
+
onClick: () => setPopoverOpen(open => !open),
|
|
53
|
+
disabled: disabled,
|
|
54
|
+
sx: {
|
|
55
|
+
pointerEvents: 'all',
|
|
56
|
+
cursor: 'pointer',
|
|
57
|
+
width: 32,
|
|
58
|
+
height: 32,
|
|
59
|
+
borderRadius: '4px',
|
|
60
|
+
borderWidth: '1px',
|
|
61
|
+
borderColor: alpha('on.surface', 0.38),
|
|
62
|
+
borderStyle: 'solid',
|
|
63
|
+
outlineColor: 'transparent'
|
|
64
|
+
}
|
|
65
|
+
}),
|
|
66
|
+
maxLength: 6,
|
|
67
|
+
hideCharacterCounter: true,
|
|
68
|
+
onChange: e => {
|
|
69
|
+
if (e.target.value.match(/^[a-fA-F0-9]{6}$/)) {
|
|
70
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
71
|
+
onChange(toColor('hex', '#' + e.target.value));
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
setText(e.target.value);
|
|
76
|
+
}
|
|
77
|
+
}, otherProps)), popoverOpen && /*#__PURE__*/_jsx(Popper, {
|
|
78
|
+
anchorEl: buttonRef,
|
|
79
|
+
placement: "bottom-end",
|
|
80
|
+
style: {
|
|
81
|
+
zIndex: 2
|
|
82
|
+
},
|
|
83
|
+
children: /*#__PURE__*/_jsxs(Box, {
|
|
84
|
+
ref: popoverRef,
|
|
85
|
+
py: 2,
|
|
86
|
+
children: [/*#__PURE__*/_jsx(Box, {
|
|
87
|
+
boxShadow: 4,
|
|
88
|
+
children: /*#__PURE__*/_jsx(ColorPicker, {
|
|
89
|
+
color: value // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
90
|
+
,
|
|
91
|
+
onChange: onChange,
|
|
92
|
+
width: 220,
|
|
93
|
+
height: 220
|
|
94
|
+
})
|
|
95
|
+
}), /*#__PURE__*/_jsx(Box, {})]
|
|
96
|
+
})
|
|
97
|
+
})]
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
//# sourceMappingURL=TextFieldColorPicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/ThemeExplorer/TextFieldColorPicker.tsx"],"names":["toColor","Popper","useControlledState","useOnClickOutside","alpha","Box","TextField","Button","useRef","useState","memo","useCallback","ColorPicker","TextFieldColorPicker","props","value","valueProp","defaultValue","onChange","onChangeProp","disabled","otherProps","popoverOpen","setPopoverOpen","text","setText","hex","_onChange","setState","v","color","replace","popoverRef","buttonRef","e","target","current","backgroundColor","open","pointerEvents","cursor","width","height","borderRadius","borderWidth","borderColor","borderStyle","outlineColor","match","zIndex"],"mappings":"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","sourcesContent":["import { Color, toColor } from '@basic-ui/color-picker';\nimport { Popper, useControlledState, useOnClickOutside } from '@basic-ui/core';\nimport { alpha, Box, TextField, Button, TextFieldProps } from '../';\nimport { useRef, useState, memo, useCallback } from 'react';\nimport { ColorPicker } from './ColorPicker';\n\nexport interface TextFieldColorPickerProps\n extends Omit<TextFieldProps, 'value' | 'defaultValue' | 'onChange'> {\n value?: Color;\n defaultValue?: Color;\n onChange?: (color: Color) => void;\n}\n\nexport const TextFieldColorPicker = memo<TextFieldColorPickerProps>((props) => {\n const {\n value: valueProp,\n defaultValue = toColor('hex', '#33ff33'),\n onChange: onChangeProp,\n disabled,\n ...otherProps\n } = props;\n\n const [popoverOpen, setPopoverOpen] = useState(false);\n const [text, setText] = useState(valueProp?.hex || defaultValue.hex);\n const [value, _onChange] = useControlledState<Color, any, []>(\n valueProp,\n onChangeProp as any,\n defaultValue,\n (setState) => (v: any) => {\n setState(v);\n setText(v.hex);\n }\n );\n\n const onChange = useCallback(\n (color: Color) => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n _onChange!(color);\n setText(color.hex.replace('#', ''));\n },\n [_onChange]\n );\n\n const popoverRef = useRef<HTMLDivElement>(null);\n const buttonRef = useRef<HTMLButtonElement>(null);\n useOnClickOutside(popoverRef, (e) => {\n if (e.target === buttonRef?.current) {\n return;\n }\n setPopoverOpen(false);\n });\n\n return (\n <>\n <TextField\n disabled={disabled}\n value={text.replace('#', '')}\n leadingIcon={'#'}\n trailingIcon={\n <Button\n style={{ backgroundColor: value.hex }}\n color=\"on.surface\"\n ref={buttonRef}\n onClick={() => setPopoverOpen((open) => !open)}\n disabled={disabled}\n sx={{\n pointerEvents: 'all',\n cursor: 'pointer',\n width: 32,\n height: 32,\n borderRadius: '4px',\n borderWidth: '1px',\n borderColor: alpha('on.surface', 0.38),\n borderStyle: 'solid',\n outlineColor: 'transparent',\n }}\n />\n }\n maxLength={6}\n hideCharacterCounter\n onChange={(e) => {\n if (e.target.value.match(/^[a-fA-F0-9]{6}$/)) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n onChange!(toColor('hex', '#' + e.target.value));\n return;\n }\n setText(e.target.value);\n }}\n {...otherProps}\n />\n {popoverOpen && (\n <Popper\n anchorEl={buttonRef}\n placement=\"bottom-end\"\n style={{ zIndex: 2 }}\n >\n <Box ref={popoverRef} py={2}>\n <Box boxShadow={4}>\n <ColorPicker\n color={value}\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n onChange={onChange!}\n width={220}\n height={220}\n />\n </Box>\n <Box></Box>\n </Box>\n </Popper>\n )}\n </>\n );\n});\n"],"file":"TextFieldColorPicker.js"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import React, { memo } from 'react';
|
|
2
|
+
import { Box } from '..';
|
|
3
|
+
import { ColorRow } from './components';
|
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
|
+
export const ThemeColors = /*#__PURE__*/memo(({
|
|
7
|
+
scheme
|
|
8
|
+
}) => {
|
|
9
|
+
function makeColorArrayForToken(token) {
|
|
10
|
+
return [{
|
|
11
|
+
token: "".concat(token),
|
|
12
|
+
bg: scheme[token],
|
|
13
|
+
color: scheme.on[token]
|
|
14
|
+
}, {
|
|
15
|
+
token: "on.".concat(token),
|
|
16
|
+
bg: scheme.on[token],
|
|
17
|
+
color: scheme[token]
|
|
18
|
+
}, {
|
|
19
|
+
token: "".concat(token, "-container"),
|
|
20
|
+
bg: scheme["".concat(token, "-container")],
|
|
21
|
+
color: scheme.on["".concat(token, "-container")]
|
|
22
|
+
}, {
|
|
23
|
+
token: "on.".concat(token, "-container"),
|
|
24
|
+
bg: scheme.on["".concat(token, "-container")],
|
|
25
|
+
color: scheme["".concat(token, "-container")]
|
|
26
|
+
}];
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return /*#__PURE__*/_jsxs(Box, {
|
|
30
|
+
width: "600",
|
|
31
|
+
display: "flex",
|
|
32
|
+
flexDirection: "column",
|
|
33
|
+
sx: {
|
|
34
|
+
gap: 2
|
|
35
|
+
},
|
|
36
|
+
children: [/*#__PURE__*/_jsx(ColorRow, {
|
|
37
|
+
colors: makeColorArrayForToken('primary'),
|
|
38
|
+
height: 118
|
|
39
|
+
}), /*#__PURE__*/_jsx(ColorRow, {
|
|
40
|
+
colors: makeColorArrayForToken('secondary')
|
|
41
|
+
}), /*#__PURE__*/_jsx(ColorRow, {
|
|
42
|
+
colors: makeColorArrayForToken('tertiary')
|
|
43
|
+
}), /*#__PURE__*/_jsx(ColorRow, {
|
|
44
|
+
colors: makeColorArrayForToken('error')
|
|
45
|
+
}), /*#__PURE__*/_jsx(ColorRow, {
|
|
46
|
+
colors: [{
|
|
47
|
+
token: "background",
|
|
48
|
+
bg: scheme.background,
|
|
49
|
+
color: scheme.on.background
|
|
50
|
+
}, {
|
|
51
|
+
token: "on.background",
|
|
52
|
+
bg: scheme.on.background,
|
|
53
|
+
color: scheme.background
|
|
54
|
+
}, {
|
|
55
|
+
token: "surface",
|
|
56
|
+
bg: scheme.surface,
|
|
57
|
+
color: scheme.on.surface
|
|
58
|
+
}, {
|
|
59
|
+
token: "on.surface",
|
|
60
|
+
bg: scheme.on.surface,
|
|
61
|
+
color: scheme.surface
|
|
62
|
+
}]
|
|
63
|
+
}), /*#__PURE__*/_jsx(ColorRow, {
|
|
64
|
+
colors: [{
|
|
65
|
+
token: "surface-variant",
|
|
66
|
+
bg: scheme['surface-variant'],
|
|
67
|
+
color: scheme.on['surface-variant']
|
|
68
|
+
}, {
|
|
69
|
+
token: "on.surface-variant",
|
|
70
|
+
bg: scheme.on['surface-variant'],
|
|
71
|
+
color: scheme['surface-variant']
|
|
72
|
+
}, {
|
|
73
|
+
token: "outline",
|
|
74
|
+
bg: scheme.outline,
|
|
75
|
+
color: scheme.on.outline
|
|
76
|
+
}]
|
|
77
|
+
})]
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
//# sourceMappingURL=ThemeColors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/ThemeExplorer/ThemeColors.tsx"],"names":["React","memo","Box","ColorRow","ThemeColors","scheme","makeColorArrayForToken","token","bg","color","on","gap","background","surface","outline"],"mappings":"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","sourcesContent":["import React, { memo } from 'react';\nimport { Box } from '..';\nimport { ColorRow } from './components';\nimport { makeColorScheme } from './makeColorScheme';\n\nexport const ThemeColors = memo(\n ({\n scheme,\n }: {\n scheme: Omit<ReturnType<typeof makeColorScheme>, 'modes'>;\n }) => {\n function makeColorArrayForToken(token: string) {\n return [\n {\n token: `${token}`,\n bg: scheme[token],\n color: scheme.on[token],\n },\n {\n token: `on.${token}`,\n bg: scheme.on[token],\n color: scheme[token],\n },\n {\n token: `${token}-container`,\n bg: scheme[`${token}-container`],\n color: scheme.on[`${token}-container`],\n },\n {\n token: `on.${token}-container`,\n bg: scheme.on[`${token}-container`],\n color: scheme[`${token}-container`],\n },\n ];\n }\n return (\n <Box width=\"600\" display=\"flex\" flexDirection=\"column\" sx={{ gap: 2 }}>\n <ColorRow colors={makeColorArrayForToken('primary')} height={118} />\n <ColorRow colors={makeColorArrayForToken('secondary')} />\n <ColorRow colors={makeColorArrayForToken('tertiary')} />\n <ColorRow colors={makeColorArrayForToken('error')} />\n <ColorRow\n colors={[\n {\n token: `background`,\n bg: scheme.background,\n color: scheme.on.background,\n },\n {\n token: `on.background`,\n bg: scheme.on.background,\n color: scheme.background,\n },\n {\n token: `surface`,\n bg: scheme.surface,\n color: scheme.on.surface,\n },\n {\n token: `on.surface`,\n bg: scheme.on.surface,\n color: scheme.surface,\n },\n ]}\n />\n <ColorRow\n colors={[\n {\n token: `surface-variant`,\n bg: scheme['surface-variant'],\n color: scheme.on['surface-variant'],\n },\n {\n token: `on.surface-variant`,\n bg: scheme.on['surface-variant'],\n color: scheme['surface-variant'],\n },\n {\n token: `outline`,\n bg: scheme.outline,\n color: scheme.on.outline,\n },\n ]}\n />\n </Box>\n );\n }\n);\n"],"file":"ThemeColors.js"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React, { CSSProperties } from 'react';
|
|
2
|
+
import { TonalPalette } from '@material/material-color-utilities';
|
|
3
|
+
export declare const ColorItem: React.MemoExoticComponent<(props: {
|
|
4
|
+
token: string;
|
|
5
|
+
style: CSSProperties;
|
|
6
|
+
height: number;
|
|
7
|
+
width: string;
|
|
8
|
+
}) => JSX.Element>;
|
|
9
|
+
export declare const ColorRow: React.MemoExoticComponent<(props: {
|
|
10
|
+
colors: {
|
|
11
|
+
token: string;
|
|
12
|
+
bg: string;
|
|
13
|
+
color: string;
|
|
14
|
+
}[];
|
|
15
|
+
height?: number;
|
|
16
|
+
}) => JSX.Element>;
|
|
17
|
+
export declare const TonalColorItem: React.MemoExoticComponent<(props: {
|
|
18
|
+
color: string;
|
|
19
|
+
level: number;
|
|
20
|
+
}) => JSX.Element>;
|
|
21
|
+
export declare const TonalColorsFromToken: React.MemoExoticComponent<(props: {
|
|
22
|
+
token: string;
|
|
23
|
+
}) => JSX.Element>;
|
|
24
|
+
export declare const TonalColors: React.MemoExoticComponent<(props: {
|
|
25
|
+
palette: TonalPalette;
|
|
26
|
+
}) => JSX.Element>;
|
|
27
|
+
export declare function makeColorArrayForToken(token: string): {
|
|
28
|
+
token: string;
|
|
29
|
+
bg: string;
|
|
30
|
+
color: string;
|
|
31
|
+
}[];
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import React, { memo, useState } from 'react';
|
|
2
|
+
import { Box, Text, Tooltip } from '../';
|
|
3
|
+
import { rgb, parseToHsl, parseToRgb } from 'polished';
|
|
4
|
+
import { hexFromArgb, TonalPalette } from '@material/material-color-utilities';
|
|
5
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
7
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
8
|
+
export const ColorItem = /*#__PURE__*/memo(props => {
|
|
9
|
+
const {
|
|
10
|
+
token,
|
|
11
|
+
style,
|
|
12
|
+
height = 50,
|
|
13
|
+
width
|
|
14
|
+
} = props;
|
|
15
|
+
const [computedColor, setComputedColor] = useState();
|
|
16
|
+
const hslColor = computedColor ? parseToHsl(computedColor) : {
|
|
17
|
+
hue: 0,
|
|
18
|
+
saturation: 0,
|
|
19
|
+
lightness: 0
|
|
20
|
+
};
|
|
21
|
+
const rgbColor = computedColor ? parseToRgb(computedColor) : {
|
|
22
|
+
red: 0,
|
|
23
|
+
green: 0,
|
|
24
|
+
blue: 0
|
|
25
|
+
};
|
|
26
|
+
return /*#__PURE__*/_jsx(Tooltip, {
|
|
27
|
+
label: computedColor ? /*#__PURE__*/_jsxs(_Fragment, {
|
|
28
|
+
children: [/*#__PURE__*/_jsx("p", {
|
|
29
|
+
children: token
|
|
30
|
+
}), /*#__PURE__*/_jsx("p", {
|
|
31
|
+
children: rgb(rgbColor)
|
|
32
|
+
}), /*#__PURE__*/_jsxs("p", {
|
|
33
|
+
children: ["rgb(", rgbColor.red, ", ", rgbColor.green, ", ", rgbColor.blue, ")"]
|
|
34
|
+
}), /*#__PURE__*/_jsxs("p", {
|
|
35
|
+
children: ["hsl(", Math.round(hslColor.hue), ",", ' ', Math.round(hslColor.saturation * 100), "%,", ' ', Math.round(hslColor.lightness * 100), "%)"]
|
|
36
|
+
})]
|
|
37
|
+
}) : /*#__PURE__*/_jsx("p", {
|
|
38
|
+
children: token
|
|
39
|
+
}),
|
|
40
|
+
children: /*#__PURE__*/_jsx(Box, {
|
|
41
|
+
width: width,
|
|
42
|
+
height: height,
|
|
43
|
+
style: style,
|
|
44
|
+
pl: "10px",
|
|
45
|
+
pt: "10px",
|
|
46
|
+
ref: ref => {
|
|
47
|
+
if (ref) {
|
|
48
|
+
setComputedColor(window.getComputedStyle(ref).backgroundColor);
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
children: /*#__PURE__*/_jsx(Text, {
|
|
52
|
+
variant: "body2",
|
|
53
|
+
as: "span",
|
|
54
|
+
fontSize: "11px",
|
|
55
|
+
lineHeight: "11px",
|
|
56
|
+
children: token
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
export const ColorRow = /*#__PURE__*/memo(props => {
|
|
62
|
+
const {
|
|
63
|
+
colors,
|
|
64
|
+
height = 50
|
|
65
|
+
} = props;
|
|
66
|
+
return /*#__PURE__*/_jsx(Box, {
|
|
67
|
+
width: "100%",
|
|
68
|
+
display: "flex",
|
|
69
|
+
sx: {
|
|
70
|
+
':first-of-type': {
|
|
71
|
+
borderTopLeftRadius: 24,
|
|
72
|
+
borderTopRightRadius: 24,
|
|
73
|
+
overflow: 'hidden'
|
|
74
|
+
},
|
|
75
|
+
':last-of-type': {
|
|
76
|
+
borderBottomLeftRadius: 24,
|
|
77
|
+
borderBottomRightRadius: 24,
|
|
78
|
+
overflow: 'hidden'
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
children: colors.map(({
|
|
82
|
+
token,
|
|
83
|
+
bg,
|
|
84
|
+
color
|
|
85
|
+
}, idx) => /*#__PURE__*/_jsx(ColorItem, {
|
|
86
|
+
width: colors.length % 2 === 1 ? idx === colors.length - 1 ? '50%' : '25%' : '33.33%',
|
|
87
|
+
token: token,
|
|
88
|
+
style: {
|
|
89
|
+
backgroundColor: bg,
|
|
90
|
+
color: color
|
|
91
|
+
},
|
|
92
|
+
height: height
|
|
93
|
+
}, token))
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
export const TonalColorItem = /*#__PURE__*/memo(props => {
|
|
97
|
+
const {
|
|
98
|
+
level,
|
|
99
|
+
color
|
|
100
|
+
} = props;
|
|
101
|
+
const hslColor = parseToHsl(color);
|
|
102
|
+
const rgbColor = parseToRgb(color);
|
|
103
|
+
return /*#__PURE__*/_jsx(Tooltip, {
|
|
104
|
+
label: /*#__PURE__*/_jsxs(_Fragment, {
|
|
105
|
+
children: [/*#__PURE__*/_jsxs("p", {
|
|
106
|
+
children: ["Luminance: ", level]
|
|
107
|
+
}), /*#__PURE__*/_jsx("p", {
|
|
108
|
+
children: rgb(rgbColor)
|
|
109
|
+
}), /*#__PURE__*/_jsxs("p", {
|
|
110
|
+
children: ["rgb(", rgbColor.red, ", ", rgbColor.green, ", ", rgbColor.blue, ")"]
|
|
111
|
+
}), /*#__PURE__*/_jsxs("p", {
|
|
112
|
+
children: ["hsl(", Math.round(hslColor.hue), ",", ' ', Math.round(hslColor.saturation * 100), "%,", ' ', Math.round(hslColor.lightness * 100), "%)"]
|
|
113
|
+
})]
|
|
114
|
+
}),
|
|
115
|
+
children: /*#__PURE__*/_jsx(Box, {
|
|
116
|
+
flex: 1,
|
|
117
|
+
display: "flex",
|
|
118
|
+
alignItems: "center",
|
|
119
|
+
justifyContent: "center",
|
|
120
|
+
style: {
|
|
121
|
+
backgroundColor: color,
|
|
122
|
+
color: level <= 50 ? '#fff' : '#000'
|
|
123
|
+
},
|
|
124
|
+
children: level
|
|
125
|
+
}, level)
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
export const TonalColorsFromToken = /*#__PURE__*/memo(props => {
|
|
129
|
+
const [computedColor, setComputedColor] = useState();
|
|
130
|
+
|
|
131
|
+
if (!computedColor) {
|
|
132
|
+
return /*#__PURE__*/_jsx(Box, {
|
|
133
|
+
ref: ref => {
|
|
134
|
+
if (ref) {
|
|
135
|
+
setComputedColor(window.getComputedStyle(ref).backgroundColor);
|
|
136
|
+
}
|
|
137
|
+
},
|
|
138
|
+
bg: props.token,
|
|
139
|
+
style: {
|
|
140
|
+
position: 'fixed',
|
|
141
|
+
left: -5000,
|
|
142
|
+
top: -5000
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
const colorInt = parseInt(rgb(parseToRgb(computedColor)).slice(1), 16);
|
|
148
|
+
const tonal = TonalPalette.fromInt(colorInt);
|
|
149
|
+
return /*#__PURE__*/_jsx(TonalColors, {
|
|
150
|
+
palette: tonal
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
export const TonalColors = /*#__PURE__*/memo(props => {
|
|
154
|
+
const luminanceLevels = [0, 10, 20, 25, 30, 35, 40, 50, 60, 70, 80, 90, 95, 98, 99, 100];
|
|
155
|
+
return /*#__PURE__*/_jsx(Box, {
|
|
156
|
+
display: "flex",
|
|
157
|
+
height: "72px",
|
|
158
|
+
width: "100%",
|
|
159
|
+
children: luminanceLevels.map(level => /*#__PURE__*/_jsx(TonalColorItem, {
|
|
160
|
+
level: level,
|
|
161
|
+
color: hexFromArgb(props.palette.tone(level))
|
|
162
|
+
}, level))
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
export function makeColorArrayForToken(token) {
|
|
166
|
+
return [{
|
|
167
|
+
token,
|
|
168
|
+
bg: token,
|
|
169
|
+
color: 'on.' + token
|
|
170
|
+
}, {
|
|
171
|
+
token,
|
|
172
|
+
bg: 'on.' + token,
|
|
173
|
+
color: token
|
|
174
|
+
}, {
|
|
175
|
+
token,
|
|
176
|
+
bg: token + '-container',
|
|
177
|
+
color: 'on.' + token + '-container'
|
|
178
|
+
}, {
|
|
179
|
+
token,
|
|
180
|
+
bg: 'on.' + token + '-container',
|
|
181
|
+
color: token + '-container'
|
|
182
|
+
}];
|
|
183
|
+
}
|
|
184
|
+
//# sourceMappingURL=components.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/ThemeExplorer/components.tsx"],"names":["React","memo","useState","Box","Text","Tooltip","rgb","parseToHsl","parseToRgb","hexFromArgb","TonalPalette","ColorItem","props","token","style","height","width","computedColor","setComputedColor","hslColor","hue","saturation","lightness","rgbColor","red","green","blue","Math","round","ref","window","getComputedStyle","backgroundColor","ColorRow","colors","borderTopLeftRadius","borderTopRightRadius","overflow","borderBottomLeftRadius","borderBottomRightRadius","map","bg","color","idx","length","TonalColorItem","level","TonalColorsFromToken","position","left","top","colorInt","parseInt","slice","tonal","fromInt","TonalColors","luminanceLevels","palette","tone","makeColorArrayForToken"],"mappings":"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","sourcesContent":["import React, { memo, useState, CSSProperties } from 'react';\nimport { Box, Text, Tooltip } from '../';\nimport { rgb, parseToHsl, parseToRgb } from 'polished';\nimport { hexFromArgb, TonalPalette } from '@material/material-color-utilities';\n\nexport const ColorItem = memo(\n (props: {\n token: string;\n style: CSSProperties;\n height: number;\n width: string;\n }) => {\n const { token, style, height = 50, width } = props;\n const [computedColor, setComputedColor] = useState<string>();\n const hslColor = computedColor\n ? parseToHsl(computedColor)\n : { hue: 0, saturation: 0, lightness: 0 };\n const rgbColor = computedColor\n ? parseToRgb(computedColor)\n : { red: 0, green: 0, blue: 0 };\n return (\n <Tooltip\n label={\n computedColor ? (\n <>\n <p>{token}</p>\n <p>{rgb(rgbColor)}</p>\n <p>\n rgb({rgbColor.red}, {rgbColor.green}, {rgbColor.blue})\n </p>\n <p>\n hsl({Math.round(hslColor.hue)},{' '}\n {Math.round(hslColor.saturation * 100)}%,{' '}\n {Math.round(hslColor.lightness * 100)}%)\n </p>\n </>\n ) : (\n <p>{token}</p>\n )\n }\n >\n <Box\n width={width}\n height={height}\n style={style}\n pl=\"10px\"\n pt=\"10px\"\n ref={(ref: HTMLDivElement | null) => {\n if (ref) {\n setComputedColor(window.getComputedStyle(ref).backgroundColor);\n }\n }}\n >\n <Text variant=\"body2\" as=\"span\" fontSize=\"11px\" lineHeight=\"11px\">\n {token}\n </Text>\n </Box>\n </Tooltip>\n );\n }\n);\n\nexport const ColorRow = memo(\n (props: {\n colors: { token: string; bg: string; color: string }[];\n height?: number;\n }) => {\n const { colors, height = 50 } = props;\n return (\n <Box\n width=\"100%\"\n display=\"flex\"\n sx={{\n ':first-of-type': {\n borderTopLeftRadius: 24,\n borderTopRightRadius: 24,\n overflow: 'hidden',\n },\n ':last-of-type': {\n borderBottomLeftRadius: 24,\n borderBottomRightRadius: 24,\n overflow: 'hidden',\n },\n }}\n >\n {colors.map(({ token, bg, color }, idx) => (\n <ColorItem\n width={\n colors.length % 2 === 1\n ? idx === colors.length - 1\n ? '50%'\n : '25%'\n : '33.33%'\n }\n key={token}\n token={token}\n style={{ backgroundColor: bg, color: color }}\n height={height}\n />\n ))}\n </Box>\n );\n }\n);\n\nexport const TonalColorItem = memo(\n (props: { color: string; level: number }) => {\n const { level, color } = props;\n const hslColor = parseToHsl(color);\n const rgbColor = parseToRgb(color);\n return (\n <Tooltip\n label={\n <>\n <p>Luminance: {level}</p>\n <p>{rgb(rgbColor)}</p>\n <p>\n rgb({rgbColor.red}, {rgbColor.green}, {rgbColor.blue})\n </p>\n <p>\n hsl({Math.round(hslColor.hue)},{' '}\n {Math.round(hslColor.saturation * 100)}%,{' '}\n {Math.round(hslColor.lightness * 100)}%)\n </p>\n </>\n }\n >\n <Box\n key={level}\n flex={1}\n display=\"flex\"\n alignItems=\"center\"\n justifyContent=\"center\"\n style={{\n backgroundColor: color,\n color: level <= 50 ? '#fff' : '#000',\n }}\n >\n {level}\n </Box>\n </Tooltip>\n );\n }\n);\n\nexport const TonalColorsFromToken = memo((props: { token: string }) => {\n const [computedColor, setComputedColor] = useState<string>();\n if (!computedColor) {\n return (\n <Box\n ref={(ref: HTMLDivElement | null) => {\n if (ref) {\n setComputedColor(window.getComputedStyle(ref).backgroundColor);\n }\n }}\n bg={props.token}\n style={{ position: 'fixed', left: -5000, top: -5000 }}\n />\n );\n }\n const colorInt = parseInt(rgb(parseToRgb(computedColor)).slice(1), 16);\n const tonal = TonalPalette.fromInt(colorInt);\n\n return <TonalColors palette={tonal} />;\n});\n\nexport const TonalColors = memo((props: { palette: TonalPalette }) => {\n const luminanceLevels = [\n 0,\n 10,\n 20,\n 25,\n 30,\n 35,\n 40,\n 50,\n 60,\n 70,\n 80,\n 90,\n 95,\n 98,\n 99,\n 100,\n ];\n return (\n <Box display=\"flex\" height=\"72px\" width=\"100%\">\n {luminanceLevels.map((level) => (\n <TonalColorItem\n key={level}\n level={level}\n color={hexFromArgb(props.palette.tone(level))}\n />\n ))}\n </Box>\n );\n});\n\nexport function makeColorArrayForToken(\n token: string\n): { token: string; bg: string; color: string }[] {\n return [\n { token, bg: token, color: 'on.' + token },\n { token, bg: 'on.' + token, color: token },\n { token, bg: token + '-container', color: 'on.' + token + '-container' },\n { token, bg: 'on.' + token + '-container', color: token + '-container' },\n ];\n}\n"],"file":"components.js"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { TonalPalette } from '@material/material-color-utilities';
|
|
2
|
+
export declare function makeColorScheme(opts: {
|
|
3
|
+
primary: TonalPalette;
|
|
4
|
+
secondary: TonalPalette;
|
|
5
|
+
tertiary: TonalPalette;
|
|
6
|
+
error: TonalPalette;
|
|
7
|
+
neutral: TonalPalette;
|
|
8
|
+
neutralVariant: TonalPalette;
|
|
9
|
+
}): {
|
|
10
|
+
primary: string;
|
|
11
|
+
secondary: string;
|
|
12
|
+
tertiary: string;
|
|
13
|
+
error: string;
|
|
14
|
+
'primary-container': string;
|
|
15
|
+
'secondary-container': string;
|
|
16
|
+
'tertiary-container': string;
|
|
17
|
+
'error-container': string;
|
|
18
|
+
background: string;
|
|
19
|
+
surface: string;
|
|
20
|
+
'surface-variant': string;
|
|
21
|
+
outline: string;
|
|
22
|
+
on: {
|
|
23
|
+
primary: string;
|
|
24
|
+
secondary: string;
|
|
25
|
+
tertiary: string;
|
|
26
|
+
error: string;
|
|
27
|
+
'primary-container': string;
|
|
28
|
+
'secondary-container': string;
|
|
29
|
+
'tertiary-container': string;
|
|
30
|
+
'error-container': string;
|
|
31
|
+
background: string;
|
|
32
|
+
surface: string;
|
|
33
|
+
'surface-variant': string;
|
|
34
|
+
outline: string;
|
|
35
|
+
};
|
|
36
|
+
modes: {
|
|
37
|
+
dark: {
|
|
38
|
+
primary: string;
|
|
39
|
+
secondary: string;
|
|
40
|
+
tertiary: string;
|
|
41
|
+
error: string;
|
|
42
|
+
'primary-container': string;
|
|
43
|
+
'secondary-container': string;
|
|
44
|
+
'tertiary-container': string;
|
|
45
|
+
'error-container': string;
|
|
46
|
+
background: string;
|
|
47
|
+
surface: string;
|
|
48
|
+
'surface-variant': string;
|
|
49
|
+
outline: string;
|
|
50
|
+
on: {
|
|
51
|
+
primary: string;
|
|
52
|
+
secondary: string;
|
|
53
|
+
tertiary: string;
|
|
54
|
+
error: string;
|
|
55
|
+
'primary-container': string;
|
|
56
|
+
'secondary-container': string;
|
|
57
|
+
'tertiary-container': string;
|
|
58
|
+
'error-container': string;
|
|
59
|
+
background: string;
|
|
60
|
+
surface: string;
|
|
61
|
+
'surface-variant': string;
|
|
62
|
+
outline: string;
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
};
|
|
66
|
+
};
|