X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/be8de5acc35c47d0b191223e5ece96fcf452ea5d..21abfcbaba4e8e735f353a1e3b030dd5dae8465b:/src/store/resource-type-filters/resource-type-filters.ts diff --git a/src/store/resource-type-filters/resource-type-filters.ts b/src/store/resource-type-filters/resource-type-filters.ts index 8e856c94..26db4e9e 100644 --- a/src/store/resource-type-filters/resource-type-filters.ts +++ b/src/store/resource-type-filters/resource-type-filters.ts @@ -10,6 +10,7 @@ import { FilterBuilder } from '~/services/api/filter-builder'; import { getSelectedNodes } from '~/models/tree'; import { CollectionType } from '~/models/collection'; import { GroupContentsResourcePrefix } from '~/services/groups-service/groups-service'; +import { ContainerState } from '~/models/container'; export enum ProcessStatusFilter { ALL = 'All', @@ -24,7 +25,12 @@ export enum ProcessStatusFilter { export enum ObjectTypeFilter { PROJECT = 'Project', PROCESS = 'Process', - COLLECTION = 'Data Collection', + COLLECTION = 'Data collection', +} + +export enum GroupTypeFilter { + PROJECT = 'Project (normal)', + FILTER_GROUP = 'Filter group', } export enum CollectionTypeFilter { @@ -33,6 +39,11 @@ export enum CollectionTypeFilter { LOG_COLLECTION = 'Log', } +export enum ProcessTypeFilter { + MAIN_PROCESS = 'Main', + CHILD_PROCESS = 'Child', +} + const initFilter = (name: string, parent = '', isSelected?: boolean) => setNode({ id: name, @@ -52,25 +63,45 @@ export const getSimpleObjectTypeFilters = pipe( initFilter(ObjectTypeFilter.COLLECTION), ); +// Using pipe() with more than 7 arguments makes the return type be 'any', +// causing compile issues. export const getInitialResourceTypeFilters = pipe( (): DataTableFilters => createTree(), - initFilter(ObjectTypeFilter.PROJECT), - initFilter(ObjectTypeFilter.PROCESS), - initFilter(ObjectTypeFilter.COLLECTION), - initFilter(CollectionTypeFilter.GENERAL_COLLECTION, ObjectTypeFilter.COLLECTION), - initFilter(CollectionTypeFilter.OUTPUT_COLLECTION, ObjectTypeFilter.COLLECTION), - initFilter(CollectionTypeFilter.LOG_COLLECTION, ObjectTypeFilter.COLLECTION), + pipe( + initFilter(ObjectTypeFilter.PROJECT), + initFilter(GroupTypeFilter.PROJECT, ObjectTypeFilter.PROJECT), + initFilter(GroupTypeFilter.FILTER_GROUP, ObjectTypeFilter.PROJECT), + ), + pipe( + initFilter(ObjectTypeFilter.PROCESS), + initFilter(ProcessTypeFilter.MAIN_PROCESS, ObjectTypeFilter.PROCESS), + initFilter(ProcessTypeFilter.CHILD_PROCESS, ObjectTypeFilter.PROCESS) + ), + pipe( + initFilter(ObjectTypeFilter.COLLECTION), + initFilter(CollectionTypeFilter.GENERAL_COLLECTION, ObjectTypeFilter.COLLECTION), + initFilter(CollectionTypeFilter.OUTPUT_COLLECTION, ObjectTypeFilter.COLLECTION), + initFilter(CollectionTypeFilter.LOG_COLLECTION, ObjectTypeFilter.COLLECTION), + ), +); + +export const getInitialProcessTypeFilters = pipe( + (): DataTableFilters => createTree(), + initFilter(ProcessTypeFilter.MAIN_PROCESS), + initFilter(ProcessTypeFilter.CHILD_PROCESS, '', false) ); export const getInitialProcessStatusFilters = pipe( (): DataTableFilters => createTree(), - 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), + pipe( + 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( @@ -102,12 +133,20 @@ const objectTypeToResourceKind = (type: ObjectTypeFilter) => { }; const serializeObjectTypeFilters = ({ fb, selectedFilters }: ReturnType) => { + const groupFilters = getMatchingFilters(values(GroupTypeFilter), selectedFilters); const collectionFilters = getMatchingFilters(values(CollectionTypeFilter), selectedFilters); + const processFilters = getMatchingFilters(values(ProcessTypeFilter), selectedFilters); const typeFilters = pipe( () => new Set(getMatchingFilters(values(ObjectTypeFilter), selectedFilters)), + set => groupFilters.length > 0 + ? set.add(ObjectTypeFilter.PROJECT) + : set, set => collectionFilters.length > 0 ? set.add(ObjectTypeFilter.COLLECTION) : set, + set => processFilters.length > 0 + ? set.add(ObjectTypeFilter.PROCESS) + : set, set => Array.from(set) )(); @@ -156,10 +195,74 @@ const buildCollectionTypeFilters = ({ fb, filters }: { fb: FilterBuilder, filter } }; +const serializeGroupTypeFilters = ({ fb, selectedFilters }: ReturnType) => pipe( + () => getMatchingFilters(values(GroupTypeFilter), selectedFilters), + filters => filters, + mappedFilters => ({ + fb: buildGroupTypeFilters({ fb, filters: mappedFilters, use_prefix: true }), + selectedFilters + }) +)(); + +const GROUP_TYPES = values(GroupTypeFilter); + +const buildGroupTypeFilters = ({ fb, filters, use_prefix }: { fb: FilterBuilder, filters: string[], use_prefix: boolean }) => { + switch (true) { + case filters.length === 0 || filters.length === GROUP_TYPES.length: + return fb; + case includes(GroupTypeFilter.PROJECT, filters): + return fb.addEqual('groups.group_class', 'project'); + case includes(GroupTypeFilter.FILTER_GROUP, filters): + return fb.addEqual('groups.group_class', 'filter'); + default: + return fb; + } +}; + +const serializeProcessTypeFilters = ({ fb, selectedFilters }: ReturnType) => pipe( + () => getMatchingFilters(values(ProcessTypeFilter), selectedFilters), + filters => filters, + mappedFilters => ({ + fb: buildProcessTypeFilters({ fb, filters: mappedFilters, use_prefix: true }), + selectedFilters + }) +)(); + +const PROCESS_TYPES = values(ProcessTypeFilter); +const PROCESS_PREFIX = GroupContentsResourcePrefix.PROCESS; + +const buildProcessTypeFilters = ({ fb, filters, use_prefix }: { fb: FilterBuilder, filters: string[], use_prefix: boolean }) => { + switch (true) { + case filters.length === 0 || filters.length === PROCESS_TYPES.length: + return fb; + case includes(ProcessTypeFilter.MAIN_PROCESS, filters): + return fb.addEqual('requesting_container_uuid', null, use_prefix ? PROCESS_PREFIX : ''); + case includes(ProcessTypeFilter.CHILD_PROCESS, filters): + return fb.addDistinct('requesting_container_uuid', null, use_prefix ? PROCESS_PREFIX : ''); + default: + return fb; + } +}; + export const serializeResourceTypeFilters = pipe( createFiltersBuilder, serializeObjectTypeFilters, + serializeGroupTypeFilters, serializeCollectionTypeFilters, + serializeProcessTypeFilters, + ({ fb }) => fb.getFilters(), +); + +export const serializeOnlyProcessTypeFilters = pipe( + createFiltersBuilder, + ({ fb, selectedFilters }: ReturnType) => pipe( + () => getMatchingFilters(values(ProcessTypeFilter), selectedFilters), + filters => filters, + mappedFilters => ({ + fb: buildProcessTypeFilters({ fb, filters: mappedFilters, use_prefix: false }), + selectedFilters + }) + )(), ({ fb }) => fb.getFilters(), ); @@ -168,3 +271,31 @@ export const serializeSimpleObjectTypeFilters = (filters: Tree f.id) .map(objectTypeToResourceKind); }; + +export const buildProcessStatusFilters = ( fb:FilterBuilder, activeStatusFilter:string ): FilterBuilder => { + switch (activeStatusFilter) { + case ProcessStatusFilter.COMPLETED: { + fb.addEqual('container.state', ContainerState.COMPLETE); + fb.addEqual('container.exit_code', '0'); + break; + } + case ProcessStatusFilter.FAILED: { + fb.addEqual('container.state', ContainerState.COMPLETE); + fb.addDistinct('container.exit_code', '0'); + break; + } + case ProcessStatusFilter.QUEUED: { + fb.addEqual('container.state', ContainerState.QUEUED); + fb.addDistinct('container.priority', '0'); + break; + } + case ProcessStatusFilter.CANCELLED: + case ProcessStatusFilter.FAILED: + case ProcessStatusFilter.LOCKED: + case ProcessStatusFilter.RUNNING: { + fb.addEqual('container.state', activeStatusFilter); + break; + } + } + return fb; +};