Newer
Older
/*
* Copyright ETH 2023 Zürich, Scientific IT Services
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
vkovtun
committed
import React from 'react'
import { withStyles } from '@material-ui/core/styles'
import Table from '@material-ui/core/Table'
import TableBody from '@material-ui/core/TableBody'
import TableCell from '@material-ui/core/TableCell'
import TableContainer from '@material-ui/core/TableContainer'
import TableHead from '@material-ui/core/TableHead'
import TableRow from '@material-ui/core/TableRow'
import { ListViewItem } from '@src/js/components/database/data-browser/ListViewItem.jsx'
import logger from '@src/js/common/logger.js'
const styles = (theme) => ({
borderSpacing: '0',
fontFamily: theme.typography.fontFamily,
'& thead > tr > th': {
fontWeight: 'bold'
},
'& tbody > tr': {
cursor: 'pointer',
'&:hover': {
backgroundColor: '#0000000a'
}
},
tableHeader: {
textAlign: 'left'
},
},
text: {
fontSize: theme.typography.body2.fontSize,
lineHeight: theme.typography.body2.fontSize
},
listContainer: {
flex: '1 1 100%'
},
modifiedColumn: {
width: '11rem',
textAlign: 'right'
},
tableRow: {
fontSize: theme.typography.body1.fontSize,
padding: theme.spacing(2),
borderWidth: '0'
logger.log(logger.DEBUG, 'ListView.render')
const { classes, files, configuration } = this.props
/* Create strings in messages. */
return (
<TableContainer>
<Table className={classes.content}>
<TableHead>
<TableRow className={classes.tableRow}>
<TableCell className={`${classes.tableData} ${classes.tableHeader}`}>Name</TableCell>
<TableCell className={`${classes.tableData} ${classes.tableHeader}`}>Size</TableCell>
<TableCell className={`${classes.tableData} ${classes.modifiedColumn} ${classes.tableHeader}`}>Modified</TableCell>
</TableRow>
</TableHead>
<TableBody>
{files.map((file, index) =>
<ListViewItem key={index} {...this.props} file={file} />
</TableBody>
</Table>
</TableContainer>