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>
352 lines (351 loc) • 60.3 kB
JavaScript
"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 _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _rcAnimate = _interopRequireDefault(require("rc-animate"));
var _button = _interopRequireDefault(require("../button"));
var _icon = _interopRequireDefault(require("../icon"));
var _popover = _interopRequireDefault(require("../popover"));
var _isEqualArrays = _interopRequireDefault(require("../_util/isEqualArrays"));
require("./style");
var _excluded = ["allowClear", "changeOnSelect", "children", "className", "defaultValue", "disabled", "displayRender", "expandTrigger", "onChange", "onVisibleChange", "options", "placeholder", "popoverProps", "size", "value", "visible"];
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 _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 _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 _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 _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 _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure 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 _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 _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
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; }
var prefix = "adui-cascader";
var Cascader = function Cascader(_ref) {
var allowClear = _ref.allowClear,
changeOnSelect = _ref.changeOnSelect,
children = _ref.children,
className = _ref.className,
defaultValue = _ref.defaultValue,
disabled = _ref.disabled,
_ref$displayRender = _ref.displayRender,
displayRender = _ref$displayRender === void 0 ? function (title) {
return title.join("/");
} : _ref$displayRender,
expandTrigger = _ref.expandTrigger,
onChange = _ref.onChange,
onVisibleChange = _ref.onVisibleChange,
options = _ref.options,
placeholder = _ref.placeholder,
popoverProps = _ref.popoverProps,
size = _ref.size,
valueProps = _ref.value,
visibleProps = _ref.visible,
otherProps = _objectWithoutProperties(_ref, _excluded);
var _useState = (0, _react.useState)(valueProps !== null ? valueProps || [] : defaultValue || []),
_useState2 = _slicedToArray(_useState, 2),
value = _useState2[0],
setValue = _useState2[1];
var _useState3 = (0, _react.useState)(valueProps !== null ? valueProps || [] : defaultValue || []),
_useState4 = _slicedToArray(_useState3, 2),
activeValue = _useState4[0],
setActiveValue = _useState4[1];
var _useState5 = (0, _react.useState)(visibleProps !== null ? visibleProps : false),
_useState6 = _slicedToArray(_useState5, 2),
visible = _useState6[0],
setVisible = _useState6[1];
var delayTimer = (0, _react.useRef)(0);
if (valueProps !== null && !(0, _isEqualArrays["default"])(valueProps || [], value)) {
setValue(valueProps || []);
}
if (visibleProps !== null && visible !== visibleProps) {
setVisible(visibleProps);
}
var setPopupVisible = function setPopupVisible(popupVisible) {
if (visibleProps === null) {
setVisible(popupVisible);
}
if (popupVisible && !visible) {
setActiveValue(value);
}
if (onVisibleChange) {
onVisibleChange(popupVisible);
}
};
var handleClear = function handleClear(e) {
e.preventDefault();
e.stopPropagation();
setPopupVisible(false);
if (!valueProps) {
setValue([]);
}
if (onChange) {
onChange([], []);
}
};
var handleChange = function handleChange(opts, _ref2) {
var popupVisible = _ref2.visible;
setPopupVisible(popupVisible);
if (onChange) {
onChange(opts.map(function (_ref3) {
var v = _ref3.value;
return v || "";
}), opts);
}
};
var hasValue = value === null || value === void 0 ? void 0 : value.length;
var arrayTreeFilter = function arrayTreeFilter() {
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
var filterFn = arguments.length > 1 ? arguments[1] : undefined;
var childs = data;
var result = [];
var level = 0;
do {
var foundItem = childs.filter(function (item) {
return filterFn(item, level);
})[0];
if (!foundItem) {
break;
}
result.push(foundItem);
childs = foundItem.children || [];
level += 1;
} while (childs.length > 0);
return result;
};
var getTitle = function getTitle() {
var unwrappedValue = Array.isArray(value[0]) ? value[0] : value;
var selectedOptions = arrayTreeFilter(options, function (o, level) {
return o.value === unwrappedValue[level];
});
var title = selectedOptions.length ? selectedOptions.map(function (o) {
return o.title;
}) : value;
return displayRender(title.map(function (o) {
return (o || "").toString();
}), selectedOptions);
};
var isActiveOption = function isActiveOption(option, menuIndex) {
return activeValue[menuIndex] === option.value;
};
var getActiveOptions = function getActiveOptions(activeValueParam) {
return arrayTreeFilter(options, function (o, level) {
return o.value === (activeValueParam || activeValue)[level];
});
};
var getShowOptions = function getShowOptions() {
var result = getActiveOptions().map(function (_ref4) {
var childs = _ref4.children;
return childs;
}).filter(function (activeOption) {
return activeOption === null || activeOption === void 0 ? void 0 : activeOption.length;
});
result.unshift(options);
return result;
};
var delaySelect = function delaySelect(func) {
if (delayTimer.current) {
clearTimeout(delayTimer.current);
delayTimer.current = 0;
}
if (typeof func === "function") {
delayTimer.current = window.setTimeout(function () {
func();
delayTimer.current = 0;
}, 150);
}
};
var optss = getShowOptions();
var menus = _react["default"].createElement("div", {
className: "".concat(prefix, "-menus")
}, _react["default"].createElement(_rcAnimate["default"], {
transitionAppear: true,
component: "div",
style: {
display: "flex"
},
animation: {
appear: function appear(node, done) {
node.classList.add("".concat(prefix, "-enter"));
setTimeout(function () {
node.classList.add("".concat(prefix, "-enter-active"));
}, 50);
var promise = new Promise(function (resolve) {
return setTimeout(resolve, 200);
});
promise.then(function () {
node.classList.remove("".concat(prefix, "-enter-active"));
node.classList.remove("".concat(prefix, "-enter"));
return done();
});
return done();
},
enter: function enter(node, done) {
node.classList.add("".concat(prefix, "-enter"));
setTimeout(function () {
node.classList.add("".concat(prefix, "-enter-active"));
}, 50);
var promise = new Promise(function (resolve) {
return setTimeout(resolve, 200);
});
promise.then(function () {
node.classList.remove("".concat(prefix, "-enter-active"));
node.classList.remove("".concat(prefix, "-enter"));
return done();
});
return done();
},
leave: function leave(node, done) {
node.classList.add("".concat(prefix, "-leave"));
setTimeout(function () {
node.classList.add("".concat(prefix, "-leave-active"));
}, 50);
var promise = new Promise(function (resolve) {
return setTimeout(resolve, 200);
});
promise.then(function () {
return done();
});
}
}
}, optss.map(function (opts, menuIndex) {
return _react["default"].createElement("div", {
className: (0, _classnames["default"])("".concat(prefix, "-menu"), _defineProperty({}, "".concat(prefix, "-menu-").concat(size), size)),
key: menuIndex
}, (opts || []).map(function (o, j) {
var v = o.value,
title = o.title,
c = o.children,
d = o.disabled;
var handleSelect = function handleSelect() {
if (d) {
return;
}
var activeValueDuplicated = _toConsumableArray(activeValue);
activeValueDuplicated = activeValueDuplicated.slice(0, menuIndex + 1);
activeValueDuplicated[menuIndex] = v || "";
var activeOptions = getActiveOptions(activeValueDuplicated);
setActiveValue(activeValueDuplicated);
if (!(c !== null && c !== void 0 && c.length)) {
handleChange(activeOptions, {
visible: false
});
if (valueProps === null) {
setValue(activeValueDuplicated);
}
} else if (changeOnSelect) {
handleChange(activeOptions, {
visible: true
});
if (valueProps === null) {
setValue(activeValueDuplicated);
}
}
};
return _react["default"].createElement("div", {
role: "none",
key: v || j,
className: (0, _classnames["default"])("".concat(prefix, "-menu-item"), _defineProperty({}, "".concat(prefix, "-menu-item-active"), isActiveOption(o, menuIndex))),
title: title === null || title === void 0 ? void 0 : title.toString(),
onMouseDown: function onMouseDown(e) {
return e.preventDefault();
},
onClick: handleSelect,
onMouseEnter: function onMouseEnter() {
if (expandTrigger === "hover" && c !== null && c !== void 0 && c.length) {
delaySelect(handleSelect);
}
},
onMouseLeave: function onMouseLeave() {
if (expandTrigger === "hover" && c !== null && c !== void 0 && c.length) {
delaySelect();
}
}
}, _react["default"].createElement("div", {
className: "".concat(prefix, "-menu-item-content")
}, title), !!(c !== null && c !== void 0 && c.length) && _react["default"].createElement(_icon["default"], {
icon: "triangle-right",
className: "".concat(prefix, "-menu-item-icon")
}));
}));
})));
return _react["default"].createElement(_popover["default"], _extends({
arrowed: false,
popupClassName: "".concat(prefix, "-popup"),
visible: disabled ? false : visible,
onVisibleChange: setPopupVisible,
trigger: "click",
popup: menus
}, popoverProps), _react["default"].createElement(_button["default"], _extends({
disabled: disabled,
className: (0, _classnames["default"])("".concat(prefix, "-button"), className, _defineProperty(_defineProperty({}, "".concat(prefix, "-button-valued"), hasValue), "".concat(prefix, "-button-clearable"), allowClear)),
size: size
}, otherProps), hasValue ? _react["default"].createElement("span", {
className: "".concat(prefix, "-label")
}, getTitle()) : _react["default"].createElement("span", {
className: "".concat(prefix, "-placeholder")
}, placeholder), _react["default"].createElement("div", {
className: "".concat(prefix, "-icons")
}, _react["default"].createElement(_icon["default"], {
icon: "triangle-down",
className: "".concat(prefix, "-suffix"),
color: disabled ? "var(--transparent-gray-600)" : "var(--transparent-gray-700)"
}), allowClear && !disabled && _react["default"].createElement(_icon["default"], {
icon: "cancel-circle",
className: "".concat(prefix, "-remove"),
color: "var(--transparent-gray-700)",
onClick: handleClear
}))));
};
Cascader.displayName = "Cascader";
Cascader.propTypes = {
allowClear: _propTypes["default"].bool,
changeOnSelect: _propTypes["default"].bool,
children: _propTypes["default"].node,
className: _propTypes["default"].string,
defaultValue: _propTypes["default"].any,
disabled: _propTypes["default"].bool,
displayRender: _propTypes["default"].any,
expandTrigger: _propTypes["default"].oneOf(["click", "hover"]),
options: _propTypes["default"].any,
onChange: _propTypes["default"].any,
onVisibleChange: _propTypes["default"].any,
placeholder: _propTypes["default"].any,
popoverProps: _propTypes["default"].any,
size: _propTypes["default"].oneOf(["mini", "small", "medium", "large"]),
value: _propTypes["default"].any,
visible: _propTypes["default"].any
};
Cascader.defaultProps = {
allowClear: true,
changeOnSelect: false,
children: null,
className: undefined,
defaultValue: null,
disabled: false,
displayRender: undefined,
expandTrigger: "click",
onChange: undefined,
onVisibleChange: undefined,
options: [],
placeholder: "请选择",
popoverProps: {},
size: "small",
value: null,
visible: null
};
var _default = exports["default"] = Cascader;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_classnames","_rcAnimate","_button","_icon","_popover","_isEqualArrays","_excluded","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","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","Symbol","iterator","Array","from","isArray","_arrayLikeToArray","_defineProperty","_toPropertyKey","value","enumerable","configurable","writable","_toPrimitive","toPrimitive","String","Number","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","toString","slice","constructor","name","test","l","f","o","next","done","push","_objectWithoutProperties","_objectWithoutPropertiesLoose","getOwnPropertySymbols","s","includes","propertyIsEnumerable","prefix","Cascader","_ref","allowClear","changeOnSelect","children","className","defaultValue","disabled","_ref$displayRender","displayRender","title","join","expandTrigger","onChange","onVisibleChange","options","placeholder","popoverProps","size","valueProps","visibleProps","visible","otherProps","_useState","useState","_useState2","setValue","_useState3","_useState4","activeValue","setActiveValue","_useState5","_useState6","setVisible","delayTimer","useRef","isEqualArrays","setPopupVisible","popupVisible","handleClear","preventDefault","stopPropagation","handleChange","opts","_ref2","map","_ref3","v","hasValue","arrayTreeFilter","data","undefined","filterFn","childs","result","level","foundItem","filter","item","getTitle","unwrappedValue","selectedOptions","isActiveOption","option","menuIndex","getActiveOptions","activeValueParam","getShowOptions","_ref4","activeOption","unshift","delaySelect","func","current","clearTimeout","window","setTimeout","optss","menus","createElement","concat","transitionAppear","component","style","display","animation","appear","node","classList","add","promise","Promise","resolve","then","remove","enter","leave","classNames","key","j","c","d","handleSelect","activeValueDuplicated","activeOptions","role","onMouseDown","onClick","onMouseEnter","onMouseLeave","icon","arrowed","popupClassName","trigger","popup","color","displayName","propTypes","PropTypes","bool","string","any","oneOf","defaultProps","_default","exports"],"sources":["../../components/cascader/Cascader.tsx"],"sourcesContent":["/* eslint-disable no-loop-func  */\n/* eslint-disable react/no-array-index-key */\nimport React, { useRef, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Animate from \"rc-animate\"\nimport Button from \"../button\"\nimport Icon from \"../icon\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport isEqualArrays from \"../_util/isEqualArrays\"\nimport \"./style\"\n\nconst prefix = \"adui-cascader\"\n\nexport type CascaderValueType = React.ReactText[]\n\nexport interface CascaderOption {\n  [key: string]: any\n  value?: string | number\n  title: React.ReactNode\n  disabled?: boolean\n  children?: CascaderOption[]\n}\n\nexport interface ICascaderProps {\n  [key: string]: any\n  /**\n   * 是否支持清除\n   */\n  allowClear?: boolean\n  /**\n   * 当此项为 true 时，点选每级菜单选项值都会发生变化\n   */\n  changeOnSelect?: boolean\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名，注意 Cascader 所有的属性会附加到内部的内容元素上，而不是包含 mask 的最外层元素\n   */\n  className?: string\n  /**\n   * 默认值，内部驱动\n   */\n  defaultValue?: CascaderValueType | null\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean\n  /**\n   * 选择后展示的渲染函数\n   */\n  displayRender?: (\n    title: string[],\n    selectedOptions?: CascaderOption[]\n  ) => React.ReactNode\n  /**\n   * 次级菜单的展开方式，可选 'click' 和 'hover'\n   */\n  expandTrigger?: \"click\" | \"hover\"\n  /**\n   * 值变化时的 handler\n   */\n  onChange?: (value: CascaderValueType, selectOptions: CascaderOption[]) => void\n  /**\n   * 下拉框 visible 状态改变时的回调\n   */\n  onVisibleChange?: (visible: boolean) => void\n  /**\n   * 可选项数据源\n   */\n  options?: CascaderOption[]\n  /**\n   * 占位文本\n   */\n  placeholder?: React.ReactNode\n  /**\n   * 属性将会透传给 Popover 组件\n   */\n  popoverProps?: IPopoverProps\n  /**\n   * 尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 值，外部控制\n   */\n  value?: CascaderValueType | null\n  /**\n   * 外部控制下拉框 visible 状态\n   */\n  visible?: boolean | null\n}\n\n/**\n * 级联选择器直观展示已有的层级关系。\n */\nconst Cascader: React.FC<ICascaderProps> = ({\n  allowClear,\n  changeOnSelect,\n  children,\n  className,\n  defaultValue,\n  disabled,\n  displayRender = (title: string[]) => title.join(\"/\"),\n  expandTrigger,\n  onChange,\n  onVisibleChange,\n  options,\n  placeholder,\n  popoverProps,\n  size,\n  value: valueProps,\n  visible: visibleProps,\n  ...otherProps\n}) => {\n  const [value, setValue] = useState<CascaderValueType>(\n    valueProps !== null ? valueProps || [] : defaultValue || []\n  )\n  const [activeValue, setActiveValue] = useState<CascaderValueType>(\n    valueProps !== null ? valueProps || [] : defaultValue || []\n  )\n  const [visible, setVisible] = useState(\n    visibleProps !== null ? visibleProps : false\n  )\n  const delayTimer = useRef(0)\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (valueProps !== null && !isEqualArrays(valueProps || [], value)) {\n    setValue(valueProps || [])\n  }\n  if (visibleProps !== null && visible !== visibleProps) {\n    setVisible(visibleProps)\n  }\n\n  const setPopupVisible = (popupVisible: boolean) => {\n    if (visibleProps === null) {\n      setVisible(popupVisible)\n    }\n    if (popupVisible && !visible) {\n      setActiveValue(value)\n    }\n    if (onVisibleChange) {\n      onVisibleChange(popupVisible)\n    }\n  }\n\n  const handleClear = (e: React.MouseEvent<SVGSVGElement>) => {\n    e.preventDefault()\n    e.stopPropagation()\n    setPopupVisible(false)\n    if (!valueProps) {\n      setValue([])\n    }\n    if (onChange) {\n      onChange([], [])\n    }\n  }\n\n  const handleChange = (\n    opts: CascaderOption[],\n    { visible: popupVisible }: { visible: boolean }\n  ) => {\n    setPopupVisible(popupVisible)\n    if (onChange) {\n      onChange(\n        opts.map(({ value: v }) => v || \"\"),\n        opts\n      )\n    }\n  }\n\n  const hasValue = value?.length\n\n  const arrayTreeFilter = <T extends unknown>(\n    data: T[] = [],\n    filterFn: (item: T, level: number) => boolean\n  ) => {\n    let childs = data\n    const result: T[] = []\n    let level = 0\n    do {\n      const foundItem: T = childs.filter((item) => filterFn(item, level))[0]\n      if (!foundItem) {\n        break\n      }\n      result.push(foundItem)\n      childs = (foundItem as any).children || []\n      level += 1\n    } while (childs.length > 0)\n    return result\n  }\n\n  const getTitle = () => {\n    const unwrappedValue = Array.isArray(value[0]) ? value[0] : value\n    const selectedOptions = arrayTreeFilter(\n      options,\n      (o, level: number) => o.value === unwrappedValue[level]\n    )\n    const title = selectedOptions.length\n      ? selectedOptions.map((o) => o.title)\n      : value\n    return displayRender(\n      title.map((o) => (o || \"\").toString()),\n      selectedOptions\n    )\n  }\n\n  const isActiveOption = (option: CascaderOption, menuIndex: number) =>\n    activeValue[menuIndex] === option.value\n\n  const getActiveOptions = (\n    activeValueParam?: CascaderValueType\n  ): CascaderOption[] =>\n    arrayTreeFilter(\n      options,\n      (o, level) => o.value === (activeValueParam || activeValue)[level]\n    )\n\n  const getShowOptions = (): (CascaderOption[] | undefined)[] => {\n    const result = getActiveOptions()\n      .map(({ children: childs }) => childs)\n      .filter((activeOption) => activeOption?.length)\n    result.unshift(options)\n\n    return result\n  }\n\n  const delaySelect = (func?: () => void) => {\n    if (delayTimer.current) {\n      clearTimeout(delayTimer.current)\n      delayTimer.current = 0\n    }\n    if (typeof func === \"function\") {\n      delayTimer.current = window.setTimeout(() => {\n        func()\n        delayTimer.current = 0\n      }, 150)\n    }\n  }\n\n  const optss = getShowOptions()\n\n  const menus = (\n    <div className={`${prefix}-menus`}>\n      <Animate\n        transitionAppear\n        component=\"div\"\n        style={{ display: \"flex\" }}\n        animation={{\n          appear(node: HTMLElement, done: () => void) {\n            node.classList.add(`${prefix}-enter`)\n            setTimeout(() => {\n              node.classList.add(`${prefix}-enter-active`)\n            }, 50)\n            const promise = new Promise((resolve) => setTimeout(resolve, 200))\n            promise.then(() => {\n              node.classList.remove(`${prefix}-enter-active`)\n              node.classList.remove(`${prefix}-enter`)\n              return done()\n            })\n            return done()\n          },\n          enter(node: HTMLElement, done: () => void) {\n            node.classList.add(`${prefix}-enter`)\n            setTimeout(() => {\n              node.classList.add(`${prefix}-enter-active`)\n            }, 50)\n            const promise = new Promise((resolve) => setTimeout(resolve, 200))\n            promise.then(() => {\n              node.classList.remove(`${prefix}-enter-active`)\n              node.classList.remove(`${prefix}-enter`)\n              return done()\n            })\n            return done()\n          },\n          leave(node: HTMLElement, done: () => void) {\n            node.classList.add(`${prefix}-leave`)\n            setTimeout(() => {\n              node.classList.add(`${prefix}-leave-active`)\n            }, 50)\n            const promise = new Promise((resolve) => setTimeout(resolve, 200))\n            promise.then(() => {\n              return done()\n            })\n          },\n        }}\n      >\n        {optss.map((opts, menuIndex) => (\n          <div\n            className={classNames(`${prefix}-menu`, {\n              [`${prefix}-menu-${size}`]: size,\n            })}\n            key={menuIndex}\n          >\n            {(opts || []).map((o, j) => {\n              const { value: v, title, children: c, disabled: d } = o\n              const handleSelect = () => {\n                if (d) {\n                  return\n                }\n                let activeValueDuplicated = [...activeValue]\n                activeValueDuplicated = activeValueDuplicated.slice(\n                  0,\n                  menuIndex + 1\n                )\n                activeValueDuplicated[menuIndex] = v || \"\"\n                const activeOptions = getActiveOptions(activeValueDuplicated)\n                setActiveValue(activeValueDuplicated)\n                if (!c?.length) {\n                  handleChange(activeOptions, { visible: false })\n                  if (valueProps === null) {\n                    setValue(activeValueDuplicated)\n                  }\n                } else if (changeOnSelect) {\n                  handleChange(activeOptions, { visible: true })\n                  if (valueProps === null) {\n                    setValue(activeValueDuplicated)\n                  }\n                }\n              }\n              return (\n                <div\n                  role=\"none\"\n                  key={v || j}\n                  className={classNames(`${prefix}-menu-item`, {\n                    [`${prefix}-menu-item-active`]: isActiveOption(\n                      o,\n                      menuIndex\n                    ),\n                  })}\n                  title={title?.toString()}\n                  onMouseDown={(e) => e.preventDefault()}\n                  onClick={handleSelect}\n                  onMouseEnter={() => {\n                    if (expandTrigger === \"hover\" && c?.length) {\n                      delaySelect(handleSelect)\n                    }\n                  }}\n                  onMouseLeave={() => {\n                    if (expandTrigger === \"hover\" && c?.length) {\n                      delaySelect()\n                    }\n                  }}\n                >\n                  <div className={`${prefix}-menu-item-content`}>{title}</div>\n                  {!!c?.length && (\n                    <Icon\n                      icon=\"triangle-right\"\n                      className={`${prefix}-menu-item-icon`}\n                    />\n                  )}\n                </div>\n              )\n            })}\n          </div>\n        ))}\n      </Animate>\n    </div>\n  )\n\n  return (\n    <Popover\n      arrowed={false}\n      popupClassName={`${prefix}-popup`}\n      visible={disabled ? false : visible}\n      onVisibleChange={setPopupVisible}\n      trigger=\"click\"\n      popup={menus}\n      {...popoverProps}\n    >\n      <Button\n        disabled={disabled}\n        className={classNames(`${prefix}-button`, className, {\n          [`${prefix}-button-valued`]: hasValue,\n          [`${prefix}-button-clearable`]: allowClear,\n        })}\n        size={size}\n        {...otherProps}\n      >\n        {hasValue ? (\n          <span className={`${prefix}-label`}>{getTitle()}</span>\n        ) : (\n          <span className={`${prefix}-placeholder`}>{placeholder}</span>\n        )}\n        <div className={`${prefix}-icons`}>\n          <Icon\n            icon=\"triangle-down\"\n            className={`${prefix}-suffix`}\n            color={\n              disabled\n                ? \"var(--transparent-gray-600)\"\n                : \"var(--transparent-gray-700)\"\n            }\n          />\n          {allowClear && !disabled && (\n            <Icon\n              icon=\"cancel-circle\"\n              className={`${prefix}-remove`}\n              color=\"var(--transparent-gray-700)\"\n              onClick={handleClear}\n            />\n          )}\n        </div>\n      </Button>\n    </Popover>\n  )\n}\n\nCascader.displayName = \"Cascader\"\n\nCascader.propTypes = {\n  /**\n   * 是否支持清除\n   */\n  allowClear: PropTypes.bool,\n  /**\n   * 当此项为 true 时，点选每级菜单选项值都会发生变化\n   */\n  changeOnSelect: PropTypes.bool,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名，注意 Dialog 所有的属性会附加到内部的内容元素上，而不是包含 mask 的最外层元素\n   */\n  className: PropTypes.string,\n  /**\n   * 默认值，内部驱动\n   */\n  defaultValue: PropTypes.any,\n  /**\n   * 是否禁用\n   */\n  disabled: PropTypes.bool,\n  /**\n   * 选择后展示的渲染函数\n   */\n  displayRender: PropTypes.any,\n  /**\n   * 次级菜单的展开方式，可选 'click' 和 'hover'\n   */\n  expandTrigger: PropTypes.oneOf([\"click\", \"hover\"]),\n  /**\n   * 可选项数据源\n   */\n  options: PropTypes.any,\n  /**\n   * 值变化时的 handler\n   */\n  onChange: PropTypes.any,\n  /**\n   * 下拉框 visible 状态改变时的回调\n   */\n  onVisibleChange: PropTypes.any,\n  /**\n   * 占位文本\n   */\n  placeholder: PropTypes.any,\n  /**\n   * 属性将会透传给 Popover 组件\n   */\n  popoverProps: PropTypes.any,\n  /**\n   * 尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 值，外部控制\n   */\n  value: PropTypes.any,\n  /**\n   * 外部控制下拉框 visible 状态\n   */\n  visible: PropTypes.any,\n}\n\nCascader.defaultProps = {\n  allowClear: true,\n  changeOnSelect: false,\n  children: null,\n  className: undefined,\n  defaultValue: null,\n  disabled: false,\n  displayRender: undefined,\n  expandTrigger: \"click\",\n  onChange: undefined,\n  onVisibleChange: undefined,\n  options: [],\n  placeholder: \"请选择\",\n  popoverProps: {},\n  size: \"small\",\n  value: null,\n  visible: null,\n}\n\nexport default Cascader\n"],"mappings":"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