X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/ab54fbc8f8934aab2b4a824bb2b71e354503c9ec..00b22552554ddcae9cf3b68ed4017067555ba02e:/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 b75b37aa..aa361bc9 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"; @@ -148,7 +151,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)); }