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 } from "../tree/tree";
7 import { ProjectIcon, MoreOptionsIcon, DefaultIcon, CollectionIcon } from "../icon/icon";
8 import { Typography, IconButton, StyleRulesCallback, withStyles, WithStyles, Tooltip } from '@material-ui/core';
9 import { formatFileSize } from "~/common/formatters";
10 import { ListItemTextIcon } from "../list-item-text-icon/list-item-text-icon";
11 import { FileTreeData } from "./file-tree-data";
12 import { FileThumbnail } from '~/components/file-tree/file-thumbnail';
14 type CssRules = "root" | "spacer" | "sizeInfo" | "button" | "moreOptions";
16 const fileTreeItemStyle: StyleRulesCallback<CssRules> = theme => ({
20 paddingRight: `${theme.spacing.unit * 1.5}px`
26 width: `${theme.spacing.unit * 8}px`
29 width: theme.spacing.unit * 3,
30 height: theme.spacing.unit * 3,
31 marginRight: theme.spacing.unit,
38 export interface FileTreeItemProps {
39 item: TreeItem<FileTreeData>;
40 onMoreClick: (event: React.MouseEvent<any>, item: TreeItem<FileTreeData>) => void;
42 export const FileTreeItem = withStyles(fileTreeItemStyle)(
43 class extends React.Component<FileTreeItemProps & WithStyles<CssRules>> {
45 const { classes, item } = this.props;
47 <div className={classes.root}>
50 name={item.data.name} />
51 <div className={classes.spacer} />
53 className={classes.sizeInfo}
54 variant="caption">{formatFileSize(item.data.size)}</Typography>
55 <Tooltip title="More options" disableFocusListener>
57 className={classes.button}
58 onClick={this.handleClick}>
59 <MoreOptionsIcon className={classes.moreOptions} />
63 <FileThumbnail file={item.data} />
67 handleClick = (event: React.MouseEvent<any>) => {
68 this.props.onMoreClick(event, this.props.item);
72 const getIcon = (item: TreeItem<FileTreeData>) => {
73 switch (item.data.type) {
77 return CollectionIcon;