antd
Version:
An enterprise-class UI design language and React components implementation
71 lines (70 loc) • 3.2 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"];
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = renderSwitcherIcon;
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _CaretDownFilled = _interopRequireDefault(require("@ant-design/icons/CaretDownFilled"));
var _FileOutlined = _interopRequireDefault(require("@ant-design/icons/FileOutlined"));
var _LoadingOutlined = _interopRequireDefault(require("@ant-design/icons/LoadingOutlined"));
var _MinusSquareOutlined = _interopRequireDefault(require("@ant-design/icons/MinusSquareOutlined"));
var _PlusSquareOutlined = _interopRequireDefault(require("@ant-design/icons/PlusSquareOutlined"));
var _classnames = _interopRequireDefault(require("classnames"));
var React = _interopRequireWildcard(require("react"));
var _reactNode = require("../../_util/reactNode");
function renderSwitcherIcon(prefixCls, switcherIcon, showLine, treeNodeProps) {
var isLeaf = treeNodeProps.isLeaf,
expanded = treeNodeProps.expanded,
loading = treeNodeProps.loading;
if (loading) {
return /*#__PURE__*/React.createElement(_LoadingOutlined["default"], {
className: "".concat(prefixCls, "-switcher-loading-icon")
});
}
var showLeafIcon;
if (showLine && (0, _typeof2["default"])(showLine) === 'object') {
showLeafIcon = showLine.showLeafIcon;
}
if (isLeaf) {
if (!showLine) {
return null;
}
if (typeof showLeafIcon !== 'boolean' && !!showLeafIcon) {
var leafIcon = typeof showLeafIcon === 'function' ? showLeafIcon(treeNodeProps) : showLeafIcon;
var leafCls = "".concat(prefixCls, "-switcher-line-custom-icon");
if ((0, _reactNode.isValidElement)(leafIcon)) {
return (0, _reactNode.cloneElement)(leafIcon, {
className: (0, _classnames["default"])(leafIcon.props.className || '', leafCls)
});
}
return leafIcon;
}
return showLeafIcon ? ( /*#__PURE__*/React.createElement(_FileOutlined["default"], {
className: "".concat(prefixCls, "-switcher-line-icon")
})) : ( /*#__PURE__*/React.createElement("span", {
className: "".concat(prefixCls, "-switcher-leaf-line")
}));
}
var switcherCls = "".concat(prefixCls, "-switcher-icon");
var switcher = typeof switcherIcon === 'function' ? switcherIcon(treeNodeProps) : switcherIcon;
if ((0, _reactNode.isValidElement)(switcher)) {
return (0, _reactNode.cloneElement)(switcher, {
className: (0, _classnames["default"])(switcher.props.className || '', switcherCls)
});
}
if (switcher) {
return switcher;
}
if (showLine) {
return expanded ? ( /*#__PURE__*/React.createElement(_MinusSquareOutlined["default"], {
className: "".concat(prefixCls, "-switcher-line-icon")
})) : ( /*#__PURE__*/React.createElement(_PlusSquareOutlined["default"], {
className: "".concat(prefixCls, "-switcher-line-icon")
}));
}
return /*#__PURE__*/React.createElement(_CaretDownFilled["default"], {
className: switcherCls
});
}