1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import { TreeItem, TreeItemStatus } from '~/components/tree/tree';
7 import { FileTreeData } from '~/components/file-tree/file-tree-data';
8 import { FileTree } from '~/components/file-tree/file-tree';
9 import { IconButton, Grid, Typography, StyleRulesCallback, withStyles, WithStyles, CardHeader, Card, Button, Tooltip, CircularProgress } from '@material-ui/core';
10 import { CustomizeTableIcon } from '~/components/icon/icon';
11 import { DownloadIcon } from '~/components/icon/icon';
13 export interface CollectionPanelFilesProps {
14 items: Array<TreeItem<FileTreeData>>;
17 tooManyFiles: boolean;
18 onUploadDataClick: () => void;
19 onItemMenuOpen: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>, isWritable: boolean) => void;
20 onOptionsMenuOpen: (event: React.MouseEvent<HTMLElement>, isWritable: boolean) => void;
21 onSelectionToggle: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>) => void;
22 onCollapseToggle: (id: string, status: TreeItemStatus) => void;
23 onFileClick: (id: string) => void;
24 loadFilesFunc: () => void;
25 currentItemUuid?: string;
28 type CssRules = 'root' | 'cardSubheader' | 'nameHeader' | 'fileSizeHeader' | 'uploadIcon' | 'button' | 'centeredLabel';
30 const styles: StyleRulesCallback<CssRules> = theme => ({
32 paddingBottom: theme.spacing.unit,
46 transform: 'rotate(180deg)'
49 marginRight: -theme.spacing.unit,
58 export const CollectionPanelFiles =
60 ({ onItemMenuOpen, onOptionsMenuOpen, onUploadDataClick, classes,
61 isWritable, isLoading, tooManyFiles, loadFilesFunc, ...treeProps }: CollectionPanelFilesProps & WithStyles<CssRules>) =>
62 <Card data-cy='collection-files-panel' className={classes.root}>
65 className={classes.cardSubheader}
66 classes={{ action: classes.button }}
70 data-cy='upload-button'
71 onClick={onUploadDataClick}
75 <DownloadIcon className={classes.uploadIcon} />
79 <Tooltip title="More options" disableFocusListener>
81 data-cy='collection-files-panel-options-btn'
82 onClick={(ev) => onOptionsMenuOpen(ev, isWritable)}>
83 <CustomizeTableIcon />
89 ? <div className={classes.centeredLabel}>
90 File listing may take some time, please click to browse: <Button onClick={loadFilesFunc}><DownloadIcon/>Show files</Button>
93 <Grid container justify="space-between">
94 <Typography variant="caption" className={classes.nameHeader}>
97 <Typography variant="caption" className={classes.fileSizeHeader}>
102 ? <div className={classes.centeredLabel}><CircularProgress /></div>
103 : <div style={{height: 'calc(100% - 60px)'}}><FileTree onMenuOpen={(ev, item) => onItemMenuOpen(ev, item, isWritable)} {...treeProps} /></div> }