X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/dd315a23e98b926d4d15b9d05f1aaa1e211548a4..2c2339c775f9112f5da638b2beb81d8b6d5abc2b:/src/store/search-results-panel/search-results-middleware-service.ts diff --git a/src/store/search-results-panel/search-results-middleware-service.ts b/src/store/search-results-panel/search-results-middleware-service.ts index f054a4e4..c13092d4 100644 --- a/src/store/search-results-panel/search-results-middleware-service.ts +++ b/src/store/search-results-panel/search-results-middleware-service.ts @@ -2,29 +2,30 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { ServiceRepository } from '~/services/services'; +import { ServiceRepository } from 'services/services'; import { MiddlewareAPI, Dispatch } from 'redux'; -import { DataExplorerMiddlewareService, dataExplorerToListParams, listResultsToDataExplorerItemsMeta, getDataExplorerColumnFilters } from '~/store/data-explorer/data-explorer-middleware-service'; -import { RootState } from '~/store/store'; -import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions'; -import { DataExplorer, getDataExplorer } from '~/store/data-explorer/data-explorer-reducer'; -import { updateResources } from '~/store/resources/resources-actions'; -import { SortDirection } from '~/components/data-table/data-column'; -import { OrderDirection, OrderBuilder } from '~/services/api/order-builder'; -import { GroupContentsResource, GroupContentsResourcePrefix } from "~/services/groups-service/groups-service"; -import { ListResults } from '~/services/common-service/common-service'; -import { searchResultsPanelActions } from '~/store/search-results-panel/search-results-panel-actions'; +import { DataExplorerMiddlewareService, dataExplorerToListParams, listResultsToDataExplorerItemsMeta, getDataExplorerColumnFilters } from 'store/data-explorer/data-explorer-middleware-service'; +import { RootState } from 'store/store'; +import { snackbarActions, SnackbarKind } from 'store/snackbar/snackbar-actions'; +import { DataExplorer, getDataExplorer } from 'store/data-explorer/data-explorer-reducer'; +import { updateResources } from 'store/resources/resources-actions'; +import { SortDirection } from 'components/data-table/data-column'; +import { OrderDirection, OrderBuilder } from 'services/api/order-builder'; +import { GroupContentsResource, GroupContentsResourcePrefix } from "services/groups-service/groups-service"; +import { ListResults } from 'services/common-service/common-service'; +import { searchResultsPanelActions } from 'store/search-results-panel/search-results-panel-actions'; import { getSearchSessions, queryToFilters, getAdvancedDataFromQuery -} from '~/store/search-bar/search-bar-actions'; -import { getSortColumn } from "~/store/data-explorer/data-explorer-reducer"; -import { joinFilters } from '~/services/api/filter-builder'; -import { DataColumns } from '~/components/data-table/data-table'; -import { serializeResourceTypeFilters } from '~/store//resource-type-filters/resource-type-filters'; -import { ProjectPanelColumnNames } from '~/views/project-panel/project-panel'; -import { Resource } from '~/models/resource'; +} from 'store/search-bar/search-bar-actions'; +import { getSortColumn } from "store/data-explorer/data-explorer-reducer"; +import { FilterBuilder, joinFilters } from 'services/api/filter-builder'; +import { DataColumns } from 'components/data-table/data-table'; +import { serializeResourceTypeFilters } from 'store//resource-type-filters/resource-type-filters'; +import { ProjectPanelColumnNames } from 'views/project-panel/project-panel'; +import { ResourceKind } from 'models/resource'; +import { ContainerRequestResource } from 'models/container-request'; export class SearchResultsMiddlewareService extends DataExplorerMiddlewareService { constructor(private services: ServiceRepository, id: string) { @@ -54,12 +55,24 @@ export class SearchResultsMiddlewareService extends DataExplorerMiddlewareServic api.dispatch(setItems(initial)); } - sessions.map(session => { + sessions.forEach(session => { const params = getParams(dataExplorer, searchValue, session.apiRevision); this.services.groupsService.contents('', params, session) .then((response) => { api.dispatch(updateResources(response.items)); api.dispatch(appendItems(response)); + // Request all containers for process status to be available + const containerRequests = response.items.filter((item) => item.kind === ResourceKind.CONTAINER_REQUEST) as ContainerRequestResource[]; + const containerUuids = containerRequests.map(container => container.containerUuid).filter(uuid => uuid !== null) as string[]; + containerUuids.length && this.services.containerService + .list({ + filters: new FilterBuilder() + .addIn('uuid', containerUuids) + .getFilters() + }, false) + .then((containers) => { + api.dispatch(updateResources(containers.items)); + }); }).catch(() => { api.dispatch(couldNotFetchSearchResults(session.clusterId)); }); @@ -68,30 +81,31 @@ export class SearchResultsMiddlewareService extends DataExplorerMiddlewareServic } } -const typeFilters = (columns: DataColumns) => serializeResourceTypeFilters(getDataExplorerColumnFilters(columns, ProjectPanelColumnNames.TYPE)); +const typeFilters = (columns: DataColumns) => serializeResourceTypeFilters(getDataExplorerColumnFilters(columns, ProjectPanelColumnNames.TYPE)); -const getParams = (dataExplorer: DataExplorer, query: string, apiRevision: number) => ({ +export const getParams = (dataExplorer: DataExplorer, query: string, apiRevision: number) => ({ ...dataExplorerToListParams(dataExplorer), filters: joinFilters( queryToFilters(query, apiRevision), typeFilters(dataExplorer.columns) ), order: getOrder(dataExplorer), - includeTrash: getAdvancedDataFromQuery(query).inTrash + includeTrash: getAdvancedDataFromQuery(query).inTrash, + includeOldVersions: getAdvancedDataFromQuery(query).pastVersions }); const getOrder = (dataExplorer: DataExplorer) => { - const sortColumn = getSortColumn(dataExplorer); + const sortColumn = getSortColumn(dataExplorer); const order = new OrderBuilder(); - if (sortColumn) { - const sortDirection = sortColumn && sortColumn.sortDirection === SortDirection.ASC + if (sortColumn && sortColumn.sort) { + const sortDirection = sortColumn.sort.direction === SortDirection.ASC ? OrderDirection.ASC : OrderDirection.DESC; return order - .addOrder(sortDirection, sortColumn.name as keyof Resource, GroupContentsResourcePrefix.COLLECTION) - .addOrder(sortDirection, sortColumn.name as keyof Resource, GroupContentsResourcePrefix.PROCESS) - .addOrder(sortDirection, sortColumn.name as keyof Resource, GroupContentsResourcePrefix.PROJECT) + .addOrder(sortDirection, sortColumn.sort.field, GroupContentsResourcePrefix.COLLECTION) + .addOrder(sortDirection, sortColumn.sort.field, GroupContentsResourcePrefix.PROCESS) + .addOrder(sortDirection, sortColumn.sort.field, GroupContentsResourcePrefix.PROJECT) .getOrder(); } else { return order.getOrder();