Merge branch '21128-toolbar-context-menu'
[arvados-workbench2.git] / src / views-components / context-menu / actions / download-collection-file-action.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { connect } from "react-redux";
6 import { RootState } from "../../../store/store";
7 import { DownloadAction } from "./download-action";
8 import { getNodeValue } from "../../../models/tree";
9 import { ContextMenuKind } from '../context-menu';
10 import { filterCollectionFilesBySelection } from "store/collection-panel/collection-panel-files/collection-panel-files-state";
11 import { sanitizeToken } from "./helpers";
12
13 const mapStateToProps = (state: RootState) => {
14     const { resource } = state.contextMenu;
15     const currentCollectionUuid = state.collectionPanel.item ? state.collectionPanel.item.uuid : '';
16     if (resource && [
17         ContextMenuKind.COLLECTION_FILE_ITEM,
18         ContextMenuKind.READONLY_COLLECTION_FILE_ITEM,
19         ContextMenuKind.COLLECTION_DIRECTORY_ITEM,
20         ContextMenuKind.READONLY_COLLECTION_DIRECTORY_ITEM ].indexOf(resource.menuKind as ContextMenuKind) > -1) {
21         const file = getNodeValue(resource.uuid)(state.collectionPanelFiles);
22         if (file) {
23             return {
24                 href: sanitizeToken(file.url, true),
25                 kind: 'file',
26                 currentCollectionUuid
27             };
28         }
29     } else {
30         const files = filterCollectionFilesBySelection(state.collectionPanelFiles, true);
31         return {
32             href: files.map(file => file.url),
33             kind: 'files',
34             currentCollectionUuid
35         };
36     }
37     return {};
38 };
39
40 export const DownloadCollectionFileAction = connect(mapStateToProps)(DownloadAction);