X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f5c0cb11102a006cda59711f29458b7569b9a21f..ffdce0fe089aab55d26a3a4fe05934b912c691af:/src/views/project-panel/project-panel.tsx diff --git a/src/views/project-panel/project-panel.tsx b/src/views/project-panel/project-panel.tsx index 1cb72a963b..63aedaddeb 100644 --- a/src/views/project-panel/project-panel.tsx +++ b/src/views/project-panel/project-panel.tsx @@ -12,7 +12,7 @@ import { RootState } from '~/store/store'; import { DataTableFilterItem } from '~/components/data-table-filters/data-table-filters'; import { ContainerRequestState } from '~/models/container-request'; import { SortDirection } from '~/components/data-table/data-column'; -import { ResourceKind } from '~/models/resource'; +import { ResourceKind, Resource } from '~/models/resource'; import { resourceLabel } from '~/common/labels'; import { ArvadosTheme } from '~/common/custom-theme'; import { ResourceFileSize, ResourceLastModifiedDate, ProcessStatus, ResourceType, ResourceOwner } from '~/views-components/data-explorer/renderers'; @@ -25,8 +25,11 @@ import { ProjectResource } from '~/models/project'; import { navigateTo } from '~/store/navigation/navigation-action'; import { getProperty } from '~/store/properties/properties'; import { PROJECT_PANEL_CURRENT_UUID } from '~/store/project-panel/project-panel-action'; -import { openCollectionCreateDialog } from '../../store/collections/collection-create-actions'; +import { openCollectionCreateDialog } from '~/store/collections/collection-create-actions'; import { openProjectCreateDialog } from '~/store/projects/project-create-actions'; +import { filterResources } from '~/store/resources/resources'; +import { PanelDefaultView } from '~/components/panel-default-view/panel-default-view'; +import { DataTableDefaultView } from '~/components/data-table-default-view/data-table-default-view'; type CssRules = 'root' | "toolbar" | "button"; @@ -65,39 +68,19 @@ export const projectPanelColumns: DataColumns = [ configurable: true, sortDirection: SortDirection.ASC, filters: [], - render: uuid => , - width: "450px" + render: uuid => }, { name: "Status", selected: true, configurable: true, - sortDirection: SortDirection.NONE, - filters: [ - { - name: ContainerRequestState.COMMITTED, - selected: true, - type: ContainerRequestState.COMMITTED - }, - { - name: ContainerRequestState.FINAL, - selected: true, - type: ContainerRequestState.FINAL - }, - { - name: ContainerRequestState.UNCOMMITTED, - selected: true, - type: ContainerRequestState.UNCOMMITTED - } - ], + filters: [], render: uuid => , - width: "75px" }, { name: ProjectPanelColumnNames.TYPE, selected: true, configurable: true, - sortDirection: SortDirection.NONE, filters: [ { name: resourceLabel(ResourceKind.COLLECTION), @@ -115,26 +98,21 @@ export const projectPanelColumns: DataColumns = [ type: ResourceKind.PROJECT } ], - render: uuid => , - width: "125px" + render: uuid => }, { name: ProjectPanelColumnNames.OWNER, selected: true, configurable: true, - sortDirection: SortDirection.NONE, filters: [], - render: uuid => , - width: "200px" + render: uuid => }, { name: ProjectPanelColumnNames.FILE_SIZE, selected: true, configurable: true, - sortDirection: SortDirection.NONE, filters: [], - render: uuid => , - width: "50px" + render: uuid => }, { name: ProjectPanelColumnNames.LAST_MODIFIED, @@ -142,8 +120,7 @@ export const projectPanelColumns: DataColumns = [ configurable: true, sortDirection: SortDirection.NONE, filters: [], - render: uuid => , - width: "150px" + render: uuid => } ]; @@ -168,7 +145,7 @@ export const ProjectPanel = withStyles(styles)( return
- + {this.hasAnyItems() + ? } /> + : + } +
; } + hasAnyItems = () => { + const resources = filterResources(this.isCurrentItemChild)(this.props.resources); + return resources.length > 0; + } + + isCurrentItemChild = (resource: Resource) => { + return resource.ownerUuid === this.props.currentItemId; + } + handleNewProjectClick = () => { this.props.dispatch(openProjectCreateDialog(this.props.currentItemId)); }