index.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. Object.defineProperty(exports, "TreeNode", {
  9. enumerable: true,
  10. get: function () {
  11. return _rcTreeSelect.TreeNode;
  12. }
  13. });
  14. exports.default = void 0;
  15. var React = _interopRequireWildcard(require("react"));
  16. var _classnames = _interopRequireDefault(require("classnames"));
  17. var _rcTreeSelect = _interopRequireWildcard(require("rc-tree-select"));
  18. var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
  19. var _useZIndex = require("../_util/hooks/useZIndex");
  20. var _motion = require("../_util/motion");
  21. var _PurePanel = _interopRequireDefault(require("../_util/PurePanel"));
  22. var _statusUtils = require("../_util/statusUtils");
  23. var _warning = require("../_util/warning");
  24. var _configProvider = require("../config-provider");
  25. var _context = require("../config-provider/context");
  26. var _defaultRenderEmpty = _interopRequireDefault(require("../config-provider/defaultRenderEmpty"));
  27. var _DisabledContext = _interopRequireDefault(require("../config-provider/DisabledContext"));
  28. var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls"));
  29. var _useSize = _interopRequireDefault(require("../config-provider/hooks/useSize"));
  30. var _context2 = require("../form/context");
  31. var _useVariants = _interopRequireDefault(require("../form/hooks/useVariants"));
  32. var _mergedBuiltinPlacements = _interopRequireDefault(require("../select/mergedBuiltinPlacements"));
  33. var _style = _interopRequireDefault(require("../select/style"));
  34. var _useIcons = _interopRequireDefault(require("../select/useIcons"));
  35. var _usePopupRender = _interopRequireDefault(require("../select/usePopupRender"));
  36. var _useShowArrow = _interopRequireDefault(require("../select/useShowArrow"));
  37. var _Compact = require("../space/Compact");
  38. var _internal = require("../theme/internal");
  39. var _iconUtil = _interopRequireDefault(require("../tree/utils/iconUtil"));
  40. var _style2 = _interopRequireDefault(require("./style"));
  41. var __rest = void 0 && (void 0).__rest || function (s, e) {
  42. var t = {};
  43. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  44. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  45. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  46. }
  47. return t;
  48. };
  49. const InternalTreeSelect = (props, ref) => {
  50. var _a, _b, _c, _d, _e;
  51. const {
  52. prefixCls: customizePrefixCls,
  53. size: customizeSize,
  54. disabled: customDisabled,
  55. bordered = true,
  56. style,
  57. className,
  58. rootClassName,
  59. treeCheckable,
  60. multiple,
  61. listHeight = 256,
  62. listItemHeight: customListItemHeight,
  63. placement,
  64. notFoundContent,
  65. switcherIcon,
  66. treeLine,
  67. getPopupContainer,
  68. popupClassName,
  69. dropdownClassName,
  70. treeIcon = false,
  71. transitionName,
  72. choiceTransitionName = '',
  73. status: customStatus,
  74. treeExpandAction,
  75. builtinPlacements,
  76. dropdownMatchSelectWidth,
  77. popupMatchSelectWidth,
  78. allowClear,
  79. variant: customVariant,
  80. dropdownStyle,
  81. dropdownRender,
  82. popupRender,
  83. onDropdownVisibleChange,
  84. onOpenChange,
  85. tagRender,
  86. maxCount,
  87. showCheckedStrategy,
  88. treeCheckStrictly,
  89. styles,
  90. classNames
  91. } = props,
  92. restProps = __rest(props, ["prefixCls", "size", "disabled", "bordered", "style", "className", "rootClassName", "treeCheckable", "multiple", "listHeight", "listItemHeight", "placement", "notFoundContent", "switcherIcon", "treeLine", "getPopupContainer", "popupClassName", "dropdownClassName", "treeIcon", "transitionName", "choiceTransitionName", "status", "treeExpandAction", "builtinPlacements", "dropdownMatchSelectWidth", "popupMatchSelectWidth", "allowClear", "variant", "dropdownStyle", "dropdownRender", "popupRender", "onDropdownVisibleChange", "onOpenChange", "tagRender", "maxCount", "showCheckedStrategy", "treeCheckStrictly", "styles", "classNames"]);
  93. const {
  94. getPopupContainer: getContextPopupContainer,
  95. getPrefixCls,
  96. renderEmpty,
  97. direction,
  98. virtual,
  99. popupMatchSelectWidth: contextPopupMatchSelectWidth,
  100. popupOverflow
  101. } = React.useContext(_configProvider.ConfigContext);
  102. const {
  103. styles: contextStyles,
  104. classNames: contextClassNames
  105. } = (0, _context.useComponentConfig)('treeSelect');
  106. const [, token] = (0, _internal.useToken)();
  107. const listItemHeight = customListItemHeight !== null && customListItemHeight !== void 0 ? customListItemHeight : (token === null || token === void 0 ? void 0 : token.controlHeightSM) + (token === null || token === void 0 ? void 0 : token.paddingXXS);
  108. if (process.env.NODE_ENV !== 'production') {
  109. const warning = (0, _warning.devUseWarning)('TreeSelect');
  110. const deprecatedProps = {
  111. dropdownMatchSelectWidth: 'popupMatchSelectWidth',
  112. dropdownStyle: 'styles.popup.root',
  113. dropdownClassName: 'classNames.popup.root',
  114. popupClassName: 'classNames.popup.root',
  115. dropdownRender: 'popupRender',
  116. onDropdownVisibleChange: 'onOpenChange',
  117. bordered: 'variant'
  118. };
  119. Object.entries(deprecatedProps).forEach(([oldProp, newProp]) => {
  120. warning.deprecated(!(oldProp in props), oldProp, newProp);
  121. });
  122. process.env.NODE_ENV !== "production" ? warning(multiple !== false || !treeCheckable, 'usage', '`multiple` will always be `true` when `treeCheckable` is true') : void 0;
  123. process.env.NODE_ENV !== "production" ? warning(!('showArrow' in props), 'deprecated', '`showArrow` is deprecated which will be removed in next major version. It will be a default behavior, you can hide it by setting `suffixIcon` to null.') : void 0;
  124. }
  125. const rootPrefixCls = getPrefixCls();
  126. const prefixCls = getPrefixCls('select', customizePrefixCls);
  127. const treePrefixCls = getPrefixCls('select-tree', customizePrefixCls);
  128. const treeSelectPrefixCls = getPrefixCls('tree-select', customizePrefixCls);
  129. const {
  130. compactSize,
  131. compactItemClassnames
  132. } = (0, _Compact.useCompactItemContext)(prefixCls, direction);
  133. const rootCls = (0, _useCSSVarCls.default)(prefixCls);
  134. const treeSelectRootCls = (0, _useCSSVarCls.default)(treeSelectPrefixCls);
  135. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
  136. const [treeSelectWrapCSSVar] = (0, _style2.default)(treeSelectPrefixCls, treePrefixCls, treeSelectRootCls);
  137. const [variant, enableVariantCls] = (0, _useVariants.default)('treeSelect', customVariant, bordered);
  138. const mergedPopupClassName = (0, _classnames.default)(((_a = classNames === null || classNames === void 0 ? void 0 : classNames.popup) === null || _a === void 0 ? void 0 : _a.root) || ((_b = contextClassNames === null || contextClassNames === void 0 ? void 0 : contextClassNames.popup) === null || _b === void 0 ? void 0 : _b.root) || popupClassName || dropdownClassName, `${treeSelectPrefixCls}-dropdown`, {
  139. [`${treeSelectPrefixCls}-dropdown-rtl`]: direction === 'rtl'
  140. }, rootClassName, contextClassNames.root, classNames === null || classNames === void 0 ? void 0 : classNames.root, cssVarCls, rootCls, treeSelectRootCls, hashId);
  141. const mergedPopupStyle = ((_c = styles === null || styles === void 0 ? void 0 : styles.popup) === null || _c === void 0 ? void 0 : _c.root) || ((_d = contextStyles === null || contextStyles === void 0 ? void 0 : contextStyles.popup) === null || _d === void 0 ? void 0 : _d.root) || dropdownStyle;
  142. const mergedPopupRender = (0, _usePopupRender.default)(popupRender || dropdownRender);
  143. const mergedOnOpenChange = onOpenChange || onDropdownVisibleChange;
  144. const isMultiple = !!(treeCheckable || multiple);
  145. const mergedMaxCount = React.useMemo(() => {
  146. if (maxCount && (showCheckedStrategy === 'SHOW_ALL' && !treeCheckStrictly || showCheckedStrategy === 'SHOW_PARENT')) {
  147. return undefined;
  148. }
  149. return maxCount;
  150. }, [maxCount, showCheckedStrategy, treeCheckStrictly]);
  151. const showSuffixIcon = (0, _useShowArrow.default)(props.suffixIcon, props.showArrow);
  152. const mergedPopupMatchSelectWidth = (_e = popupMatchSelectWidth !== null && popupMatchSelectWidth !== void 0 ? popupMatchSelectWidth : dropdownMatchSelectWidth) !== null && _e !== void 0 ? _e : contextPopupMatchSelectWidth;
  153. // ===================== Form =====================
  154. const {
  155. status: contextStatus,
  156. hasFeedback,
  157. isFormItemInput,
  158. feedbackIcon
  159. } = React.useContext(_context2.FormItemInputContext);
  160. const mergedStatus = (0, _statusUtils.getMergedStatus)(contextStatus, customStatus);
  161. // ===================== Icons =====================
  162. const {
  163. suffixIcon,
  164. removeIcon,
  165. clearIcon
  166. } = (0, _useIcons.default)(Object.assign(Object.assign({}, restProps), {
  167. multiple: isMultiple,
  168. showSuffixIcon,
  169. hasFeedback,
  170. feedbackIcon,
  171. prefixCls,
  172. componentName: 'TreeSelect'
  173. }));
  174. const mergedAllowClear = allowClear === true ? {
  175. clearIcon
  176. } : allowClear;
  177. // ===================== Empty =====================
  178. let mergedNotFound;
  179. if (notFoundContent !== undefined) {
  180. mergedNotFound = notFoundContent;
  181. } else {
  182. mergedNotFound = (renderEmpty === null || renderEmpty === void 0 ? void 0 : renderEmpty('Select')) || /*#__PURE__*/React.createElement(_defaultRenderEmpty.default, {
  183. componentName: "Select"
  184. });
  185. }
  186. // ==================== Render =====================
  187. const selectProps = (0, _omit.default)(restProps, ['suffixIcon', 'removeIcon', 'clearIcon', 'itemIcon', 'switcherIcon', 'style']);
  188. // ===================== Placement =====================
  189. const memoizedPlacement = React.useMemo(() => {
  190. if (placement !== undefined) {
  191. return placement;
  192. }
  193. return direction === 'rtl' ? 'bottomRight' : 'bottomLeft';
  194. }, [placement, direction]);
  195. const mergedSize = (0, _useSize.default)(ctx => {
  196. var _a;
  197. return (_a = customizeSize !== null && customizeSize !== void 0 ? customizeSize : compactSize) !== null && _a !== void 0 ? _a : ctx;
  198. });
  199. // ===================== Disabled =====================
  200. const disabled = React.useContext(_DisabledContext.default);
  201. const mergedDisabled = customDisabled !== null && customDisabled !== void 0 ? customDisabled : disabled;
  202. const mergedClassName = (0, _classnames.default)(!customizePrefixCls && treeSelectPrefixCls, {
  203. [`${prefixCls}-lg`]: mergedSize === 'large',
  204. [`${prefixCls}-sm`]: mergedSize === 'small',
  205. [`${prefixCls}-rtl`]: direction === 'rtl',
  206. [`${prefixCls}-${variant}`]: enableVariantCls,
  207. [`${prefixCls}-in-form-item`]: isFormItemInput
  208. }, (0, _statusUtils.getStatusClassNames)(prefixCls, mergedStatus, hasFeedback), compactItemClassnames, className, rootClassName, contextClassNames.root, classNames === null || classNames === void 0 ? void 0 : classNames.root, cssVarCls, rootCls, treeSelectRootCls, hashId);
  209. const renderSwitcherIcon = nodeProps => (/*#__PURE__*/React.createElement(_iconUtil.default, {
  210. prefixCls: treePrefixCls,
  211. switcherIcon: switcherIcon,
  212. treeNodeProps: nodeProps,
  213. showLine: treeLine
  214. }));
  215. // ============================ zIndex ============================
  216. const [zIndex] = (0, _useZIndex.useZIndex)('SelectLike', mergedPopupStyle === null || mergedPopupStyle === void 0 ? void 0 : mergedPopupStyle.zIndex);
  217. const returnNode = /*#__PURE__*/React.createElement(_rcTreeSelect.default, Object.assign({
  218. virtual: virtual,
  219. disabled: mergedDisabled
  220. }, selectProps, {
  221. dropdownMatchSelectWidth: mergedPopupMatchSelectWidth,
  222. builtinPlacements: (0, _mergedBuiltinPlacements.default)(builtinPlacements, popupOverflow),
  223. ref: ref,
  224. prefixCls: prefixCls,
  225. className: mergedClassName,
  226. style: Object.assign(Object.assign({}, styles === null || styles === void 0 ? void 0 : styles.root), style),
  227. listHeight: listHeight,
  228. listItemHeight: listItemHeight,
  229. treeCheckable: treeCheckable ? /*#__PURE__*/React.createElement("span", {
  230. className: `${prefixCls}-tree-checkbox-inner`
  231. }) : treeCheckable,
  232. treeLine: !!treeLine,
  233. suffixIcon: suffixIcon,
  234. multiple: isMultiple,
  235. placement: memoizedPlacement,
  236. removeIcon: removeIcon,
  237. allowClear: mergedAllowClear,
  238. switcherIcon: renderSwitcherIcon,
  239. showTreeIcon: treeIcon,
  240. notFoundContent: mergedNotFound,
  241. getPopupContainer: getPopupContainer || getContextPopupContainer,
  242. treeMotion: null,
  243. dropdownClassName: mergedPopupClassName,
  244. dropdownStyle: Object.assign(Object.assign({}, mergedPopupStyle), {
  245. zIndex
  246. }),
  247. dropdownRender: mergedPopupRender,
  248. onDropdownVisibleChange: mergedOnOpenChange,
  249. choiceTransitionName: (0, _motion.getTransitionName)(rootPrefixCls, '', choiceTransitionName),
  250. transitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'slide-up', transitionName),
  251. treeExpandAction: treeExpandAction,
  252. tagRender: isMultiple ? tagRender : undefined,
  253. maxCount: mergedMaxCount,
  254. showCheckedStrategy: showCheckedStrategy,
  255. treeCheckStrictly: treeCheckStrictly
  256. }));
  257. return wrapCSSVar(treeSelectWrapCSSVar(returnNode));
  258. };
  259. const TreeSelectRef = /*#__PURE__*/React.forwardRef(InternalTreeSelect);
  260. const TreeSelect = TreeSelectRef;
  261. // We don't care debug panel
  262. /* istanbul ignore next */
  263. const PurePanel = (0, _PurePanel.default)(TreeSelect, 'dropdownAlign', props => (0, _omit.default)(props, ['visible']));
  264. TreeSelect.TreeNode = _rcTreeSelect.TreeNode;
  265. TreeSelect.SHOW_ALL = _rcTreeSelect.SHOW_ALL;
  266. TreeSelect.SHOW_PARENT = _rcTreeSelect.SHOW_PARENT;
  267. TreeSelect.SHOW_CHILD = _rcTreeSelect.SHOW_CHILD;
  268. TreeSelect._InternalPanelDoNotUseOrYouWillBeFired = PurePanel;
  269. if (process.env.NODE_ENV !== 'production') {
  270. TreeSelect.displayName = 'TreeSelect';
  271. }
  272. var _default = exports.default = TreeSelect;