X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e8dae47a3dead0a49cb60c1075b96a95ef8142e5..64b25cb874d430f23d169606265c9534a52bdc6c:/src/store/run-process-panel/run-process-panel-reducer.ts diff --git a/src/store/run-process-panel/run-process-panel-reducer.ts b/src/store/run-process-panel/run-process-panel-reducer.ts index 2470de14..560e91cd 100644 --- a/src/store/run-process-panel/run-process-panel-reducer.ts +++ b/src/store/run-process-panel/run-process-panel-reducer.ts @@ -9,6 +9,7 @@ interface RunProcessPanel { processOwnerUuid: string; currentStep: number; workflows: WorkflowResource[]; + searchWorkflows: WorkflowResource[]; selectedWorkflow: WorkflowResource | undefined; inputs: CommandInputParameter[]; } @@ -19,17 +20,26 @@ const initialState: RunProcessPanel = { workflows: [], selectedWorkflow: undefined, inputs: [], + searchWorkflows: [], }; export const runProcessPanelReducer = (state = initialState, action: RunProcessPanelAction): RunProcessPanel => runProcessPanelActions.match(action, { SET_PROCESS_OWNER_UUID: processOwnerUuid => ({ ...state, processOwnerUuid }), SET_CURRENT_STEP: currentStep => ({ ...state, currentStep }), - SET_WORKFLOWS: workflows => ({ ...state, workflows }), SET_SELECTED_WORKFLOW: selectedWorkflow => ({ ...state, selectedWorkflow, inputs: getWorkflowInputs(parseWorkflowDefinition(selectedWorkflow)) || [], }), + SET_WORKFLOWS: workflows => ({ ...state, workflows, searchWorkflows: workflows }), + SEARCH_WORKFLOWS: term => { + const termRegex = new RegExp(term, 'i'); + return { + ...state, + searchWorkflows: state.workflows.filter(workflow => termRegex.test(workflow.name)), + }; + }, + RESET_RUN_PROCESS_PANEL: () => ({ ...initialState, processOwnerUuid: state.processOwnerUuid }), default: () => state }); \ No newline at end of file