Initialize groups panel store and view component
[arvados.git] / src / store / side-panel / side-panel-action.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { Dispatch } from 'redux';
6 import { isSidePanelTreeCategory, SidePanelTreeCategory } from '~/store/side-panel-tree/side-panel-tree-actions';
7 import { navigateToFavorites, navigateTo, navigateToTrash, navigateToSharedWithMe, navigateToWorkflows } from '../navigation/navigation-action';
8 import { snackbarActions } from '~/store/snackbar/snackbar-actions';
9
10 export const navigateFromSidePanel = (id: string) =>
11     (dispatch: Dispatch) => {
12         if (isSidePanelTreeCategory(id)) {
13             dispatch<any>(getSidePanelTreeCategoryAction(id));
14         } else {
15             dispatch<any>(navigateTo(id));
16         }
17     };
18
19 const getSidePanelTreeCategoryAction = (id: string) => {
20     switch (id) {
21         case SidePanelTreeCategory.FAVORITES:
22             return navigateToFavorites;
23         case SidePanelTreeCategory.TRASH:
24             return navigateToTrash;
25         case SidePanelTreeCategory.SHARED_WITH_ME:
26             return navigateToSharedWithMe;
27         case SidePanelTreeCategory.WORKFLOWS:
28             return navigateToWorkflows;
29         default:
30             return sidePanelTreeCategoryNotAvailable(id);
31     }
32 };
33
34 const sidePanelTreeCategoryNotAvailable = (id: string) =>
35     snackbarActions.OPEN_SNACKBAR({
36         message: `${id} not available`,
37         hideDuration: 3000,
38     });