2024-08-02 18:19:39 +08:00

120 lines
3.4 KiB
JavaScript

import { computed } from 'vue';
import { happensIn } from 'seemly';
import { isBrowser } from "../../_utils/index.mjs";
export function useMergedCheckStrategy(props) {
return computed(() => props.leafOnly ? 'child' : props.checkStrategy);
}
export function isNodeDisabled(node, disabledField) {
return !!node.rawNode[disabledField];
}
function traverse(nodes, childrenField, callback, callbackAfter) {
nodes === null || nodes === void 0 ? void 0 : nodes.forEach(node => {
callback(node);
traverse(node[childrenField], childrenField, callback, callbackAfter);
callbackAfter(node);
});
}
export function keysWithFilter(nodes, pattern, keyField, childrenField, filter) {
const keys = new Set();
const highlightKeySet = new Set();
const path = [];
traverse(nodes, childrenField, node => {
path.push(node);
if (filter(pattern, node)) {
highlightKeySet.add(node[keyField]);
for (let i = path.length - 2; i >= 0; --i) {
if (!keys.has(path[i][keyField])) {
keys.add(path[i][keyField]);
} else {
return;
}
}
}
}, () => {
path.pop();
});
return {
expandedKeys: Array.from(keys),
highlightKeySet
};
}
const emptyImage = null;
if (isBrowser && Image) {
const emptyImage = new Image();
emptyImage.src = '';
}
export { emptyImage };
export function filterTree(tree, filter, pattern, keyField, childrenField) {
const visitedTailKeys = new Set();
const visitedNonTailKeys = new Set();
const highlightKeySet = new Set();
const expandedKeys = [];
const filteredTree = [];
const path = [];
function visit(t) {
t.forEach(n => {
path.push(n);
if (filter(pattern, n)) {
visitedTailKeys.add(n[keyField]);
highlightKeySet.add(n[keyField]);
for (let i = path.length - 2; i >= 0; --i) {
const key = path[i][keyField];
if (!visitedNonTailKeys.has(key)) {
visitedNonTailKeys.add(key);
if (visitedTailKeys.has(key)) {
visitedTailKeys.delete(key);
}
} else {
break;
}
}
}
const children = n[childrenField];
if (children) {
visit(children);
}
path.pop();
});
}
visit(tree);
function build(t, sibs) {
t.forEach(n => {
const key = n[keyField];
const isVisitedTail = visitedTailKeys.has(key);
const isVisitedNonTail = visitedNonTailKeys.has(key);
if (!isVisitedTail && !isVisitedNonTail) return;
const children = n[childrenField];
if (children) {
if (isVisitedTail) {
// If it is visited path tail, use origin node
sibs.push(n);
} else {
// It it is not visited path tail, use cloned node
expandedKeys.push(key);
const clonedNode = Object.assign(Object.assign({}, n), {
[childrenField]: []
});
sibs.push(clonedNode);
build(children, clonedNode[childrenField]);
}
} else {
sibs.push(n);
}
});
}
build(tree, filteredTree);
return {
filteredTree,
highlightKeySet,
expandedKeys
};
}
export function treeGetClickTarget(e) {
if (happensIn(e, 'checkbox')) {
return 'checkbox';
} else if (happensIn(e, 'switcher')) {
return 'switcher';
} else {
return 'node';
}
}