X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/4a72c22ddb45dce37ff0f9f18d4d73c289a08070..5a84b3bf9b7bf9a1d07e9595b2453c4133ffd23d:/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 efe62f230b..9d7e3207f0 100644 --- a/src/store/search-results-panel/search-results-middleware-service.ts +++ b/src/store/search-results-panel/search-results-middleware-service.ts @@ -16,10 +16,9 @@ import { GroupContentsResource, GroupContentsResourcePrefix } from "~/services/g import { ListResults } from '~/services/common-service/common-service'; import { searchResultsPanelActions } from '~/store/search-results-panel/search-results-panel-actions'; import { - getFilters, - getSearchQueryFirstProp, - getSearchSessions, ParseSearchQuery, - parseSearchQuery + 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'; @@ -27,6 +26,7 @@ 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 * as _ from 'lodash'; +import { Resource } from '~/models/resource'; export class SearchResultsMiddlewareService extends DataExplorerMiddlewareService { constructor(private services: ServiceRepository, id: string) { @@ -35,11 +35,9 @@ export class SearchResultsMiddlewareService extends DataExplorerMiddlewareServic async requestItems(api: MiddlewareAPI, criteriaChanged?: boolean) { const state = api.getState(); - const userUuid = state.auth.user!.uuid; const dataExplorer = getDataExplorer(state.dataExplorer, this.getId()); const searchValue = state.searchBar.searchValue; - const sq = parseSearchQuery(searchValue); - const clusterId = getSearchQueryFirstProp(sq, 'cluster'); + const { cluster: clusterId } = getAdvancedDataFromQuery(searchValue); const sessions = getSearchSessions(clusterId, state.auth.sessions); if (searchValue.trim() === '') { @@ -47,46 +45,31 @@ export class SearchResultsMiddlewareService extends DataExplorerMiddlewareServic } try { - const nameParams = getParams(dataExplorer, searchValue, sq, 'name'); + const params = getParams(dataExplorer, searchValue); - const nameLists: ListResults[] = await Promise.all(sessions.map(session => - this.services.groupsService.contents('', nameParams, session) + const responses = await Promise.all(sessions.map(session => + this.services.groupsService.contents('', params, session) )); - const nameItems = nameLists - .reduce((items, list) => items.concat(list.items), [] as GroupContentsResource[]); - - const nameItemsAvailable = nameLists - .reduce((itemsAvailable, list) => itemsAvailable + list.itemsAvailable, 0); - - const descriptionParams = getParams(dataExplorer, searchValue, sq, 'description'); - - const descriptionLists: ListResults[] = await Promise.all(sessions.map(session => - this.services.groupsService.contents('', descriptionParams, session) - )); - - const descriptionItems = descriptionLists - .reduce((items, list) => items.concat(list.items), [] as GroupContentsResource[]); - - const descriptionItemsAvailable = descriptionLists - .reduce((itemsAvailable, list) => itemsAvailable + list.itemsAvailable, 0); - - const items = nameItems.concat(descriptionItems); - - const uniqueItems = _.uniqBy(items, 'uuid'); - - const mainList: ListResults = { - ...nameParams, + const initial = { + itemsAvailable: 0, + items: [] as GroupContentsResource[], kind: '', - items: uniqueItems, - itemsAvailable: nameItemsAvailable + descriptionItemsAvailable + offset: 0, + limit: 10 }; - api.dispatch(updateResources(mainList.items)); + const mergedResponse = responses.reduce((merged, current) => ({ + ...merged, + itemsAvailable: merged.itemsAvailable + current.itemsAvailable, + items: merged.items.concat(current.items) + }), initial); + + api.dispatch(updateResources(mergedResponse.items)); api.dispatch(criteriaChanged - ? setItems(mainList) - : appendItems(mainList)); + ? setItems(mergedResponse) + : appendItems(mergedResponse)); } catch { api.dispatch(couldNotFetchSearchResults()); @@ -96,16 +79,17 @@ export class SearchResultsMiddlewareService extends DataExplorerMiddlewareServic const typeFilters = (columns: DataColumns) => serializeResourceTypeFilters(getDataExplorerColumnFilters(columns, ProjectPanelColumnNames.TYPE)); -export const getParams = (dataExplorer: DataExplorer, searchValue: string, sq: ParseSearchQuery, filter: string) => ({ +export const getParams = (dataExplorer: DataExplorer, query: string) => ({ ...dataExplorerToListParams(dataExplorer), filters: joinFilters( - getFilters(filter, searchValue, sq), - typeFilters(dataExplorer.columns)), - order: getOrder(dataExplorer, filter), - includeTrash: true + queryToFilters(query), + typeFilters(dataExplorer.columns) + ), + order: getOrder(dataExplorer), + includeTrash: getAdvancedDataFromQuery(query).inTrash }); -const getOrder = (dataExplorer: DataExplorer, orderBy: any) => { +const getOrder = (dataExplorer: DataExplorer) => { const sortColumn = getSortColumn(dataExplorer); const order = new OrderBuilder(); if (sortColumn) { @@ -113,11 +97,10 @@ const getOrder = (dataExplorer: DataExplorer, orderBy: any) => { ? OrderDirection.ASC : OrderDirection.DESC; - const columnName = sortColumn && sortColumn.name === SearchResultsPanelColumnNames.NAME ? orderBy : "modifiedAt"; return order - .addOrder(sortDirection, columnName, GroupContentsResourcePrefix.COLLECTION) - .addOrder(sortDirection, columnName, GroupContentsResourcePrefix.PROCESS) - .addOrder(sortDirection, columnName, GroupContentsResourcePrefix.PROJECT) + .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) .getOrder(); } else { return order.getOrder();