-type DataExplorerState = Pick<DataTableProps<DataItem>, "columns">;
-
-class DataExplorer extends React.Component<DataExplorerProps, DataExplorerState> {
-
- state: DataExplorerState = {
- columns: [
- {
- header: "Name",
- selected: true,
- render: item => (
- <Grid
- container
- alignItems="center"
- wrap="nowrap"
- spacing={16}
- onClick={() => this.props.onItemClick(item)}
- >
- <Grid item>
- {renderIcon(item)}
- </Grid>
- <Grid item>
- <Typography color="primary">
- {item.name}
- </Typography>
- </Grid>
- </Grid>
- )
- },
- {
- header: "Status",
- selected: true,
- render: item => (
- <Typography noWrap align="center">
- {item.status || "-"}
- </Typography>
- )
- },
- {
- header: "Type",
- selected: true,
- render: item => (
- <Typography noWrap>
- {item.type}
- </Typography>
- )
- },
- {
- header: "Owner",
- selected: true,
- render: item => (
- <Typography noWrap color="primary">
- {item.owner}
- </Typography>
- )
- },
- {
- header: "File size",
- selected: true,
- render: ({ fileSize }) => (
- <Typography noWrap>
- {typeof fileSize === "number" ? formatFileSize(fileSize) : "-"}
- </Typography>
- )
- },
- {
- header: "Last modified",
- selected: true,
- render: item => (
- <Typography noWrap>
- {formatDate(item.lastModified)}
- </Typography>
- )
- },
- {
- header: "Actions",
- key: "Actions",
- selected: true,
- configurable: false,
- renderHeader: () => (
- <Grid container justify="flex-end">
- <ColumnsConfigurator
- columns={this.state.columns}
- onColumnToggle={this.toggleColumn}
- />
- </Grid>
- ),
- render: item => (
- <Grid container justify="flex-end">
- <Popover triggerComponent={ItemActionsTrigger}>
- <List dense>
- {[
- {
- icon: "fas fa-users",
- label: "Share"
- },
- {
- icon: "fas fa-sign-out-alt",
- label: "Move to"
- },
- {
- icon: "fas fa-star",
- label: "Add to favourite"
- },
- {
- icon: "fas fa-edit",
- label: "Rename"
- },
- {
- icon: "fas fa-copy",
- label: "Make a copy"
- },
- {
- icon: "fas fa-download",
- label: "Download"
- }].map(renderAction)
- }
- < Divider />
- {
- renderAction({ icon: "fas fa-trash-alt", label: "Remove" })
- }
- </List>
- </Popover>
- </Grid>
- )
- }
- ]