// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import { connect } from 'react-redux'; import { RootState } from 'store/store'; import { Dispatch } from 'redux'; import { goToView, searchData, deleteSavedQuery, loadRecentQueries, openSearchView, closeSearchView, closeAdvanceView, navigateToItem, editSavedQuery, changeData, submitData, moveUp, moveDown, setAdvancedDataFromSearchValue, SEARCH_BAR_ADVANCED_FORM_NAME } from 'store/search-bar/search-bar-actions'; import { SearchBarView, SearchBarActionProps, SearchBarDataProps } from 'views-components/search-bar/search-bar-view'; import { SearchBarAdvancedFormData } from 'models/search-bar'; import { Vocabulary } from 'models/vocabulary'; const mapStateToProps = ({ searchBar, form }: RootState): SearchBarDataProps => { return { searchValue: searchBar.searchValue, currentView: searchBar.currentView, isPopoverOpen: searchBar.open, searchResults: searchBar.searchResults, selectedItem: searchBar.selectedItem, savedQueries: searchBar.savedQueries, tags: form[SEARCH_BAR_ADVANCED_FORM_NAME], saveQuery: form[SEARCH_BAR_ADVANCED_FORM_NAME] && form[SEARCH_BAR_ADVANCED_FORM_NAME].values && form[SEARCH_BAR_ADVANCED_FORM_NAME].values!.saveQuery }; }; const mapDispatchToProps = (dispatch: Dispatch): SearchBarActionProps => ({ onSearch: (valueSearch: string) => dispatch(searchData(valueSearch, true)), onChange: (event: React.ChangeEvent) => dispatch(changeData(event.target.value)), onSetView: (currentView: string) => dispatch(goToView(currentView)), onSubmit: (event: React.FormEvent) => dispatch(submitData(event)), closeView: () => dispatch(closeSearchView()), closeAdvanceView: () => dispatch(closeAdvanceView()), loadRecentQueries: () => dispatch(loadRecentQueries()), deleteSavedQuery: (id: number) => dispatch(deleteSavedQuery(id)), openSearchView: () => dispatch(openSearchView()), navigateTo: (uuid: string) => dispatch(navigateToItem(uuid)), editSavedQuery: (data: SearchBarAdvancedFormData) => dispatch(editSavedQuery(data)), moveUp: () => dispatch(moveUp()), moveDown: () => dispatch(moveDown()), setAdvancedDataFromSearchValue: (search: string, vocabulary: Vocabulary) => dispatch(setAdvancedDataFromSearchValue(search, vocabulary)) }); export const SearchBar = connect(mapStateToProps, mapDispatchToProps)(SearchBarView);