15064: Tell users which clusters are being searched.
[arvados-workbench2.git] / src / views / search-results-panel / search-results-panel.tsx
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 { connect } from "react-redux";
7 import { navigateTo } from '~/store/navigation/navigation-action';
8 import { SearchResultsPanelActionProps } from './search-results-panel-view';
9 import { openContextMenu, resourceKindToContextMenuKind } from '~/store/context-menu/context-menu-actions';
10 import { ResourceKind } from '~/models/resource';
11 import { loadDetailsPanel } from '~/store/details-panel/details-panel-action';
12 import { SearchResultsPanelView } from '~/views/search-results-panel/search-results-panel-view';
13 import { RootState } from '~/store/store';
14
15 const mapStateToProps = (rootState: RootState) => {
16     return {
17         user: rootState.auth.user,
18         sessions: rootState.auth.sessions,
19         remoteHostsConfig: rootState.auth.remoteHostsConfig
20     };
21 };
22
23 const mapDispatchToProps = (dispatch: Dispatch): SearchResultsPanelActionProps => ({
24     onContextMenu: (event, resourceUuid) => {
25         const kind = resourceKindToContextMenuKind(resourceUuid);
26         if (kind) {
27             dispatch<any>(openContextMenu(event, {
28                 name: '',
29                 uuid: resourceUuid,
30                 ownerUuid: '',
31                 kind: ResourceKind.NONE,
32                 menuKind: kind
33             }));
34         }
35         dispatch<any>(loadDetailsPanel(resourceUuid));
36     },
37     onDialogOpen: (ownerUuid: string) => { return; },
38     onItemClick: (resourceUuid: string) => {
39         dispatch<any>(loadDetailsPanel(resourceUuid));
40     },
41     onItemDoubleClick: uuid => {
42         dispatch<any>(navigateTo(uuid));
43     }
44 });
45
46 export const SearchResultsPanel = connect(mapStateToProps, mapDispatchToProps)(SearchResultsPanelView);