123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- "use strict";
- "use client";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _react = _interopRequireDefault(require("react"));
- var _HolderOutlined = _interopRequireDefault(require("@ant-design/icons/HolderOutlined"));
- var _classnames = _interopRequireDefault(require("classnames"));
- var _rcTree = _interopRequireDefault(require("rc-tree"));
- var _motion = _interopRequireDefault(require("../_util/motion"));
- var _configProvider = require("../config-provider");
- var _internal = require("../theme/internal");
- var _style = _interopRequireDefault(require("./style"));
- var _dropIndicator = _interopRequireDefault(require("./utils/dropIndicator"));
- var _iconUtil = _interopRequireDefault(require("./utils/iconUtil"));
- const Tree = /*#__PURE__*/_react.default.forwardRef((props, ref) => {
- var _a;
- const {
- getPrefixCls,
- direction,
- virtual,
- tree
- } = _react.default.useContext(_configProvider.ConfigContext);
- const {
- prefixCls: customizePrefixCls,
- className,
- showIcon = false,
- showLine,
- switcherIcon,
- switcherLoadingIcon,
- blockNode = false,
- children,
- checkable = false,
- selectable = true,
- draggable,
- motion: customMotion,
- style
- } = props;
- const prefixCls = getPrefixCls('tree', customizePrefixCls);
- const rootPrefixCls = getPrefixCls();
- const motion = customMotion !== null && customMotion !== void 0 ? customMotion : Object.assign(Object.assign({}, (0, _motion.default)(rootPrefixCls)), {
- motionAppear: false
- });
- const newProps = Object.assign(Object.assign({}, props), {
- checkable,
- selectable,
- showIcon,
- motion,
- blockNode,
- showLine: Boolean(showLine),
- dropIndicatorRender: _dropIndicator.default
- });
- const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls);
- const [, token] = (0, _internal.useToken)();
- const itemHeight = token.paddingXS / 2 + (((_a = token.Tree) === null || _a === void 0 ? void 0 : _a.titleHeight) || token.controlHeightSM);
- const draggableConfig = _react.default.useMemo(() => {
- if (!draggable) {
- return false;
- }
- let mergedDraggable = {};
- switch (typeof draggable) {
- case 'function':
- mergedDraggable.nodeDraggable = draggable;
- break;
- case 'object':
- mergedDraggable = Object.assign({}, draggable);
- break;
- default:
- break;
- // Do nothing
- }
- if (mergedDraggable.icon !== false) {
- mergedDraggable.icon = mergedDraggable.icon || /*#__PURE__*/_react.default.createElement(_HolderOutlined.default, null);
- }
- return mergedDraggable;
- }, [draggable]);
- const renderSwitcherIcon = nodeProps => (/*#__PURE__*/_react.default.createElement(_iconUtil.default, {
- prefixCls: prefixCls,
- switcherIcon: switcherIcon,
- switcherLoadingIcon: switcherLoadingIcon,
- treeNodeProps: nodeProps,
- showLine: showLine
- }));
- return wrapCSSVar(
- /*#__PURE__*/
- // @ts-ignore
- _react.default.createElement(_rcTree.default, Object.assign({
- itemHeight: itemHeight,
- ref: ref,
- virtual: virtual
- }, newProps, {
- // newProps may contain style so declare style below it
- style: Object.assign(Object.assign({}, tree === null || tree === void 0 ? void 0 : tree.style), style),
- prefixCls: prefixCls,
- className: (0, _classnames.default)({
- [`${prefixCls}-icon-hide`]: !showIcon,
- [`${prefixCls}-block-node`]: blockNode,
- [`${prefixCls}-unselectable`]: !selectable,
- [`${prefixCls}-rtl`]: direction === 'rtl'
- }, tree === null || tree === void 0 ? void 0 : tree.className, className, hashId, cssVarCls),
- direction: direction,
- checkable: checkable ? /*#__PURE__*/_react.default.createElement("span", {
- className: `${prefixCls}-checkbox-inner`
- }) : checkable,
- selectable: selectable,
- switcherIcon: renderSwitcherIcon,
- draggable: draggableConfig
- }), children));
- });
- if (process.env.NODE_ENV !== 'production') {
- Tree.displayName = 'Tree';
- }
- var _default = exports.default = Tree;
|