Merge branch '16118-readonly-collections-lucas'
[arvados-workbench2.git] / src / components / collection-panel-files / collection-panel-files.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
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 } from '@material-ui/core';
10 import { CustomizeTableIcon } from '~/components/icon/icon';
11 import { DownloadIcon } from '~/components/icon/icon';
12
13 export interface CollectionPanelFilesProps {
14     items: Array<TreeItem<FileTreeData>>;
15     isWritable: boolean;
16     onUploadDataClick: () => void;
17     onItemMenuOpen: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>, isWritable: boolean) => void;
18     onOptionsMenuOpen: (event: React.MouseEvent<HTMLElement>, isWritable: boolean) => void;
19     onSelectionToggle: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>) => void;
20     onCollapseToggle: (id: string, status: TreeItemStatus) => void;
21     onFileClick: (id: string) => void;
22     currentItemUuid?: string;
23 }
24
25 type CssRules = 'root' | 'cardSubheader' | 'nameHeader' | 'fileSizeHeader' | 'uploadIcon' | 'button';
26
27 const styles: StyleRulesCallback<CssRules> = theme => ({
28     root: {
29         paddingBottom: theme.spacing.unit
30     },
31     cardSubheader: {
32         paddingTop: 0,
33         paddingBottom: 0
34     },
35     nameHeader: {
36         marginLeft: '75px'
37     },
38     fileSizeHeader: {
39         marginRight: '65px'
40     },
41     uploadIcon: {
42         transform: 'rotate(180deg)'
43     },
44     button: {
45         marginRight: -theme.spacing.unit,
46         marginTop: '0px'
47     }
48 });
49
50 export const CollectionPanelFiles =
51     withStyles(styles)(
52         ({ onItemMenuOpen, onOptionsMenuOpen, onUploadDataClick, classes, isWritable, ...treeProps }: CollectionPanelFilesProps & WithStyles<CssRules>) =>
53             <Card data-cy='collection-files-panel' className={classes.root}>
54                 <CardHeader
55                     title="Files"
56                     classes={{ action: classes.button }}
57                     action={
58                         isWritable &&
59                         <Button
60                             data-cy='upload-button'
61                             onClick={onUploadDataClick}
62                             variant='contained'
63                             color='primary'
64                             size='small'>
65                             <DownloadIcon className={classes.uploadIcon} />
66                             Upload data
67                         </Button>
68                     } />
69                 <CardHeader
70                     className={classes.cardSubheader}
71                     action={
72                         <Tooltip title="More options" disableFocusListener>
73                             <IconButton
74                                 data-cy='collection-files-panel-options-btn'
75                                 onClick={(ev) => onOptionsMenuOpen(ev, isWritable)}>
76                                 <CustomizeTableIcon />
77                             </IconButton>
78                         </Tooltip>
79                     } />
80                 <Grid container justify="space-between">
81                     <Typography variant="caption" className={classes.nameHeader}>
82                         Name
83                     </Typography>
84                     <Typography variant="caption" className={classes.fileSizeHeader}>
85                         File size
86                     </Typography>
87                 </Grid>
88                 <FileTree onMenuOpen={(ev, item) => onItemMenuOpen(ev, item, isWritable)} {...treeProps} />
89             </Card>);