X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e8dae47a3dead0a49cb60c1075b96a95ef8142e5..f22d9424ca3321c01e3a9b27ed5905b80eee35f5:/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..0ad06bee 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,19 @@ 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 => ({ ...state, searchWorkflows: state.workflows.filter(workflow => workflow.name.includes(term)) }), default: () => state }); \ No newline at end of file