import { computed } from 'vue'; import { isBrowser } from "../../_utils/index.mjs"; import { happensIn } from 'seemly'; 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'; } }