X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/72c12f527787181e4abb09fc968f07e795179c3c..dcf2e835b33e926073dad1f636cf92a95493ca0b:/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 d6f2fa4a..298a5a1e 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,8 +2,10 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { CollectionFile, CollectionDirectory, CollectionFileType } from '../../../models/collection-file'; -import { Tree, TreeNode } from '../../../models/tree'; +import { Tree, TreeNode, mapTreeValues, getNodeValue, getNodeDescendants } from 'models/tree'; +import { CollectionFile, CollectionDirectory, CollectionFileType } from 'models/collection-file'; +import { ContextMenuResource } from 'store/context-menu/context-menu-actions'; +import { CollectionResource } from 'models/collection'; export type CollectionPanelFilesState = Tree; @@ -16,6 +18,11 @@ export interface CollectionPanelFile extends CollectionFile { selected: boolean; } +export interface CollectionFileSelection { + collection: CollectionResource; + selectedPaths: string[]; +} + export const mapCollectionFileToCollectionPanelFile = (node: TreeNode): TreeNode => { return { ...node, @@ -23,4 +30,34 @@ export const mapCollectionFileToCollectionPanelFile = (node: TreeNode { + 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): (CollectionPanelFile | CollectionPanelDirectory)[] => { + 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] + .filter((value, index, array) => ( + array.indexOf(value) === index + )); +}; + +export const getCollectionSelection = (sourceCollection: CollectionResource, selectedItems: (CollectionPanelDirectory | CollectionPanelFile | ContextMenuResource)[]) => ({ + collection: sourceCollection, + selectedPaths: selectedItems.map(itemsToPaths).map(trimPathUuids(sourceCollection.uuid)), +}) + +const itemsToPaths = (item: (CollectionPanelDirectory | CollectionPanelFile | ContextMenuResource)): string => ('uuid' in item) ? item.uuid : item.id; + +const trimPathUuids = (parentCollectionUuid: string) => (path: string) => path.replace(new RegExp(`(^${parentCollectionUuid})`), '');