UNPKG

adui

Version:

<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>

796 lines (795 loc) 127 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var React = _interopRequireWildcard(require("react")); var _rcTreeSelect = _interopRequireWildcard(require("rc-tree-select")); var _propTypes = _interopRequireDefault(require("prop-types")); var _shallowequal = _interopRequireDefault(require("shallowequal")); var _classnames = _interopRequireDefault(require("classnames")); var _toArray = _interopRequireDefault(require("rc-util/lib/Children/toArray")); var _omit = _interopRequireDefault(require("../_util/omit")); var _configProvider = require("../config-provider"); var _checkbox = _interopRequireDefault(require("../checkbox")); var _icon = _interopRequireDefault(require("../icon")); var _popover = _interopRequireDefault(require("../popover")); var _portal = _interopRequireDefault(require("../portal")); var _spinner = _interopRequireDefault(require("../spinner")); require("./style"); var _excluded = ["children", "value", "popover", "popoverProps", "title"], _excluded2 = ["autoClearSearchValue", "bottomContent", "children", "className", "filterTreeNode", "getPopupContainer", "intent", "maxTagCount", "multiple", "onDropdownVisibleChange", "placeholder", "rightIcon", "resultRender", "resultVisible", "sameValueEnabled", "selectAll", "showCheckedStrategy", "topContent", "treeData"]; function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; } function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } var prefix = "adui-tree-select"; var sameValueSplitter = "__@@__"; var noop = function noop() {}; var strategies = { "show-all": _rcTreeSelect.SHOW_ALL, "show-child": _rcTreeSelect.SHOW_CHILD, "show-parent": _rcTreeSelect.SHOW_PARENT }; var isArrayIncludes = function isArrayIncludes(a1, a2) { if (!Array.isArray(a1) || !Array.isArray(a2)) { return false; } return a2.every(function (o) { return a1.includes(o); }); }; var TreeSelect = function (_React$Component) { function TreeSelect(props) { var _this; _classCallCheck(this, TreeSelect); _this = _callSuper(this, TreeSelect, [props]); _this.select = void 0; _this.portal = void 0; _this.wrapper = void 0; _this.treeData = void 0; _this.treeValueAll = void 0; _this.treeValueFlatten = []; _this.shouldComponentUpdate = function (nextProps, nextState) { return !(0, _shallowequal["default"])(_this.props, nextProps) || !(0, _shallowequal["default"])(_this.state, nextState); }; _this.saveSelect = function (node) { _this.select = node; }; _this.saveWrapper = function (node) { _this.wrapper = node; }; _this.renderSwitcherIcon = function (_ref) { var isLeaf = _ref.isLeaf, loading = _ref.loading; if (loading) { return React.createElement(_spinner["default"], { size: "mini", className: "".concat(prefix, "-tree-switcher-icon") }); } if (isLeaf) { return null; } return React.createElement(_icon["default"], { icon: "triangle-right", className: "".concat(prefix, "-tree-switcher-icon") }); }; _this.handleVisibleChange = function (visible) { setTimeout(function () { _this.forceUpdate(function () { var _this$props = _this.props, bottomContent = _this$props.bottomContent, topContent = _this$props.topContent; var _this$state = _this.state, hash = _this$state.hash, bottomContentPortalTarget = _this$state.bottomContentPortalTarget, topContentPortalTarget = _this$state.topContentPortalTarget; if (visible && (topContent && !topContentPortalTarget || bottomContent && !bottomContentPortalTarget)) { var dropdown = document.querySelector(".".concat(prefix, "-dropdown_").concat(hash)); if (dropdown) { if (topContent && !topContentPortalTarget) { var el = document.createElement("div"); el.onmousedown = function (e) { e.preventDefault(); e.stopImmediatePropagation(); }; dropdown.insertBefore(el, dropdown.children[0]); _this.setState({ topContentPortalTarget: el }); } if (bottomContent && !bottomContentPortalTarget) { var _el = document.createElement("div"); _el.onmousedown = function (e) { e.preventDefault(); e.stopImmediatePropagation(); }; dropdown.appendChild(_el); _this.setState({ bottomContentPortalTarget: _el }); } } } }); }, 0); }; _this.handleChange = function (value, titleList) { var valueParam = []; var _this$props2 = _this.props, disabled = _this$props2.disabled, multiple = _this$props2.multiple, onChange = _this$props2.onChange, valueProp = _this$props2.value, sameValueEnabled = _this$props2.sameValueEnabled; var valueState = _this.state.value; if (!disabled) { if (sameValueEnabled) { value === null || value === void 0 || value.forEach(function (v) { var splited = "".concat(v).split(sameValueSplitter); var val = splited[splited.length - 1]; var _value$filter = value.filter(function (o) { return "".concat(o).endsWith("".concat(sameValueSplitter).concat(val)); }), length = _value$filter.length; if (length === _this.treeValueFlatten.filter(function (o) { return "".concat(o).endsWith("".concat(sameValueSplitter).concat(val)); }).length) { valueParam.push(val); } else if (!(valueState !== null && valueState !== void 0 && valueState.includes(val))) { valueParam.push(val); } }); } else if (value) { valueParam = value; } if (multiple) { valueParam = _toConsumableArray(new Set(valueParam)); } if (valueProp === null) { _this.setState({ value: valueParam }); } if (onChange) { onChange(valueParam, titleList); } } }; _this.getFilteredTreeData = function (searchValue) { var filterTreeNode = _this.props.filterTreeNode; if (!searchValue || filterTreeNode === false) { return _this.treeData; } var filterOptionFunc; if (typeof filterTreeNode === "function") { filterOptionFunc = filterTreeNode; } else { filterOptionFunc = _this.filterTreeNode; } var _dig = function dig(list) { var keepAll = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; return list.map(function (dataNode) { var children = dataNode.children; var match = keepAll || filterOptionFunc && filterOptionFunc(searchValue, dataNode); var childList = _dig(children || [], match); if (match || childList.length) { return _objectSpread(_objectSpread({}, dataNode), {}, { children: childList }); } return null; }).filter(function (node) { return node; }); }; return _dig(_this.treeData); }; _this.handleSearch = function (val) { var onSearch = _this.props.onSearch; if (onSearch) { onSearch(val, _this.getFilteredTreeData(val)); setTimeout(function () { _this.forceUpdate(); }, 0); } }; _this.filterTreeNode = function (input, treeNode) { var filterCaseSensitive = _this.props.filterCaseSensitive; var key = treeNode.key, title = treeNode.title, value = treeNode.value, dataTitle = treeNode.dataTitle; if (!key || !value) { return false; } if (!filterCaseSensitive) { return String(dataTitle || title).toLocaleLowerCase().includes(input.toLocaleLowerCase()); } return String(dataTitle || title).includes(input); }; _this.getMaxTagCount = function () { var maxTagCount = _this.props.maxTagCount; var value = _this.state.value; if (!maxTagCount || !value || value.length <= maxTagCount) { return null; } return 0; }; _this.handleSelectAll = function () { var _this$props3 = _this.props, valueProp = _this$props3.value, onChange = _this$props3.onChange; var value = _this.state.value; if (isArrayIncludes(value || [], _this.treeValueAll)) { if (valueProp === null) { _this.setState({ value: [] }); } if (onChange) { onChange([], []); } } else { if (valueProp === null) { _this.setState({ value: _this.treeValueAll }); } if (onChange) { onChange(_this.treeValueAll, []); } } }; _this.getMaxTagPlaceholder = function (nodes) { var _nodes$; if (!_this.select) { return null; } var _this$props4 = _this.props, onChange = _this$props4.onChange, resultRender = _this$props4.resultRender, value = _this$props4.value, disabledProp = _this$props4.disabled; if (resultRender) { return resultRender(nodes); } var length = nodes.length; var placeholderText = React.createElement(React.Fragment, null, React.createElement("span", { style: { display: "inline-block", verticalAlign: "top", maxWidth: "calc(100% - 53px)", overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" } }, (_nodes$ = nodes[0]) === null || _nodes$ === void 0 ? void 0 : _nodes$.label), React.createElement("span", { style: { display: "inline-block", verticalAlign: "top" } }, "\u7B49 ", length, " \u4E2A")); return React.createElement(_popover["default"], { visible: disabledProp ? false : undefined, alignEdge: false, placement: "top", popup: React.createElement("div", { role: "none", className: "".concat(prefix, "-max-popover-item-wrapper"), onMouseDown: function onMouseDown(e) { return e.stopPropagation(); } }, nodes.map(function (_ref2, i) { var key = _ref2.key, disabled = _ref2.disabled, label = _ref2.label; return React.createElement("div", { className: "".concat(prefix, "-max-popover-item"), key: key }, React.createElement("span", null, label), !disabled && React.createElement(_icon["default"], { icon: "cancel", onClick: function onClick() { var vals = nodes.map(function (o) { return o.value; }); vals.splice(i, 1); if (value === null) { _this.setState({ value: vals }); } var labels = nodes.map(function (o) { return o.label; }); labels.splice(i, 1); if (onChange) { onChange(vals, labels); } } })); })), popupClassName: "".concat(prefix, "-maxPopover") }, React.createElement("div", { className: "".concat(prefix, "-maxPlaceholder"), role: "none", onClick: function onClick(e) { return e.stopPropagation(); } }, placeholderText, React.createElement(_icon["default"], { icon: "cancel", size: 14, onClick: function onClick() { if (!disabledProp) { if (value === null) { _this.setState({ value: [] }); } if (onChange) { onChange([], []); } } } }))); }; _this.convertChildrenToData = function (nodes) { return (0, _toArray["default"])(nodes).map(function (node) { if (!React.isValidElement(node) || !node.type) { return null; } var _ref3 = node, key = _ref3.key, _ref3$props = _ref3.props, children = _ref3$props.children, value = _ref3$props.value, popover = _ref3$props.popover, popoverProps = _ref3$props.popoverProps, title = _ref3$props.title, restProps = _objectWithoutProperties(_ref3$props, _excluded); var data = _objectSpread({ key: key, value: value, dataTitle: title, title: popover ? React.createElement(React.Fragment, null, React.createElement("div", { className: "".concat(prefix, "-pop-trigger") }, title), React.createElement(_popover["default"], _extends({ popup: popover, placement: "right" }, popoverProps), React.createElement("div", { className: "".concat(prefix, "-pop-trigger-placeholder") }))) : title }, restProps); var childData = _this.convertChildrenToData(children); if (childData.length) { data.children = childData; } return data; }).filter(function (data) { return data; }); }; _this.convertTreeData = function (dataNodeParam) { var _dataNode$, _dataNode$2; var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var sameValueEnabled = _this.props.sameValueEnabled; if (!dataNodeParam) { return undefined; } var dataNode = _toConsumableArray(dataNodeParam); var valueState = _this.state.value; var isAllSelected = isArrayIncludes(valueState || [], _this.treeValueAll); var indeterminate = !isAllSelected && !!(valueState !== null && valueState !== void 0 && valueState.length); if (((_dataNode$ = dataNode[0]) === null || _dataNode$ === void 0 ? void 0 : _dataNode$.key) === "".concat(prefix, "-tree-treenode-all")) { return dataNode; } if (sameValueEnabled && !((_dataNode$2 = dataNode[0]) !== null && _dataNode$2 !== void 0 && _dataNode$2.dataTitle)) { _this.treeValueFlatten = []; } var selectAll = options.selectAll; var _process = function process(node, parentValue) { node.forEach(function (o) { var children = o.children, key = o.key, title = o.title, dataChildren = o.dataChildren, dataTitle = o.dataTitle, value = o.value, popover = o.popover, _o$popoverProps = o.popoverProps, popoverProps = _o$popoverProps === void 0 ? {} : _o$popoverProps; if (dataTitle && dataChildren) { return; } if (title && !dataTitle) { o.dataTitle = title; } if (children !== null && children !== void 0 && children.length) { o.dataChildren = 1; } if (key === undefined) { o.key = value; } else if (value === undefined) { o.value = key; } if (sameValueEnabled) { var newVal = "".concat(parentValue ? "".concat(parentValue).concat(sameValueSplitter) : "").concat(value); o.key = newVal; o.value = newVal; if (!_this.treeValueFlatten.includes(newVal)) { _this.treeValueFlatten.push(newVal); } } if (popover) { o.title = React.createElement(React.Fragment, null, React.createElement("div", { className: "".concat(prefix, "-pop-trigger") }, title), React.createElement(_popover["default"], _extends({ popup: popover, placement: "right" }, popoverProps), React.createElement("div", { className: "".concat(prefix, "-pop-trigger-placeholder") }))); } if (children) { _process(children, o.value); } }); }; _process(dataNode); if (selectAll) { dataNode.unshift({ title: React.createElement("div", { role: "none", className: "".concat(prefix, "-tree-treenode-all-inner"), onClick: _this.handleSelectAll }, "\u5168\u9009", React.createElement(_checkbox["default"], { size: "medium", checked: isAllSelected, indeterminate: indeterminate })), className: "".concat(prefix, "-tree-treenode-all"), key: "".concat(prefix, "-tree-treenode-all"), value: "".concat(prefix, "-tree-treenode-all"), checkable: false, disableCheckbox: true }); } return dataNode; }; _this.listenInputChange = function (e) { var onSearchEnter = _this.props.onSearchEnter; var value = e.target.value, key = e.key; if (key === "Backspace" && value === "") { e.stopPropagation(); } setTimeout(function () { if (key === "Enter" && onSearchEnter) { onSearchEnter(e); } }, 0); }; _this.componentDidMount = function () { var _this$wrapper; var input = (_this$wrapper = _this.wrapper) === null || _this$wrapper === void 0 ? void 0 : _this$wrapper.querySelector("input"); var _this$props5 = _this.props, maxTagCount = _this$props5.maxTagCount, placeholder = _this$props5.placeholder, resultVisible = _this$props5.resultVisible; var value = _this.state.value; if (input) { input.addEventListener("keydown", _this.listenInputChange, false); } if (maxTagCount !== null && value) { _this.forceUpdate(); } if (!resultVisible && _this.wrapper) { if (input) { input.placeholder = placeholder; } } }; _this.componentDidUpdate = function () { var _this$props6 = _this.props, resultVisible = _this$props6.resultVisible, placeholder = _this$props6.placeholder; if (!resultVisible) { setTimeout(function () { var _this$wrapper2; window.dispatchEvent(new Event("resize")); var input = (_this$wrapper2 = _this.wrapper) === null || _this$wrapper2 === void 0 ? void 0 : _this$wrapper2.querySelector("input"); if (input) { input.placeholder = placeholder; } }, 0); } }; var _value = props.value, defaultValue = props.defaultValue; var _valueState = _value !== null ? _value : defaultValue; _this.state = { hash: Math.random().toString(36).substring(3, 8), value: _valueState }; return _this; } _inherits(TreeSelect, _React$Component); return _createClass(TreeSelect, [{ key: "render", value: function render() { var _this2 = this; var _this$props7 = this.props, autoClearSearchValue = _this$props7.autoClearSearchValue, bottomContent = _this$props7.bottomContent, children = _this$props7.children, className = _this$props7.className, filterTreeNode = _this$props7.filterTreeNode, getPopupContainer = _this$props7.getPopupContainer, intent = _this$props7.intent, maxTagCount = _this$props7.maxTagCount, multiple = _this$props7.multiple, _onDropdownVisibleChange = _this$props7.onDropdownVisibleChange, placeholder = _this$props7.placeholder, rightIcon = _this$props7.rightIcon, resultRender = _this$props7.resultRender, resultVisible = _this$props7.resultVisible, sameValueEnabled = _this$props7.sameValueEnabled, selectAll = _this$props7.selectAll, showCheckedStrategy = _this$props7.showCheckedStrategy, topContent = _this$props7.topContent, treeData = _this$props7.treeData, otherProps = _objectWithoutProperties(_this$props7, _excluded2); var restProps = (0, _omit["default"])(otherProps, ["filterCaseSensitive", "onChange", "onSearch", "onSearchEnter", "defaultValue", "value"]); var _this$state2 = this.state, hash = _this$state2.hash, bottomContentPortalTarget = _this$state2.bottomContentPortalTarget, topContentPortalTarget = _this$state2.topContentPortalTarget, value = _this$state2.value; var classSet = (0, _classnames["default"])(className, "".concat(prefix, "-").concat(intent), _defineProperty({}, "".concat(prefix, "_resultHidden"), !resultVisible)); var checkbox = multiple; if (multiple) { checkbox = React.createElement("div", null, React.createElement("svg", { width: "12", height: "10", className: "".concat(prefix, "-tree-checkbox-indeterminateSvg") }, React.createElement("rect", { x: "1", y: "4", width: "10", height: "2", rx: ".5", fill: "#fff", fillRule: "evenodd" })), React.createElement("svg", { width: "12", height: "10", className: "".concat(prefix, "-tree-checkbox-checkedSvg") }, React.createElement("path", { d: "M.618 5.827a.463.463 0 0 1-.02-.675l.804-.804a.52.52 0 0 1 .716-.01L4.75 6.75l4.922-5.625a.513.513 0 0 1 .707-.06l.742.62a.478.478 0 0 1 .044.687l-6.08 6.756a.506.506 0 0 1-.703.045L.618 5.827z", fillRule: "evenodd" }))); } if (value !== null) { restProps.value = value; } if (sameValueEnabled) { var trueValue = []; if (restProps.value) { restProps.value.forEach(function (o) { _this2.treeValueFlatten.forEach(function (p) { var splited = p.split(sameValueSplitter); if (splited[splited.length - 1] === o) { trueValue.push(p); } }); }); } restProps.value = trueValue; } if (maxTagCount !== null) { var count = this.getMaxTagCount(); if (count !== null) { restProps.maxTagCount = count; } } if (resultRender) { restProps.maxTagCount = 0; } var treeDataFinal = this.convertTreeData(treeData || this.convertChildrenToData(children), { selectAll: selectAll }) || []; this.treeData = treeDataFinal; if (showCheckedStrategy === "show-parent") { this.treeValueAll = treeDataFinal.map(function (_ref4) { var val = _ref4.value, disabled = _ref4.disabled, disableCheckbox = _ref4.disableCheckbox, checkable = _ref4.checkable; if (val !== undefined && !disabled && !disableCheckbox && checkable !== false) { return val; } return undefined; }).filter(function (o) { return Boolean(o) || o === 0; }); } else { var treeValueAll = []; var _getAllValue = function getAllValue(data) { data.forEach(function (_ref5) { var val = _ref5.value, disabled = _ref5.disabled, disableCheckbox = _ref5.disableCheckbox, checkable = _ref5.checkable, child = _ref5.children; if (val !== undefined && !disabled && !disableCheckbox && checkable !== false) { if (showCheckedStrategy === "show-all" || !child) { treeValueAll.push(val); } else { _getAllValue(child); } } }); }; _getAllValue(treeDataFinal); this.treeValueAll = treeValueAll.filter(function (o) { return Boolean(o) || o === 0; }); } var multiLevel = treeDataFinal.some(function (o) { var _o$children; return (_o$children = o.children) === null || _o$children === void 0 ? void 0 : _o$children.length; }); return React.createElement(_configProvider.ConfigContext.Consumer, null, function (_ref6) { var getPopupContainerContext = _ref6.getPopupContainer; return React.createElement("div", { className: (0, _classnames["default"])("".concat(prefix, "-wrapper ").concat(prefix, "-wrapper_").concat(hash), _defineProperty(_defineProperty({}, "".concat(prefix, "-wrapper-maxTag"), _this2.getMaxTagCount() !== null), "".concat(prefix, "-wrapper-resultRender"), !!resultRender)), ref: _this2.saveWrapper }, topContent && topContentPortalTarget && React.createElement(_portal["default"], { container: topContentPortalTarget }, topContent), bottomContent && bottomContentPortalTarget && React.createElement(_portal["default"], { container: bottomContentPortalTarget }, bottomContent), React.createElement(_rcTreeSelect["default"], _extends({ autoClearSearchValue: resultVisible ? autoClearSearchValue : false, className: classSet, dropdownClassName: (0, _classnames["default"])("".concat(prefix, "-dropdown_").concat(hash), _defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "".concat(prefix, "-dropdown-multiple"), multiple), "".concat(prefix, "-dropdown-single"), !multiple), "".concat(prefix, "-dropdown-all"), selectAll), "".concat(prefix, "-dropdown-single-level"), !multiLevel)), filterTreeNode: filterTreeNode || _this2.filterTreeNode, getPopupContainer: getPopupContainer || getPopupContainerContext, inputIcon: React.createElement(_icon["default"], { icon: "triangle-down" }), maxTagPlaceholder: _this2.getMaxTagPlaceholder, notFoundContent: React.createElement(React.Fragment, null, React.createElement(_icon["default"], { icon: "file-outlined", color: "var(--transparent-gray-600)", style: { marginRight: "4px" } }), "\u65E0\u5339\u914D\u9879"), onChange: _this2.handleChange, onSearch: _this2.handleSearch, placeholder: placeholder, prefixCls: prefix, ref: _this2.saveSelect, removeIcon: React.createElement(_icon["default"], { icon: "cancel", interactive: true, size: 16 }), showCheckedStrategy: showCheckedStrategy && strategies[showCheckedStrategy], showSearch: multiple, switcherIcon: _this2.renderSwitcherIcon, transitionName: "slide-up", treeCheckable: checkbox, treeNodeFilterProp: "title", listItemHeight: 32, listHeight: 280, treeData: treeDataFinal, onDropdownVisibleChange: function onDropdownVisibleChange(visible) { if (!visible) { _this2.handleSearch(""); } _this2.handleVisibleChange(visible); if (_onDropdownVisibleChange) { _onDropdownVisibleChange(visible); } } }, restProps)), !!rightIcon && multiple && React.createElement(_icon["default"], { icon: rightIcon, className: "".concat(prefix, "-icon") })); }); } }]); }(React.Component); TreeSelect.propTypes = { autoClearSearchValue: _propTypes["default"].bool, bottomContent: _propTypes["default"].node, className: _propTypes["default"].string, defaultValue: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].array]), disabled: _propTypes["default"].bool, filterTreeNode: _propTypes["default"].any, filterCaseSensitive: _propTypes["default"].bool, getPopupContainer: _propTypes["default"].func, intent: _propTypes["default"].oneOf(["normal", "primary", "success", "warning", "danger"]), maxTagCount: _propTypes["default"].number, multiple: _propTypes["default"].bool, onChange: _propTypes["default"].func, onDropdownVisibleChange: _propTypes["default"].func, onSearch: _propTypes["default"].func, onSearchEnter: _propTypes["default"].func, placeholder: _propTypes["default"].string, resultRender: _propTypes["default"].func, resultVisible: _propTypes["default"].bool, rightIcon: _propTypes["default"].string, sameValueEnabled: _propTypes["default"].bool, selectAll: _propTypes["default"].bool, showCheckedStrategy: _propTypes["default"].oneOf(["show-all", "show-parent", "show-child"]), topContent: _propTypes["default"].node, treeData: _propTypes["default"].array, value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].array]) }; TreeSelect.defaultProps = { autoClearSearchValue: false, bottomContent: undefined, className: undefined, defaultValue: null, disabled: false, filterTreeNode: undefined, filterCaseSensitive: false, getPopupContainer: null, intent: "normal", maxTagCount: null, multiple: true, onChange: noop, onDropdownVisibleChange: noop, onSearch: noop, onSearchEnter: noop, placeholder: "请选择", resultRender: null, resultVisible: true, rightIcon: "list", sameValueEnabled: false, selectAll: false, showCheckedStrategy: "show-parent", topContent: undefined, treeData: undefined, value: null }; TreeSelect.getDerivedStateFromProps = function (_ref7) { var value = _ref7.value; if (value !== null) { return { value: value }; } return null; }; TreeSelect.TreeNode = _rcTreeSelect.TreeNode; var _default = exports["default"] = TreeSelect; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_rcTreeSelect","_propTypes","_interopRequireDefault","_shallowequal","_classnames","_toArray","_omit","_configProvider","_checkbox","_icon","_popover","_portal","_spinner","_excluded","_excluded2","e","__esModule","_getRequireWildcardCache","WeakMap","r","t","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_extends","assign","bind","arguments","length","apply","_objectWithoutProperties","o","_objectWithoutPropertiesLoose","getOwnPropertySymbols","s","includes","propertyIsEnumerable","ownKeys","keys","filter","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","value","configurable","writable","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","_arrayLikeToArray","toString","slice","constructor","name","Array","from","test","Symbol","iterator","isArray","_classCallCheck","_defineProperties","key","_createClass","prototype","_toPrimitive","toPrimitive","String","Number","_callSuper","_getPrototypeOf","_possibleConstructorReturn","_isNativeReflectConstruct","Reflect","construct","_assertThisInitialized","ReferenceError","Boolean","valueOf","setPrototypeOf","getPrototypeOf","_inherits","create","_setPrototypeOf","prefix","sameValueSplitter","noop","strategies","SHOW_ALL","SHOW_CHILD","SHOW_PARENT","isArrayIncludes","a1","a2","every","TreeSelect","_React$Component","props","_this","select","portal","wrapper","treeData","treeValueAll","treeValueFlatten","shouldComponentUpdate","nextProps","nextState","shallowEqual","state","saveSelect","node","saveWrapper","renderSwitcherIcon","_ref","isLeaf","loading","createElement","size","className","concat","icon","handleVisibleChange","visible","setTimeout","forceUpdate","_this$props","bottomContent","topContent","_this$state","hash","bottomContentPortalTarget","topContentPortalTarget","dropdown","document","querySelector","el","onmousedown","preventDefault","stopImmediatePropagation","insertBefore","children","setState","appendChild","handleChange","titleList","valueParam","_this$props2","disabled","multiple","onChange","valueProp","sameValueEnabled","valueState","v","splited","split","val","_value$filter","endsWith","Set","getFilteredTreeData","searchValue","filterTreeNode","filterOptionFunc","dig","list","keepAll","undefined","map","dataNode","match","childList","handleSearch","onSearch","input","treeNode","filterCaseSensitive","title","dataTitle","toLocaleLowerCase","getMaxTagCount","maxTagCount","handleSelectAll","_this$props3","getMaxTagPlaceholder","nodes","_nodes$","_this$props4","resultRender","disabledProp","placeholderText","Fragment","style","display","verticalAlign","maxWidth","overflow","textOverflow","whiteSpace","label","alignEdge","placement","popup","role","onMouseDown","stopPropagation","_ref2","onClick","vals","splice","labels","popupClassName","convertChildrenToData","toArray","isValidElement","type","_ref3","_ref3$props","popover","popoverProps","restProps","data","childData","convertTreeData","dataNodeParam","_dataNode$","_dataNode$2","options","isAllSelected","indeterminate","selectAll","process","parentValue","dataChildren","_o$popoverProps","newVal","unshift","checked","checkable","disableCheckbox","listenInputChange","onSearchEnter","target","componentDidMount","_this$wrapper","_this$props5","placeholder","resultVisible","addEventListener","componentDidUpdate","_this$props6","_this$wrapper2","window","dispatchEvent","Event","defaultValue","Math","random","substring","render","_this2","_this$props7","autoClearSearchValue","getPopupContainer","intent","onDropdownVisibleChange","rightIcon","showCheckedStrategy","otherProps","omit","_this$state2","classSet","classNames","checkbox","width","height","x","y","rx","fill","fillRule","d","trueValue","p","count","treeDataFinal","_ref4","getAllValue","_ref5","child","multiLevel","some","_o$children","ConfigContext","Consumer","_ref6","getPopupContainerContext","ref","container","dropdownClassName","inputIcon","maxTagPlaceholder","notFoundContent","color","marginRight","prefixCls","removeIcon","interactive","showSearch","switcherIcon","transitionName","treeCheckable","treeNodeFilterProp","listItemHeight","listHeight","Component","propTypes","PropTypes","bool","string","oneOfType","array","any","func","oneOf","number","defaultProps","getDerivedStateFromProps","_ref7","TreeNode","_default","exports"],"sources":["../../components/tree-select/TreeSelect.tsx"],"sourcesContent":["/* eslint-disable max-len */\n/* eslint-disable no-empty */\n/* eslint-disable react/no-did-update-set-state */\nimport * as React from \"react\"\nimport RcTreeSelect, {\n  SHOW_ALL,\n  SHOW_PARENT,\n  SHOW_CHILD,\n  TreeNode,\n} from \"rc-tree-select\"\nimport PropTypes from \"prop-types\"\nimport shallowEqual from \"shallowequal\"\nimport classNames from \"classnames\"\nimport toArray from \"rc-util/lib/Children/toArray\"\nimport omit from \"../_util/omit\"\nimport { ConfigContext } from \"../config-provider\"\nimport Checkbox from \"../checkbox\"\nimport Icon from \"../icon\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport Portal from \"../portal\"\nimport Spinner from \"../spinner\"\nimport \"./style\"\n\nconst prefix = \"adui-tree-select\"\nconst sameValueSplitter = \"__@@__\"\nconst noop = () => {}\n\nconst strategies = {\n  \"show-all\": SHOW_ALL,\n  \"show-child\": SHOW_CHILD,\n  \"show-parent\": SHOW_PARENT,\n}\n\n/**\n * a1 是否包含 a2\n */\nconst isArrayIncludes = (\n  a1: React.ReactText[],\n  a2: React.ReactText[]\n): boolean => {\n  if (!Array.isArray(a1) || !Array.isArray(a2)) {\n    return false\n  }\n\n  return a2.every((o) => a1.includes(o))\n}\n\nexport type TreeNodeValue = React.ReactText[] | null\n\nexport interface ITreeNode {\n  value: string\n  label: string\n  key: string\n  disabled: boolean\n}\nexport interface DataNode {\n  [key: string]: any\n  value?: React.ReactText\n  title?: React.ReactNode\n  label?: React.ReactNode\n  key?: React.ReactText\n  disabled?: boolean\n  disableCheckbox?: boolean\n  checkable?: boolean\n  popover?: React.ReactNode\n  popoverProps?: IPopoverProps\n  children?: DataNode[]\n}\n\nexport interface BaseOptionType {\n  disabled?: boolean\n  checkable?: boolean\n  disableCheckbox?: boolean\n  children?: BaseOptionType[]\n  [name: string]: any\n}\n\nexport interface DefaultOptionType extends BaseOptionType {\n  value?: React.ReactText\n  title?: React.ReactNode\n  label?: React.ReactNode\n  key?: React.Key\n  children?: DefaultOptionType[]\n}\n\nexport type TreeData = DataNode[] | undefined\n\nexport interface ITreeSelectProps {\n  [key: string]: any\n  autoClearSearchValue?: boolean\n  bottomContent?: React.ReactNode\n  className?: string\n  defaultValue?: TreeNodeValue\n  disabled?: boolean\n  filterTreeNode?:\n    | boolean\n    | ((inputValue: string, treeNode: DefaultOptionType) => boolean)\n  filterCaseSensitive?: boolean\n  getPopupContainer?: null | ((node: HTMLElement) => HTMLElement)\n  intent?: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n  maxTagCount?: null | number\n  multiple?: boolean\n  onChange?: (value: TreeNodeValue, titleList: React.ReactNode[]) => void\n  onDropdownVisibleChange?: (visible: boolean) => void\n  onSearchEnter?: (e: KeyboardEvent) => void\n  onSearch?: (value: string, nodes: DataNode[]) => void\n  resultRender?: null | ((values: ITreeNode[]) => JSX.Element)\n  resultVisible?: boolean\n  sameValueEnabled?: boolean\n  selectAll?: boolean\n  showCheckedStrategy?: \"show-all\" | \"show-child\" | \"show-parent\"\n  topContent?: React.ReactNode\n  treeData?: TreeData\n  value?: TreeNodeValue\n}\n\ntype GetFuncType<T> = T extends boolean ? never : T\ntype FilterFn = GetFuncType<ITreeSelectProps[\"filterTreeNode\"]>\n\nexport interface ITreeSelectState {\n  hash: string\n  bottomContentPortalTarget?: HTMLDivElement\n  topContentPortalTarget?: HTMLDivElement\n  value?: TreeNodeValue\n}\n\nexport interface ITreeNodeProps {\n  [key: string]: any\n  className?: string\n  checkable?: boolean\n  disabled?: boolean\n  disableCheckbox?: boolean\n  title?: string | React.ReactNode\n  key?: string\n  eventKey?: string\n  isLeaf?: boolean\n  checked?: boolean\n  expanded?: boolean\n  loading?: boolean\n  selected?: boolean\n  selectable?: boolean\n  children?: React.ReactNode\n}\n\n/**\n * 树形选择\n */\nclass TreeSelect extends React.Component<ITreeSelectProps, ITreeSelectState> {\n  public static propTypes = {\n    /**\n     * 值被选择后，是否需要清空搜索框\n     */\n    autoClearSearchValue: PropTypes.bool,\n    /**\n     * 下拉框底部显示的自定义元素\n     */\n    bottomContent: PropTypes.node,\n    /**\n     * 附加类名\n     */\n    className: PropTypes.string,\n    /**\n     * 默认选中的 key\n     */\n    defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n    /**\n     * 是否禁用\n     */\n    disabled: PropTypes.bool,\n    /**\n     * 自定义树节点过滤函数\n     */\n    filterTreeNode: PropTypes.any,\n    /**\n     * 是否开启大小写敏感搜索，默认为 false\n     */\n    filterCaseSensitive: PropTypes.bool,\n    /**\n     * 指定弹出层的父级，默认为 document.body\n     */\n    getPopupContainer: PropTypes.func,\n    /**\n     * 类型\n     */\n    intent: PropTypes.oneOf([\n      \"normal\",\n      \"primary\",\n      \"success\",\n      \"warning\",\n      \"danger\",\n    ]),\n    /**\n     * 最多显示多少个 tag，如果超过了则以收起的形式出现\n     */\n    maxTagCount: PropTypes.number,\n    /**\n     * 是否多选模式\n     */\n    multiple: PropTypes.bool,\n    /**\n     * 值变化时的回调，参数: value\n     */\n    onChange: PropTypes.func,\n    /**\n     * 下拉 visible 变化时的回调，参数: boolean\n     */\n    onDropdownVisibleChange: PropTypes.func,\n    /**\n     * 搜索时的回调，参数: value\n     */\n    onSearch: PropTypes.func,\n    /**\n     * 搜索回车时的回调，参数: e\n     */\n    onSearchEnter: 