From: Pawel Kowalczyk Date: Mon, 10 Dec 2018 13:33:02 +0000 (+0100) Subject: added-snakcbar when output des not exists X-Git-Tag: 1.4.0~91^2~1^2~3^2~1 X-Git-Url: https://git.arvados.org/arvados-workbench2.git/commitdiff_plain/91fc1bd2a1df91b37755f3453e6e9693baa4ce64 added-snakcbar when output des not exists Feature #14582 Arvados-DCO-1.1-Signed-off-by: Pawel Kowalczyk --- diff --git a/src/store/process-panel/process-panel-actions.ts b/src/store/process-panel/process-panel-actions.ts index 832d4d51..2aa914af 100644 --- a/src/store/process-panel/process-panel-actions.ts +++ b/src/store/process-panel/process-panel-actions.ts @@ -6,6 +6,11 @@ import { unionize, ofType, UnionOf } from "~/common/unionize"; import { loadProcess } from '~/store/processes/processes-actions'; import { Dispatch } from 'redux'; import { ProcessStatus } from '~/store/processes/process'; +import { RootState } from '~/store/store'; +import { ServiceRepository } from "~/services/services"; +import { navigateToCollection } from '~/store/navigation/navigation-action'; +import { snackbarActions } from '~/store/snackbar/snackbar-actions'; +import { SnackbarKind } from '../snackbar/snackbar-actions'; export const procesPanelActions = unionize({ SET_PROCESS_PANEL_FILTERS: ofType(), @@ -22,6 +27,16 @@ export const loadProcessPanel = (uuid: string) => dispatch(initProcessPanelFilters); }; +export const navigateToOutput = (uuid: string) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + try { + await services.collectionService.get(uuid); + dispatch(navigateToCollection(uuid)); + } catch { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'This collection does not exists!', hideDuration: 2000, kind: SnackbarKind.ERROR })); + } + }; + export const initProcessPanelFilters = procesPanelActions.SET_PROCESS_PANEL_FILTERS([ ProcessStatus.QUEUED, ProcessStatus.COMPLETED, diff --git a/src/views/process-panel/process-panel.tsx b/src/views/process-panel/process-panel.tsx index 87f60af3..56724696 100644 --- a/src/views/process-panel/process-panel.tsx +++ b/src/views/process-panel/process-panel.tsx @@ -11,9 +11,8 @@ import { matchProcessRoute } from '~/routes/routes'; import { ProcessPanelRootDataProps, ProcessPanelRootActionProps, ProcessPanelRoot } from './process-panel-root'; import { ProcessPanel as ProcessPanelState} from '~/store/process-panel/process-panel'; import { groupBy } from 'lodash'; -import { toggleProcessPanelFilter } from '~/store/process-panel/process-panel-actions'; +import { toggleProcessPanelFilter, navigateToOutput } from '~/store/process-panel/process-panel-actions'; import { openProcessInputDialog } from '~/store/processes/process-input-actions'; -import { navigateToCollection } from '~/store/navigation/navigation-action'; const mapStateToProps = ({ router, resources, processPanel }: RootState): ProcessPanelRootDataProps => { const pathname = router.location ? router.location.pathname : ''; @@ -36,7 +35,7 @@ const mapDispatchToProps = (dispatch: Dispatch): ProcessPanelRootActionProps => dispatch(toggleProcessPanelFilter(status)); }, openProcessInputDialog: (uuid) => dispatch(openProcessInputDialog(uuid)), - navigateToOutput: (uuid) => dispatch(navigateToCollection(uuid)) + navigateToOutput: (uuid) => dispatch(navigateToOutput(uuid)) }); export const ProcessPanel = connect(mapStateToProps, mapDispatchToProps)(ProcessPanelRoot);