15672: subprocess view WIP
[arvados-workbench2.git] / src / store / resource-type-filters / resource-type-filters.ts
index eef973ed2361b830c4f654b8bc0e4495b9c056f4..8e856c9401b0f19092af0de026eb2c094f222ae9 100644 (file)
@@ -3,7 +3,7 @@
 // SPDX-License-Identifier: AGPL-3.0
 
 import { difference, pipe, values, includes, __ } from 'lodash/fp';
-import { createTree, setNode, TreeNodeStatus, TreeNode } from '~/models/tree';
+import { createTree, setNode, TreeNodeStatus, TreeNode, Tree } from '~/models/tree';
 import { DataTableFilterItem, DataTableFilters } from '~/components/data-table-filters/data-table-filters-tree';
 import { ResourceKind } from '~/models/resource';
 import { FilterBuilder } from '~/services/api/filter-builder';
@@ -11,6 +11,16 @@ import { getSelectedNodes } from '~/models/tree';
 import { CollectionType } from '~/models/collection';
 import { GroupContentsResourcePrefix } from '~/services/groups-service/groups-service';
 
+export enum ProcessStatusFilter {
+    ALL = 'All',
+    RUNNING = 'Running',
+    FAILED = 'Failed',
+    COMPLETED = 'Completed',
+    CANCELLED = 'Cancelled',
+    LOCKED = 'Locked',
+    QUEUED = 'Queued'
+}
+
 export enum ObjectTypeFilter {
     PROJECT = 'Project',
     PROCESS = 'Process',
@@ -23,14 +33,14 @@ export enum CollectionTypeFilter {
     LOG_COLLECTION = 'Log',
 }
 
-const initFilter = (name: string, parent = '') =>
+const initFilter = (name: string, parent = '', isSelected?: boolean) =>
     setNode<DataTableFilterItem>({
         id: name,
         value: { name },
         parent,
         children: [],
         active: false,
-        selected: true,
+        selected: isSelected !== undefined ? isSelected : true,
         expanded: false,
         status: TreeNodeStatus.LOADED,
     });
@@ -52,6 +62,25 @@ export const getInitialResourceTypeFilters = pipe(
     initFilter(CollectionTypeFilter.LOG_COLLECTION, ObjectTypeFilter.COLLECTION),
 );
 
+export const getInitialProcessStatusFilters = pipe(
+    (): DataTableFilters => createTree<DataTableFilterItem>(),
+    initFilter(ProcessStatusFilter.ALL, '', true),
+    initFilter(ProcessStatusFilter.RUNNING, '', false),
+    initFilter(ProcessStatusFilter.FAILED, '', false),
+    initFilter(ProcessStatusFilter.COMPLETED, '', false),
+    initFilter(ProcessStatusFilter.CANCELLED, '', false),
+    initFilter(ProcessStatusFilter.QUEUED, '', false),
+    initFilter(ProcessStatusFilter.LOCKED, '', false),
+);
+
+export const getTrashPanelTypeFilters = pipe(
+    (): DataTableFilters => createTree<DataTableFilterItem>(),
+    initFilter(ObjectTypeFilter.PROJECT),
+    initFilter(ObjectTypeFilter.COLLECTION),
+    initFilter(CollectionTypeFilter.GENERAL_COLLECTION, ObjectTypeFilter.COLLECTION),
+    initFilter(CollectionTypeFilter.OUTPUT_COLLECTION, ObjectTypeFilter.COLLECTION),
+    initFilter(CollectionTypeFilter.LOG_COLLECTION, ObjectTypeFilter.COLLECTION),
+);
 
 const createFiltersBuilder = (filters: DataTableFilters) =>
     ({ fb: new FilterBuilder(), selectedFilters: getSelectedNodes(filters) });
@@ -105,7 +134,7 @@ const serializeCollectionTypeFilters = ({ fb, selectedFilters }: ReturnType<type
     () => getMatchingFilters(values(CollectionTypeFilter), selectedFilters),
     filters => filters.map(collectionTypeToPropertyValue),
     mappedFilters => ({
-        fb: buildCollectiomTypeFilters({ fb, filters: mappedFilters }),
+        fb: buildCollectionTypeFilters({ fb, filters: mappedFilters }),
         selectedFilters
     })
 )();
@@ -116,8 +145,8 @@ const NON_GENERAL_COLLECTION_TYPES = difference(COLLECTION_TYPES, [CollectionTyp
 
 const COLLECTION_PROPERTIES_PREFIX = `${GroupContentsResourcePrefix.COLLECTION}.properties`;
 
-const buildCollectiomTypeFilters = ({ fb, filters}: { fb: FilterBuilder, filters: CollectionType[] }) => {
-    switch(true){
+const buildCollectionTypeFilters = ({ fb, filters }: { fb: FilterBuilder, filters: CollectionType[] }) => {
+    switch (true) {
         case filters.length === 0 || filters.length === COLLECTION_TYPES.length:
             return fb;
         case includes(CollectionType.GENERAL, filters):
@@ -133,3 +162,9 @@ export const serializeResourceTypeFilters = pipe(
     serializeCollectionTypeFilters,
     ({ fb }) => fb.getFilters(),
 );
+
+export const serializeSimpleObjectTypeFilters = (filters: Tree<DataTableFilterItem>) => {
+    return getSelectedNodes(filters)
+        .map(f => f.id)
+        .map(objectTypeToResourceKind);
+};