X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/fc5cb3c6ccabcc1da401d0dd9858fab764e31235..91fdf9e2d937de38309f1464b30cb699df4f6389:/src/components/data-explorer/data-explorer.tsx diff --git a/src/components/data-explorer/data-explorer.tsx b/src/components/data-explorer/data-explorer.tsx index 7107bd70..5f396bb4 100644 --- a/src/components/data-explorer/data-explorer.tsx +++ b/src/components/data-explorer/data-explorer.tsx @@ -2,16 +2,16 @@ // // SPDX-License-Identifier: AGPL-3.0 -import * as React from 'react'; +import React from 'react'; import { Grid, Paper, Toolbar, StyleRulesCallback, withStyles, WithStyles, TablePagination, IconButton, Tooltip, Button } from '@material-ui/core'; -import { ColumnSelector } from "~/components/column-selector/column-selector"; -import { DataTable, DataColumns, DataTableFetchMode } from "~/components/data-table/data-table"; -import { DataColumn } from "~/components/data-table/data-column"; -import { SearchInput } from '~/components/search-input/search-input'; -import { ArvadosTheme } from "~/common/custom-theme"; -import { createTree } from '~/models/tree'; -import { DataTableFilters } from '~/components/data-table-filters/data-table-filters-tree'; -import { MoreOptionsIcon } from '~/components/icon/icon'; +import { ColumnSelector } from "components/column-selector/column-selector"; +import { DataTable, DataColumns, DataTableFetchMode } from "components/data-table/data-table"; +import { DataColumn } from "components/data-table/data-column"; +import { SearchInput } from 'components/search-input/search-input'; +import { ArvadosTheme } from "common/custom-theme"; +import { createTree } from 'models/tree'; +import { DataTableFilters } from 'components/data-table-filters/data-table-filters-tree'; +import { MoreOptionsIcon } from 'components/icon/icon'; import { PaperProps } from '@material-ui/core/Paper'; type CssRules = 'searchBox' | "toolbar" | "toolbarUnderTitle" | "footer" | "root" | 'moreOptionsButton' | 'title'; @@ -47,6 +47,7 @@ interface DataExplorerDataProps { items: T[]; itemsAvailable: number; columns: DataColumns; + searchLabel?: string; searchValue: string; rowsPerPage: number; rowsPerPageOptions: number[]; @@ -81,27 +82,37 @@ interface DataExplorerActionProps { type DataExplorerProps = DataExplorerDataProps & DataExplorerActionProps & WithStyles; export const DataExplorer = withStyles(styles)( - class DataExplorerGeneric extends React.Component> { + class DataExplorerGeneric extends React.Component, { currentItemUuid: string }> { + constructor(props) { + super(props); + this.state = { + currentItemUuid: props.currentItemUuid + }; + } componentDidMount() { if (this.props.onSetColumns) { this.props.onSetColumns(this.props.columns); } } + render() { const { columns, onContextMenu, onFiltersChange, onSortToggle, working, extractKey, - rowsPerPage, rowsPerPageOptions, onColumnToggle, searchValue, onSearch, + rowsPerPage, rowsPerPageOptions, onColumnToggle, searchLabel, searchValue, onSearch, items, itemsAvailable, onRowClick, onRowDoubleClick, classes, dataTableDefaultView, hideColumnSelector, actions, paperProps, hideSearchInput, paperKey, fetchMode, currentItemUuid, title } = this.props; + return {title &&
{title}
} {(!hideColumnSelector || !hideSearchInput) &&
{!hideSearchInput && }
{actions} @@ -132,6 +143,8 @@ export const DataExplorer = withStyles(styles)( page={this.props.page} onChangePage={this.changePage} onChangeRowsPerPage={this.changeRowsPerPage} + // Disable next button on empty lists since that's not default behavior + nextIconButtonProps={(itemsAvailable > 0) ? {} : {disabled: true}} component="div" /> :