2023-05-19 17:44:27 +08:00
|
|
|
import type { HsbaColorType } from '@rc-component/color-picker';
|
2023-05-18 13:34:06 +08:00
|
|
|
import RcColorPicker from '@rc-component/color-picker';
|
2023-05-12 14:43:48 +08:00
|
|
|
import type { FC } from 'react';
|
|
|
|
import React from 'react';
|
|
|
|
import Divider from '../divider';
|
|
|
|
import type { Color } from './color';
|
|
|
|
import ColorClear from './components/ColorClear';
|
|
|
|
import ColorInput from './components/ColorInput';
|
|
|
|
import ColorPresets from './components/ColorPresets';
|
|
|
|
import type { ColorPickerBaseProps } from './interface';
|
|
|
|
|
|
|
|
interface ColorPickerPanelProps extends ColorPickerBaseProps {
|
2023-05-29 16:50:12 +08:00
|
|
|
onChange?: (value?: Color, type?: HsbaColorType, pickColor?: boolean) => void;
|
|
|
|
onChangeComplete?: (type?: HsbaColorType) => void;
|
2023-05-26 15:19:34 +08:00
|
|
|
onClear?: () => void;
|
2023-05-12 14:43:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const ColorPickerPanel: FC<ColorPickerPanelProps> = (props) => {
|
2023-05-29 16:50:12 +08:00
|
|
|
const {
|
|
|
|
prefixCls,
|
|
|
|
allowClear,
|
|
|
|
presets,
|
|
|
|
onChange,
|
|
|
|
onClear,
|
|
|
|
onChangeComplete,
|
|
|
|
color,
|
2023-06-07 10:25:59 +08:00
|
|
|
colorCleared,
|
2023-05-29 16:50:12 +08:00
|
|
|
...injectProps
|
|
|
|
} = props;
|
2023-05-12 14:43:48 +08:00
|
|
|
const colorPickerPanelPrefixCls = `${prefixCls}-inner-panel`;
|
|
|
|
|
2023-05-13 17:34:09 +08:00
|
|
|
const extraPanelRender = (panel: React.ReactNode) => (
|
2023-05-12 14:43:48 +08:00
|
|
|
<div className={colorPickerPanelPrefixCls}>
|
|
|
|
{allowClear && (
|
|
|
|
<ColorClear
|
|
|
|
prefixCls={prefixCls}
|
|
|
|
value={color}
|
2023-06-07 10:25:59 +08:00
|
|
|
colorCleared={colorCleared}
|
2023-05-12 14:43:48 +08:00
|
|
|
onChange={(clearColor) => {
|
|
|
|
onChange?.(clearColor);
|
2023-05-26 15:19:34 +08:00
|
|
|
onClear?.();
|
2023-05-12 14:43:48 +08:00
|
|
|
}}
|
|
|
|
{...injectProps}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
{panel}
|
2023-05-13 23:05:26 +08:00
|
|
|
<ColorInput value={color} onChange={onChange} prefixCls={prefixCls} {...injectProps} />
|
2023-05-12 14:43:48 +08:00
|
|
|
{Array.isArray(presets) && (
|
|
|
|
<>
|
|
|
|
<Divider className={`${colorPickerPanelPrefixCls}-divider`} />
|
2023-05-13 23:05:26 +08:00
|
|
|
<ColorPresets value={color} presets={presets} prefixCls={prefixCls} onChange={onChange} />
|
2023-05-12 14:43:48 +08:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
return (
|
2023-05-18 13:34:06 +08:00
|
|
|
<RcColorPicker
|
2023-05-12 14:43:48 +08:00
|
|
|
prefixCls={prefixCls}
|
|
|
|
value={color?.toHsb()}
|
2023-05-29 16:50:12 +08:00
|
|
|
onChange={(colorValue, type) => onChange?.(colorValue, type, true)}
|
2023-05-12 14:43:48 +08:00
|
|
|
panelRender={extraPanelRender}
|
2023-05-29 16:50:12 +08:00
|
|
|
onChangeComplete={onChangeComplete}
|
2023-05-12 14:43:48 +08:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
2023-05-13 23:05:26 +08:00
|
|
|
|
|
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
|
|
ColorPickerPanel.displayName = 'ColorPickerPanel';
|
|
|
|
}
|
|
|
|
|
2023-05-12 14:43:48 +08:00
|
|
|
export default ColorPickerPanel;
|