X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/54e859c204c3952a8eaf96d2145dfa96c199b934..71b9264c1720e619f8cfcb297a7848ece420c61c:/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 5ccb61bf..de325222 100644 --- a/src/store/search-results-panel/search-results-middleware-service.ts +++ b/src/store/search-results-panel/search-results-middleware-service.ts @@ -13,38 +13,73 @@ import { SortDirection } from '~/components/data-table/data-column'; import { SearchResultsPanelColumnNames } from '~/views/search-results-panel/search-results-panel-view'; import { OrderDirection, OrderBuilder } from '~/services/api/order-builder'; import { GroupContentsResource, GroupContentsResourcePrefix } from "~/services/groups-service/groups-service"; -import { ListResults } from '~/services/common-service/common-resource-service'; +import { ListResults } from '~/services/common-service/common-service'; import { searchResultsPanelActions } from '~/store/search-results-panel/search-results-panel-actions'; -import { getFilters } from '~/store/search-bar/search-bar-actions'; +import { + getFilters, + getSearchQueryFirstProp, + getSearchSessions, ParseSearchQuery, + parseSearchQuery +} from '~/store/search-bar/search-bar-actions'; +import { getSortColumn } from "~/store/data-explorer/data-explorer-reducer"; export class SearchResultsMiddlewareService extends DataExplorerMiddlewareService { constructor(private services: ServiceRepository, id: string) { super(id); } - async requestItems(api: MiddlewareAPI) { + 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 sessions = getSearchSessions(clusterId, state.auth.sessions); + + if (searchValue.trim() === '') { + return; + } + try { - const response = await this.services.groupsService.contents(userUuid, getParams(dataExplorer, searchValue)); - api.dispatch(updateResources(response.items)); - api.dispatch(setItems(response)); + const params = getParams(dataExplorer, searchValue, sq); + const lists: ListResults[] = await Promise.all(sessions.map(session => + this.services.groupsService.contents('', params, session) + )); + + const items = lists + .reduce((items, list) => items.concat(list.items), [] as GroupContentsResource[]); + + const itemsAvailable = lists + .reduce((itemsAvailable, list) => itemsAvailable + list.itemsAvailable, 0); + + const list: ListResults = { + ...params, + kind: '', + items, + itemsAvailable + }; + + api.dispatch(updateResources(list.items)); + api.dispatch(criteriaChanged + ? setItems(list) + : appendItems(list) + ); + } catch { - api.dispatch(couldNotFetchWorkflows()); + api.dispatch(couldNotFetchSearchResults()); } } } -export const getParams = (dataExplorer: DataExplorer, searchValue: string) => ({ +export const getParams = (dataExplorer: DataExplorer, searchValue: string, sq: ParseSearchQuery) => ({ ...dataExplorerToListParams(dataExplorer), - filters: getFilters('name', searchValue), + filters: getFilters('name', searchValue, sq), order: getOrder(dataExplorer) }); const getOrder = (dataExplorer: DataExplorer) => { - const sortColumn = dataExplorer.columns.find(c => c.sortDirection !== SortDirection.NONE); + const sortColumn = getSortColumn(dataExplorer); const order = new OrderBuilder(); if (sortColumn) { const sortDirection = sortColumn && sortColumn.sortDirection === SortDirection.ASC @@ -68,8 +103,14 @@ export const setItems = (listResults: ListResults) => items: listResults.items.map(resource => resource.uuid), }); -const couldNotFetchWorkflows = () => +export const appendItems = (listResults: ListResults) => + searchResultsPanelActions.APPEND_ITEMS({ + ...listResultsToDataExplorerItemsMeta(listResults), + items: listResults.items.map(resource => resource.uuid), + }); + +const couldNotFetchSearchResults = () => snackbarActions.OPEN_SNACKBAR({ - message: 'Could not fetch workflows.', + message: `Could not fetch search results for some sessions.`, kind: SnackbarKind.ERROR - }); \ No newline at end of file + });