| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- var _typeof = require("@babel/runtime/helpers/typeof");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.directoryTreeProps = exports.default = void 0;
- var _vue = require("vue");
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _debounce = _interopRequireDefault(require("lodash/debounce"));
- var _FolderOpenOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/FolderOpenOutlined"));
- var _FolderOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/FolderOutlined"));
- var _FileOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/FileOutlined"));
- var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
- var _Tree = _interopRequireWildcard(require("./Tree"));
- var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps"));
- var _treeUtil = require("../vc-tree/utils/treeUtil");
- var _util = require("../vc-tree/util");
- var _dictUtil = require("./utils/dictUtil");
- var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
- var _propsUtil = require("../_util/props-util");
- var _excluded = ["icon", "blockNode"];
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
- var directoryTreeProps = function directoryTreeProps() {
- return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _Tree.treeProps)()), {}, {
- expandAction: {
- type: [Boolean, String]
- }
- });
- };
- exports.directoryTreeProps = directoryTreeProps;
- function getIcon(props) {
- var isLeaf = props.isLeaf,
- expanded = props.expanded;
- if (isLeaf) {
- return (0, _vue.createVNode)(_FileOutlined.default, null, null);
- }
- return expanded ? (0, _vue.createVNode)(_FolderOpenOutlined.default, null, null) : (0, _vue.createVNode)(_FolderOutlined.default, null, null);
- }
- var _default = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'ADirectoryTree',
- inheritAttrs: false,
- props: (0, _initDefaultProps.default)(directoryTreeProps(), {
- showIcon: true,
- expandAction: 'click'
- }),
- slots: ['icon', 'title', 'switcherIcon', 'titleRender'],
- // emits: [
- // 'update:selectedKeys',
- // 'update:checkedKeys',
- // 'update:expandedKeys',
- // 'expand',
- // 'select',
- // 'check',
- // 'doubleclick',
- // 'dblclick',
- // 'click',
- // ],
- setup: function setup(props, _ref) {
- var _slots$default;
- var attrs = _ref.attrs,
- slots = _ref.slots,
- emit = _ref.emit,
- expose = _ref.expose;
- // convertTreeToData 兼容 a-tree-node 历史写法,未来a-tree-node移除后,删除相关代码,不要再render中调用 treeData,否则死循环
- var treeData = (0, _vue.ref)(props.treeData || (0, _treeUtil.convertTreeToData)((0, _propsUtil.filterEmpty)((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots))));
- (0, _vue.watch)(function () {
- return props.treeData;
- }, function () {
- treeData.value = props.treeData;
- });
- (0, _vue.onUpdated)(function () {
- (0, _vue.nextTick)(function () {
- if (props.treeData === undefined && slots.default) {
- var _slots$default2;
- treeData.value = (0, _treeUtil.convertTreeToData)((0, _propsUtil.filterEmpty)((_slots$default2 = slots.default) === null || _slots$default2 === void 0 ? void 0 : _slots$default2.call(slots)));
- }
- });
- });
- // Shift click usage
- var lastSelectedKey = (0, _vue.ref)();
- var cachedSelectedKeys = (0, _vue.ref)();
- var fieldNames = (0, _vue.computed)(function () {
- return (0, _treeUtil.fillFieldNames)(props.fieldNames);
- });
- var treeRef = (0, _vue.ref)();
- var scrollTo = function scrollTo(scroll) {
- var _treeRef$value;
- (_treeRef$value = treeRef.value) === null || _treeRef$value === void 0 ? void 0 : _treeRef$value.scrollTo(scroll);
- };
- expose({
- scrollTo: scrollTo,
- selectedKeys: (0, _vue.computed)(function () {
- var _treeRef$value2;
- return (_treeRef$value2 = treeRef.value) === null || _treeRef$value2 === void 0 ? void 0 : _treeRef$value2.selectedKeys;
- }),
- checkedKeys: (0, _vue.computed)(function () {
- var _treeRef$value3;
- return (_treeRef$value3 = treeRef.value) === null || _treeRef$value3 === void 0 ? void 0 : _treeRef$value3.checkedKeys;
- }),
- halfCheckedKeys: (0, _vue.computed)(function () {
- var _treeRef$value4;
- return (_treeRef$value4 = treeRef.value) === null || _treeRef$value4 === void 0 ? void 0 : _treeRef$value4.halfCheckedKeys;
- }),
- loadedKeys: (0, _vue.computed)(function () {
- var _treeRef$value5;
- return (_treeRef$value5 = treeRef.value) === null || _treeRef$value5 === void 0 ? void 0 : _treeRef$value5.loadedKeys;
- }),
- loadingKeys: (0, _vue.computed)(function () {
- var _treeRef$value6;
- return (_treeRef$value6 = treeRef.value) === null || _treeRef$value6 === void 0 ? void 0 : _treeRef$value6.loadingKeys;
- }),
- expandedKeys: (0, _vue.computed)(function () {
- var _treeRef$value7;
- return (_treeRef$value7 = treeRef.value) === null || _treeRef$value7 === void 0 ? void 0 : _treeRef$value7.expandedKeys;
- })
- });
- var getInitExpandedKeys = function getInitExpandedKeys() {
- var _convertDataToEntitie = (0, _treeUtil.convertDataToEntities)(treeData.value, {
- fieldNames: fieldNames.value
- }),
- keyEntities = _convertDataToEntitie.keyEntities;
- var initExpandedKeys;
- // Expanded keys
- if (props.defaultExpandAll) {
- initExpandedKeys = Object.keys(keyEntities);
- } else if (props.defaultExpandParent) {
- initExpandedKeys = (0, _util.conductExpandParent)(props.expandedKeys || props.defaultExpandedKeys || [], keyEntities);
- } else {
- initExpandedKeys = props.expandedKeys || props.defaultExpandedKeys;
- }
- return initExpandedKeys;
- };
- var selectedKeys = (0, _vue.ref)(props.selectedKeys || props.defaultSelectedKeys || []);
- var expandedKeys = (0, _vue.ref)(getInitExpandedKeys());
- (0, _vue.watch)(function () {
- return props.selectedKeys;
- }, function () {
- if (props.selectedKeys !== undefined) {
- selectedKeys.value = props.selectedKeys;
- }
- }, {
- immediate: true
- });
- (0, _vue.watch)(function () {
- return props.expandedKeys;
- }, function () {
- if (props.expandedKeys !== undefined) {
- expandedKeys.value = props.expandedKeys;
- }
- }, {
- immediate: true
- });
- var expandFolderNode = function expandFolderNode(event, node) {
- var isLeaf = node.isLeaf;
- if (isLeaf || event.shiftKey || event.metaKey || event.ctrlKey) {
- return;
- }
- // Call internal rc-tree expand function
- // https://github.com/ant-design/ant-design/issues/12567
- treeRef.value.onNodeExpand(event, node);
- };
- var onDebounceExpand = (0, _debounce.default)(expandFolderNode, 200, {
- leading: true
- });
- var onExpand = function onExpand(keys, info) {
- if (props.expandedKeys === undefined) {
- expandedKeys.value = keys;
- }
- // Call origin function
- emit('update:expandedKeys', keys);
- emit('expand', keys, info);
- };
- var onClick = function onClick(event, node) {
- var expandAction = props.expandAction;
- // Expand the tree
- if (expandAction === 'click') {
- onDebounceExpand(event, node);
- }
- emit('click', event, node);
- };
- var onDoubleClick = function onDoubleClick(event, node) {
- var expandAction = props.expandAction;
- // Expand the tree
- if (expandAction === 'dblclick' || expandAction === 'doubleclick') {
- onDebounceExpand(event, node);
- }
- emit('doubleclick', event, node);
- emit('dblclick', event, node);
- };
- var onSelect = function onSelect(keys, event) {
- var multiple = props.multiple;
- var node = event.node,
- nativeEvent = event.nativeEvent;
- var key = node[fieldNames.value.key];
- // const newState: DirectoryTreeState = {};
- // We need wrap this event since some value is not same
- var newEvent = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, event), {}, {
- selected: true // Directory selected always true
- });
- // Windows / Mac single pick
- var ctrlPick = (nativeEvent === null || nativeEvent === void 0 ? void 0 : nativeEvent.ctrlKey) || (nativeEvent === null || nativeEvent === void 0 ? void 0 : nativeEvent.metaKey);
- var shiftPick = nativeEvent === null || nativeEvent === void 0 ? void 0 : nativeEvent.shiftKey;
- // Generate new selected keys
- var newSelectedKeys;
- if (multiple && ctrlPick) {
- // Control click
- newSelectedKeys = keys;
- lastSelectedKey.value = key;
- cachedSelectedKeys.value = newSelectedKeys;
- newEvent.selectedNodes = (0, _dictUtil.convertDirectoryKeysToNodes)(treeData.value, newSelectedKeys, fieldNames.value);
- } else if (multiple && shiftPick) {
- // Shift click
- newSelectedKeys = Array.from(new Set([].concat((0, _toConsumableArray2.default)(cachedSelectedKeys.value || []), (0, _toConsumableArray2.default)((0, _dictUtil.calcRangeKeys)({
- treeData: treeData.value,
- expandedKeys: expandedKeys.value,
- startKey: key,
- endKey: lastSelectedKey.value,
- fieldNames: fieldNames.value
- })))));
- newEvent.selectedNodes = (0, _dictUtil.convertDirectoryKeysToNodes)(treeData.value, newSelectedKeys, fieldNames.value);
- } else {
- // Single click
- newSelectedKeys = [key];
- lastSelectedKey.value = key;
- cachedSelectedKeys.value = newSelectedKeys;
- newEvent.selectedNodes = (0, _dictUtil.convertDirectoryKeysToNodes)(treeData.value, newSelectedKeys, fieldNames.value);
- }
- emit('update:selectedKeys', newSelectedKeys);
- emit('select', newSelectedKeys, newEvent);
- if (props.selectedKeys === undefined) {
- selectedKeys.value = newSelectedKeys;
- }
- };
- var onCheck = function onCheck(checkedObjOrKeys, eventObj) {
- emit('update:checkedKeys', checkedObjOrKeys);
- emit('check', checkedObjOrKeys, eventObj);
- };
- var _useConfigInject = (0, _useConfigInject2.default)('tree', props),
- prefixCls = _useConfigInject.prefixCls,
- direction = _useConfigInject.direction;
- return function () {
- var connectClassName = (0, _classNames2.default)("".concat(prefixCls.value, "-directory"), (0, _defineProperty2.default)({}, "".concat(prefixCls.value, "-directory-rtl"), direction.value === 'rtl'), attrs.class);
- var _props$icon = props.icon,
- icon = _props$icon === void 0 ? slots.icon : _props$icon,
- _props$blockNode = props.blockNode,
- blockNode = _props$blockNode === void 0 ? true : _props$blockNode,
- otherProps = (0, _objectWithoutProperties2.default)(props, _excluded);
- return (0, _vue.createVNode)(_Tree.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
- "icon": icon || getIcon,
- "ref": treeRef,
- "blockNode": blockNode
- }, otherProps), {}, {
- "prefixCls": prefixCls.value,
- "class": connectClassName,
- "expandedKeys": expandedKeys.value,
- "selectedKeys": selectedKeys.value,
- "onSelect": onSelect,
- "onClick": onClick,
- "onDblclick": onDoubleClick,
- "onExpand": onExpand,
- "onCheck": onCheck
- }), slots);
- };
- }
- });
- exports.default = _default;
|