antd
Version:
An enterprise-class UI design language and React components implementation
94 lines (93 loc) • 3.49 kB
JavaScript
"use client";
import React, { useMemo } from 'react';
import { ColorBlock, Color as RcColor } from '@rc-component/color-picker';
import classNames from 'classnames';
import useMergedState from "rc-util/es/hooks/useMergedState";
import Collapse from '../../collapse';
import { useLocale } from '../../locale';
import { useToken } from '../../theme/internal';
import { generateColor } from '../util';
const genPresetColor = list => list.map(value => {
value.colors = value.colors.map(generateColor);
return value;
});
export const isBright = (value, bgColorToken) => {
const {
r,
g,
b,
a
} = value.toRgb();
const hsv = new RcColor(value.toRgbString()).onBackground(bgColorToken).toHsv();
if (a <= 0.5) {
// Adapted to dark mode
return hsv.v > 0.5;
}
return r * 0.299 + g * 0.587 + b * 0.114 > 192;
};
const genCollapsePanelKey = (preset, index) => {
var _a;
const mergedKey = (_a = preset.key) !== null && _a !== void 0 ? _a : index;
return `panel-${mergedKey}`;
};
const ColorPresets = _ref => {
let {
prefixCls,
presets,
value: color,
onChange
} = _ref;
const [locale] = useLocale('ColorPicker');
const [, token] = useToken();
const [presetsValue] = useMergedState(genPresetColor(presets), {
value: genPresetColor(presets),
postState: genPresetColor
});
const colorPresetsPrefixCls = `${prefixCls}-presets`;
const activeKeys = useMemo(() => presetsValue.reduce((acc, preset, index) => {
const {
defaultOpen = true
} = preset;
if (defaultOpen) {
acc.push(genCollapsePanelKey(preset, index));
}
return acc;
}, []), [presetsValue]);
const handleClick = colorValue => {
onChange === null || onChange === void 0 ? void 0 : onChange(colorValue);
};
const items = presetsValue.map((preset, index) => {
var _a;
return {
key: genCollapsePanelKey(preset, index),
label: /*#__PURE__*/React.createElement("div", {
className: `${colorPresetsPrefixCls}-label`
}, preset === null || preset === void 0 ? void 0 : preset.label),
children: (/*#__PURE__*/React.createElement("div", {
className: `${colorPresetsPrefixCls}-items`
}, Array.isArray(preset === null || preset === void 0 ? void 0 : preset.colors) && ((_a = preset.colors) === null || _a === void 0 ? void 0 : _a.length) > 0 ? preset.colors.map((presetColor, index) => (/*#__PURE__*/React.createElement(ColorBlock
// eslint-disable-next-line react/no-array-index-key
, {
// eslint-disable-next-line react/no-array-index-key
key: `preset-${index}-${presetColor.toHexString()}`,
color: generateColor(presetColor).toRgbString(),
prefixCls: prefixCls,
className: classNames(`${colorPresetsPrefixCls}-color`, {
[`${colorPresetsPrefixCls}-color-checked`]: presetColor.toHexString() === (color === null || color === void 0 ? void 0 : color.toHexString()),
[`${colorPresetsPrefixCls}-color-bright`]: isBright(presetColor, token.colorBgElevated)
}),
onClick: () => handleClick(presetColor)
}))) : (/*#__PURE__*/React.createElement("span", {
className: `${colorPresetsPrefixCls}-empty`
}, locale.presetEmpty))))
};
});
return /*#__PURE__*/React.createElement("div", {
className: colorPresetsPrefixCls
}, /*#__PURE__*/React.createElement(Collapse, {
defaultActiveKey: activeKeys,
ghost: true,
items: items
}));
};
export default ColorPresets;