- }
-
- changePage = (event: React.MouseEvent<HTMLButtonElement> | null, page: number) => {
- this.props.onChangePage(page);
- }
-
- changeRowsPerPage: React.ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement> = (event) => {
- this.props.onChangeRowsPerPage(parseInt(event.target.value, 10));
- }
-
- renderContextMenuTrigger = (item: T) =>
- <Grid container justify="flex-end">
- <IconButton onClick={event => this.openContextMenuTrigger(event, item)}>
- <MoreVertIcon />
- </IconButton>
- </Grid>
-
- openContextMenuTrigger = (event: React.MouseEvent<HTMLElement>, item: T) => {
- event.preventDefault();
- this.setState({
- contextMenu: {
- anchorEl: event.currentTarget,
- item
- }
- });
- }
-
- contextMenuColumn = {
- name: "Actions",
- selected: true,
- key: "context-actions",
- renderHeader: () => null,
- render: this.renderContextMenuTrigger,
- width: "auto"
- };
+ render() {
+ const {
+ columns, onContextMenu, onFiltersChange, onSortToggle, extractKey,
+ rowsPerPage, rowsPerPageOptions, onColumnToggle, searchValue, onSearch,
+ items, itemsAvailable, onRowClick, onRowDoubleClick, defaultIcon, defaultMessages, classes
+ } = this.props;
+ return <div>
+ { items.length > 0 ? (
+ <Paper>
+ <Toolbar className={classes.toolbar}>
+ <Grid container justify="space-between" wrap="nowrap" alignItems="center">
+ <div className={classes.searchBox}>
+ <SearchInput
+ value={searchValue}
+ onSearch={onSearch}/>
+ </div>
+ <ColumnSelector
+ columns={columns}
+ onColumnToggle={onColumnToggle}/>
+ </Grid>
+ </Toolbar>
+ <DataTable
+ columns={[...columns, this.contextMenuColumn]}
+ items={items}
+ onRowClick={(_, item: T) => onRowClick(item)}
+ onContextMenu={onContextMenu}
+ onRowDoubleClick={(_, item: T) => onRowDoubleClick(item)}
+ onFiltersChange={onFiltersChange}
+ onSortToggle={onSortToggle}
+ extractKey={extractKey}/>
+ <Toolbar>
+ <Grid container justify="flex-end">
+ <TablePagination
+ count={itemsAvailable}
+ rowsPerPage={rowsPerPage}
+ rowsPerPageOptions={rowsPerPageOptions}
+ page={this.props.page}
+ onChangePage={this.changePage}
+ onChangeRowsPerPage={this.changeRowsPerPage}
+ component="div" />
+ </Grid>
+ </Toolbar>
+ </Paper>
+ ) : (
+ <DefaultView
+ classRoot={classes.defaultRoot}
+ icon={defaultIcon}
+ classIcon={classes.defaultIcon}
+ messages={defaultMessages}
+ classMessage={classes.defaultMessage} />
+ )}
+ </div>;
+ }