15672: subprocess view WIP
[arvados-workbench2.git] / src / store / subprocess-panel / subprocess-panel-middleware-service.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { ServiceRepository } from '~/services/services';
6 import { MiddlewareAPI, Dispatch } from 'redux';
7 import { DataExplorerMiddlewareService, dataExplorerToListParams, listResultsToDataExplorerItemsMeta } from '~/store/data-explorer/data-explorer-middleware-service';
8 import { RootState } from '~/store/store';
9 import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions';
10 import { DataExplorer, getDataExplorer } from '~/store/data-explorer/data-explorer-reducer';
11 import { updateResources } from '~/store/resources/resources-actions';
12 import { SortDirection } from '~/components/data-table/data-column';
13 import { OrderDirection, OrderBuilder } from '~/services/api/order-builder';
14 import { ListResults } from '~/services/common-service/common-service';
15 import { getSortColumn } from "~/store/data-explorer/data-explorer-reducer";
16 import { ProcessResource } from '~/models/process';
17 import { SubprocessPanelColumnNames } from '~/views/subprocess-panel/subprocess-panel-root';
18 import { FilterBuilder } from '~/services/api/filter-builder';
19 import { subprocessPanelActions } from './subprocess-panel-actions';
20 /* import { getProcessStatus } from '../processes/process';
21 import { ContainerRequestResource } from '~/models/container-request';
22 import { ContainerResource } from '~/models/container';*/
23
24 export class SubprocessMiddlewareService extends DataExplorerMiddlewareService {
25     constructor(private services: ServiceRepository, id: string) {
26         super(id);
27     }
28
29     async requestItems(api: MiddlewareAPI<Dispatch, RootState>) {
30         const state = api.getState();
31         const dataExplorer = getDataExplorer(state.dataExplorer, this.getId());
32
33         try {
34             const parentContainerRequestUuid = state.processPanel.containerRequestUuid;
35             if (parentContainerRequestUuid === "") { return; }
36
37             const parentContainerRequest = await this.services.containerRequestService.get(parentContainerRequestUuid);
38             if (!parentContainerRequest.containerUuid) { return; }
39
40             // Get all the subprocess container requests and containers (not filtered based on the data explorer parameters).
41             // This lets us filter based on the combined status of the container request and its container, if it exists.
42             let filters = new FilterBuilder().addEqual('requestingContainerUuid', parentContainerRequest.containerUuid).getFilters();
43             const containerRequests = await this.services.containerRequestService.list({ filters });
44             if (containerRequests.items.length === 0) { return; }
45             console.log(containerRequests);
46
47             const containerUuids: string[] = containerRequests.items.reduce((uuids, { containerUuid }) =>
48                 containerUuid
49                     ? [...uuids, containerUuid]
50                     : uuids, []);
51             filters = new FilterBuilder().addIn('uuid', containerUuids).getFilters();
52             // const containers = await this.services.containerService.list({ filters });
53
54             // Find a container requests corresponding container if it exists and check if it should be displayed
55             const filteredContainerRequestUuids: string[] = [];
56             const filteredContainerUuids: string[] = [];
57             /* containerRequests.items.forEach(
58                 (cr: ContainerRequestResource) => {
59                     const c = containers.items.find((c: ContainerResource) => cr.containerUuid === c.uuid);
60                     const process = c ? { containerRequest: cr, container: c } : { containerRequest: cr };
61
62                     if (statusFilters === getProcessStatus(process)) {
63                         filteredContainerRequestUuids.push(process.containerRequest.uuid);
64                         if (process.container) { filteredContainerUuids.push(process.container.uuid); }
65                     }
66                 });
67 */
68             // Requery with the data expolorer query paramaters to populate the actual user view
69             filters = new FilterBuilder().addIn('uuid', filteredContainerRequestUuids).getFilters();
70             const containerRequestResources = await this.services.containerRequestService.list({ ...getParams(dataExplorer), filters });
71             api.dispatch(updateResources(containerRequestResources.items));
72
73             filters = new FilterBuilder().addIn('uuid', filteredContainerUuids).getFilters();
74             const containerResources = await this.services.containerService.list({ ...getParams(dataExplorer), filters });
75             api.dispatch(updateResources(containerResources.items));
76
77             api.dispatch(setItems(containerRequestResources));
78         } catch {
79             api.dispatch(couldNotFetchSubprocesses());
80         }
81     }
82 }
83
84 export const getParams = (dataExplorer: DataExplorer) => ({
85     ...dataExplorerToListParams(dataExplorer),
86     order: getOrder(dataExplorer)
87 });
88
89 const getOrder = (dataExplorer: DataExplorer) => {
90     const sortColumn = getSortColumn(dataExplorer);
91     const order = new OrderBuilder<ProcessResource>();
92     if (sortColumn) {
93         const sortDirection = sortColumn && sortColumn.sortDirection === SortDirection.ASC
94             ? OrderDirection.ASC
95             : OrderDirection.DESC;
96
97         const columnName = sortColumn && sortColumn.name === SubprocessPanelColumnNames.NAME ? "name" : "modifiedAt";
98         return order
99             .addOrder(sortDirection, columnName)
100             .getOrder();
101     } else {
102         return order.getOrder();
103     }
104 };
105
106 export const setItems = (listResults: ListResults<ProcessResource>) =>
107     subprocessPanelActions.SET_ITEMS({
108         ...listResultsToDataExplorerItemsMeta(listResults),
109         items: listResults.items.map(resource => resource.uuid),
110     });
111
112 const couldNotFetchSubprocesses = () =>
113     snackbarActions.OPEN_SNACKBAR({
114         message: 'Could not fetch subprocesses.',
115         kind: SnackbarKind.ERROR
116     });