X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/6bdb4758d981aa05c19700761d3ace0db7af324a..60894bab3aaca17946060ecf2d3392452547c568:/src/models/tree.ts diff --git a/src/models/tree.ts b/src/models/tree.ts index de2f7b71..e9291388 100644 --- a/src/models/tree.ts +++ b/src/models/tree.ts @@ -43,12 +43,13 @@ export const appendSubtree = (id: string, subtree: Tree) => (tree: Tree )(subtree) as Tree; export const setNode = (node: TreeNode) => (tree: Tree): Tree => { - return pipe( - (tree: Tree) => getNode(node.id)(tree) === node - ? tree - : { ...tree, [node.id]: node }, - addChild(node.parent, node.id) - )(tree); + if (tree[node.id] && tree[node.id] === node) { return tree; } + + tree[node.id] = node; + if (tree[node.parent]) { + tree[node.parent].children = Array.from(new Set([...tree[node.parent].children, node.id])); + } + return tree; }; export const getNodeValue = (id: string) => (tree: Tree) => { @@ -73,6 +74,7 @@ export const setNodeValueWith = (mapFn: (value: T) => T) => (id: string) => ( export const mapTreeValues = (mapFn: (value: T) => R) => (tree: Tree): Tree => getNodeDescendantsIds('')(tree) .map(id => getNode(id)(tree)) + .filter(node => !!node) .map(mapNodeValue(mapFn)) .reduce((newTree, node) => setNode(node)(newTree), createTree()); @@ -156,7 +158,6 @@ export const toggleNodeSelection = (id: string) => (tree: Tree) => { toggleAncestorsSelection(id), toggleDescendantsSelection(id))(tree) : tree; - }; export const selectNode = (id: string) => (tree: Tree) => { @@ -235,23 +236,3 @@ const getRootNodeChildrenIds = (tree: Tree) => Object .keys(tree) .filter(id => getNode(id)(tree)!.parent === TREE_ROOT_ID); - - -const addChild = (parentId: string, childId: string) => (tree: Tree): Tree => { - if (childId === "") { - return tree; - } - const node = getNode(parentId)(tree); - if (node) { - const children = node.children.some(id => id === childId) - ? node.children - : [...node.children, childId]; - - const newNode = children === node.children - ? node - : { ...node, children }; - - return setNode(newNode)(tree); - } - return tree; -};