search-results-view
[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, SearchResultsPanelDataProps } from './search-results-panel-view';
9 import { RootState } from '~/store/store';
10 import { openContextMenu, resourceKindToContextMenuKind } from '~/store/context-menu/context-menu-actions';
11 import { ResourceKind } from '~/models/resource';
12 import { loadDetailsPanel } from '~/store/details-panel/details-panel-action';
13 import { SearchResultsPanelView } from '~/views/search-results-panel/search-results-panel-view';
14
15 const mapStateToProps = (state: RootState): SearchResultsPanelDataProps => ({
16     data: {
17         inTrash: false,
18         dataFrom: '',
19         dataTo: '',
20         saveQuery: false,
21         searchQuery: ''
22     }
23 });
24
25 const mapDispatchToProps = (dispatch: Dispatch): SearchResultsPanelActionProps => ({
26     onContextMenu: (event, resourceUuid) => {
27         const kind = resourceKindToContextMenuKind(resourceUuid);
28         if (kind) {
29             dispatch<any>(openContextMenu(event, {
30                 name: '',
31                 uuid: resourceUuid,
32                 ownerUuid: '',
33                 kind: ResourceKind.NONE,
34                 menuKind: kind
35             }));
36         }
37     },
38     onDialogOpen: (ownerUuid: string) => { return; },
39     onItemClick: (resourceUuid: string) => {
40         dispatch<any>(loadDetailsPanel(resourceUuid));
41     },
42     onItemDoubleClick: uuid => {
43         dispatch<any>(navigateTo(uuid));
44     }
45 });
46
47 export const SearchResultsPanel = connect(mapStateToProps, mapDispatchToProps)(SearchResultsPanelView);