1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from 'react';
6 import Drawer from '@material-ui/core/Drawer';
7 import IconButton from "@material-ui/core/IconButton";
8 import CloseIcon from '@material-ui/icons/Close';
9 import { StyleRulesCallback, WithStyles, withStyles, Theme } from "@material-ui/core/styles";
10 import Tabs from '@material-ui/core/Tabs';
11 import Tab from '@material-ui/core/Tab';
12 import Typography from '@material-ui/core/Typography';
13 import * as classnames from "classnames";
14 import Grid from '@material-ui/core/Grid';
16 function TabContainer(props: any) {
18 <Typography component="div" style={{ padding: 8 * 3 }}>
24 export interface DetailsPanelProps {
25 toggleDrawer: (isOpened: boolean) => void;
29 class DetailsPanel extends React.Component<DetailsPanelProps & WithStyles<CssRules>, {}> {
34 handleChange = (event: any, value: boolean) => {
35 this.setState({ tabsValue: value });
39 const { classes, toggleDrawer, isOpened } = this.props;
40 const { tabsValue } = this.state;
42 <div className={classes.container}>
43 <Drawer variant="persistent" anchor="right" open={isOpened} onClose={() => toggleDrawer(false)}
45 paper: classes.drawerPaper
47 {/* className={classnames([classes.root, { [classes.active]: isActive }])} */}
48 <Typography component="div" className={classes.headerContainer}>
49 <Grid container alignItems='center' justify='space-around'>
50 <Typography variant="title" className={classes.headerTitle} gutterBottom>
53 <IconButton color="inherit" onClick={() => toggleDrawer(false)}>
58 <Tabs value={tabsValue} onChange={this.handleChange}
59 classes={{ indicator: classes.tabsIndicator }}>
62 classes={{ root: classes.tabRoot, selected: classes.tabSelected }}
66 classes={{ root: classes.tabRoot, selected: classes.tabSelected }}
69 {tabsValue === 0 && <TabContainer>
71 <Grid item xs={6} sm={4} className={classes.gridLabel}>
77 <Grid item xs={6} sm={4}>
85 {tabsValue === 1 && <TabContainer>
87 <Grid item xs={6} sm={4} className={classes.gridLabel}>
93 <Grid item xs={6} sm={4}>
108 type CssRules = 'drawerPaper' | 'container' | 'headerContainer' | 'headerTitle'
109 | 'tabsIndicator' | 'tabRoot' | 'tabContainer' | 'tabSelected' | 'gridLabel';
111 const drawerWidth = 320;
112 const purple = '#692498';
113 const styles: StyleRulesCallback<CssRules> = (theme: Theme) => ({
115 position: 'relative',
119 position: 'relative',
124 margin: `${theme.spacing.unit}px 0`
130 backgroundColor: purple
140 padding: theme.spacing.unit * 3
148 export default withStyles(styles)(DetailsPanel);