// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import { DataExplorerMiddlewareService } from "../data-explorer/data-explorer-middleware-service"; import { ProjectPanelColumnNames, ProjectPanelFilter } from "~/views/project-panel/project-panel"; import { RootState } from "../store"; import { DataColumns } from "~/components/data-table/data-table"; import { ServiceRepository } from "~/services/services"; import { ProjectPanelItem, resourceToDataItem } from "~/views/project-panel/project-panel-item"; import { SortDirection } from "~/components/data-table/data-column"; import { OrderBuilder, OrderDirection } from "~/common/api/order-builder"; import { FilterBuilder } from "~/common/api/filter-builder"; import { GroupContentsResourcePrefix } from "~/services/groups-service/groups-service"; import { checkPresenceInFavorites } from "../favorites/favorites-actions"; import { projectPanelActions } from "./project-panel-action"; import { Dispatch, MiddlewareAPI } from "redux"; import { ProjectResource } from "~/models/project"; export class ProjectPanelMiddlewareService extends DataExplorerMiddlewareService { constructor(private services: ServiceRepository, id: string) { super(id); } requestItems(api: MiddlewareAPI) { const state = api.getState(); const dataExplorer = state.dataExplorer[this.getId()]; const columns = dataExplorer.columns as DataColumns; const typeFilters = getColumnFilters(columns, ProjectPanelColumnNames.TYPE); const statusFilters = getColumnFilters(columns, ProjectPanelColumnNames.STATUS); const sortColumn = dataExplorer.columns.find(c => c.sortDirection !== undefined && c.sortDirection !== "none"); const sortDirection = sortColumn && sortColumn.sortDirection === SortDirection.ASC ? OrderDirection.ASC : OrderDirection.DESC; if (typeFilters.length > 0) { this.services.groupsService .contents(state.projects.currentItemId, { limit: dataExplorer.rowsPerPage, offset: dataExplorer.page * dataExplorer.rowsPerPage, order: sortColumn ? sortColumn.name === ProjectPanelColumnNames.NAME ? getOrder("name", sortDirection) : getOrder("createdAt", sortDirection) : "", filters: new FilterBuilder() .addIsA("uuid", typeFilters.map(f => f.type)) .addIn("state", statusFilters.map(f => f.type), GroupContentsResourcePrefix.PROCESS) .addILike("name", dataExplorer.searchValue, GroupContentsResourcePrefix.COLLECTION) .addILike("name", dataExplorer.searchValue, GroupContentsResourcePrefix.PROCESS) .addILike("name", dataExplorer.searchValue, GroupContentsResourcePrefix.PROJECT) .getFilters() }) .then(response => { api.dispatch(projectPanelActions.SET_ITEMS({ items: response.items.map(resourceToDataItem), itemsAvailable: response.itemsAvailable, page: Math.floor(response.offset / response.limit), rowsPerPage: response.limit })); api.dispatch(checkPresenceInFavorites(response.items.map(item => item.uuid))); }); } else { api.dispatch(projectPanelActions.SET_ITEMS({ items: [], itemsAvailable: 0, page: 0, rowsPerPage: dataExplorer.rowsPerPage })); } } } const getColumnFilters = (columns: DataColumns, columnName: string) => { const column = columns.find(c => c.name === columnName); return column && column.filters ? column.filters.filter(f => f.selected) : []; }; const getOrder = (attribute: "name" | "createdAt", direction: OrderDirection) => new OrderBuilder() .addOrder(direction, attribute, GroupContentsResourcePrefix.COLLECTION) .addOrder(direction, attribute, GroupContentsResourcePrefix.PROCESS) .addOrder(direction, attribute, GroupContentsResourcePrefix.PROJECT) .getOrder();