Skip to content
Snippets Groups Projects
ListView.jsx 2.87 KiB
Newer Older
  • Learn to ignore specific revisions
  • /*
     *  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.
     *
     */
    
    
    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'
      },
    
    vkovtun's avatar
    vkovtun committed
      icon: {
    
        fontSize: '2.5rem'
    
    vkovtun's avatar
    vkovtun committed
      },
      text: {
        fontSize: theme.typography.body2.fontSize,
        lineHeight: theme.typography.body2.fontSize
      },
      listContainer: {
        flex: '1 1 100%'
      },
    
      modifiedColumn: {
        width: '11rem',
        textAlign: 'right'
      },
    
    vkovtun's avatar
    vkovtun committed
      tableRow: {
        fontSize: theme.typography.body1.fontSize,
    
        height: '2rem'
    
    vkovtun's avatar
    vkovtun committed
      },
      tableData: {
    
        padding: theme.spacing(2),
        borderWidth: '0'
    
    vkovtun's avatar
    vkovtun committed
    class ListView extends React.Component {
    
        logger.log(logger.DEBUG, 'ListView.render')
    
        const { classes, files, configuration } = this.props
    
        /* Create strings in messages. */
        return (
    
            <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>
    
    vkovtun's avatar
    vkovtun committed
    export default withStyles(styles)(ListView)