Merge branch '14841-link-workbench1' refs #14841 refs #14720
[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     onUploadDataClick: () => void;
16     onItemMenuOpen: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>) => void;
17     onOptionsMenuOpen: (event: React.MouseEvent<HTMLElement>) => void;
18     onSelectionToggle: (event: React.MouseEvent<HTMLElement>, item: TreeItem<FileTreeData>) => void;
19     onCollapseToggle: (id: string, status: TreeItemStatus) => void;
20     onFileClick: (id: string) => void;
21     currentItemUuid?: string;
22 }
23
24 type CssRules = 'root' | 'cardSubheader' | 'nameHeader' | 'fileSizeHeader' | 'uploadIcon' | 'button';
25
26 const styles: StyleRulesCallback<CssRules> = theme => ({
27     root: {
28         paddingBottom: theme.spacing.unit
29     },
30     cardSubheader: {
31         paddingTop: 0,
32         paddingBottom: 0
33     },
34     nameHeader: {
35         marginLeft: '75px'
36     },
37     fileSizeHeader: {
38         marginRight: '65px'
39     },
40     uploadIcon: {
41         transform: 'rotate(180deg)'
42     },
43     button: {
44         marginRight: -theme.spacing.unit,
45         marginTop: '0px'
46     }
47 });
48
49 export const CollectionPanelFiles =
50     withStyles(styles)(
51         ({ onItemMenuOpen, onOptionsMenuOpen, onUploadDataClick, classes, ...treeProps }: CollectionPanelFilesProps & WithStyles<CssRules>) =>
52             <Card className={classes.root}>
53                 <CardHeader
54                     title="Files"
55                     classes={{ action: classes.button }}
56                     action={
57                         <Button onClick={onUploadDataClick}
58                             variant='contained'
59                             color='primary'
60                             size='small'>
61                             <DownloadIcon className={classes.uploadIcon} />
62                             Upload data
63                     </Button>
64                     } />
65                 <CardHeader
66                     className={classes.cardSubheader}
67                     action={
68                         <Tooltip title="More options" disableFocusListener>
69                             <IconButton onClick={onOptionsMenuOpen}>
70                                 <CustomizeTableIcon />
71                             </IconButton>
72                         </Tooltip>
73                     } />
74                 <Grid container justify="space-between">
75                     <Typography variant="caption" className={classes.nameHeader}>
76                         Name
77                     </Typography>
78                     <Typography variant="caption" className={classes.fileSizeHeader}>
79                         File size
80                     </Typography>
81                 </Grid>
82                 <FileTree onMenuOpen={onItemMenuOpen} {...treeProps} />
83             </Card>);