Add function for listing tree's selected nodes
authorMichal Klobukowski <michal.klobukowski@contractors.roche.com>
Wed, 21 Nov 2018 14:48:23 +0000 (15:48 +0100)
committerMichal Klobukowski <michal.klobukowski@contractors.roche.com>
Wed, 21 Nov 2018 14:48:23 +0000 (15:48 +0100)
Feature #14258

Arvados-DCO-1.1-Signed-off-by: Michal Klobukowski <michal.klobukowski@contractors.roche.com>

src/models/tree.ts

index 1bc15bc0824a500c1121812c252c82eaa2fc7ca0..8b71692b1c8bf8211c606573f99a8876a6392aab 100644 (file)
@@ -178,6 +178,10 @@ export const deselectNodes = (id: string | string[]) => <T>(tree: Tree<T>) => {
     return ids.reduce((tree, id) => deselectNode(id)(tree), tree);
 };
 
+export const getSelectedNodes = <T>(tree: Tree<T>) =>
+    getNodeDescendants('')(tree)
+        .filter(node => node.selected);
+
 export const initTreeNode = <T>(data: Pick<TreeNode<T>, 'id' | 'value'> & { parent?: string }): TreeNode<T> => ({
     children: [],
     active: false,