X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/846d1322282be39bd2db362c7f97a4068a3e1867..8465f354eeb09436e421d7ee4f8f68f9a5e5cc44:/services/workbench2/src/components/data-table/data-table.tsx diff --git a/services/workbench2/src/components/data-table/data-table.tsx b/services/workbench2/src/components/data-table/data-table.tsx index b9d529c2fa..fade7d4a24 100644 --- a/services/workbench2/src/components/data-table/data-table.tsx +++ b/services/workbench2/src/components/data-table/data-table.tsx @@ -24,7 +24,7 @@ import { DataTableFilters } from "../data-table-filters/data-table-filters-tree" import { DataTableMultiselectPopover } from "../data-table-multiselect-popover/data-table-multiselect-popover"; import { DataTableFiltersPopover } from "../data-table-filters/data-table-filters-popover"; import { countNodes, getTreeDirty } from "models/tree"; -import { IconType, PendingIcon } from "components/icon/icon"; +import { IconType } from "components/icon/icon"; import { SvgIconProps } from "@material-ui/core/SvgIcon"; import ArrowDownwardIcon from "@material-ui/icons/ArrowDownward"; import { createTree } from "models/tree"; @@ -54,6 +54,7 @@ export interface DataTableDataProps { toggleMSToolbar: (isVisible: boolean) => void; setCheckedListOnStore: (checkedList: TCheckedList) => void; checkedList: TCheckedList; + isNotFound?: boolean; } type CssRules = @@ -69,8 +70,7 @@ type CssRules = | "tableCell" | "arrow" | "arrowButton" - | "tableCellWorkflows" - | "loader"; + | "tableCellWorkflows"; const styles: StyleRulesCallback = (theme: Theme) => ({ root: { @@ -83,11 +83,6 @@ const styles: StyleRulesCallback = (theme: Theme) => ({ tableBody: { background: theme.palette.background.paper, }, - loader: { - left: "50%", - marginLeft: "-84px", - position: "absolute", - }, noItemsInfo: { textAlign: "center", padding: theme.spacing.unit, @@ -97,16 +92,18 @@ const styles: StyleRulesCallback = (theme: Theme) => ({ display: "flex", width: '2rem', height: "1.5rem", - paddingLeft: '0.8rem', + paddingLeft: '0.9rem', marginRight: '0.5rem' }, checkBoxCell: { padding: "0", }, clickBox: { - width: '1.4rem', - height: "1.4rem", - paddingLeft: '0.25rem', + display: 'flex', + width: '1.6rem', + height: "1.5rem", + paddingLeft: '0.35rem', + paddingTop: '0.1rem', marginLeft: '0.5rem', cursor: "pointer", }, @@ -144,6 +141,7 @@ export type TCheckedList = Record; type DataTableState = { isSelected: boolean; + isLoaded: boolean; }; type DataTableProps = DataTableDataProps & WithStyles; @@ -152,6 +150,7 @@ export const DataTable = withStyles(styles)( class Component extends React.Component> { state: DataTableState = { isSelected: false, + isLoaded: false, }; componentDidMount(): void { @@ -169,6 +168,9 @@ export const DataTable = withStyles(styles)( if (prevProps.currentRoute !== this.props.currentRoute) { this.initializeCheckedList([]) } + if(prevProps.working === true && this.props.working === false) { + this.setState({ isLoaded: true }); + } } componentWillUnmount(): void { @@ -289,7 +291,8 @@ export const DataTable = withStyles(styles)( }; render() { - const { items, classes, working, columns } = this.props; + const { items, classes, columns, isNotFound } = this.props; + const { isLoaded } = this.state; if (columns[0].name === this.checkBoxColumn.name) columns.shift(); columns.unshift(this.checkBoxColumn); return ( @@ -299,31 +302,43 @@ export const DataTable = withStyles(styles)( {this.mapVisibleColumns(this.renderHeadCell)} - {!working && items.map(this.renderBodyRow)} + {(isLoaded && !isNotFound) && items.map(this.renderBodyRow)} - {!!working && ( -
- -
- )} - {items.length === 0 && !working && this.renderNoItemsPlaceholder(this.props.columns)} + {(!isLoaded || isNotFound || items.length === 0) && this.renderNoItemsPlaceholder(this.props.columns)} ); } renderNoItemsPlaceholder = (columns: DataColumns) => { + const { isLoaded } = this.state; + const { working, isNotFound } = this.props; const dirty = columns.some(column => getTreeDirty("")(column.filters)); - return ( - - ); + if (isNotFound && isLoaded) { + return ( + + ); + } else + if (isLoaded === false || working === true) { + return ( + + ); + } else { + //if (isLoaded && !working && !isNotFound) + return ( + + ); + } }; renderHeadCell = (column: DataColumn, index: number) => {