You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
2.5 KiB
64 lines
2.5 KiB
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
import * as React from 'react';
|
|
import classNames from 'classnames';
|
|
import DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined";
|
|
import defaultLocale from '../locale/default';
|
|
import Checkbox from '../checkbox';
|
|
import TransButton from '../_util/transButton';
|
|
import LocaleReceiver from '../locale-provider/LocaleReceiver';
|
|
|
|
var ListItem = function ListItem(props) {
|
|
var _classNames;
|
|
|
|
var renderedText = props.renderedText,
|
|
renderedEl = props.renderedEl,
|
|
item = props.item,
|
|
checked = props.checked,
|
|
disabled = props.disabled,
|
|
prefixCls = props.prefixCls,
|
|
onClick = props.onClick,
|
|
onRemove = props.onRemove,
|
|
showRemove = props.showRemove;
|
|
var className = classNames((_classNames = {}, _defineProperty(_classNames, "".concat(prefixCls, "-content-item"), true), _defineProperty(_classNames, "".concat(prefixCls, "-content-item-disabled"), disabled || item.disabled), _defineProperty(_classNames, "".concat(prefixCls, "-content-item-checked"), checked), _classNames));
|
|
var title;
|
|
|
|
if (typeof renderedText === 'string' || typeof renderedText === 'number') {
|
|
title = String(renderedText);
|
|
}
|
|
|
|
return /*#__PURE__*/React.createElement(LocaleReceiver, {
|
|
componentName: "Transfer",
|
|
defaultLocale: defaultLocale.Transfer
|
|
}, function (transferLocale) {
|
|
var liProps = {
|
|
className: className,
|
|
title: title
|
|
};
|
|
var labelNode = /*#__PURE__*/React.createElement("span", {
|
|
className: "".concat(prefixCls, "-content-item-text")
|
|
}, renderedEl); // Show remove
|
|
|
|
if (showRemove) {
|
|
return /*#__PURE__*/React.createElement("li", liProps, labelNode, /*#__PURE__*/React.createElement(TransButton, {
|
|
disabled: disabled || item.disabled,
|
|
className: "".concat(prefixCls, "-content-item-remove"),
|
|
"aria-label": transferLocale.remove,
|
|
onClick: function onClick() {
|
|
onRemove === null || onRemove === void 0 ? void 0 : onRemove(item);
|
|
}
|
|
}, /*#__PURE__*/React.createElement(DeleteOutlined, null)));
|
|
} // Default click to select
|
|
|
|
|
|
liProps.onClick = disabled || item.disabled ? undefined : function () {
|
|
return onClick(item);
|
|
};
|
|
return /*#__PURE__*/React.createElement("li", liProps, /*#__PURE__*/React.createElement(Checkbox, {
|
|
className: "".concat(prefixCls, "-checkbox"),
|
|
checked: checked,
|
|
disabled: disabled || item.disabled
|
|
}), labelNode);
|
|
});
|
|
};
|
|
|
|
export default /*#__PURE__*/React.memo(ListItem); |