X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b79348f1be6a2dce8ceede8bd4c2906fc1098e2b..a459a376f98f7cb8741c8ab1057c9578e59dc327:/src/store/collection-panel/collection-panel-files/collection-panel-files-state.ts diff --git a/src/store/collection-panel/collection-panel-files/collection-panel-files-state.ts b/src/store/collection-panel/collection-panel-files/collection-panel-files-state.ts index 953f4c0111..9d5b06cea6 100644 --- a/src/store/collection-panel/collection-panel-files/collection-panel-files-state.ts +++ b/src/store/collection-panel/collection-panel-files/collection-panel-files-state.ts @@ -2,14 +2,44 @@ // // SPDX-License-Identifier: AGPL-3.0 -export type CollectionPanelFilesState = Array; +import { Tree, TreeNode, mapTreeValues, getNodeValue, getNodeDescendants } from '~/models/tree'; +import { CollectionFile, CollectionDirectory, CollectionFileType } from '~/models/collection-file'; -export interface CollectionPanelFile { - parentId?: string; - id: string; - name: string; - size?: number; +export type CollectionPanelFilesState = Tree; + +export interface CollectionPanelDirectory extends CollectionDirectory { collapsed: boolean; selected: boolean; - type: string; -} \ No newline at end of file +} + +export interface CollectionPanelFile extends CollectionFile { + selected: boolean; +} + +export const mapCollectionFileToCollectionPanelFile = (node: TreeNode): TreeNode => { + return { + ...node, + value: node.value.type === CollectionFileType.DIRECTORY + ? { ...node.value, selected: false, collapsed: true } + : { ...node.value, selected: false } + }; +}; + +export const mergeCollectionPanelFilesStates = (oldState: CollectionPanelFilesState, newState: CollectionPanelFilesState) => { + return mapTreeValues((value: CollectionPanelDirectory | CollectionPanelFile) => { + const oldValue = getNodeValue(value.id)(oldState); + return oldValue + ? oldValue.type === CollectionFileType.DIRECTORY + ? { ...value, collapsed: oldValue.collapsed, selected: oldValue.selected } + : { ...value, selected: oldValue.selected } + : value; + })(newState); +}; + +export const filterCollectionFilesBySelection = (tree: CollectionPanelFilesState, selected: boolean) => { + const allFiles = getNodeDescendants('')(tree).map(node => node.value); + + const selectedDirectories = allFiles.filter(file => file.selected === selected && file.type === CollectionFileType.DIRECTORY); + const selectedFiles = allFiles.filter(file => file.selected === selected && !selectedDirectories.some(dir => dir.id === file.path)); + return [...selectedDirectories, ...selectedFiles]; +};