tdesign-react
Version:
TDesign Component for React
143 lines (135 loc) • 6.13 kB
JavaScript
/**
* tdesign v1.13.2
* (c) 2025 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var classNames = require('classnames');
var tdesignIconsReact = require('tdesign-icons-react');
var color = require('../../../_chunks/dep-3f53c7e2.js');
var hooks_useGlobalIcon = require('../../../hooks/useGlobalIcon.js');
var hooks_useCommonClassName = require('../../../hooks/useCommonClassName.js');
require('../../../_chunks/dep-e17e2d31.js');
require('../../../_chunks/dep-b7d577ac.js');
require('../../../_chunks/dep-5ad10091.js');
require('../../../_chunks/dep-cc768e34.js');
require('../../../_chunks/dep-6d4d8660.js');
require('../../../_chunks/dep-7bc521fe.js');
require('../../../_chunks/dep-11227668.js');
require('../../../_chunks/dep-3e2d2665.js');
require('../../../_chunks/dep-f0379c5f.js');
require('../../../_chunks/dep-028b759d.js');
require('../../../_chunks/dep-ddacd27a.js');
require('../../../_chunks/dep-4cdd0807.js');
require('../../../hooks/useConfig.js');
require('../../../config-provider/ConfigContext.js');
require('../../../_chunks/dep-3a869b87.js');
require('../../../_chunks/dep-ac58e1cc.js');
require('dayjs');
require('../../../_chunks/dep-7da96a57.js');
require('../../../_chunks/dep-07b911d8.js');
require('../../../_chunks/dep-4b02d669.js');
require('../../../_chunks/dep-8a116183.js');
require('../../../_chunks/dep-4671b9bd.js');
require('../../../_chunks/dep-bed9d73e.js');
require('../../../_chunks/dep-780eda7b.js');
require('../../../_chunks/dep-47bdc05f.js');
require('../../../_chunks/dep-cab13149.js');
require('../../../_chunks/dep-a30819a4.js');
require('../../../_chunks/dep-6a7ba247.js');
require('../../../_chunks/dep-c87d9752.js');
require('../../../_chunks/dep-bd956a2d.js');
require('../../../_chunks/dep-0cdb3286.js');
require('../../../_chunks/dep-865c186c.js');
require('../../../_chunks/dep-f4e58639.js');
require('../../../_chunks/dep-781a2854.js');
require('../../../_chunks/dep-1ef213f8.js');
require('../../../_chunks/dep-e2c832a5.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames);
var Swatches = function Swatches(props) {
var baseClassName = props.baseClassName,
_props$colors = props.colors,
colors = _props$colors === void 0 ? [] : _props$colors,
_props$editable = props.editable,
editable = _props$editable === void 0 ? false : _props$editable,
title = props.title,
onChange = props.onChange,
disabled = props.disabled,
onSetColor = props.onSetColor,
handleAddColor = props.handleAddColor;
var _useGlobalIcon = hooks_useGlobalIcon["default"]({
DeleteIcon: tdesignIconsReact.DeleteIcon,
AddIcon: tdesignIconsReact.AddIcon
}),
DeleteIcon = _useGlobalIcon.DeleteIcon,
AddIcon = _useGlobalIcon.AddIcon;
var swatchesClass = "".concat(baseClassName, "__swatches");
var _useCommonClassName = hooks_useCommonClassName["default"](),
statusClassNames = _useCommonClassName.STATUS;
var isEqualCurrentColor = function isEqualCurrentColor(color$1) {
return color.Color.compare(color$1, props.color.css);
};
var selectedColorIndex = function selectedColorIndex() {
return colors.findIndex(function (color) {
return isEqualCurrentColor(color);
});
};
var handleRemoveColor = function handleRemoveColor() {
var selectedIndex = selectedColorIndex();
if (selectedIndex > -1) {
var newColors = colors.filter(function (item, index) {
return index !== selectedIndex;
});
onChange(newColors);
}
};
var handleClick = function handleClick(color) {
return onSetColor(color);
};
return /* @__PURE__ */React__default["default"].createElement("div", {
className: swatchesClass
}, title ? /* @__PURE__ */React__default["default"].createElement("h3", {
className: "".concat(swatchesClass, "--title")
}, /* @__PURE__ */React__default["default"].createElement("span", null, title), editable && /* @__PURE__ */React__default["default"].createElement("div", {
className: "".concat(swatchesClass, "--actions")
}, /* @__PURE__ */React__default["default"].createElement("span", {
role: "button",
className: "".concat(baseClassName, "__icon"),
onClick: function onClick() {
return handleAddColor();
}
}, /* @__PURE__ */React__default["default"].createElement(AddIcon, null)), colors.length > 0 ? /* @__PURE__ */React__default["default"].createElement("span", {
role: "button",
className: "".concat(baseClassName, "__icon"),
onClick: function onClick() {
return handleRemoveColor();
}
}, /* @__PURE__ */React__default["default"].createElement(DeleteIcon, null)) : null)) : /* @__PURE__ */React__default["default"].createElement(React__default["default"].Fragment, null), /* @__PURE__ */React__default["default"].createElement("ul", {
className: classNames__default["default"]("".concat(swatchesClass, "--items"), "narrow-scrollbar")
}, colors.map(function (color) {
return /* @__PURE__ */React__default["default"].createElement("li", {
className: classNames__default["default"]("".concat(swatchesClass, "--item"), isEqualCurrentColor(color) && editable ? statusClassNames.active : ""),
key: color,
onClick: function onClick() {
if (disabled) {
return;
}
handleClick(color);
}
}, /* @__PURE__ */React__default["default"].createElement("div", {
className: classNames__default["default"]("".concat(swatchesClass, "--item__color"), "".concat(baseClassName, "--bg-alpha"))
}, /* @__PURE__ */React__default["default"].createElement("span", {
className: "".concat(swatchesClass, "--item__inner"),
style: {
background: color
}
})));
})));
};
var SwatchesPanel = /*#__PURE__*/React__default["default"].memo(Swatches);
exports["default"] = SwatchesPanel;
//# sourceMappingURL=swatches.js.map