X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/dd8c26f9525bf0a8733314d5717e99f231cc90d1..956da0a3141be31119f6310734a59f4b79c254e3:/src/views-components/search-bar/search-bar-view.tsx diff --git a/src/views-components/search-bar/search-bar-view.tsx b/src/views-components/search-bar/search-bar-view.tsx index 385c4fa2..51062646 100644 --- a/src/views-components/search-bar/search-bar-view.tsx +++ b/src/views-components/search-bar/search-bar-view.tsx @@ -19,39 +19,54 @@ import { RemoveIcon } from '~/components/icon/icon'; import { SearchView } from '~/store/search-bar/search-bar-reducer'; import { SearchBarBasicView } from '~/views-components/search-bar/search-bar-basic-view'; import { SearchBarAdvancedView } from '~/views-components/search-bar/search-bar-advanced-view'; -import { SearchBarAutocompleteView } from '~/views-components/search-bar/search-bar-autocomplete-view'; +import { SearchBarAutocompleteView, SearchBarAutocompleteViewDataProps } from '~/views-components/search-bar/search-bar-autocomplete-view'; +import { ArvadosTheme } from '~/common/custom-theme'; +import { SearchBarAdvanceFormData } from '~/store/search-bar/search-bar-actions'; -type CssRules = 'container' | 'input' | 'searchBar'; +type CssRules = 'container' | 'containerSearchViewOpened' | 'input' | 'view'; -const styles: StyleRulesCallback = theme => { +const styles: StyleRulesCallback = (theme: ArvadosTheme) => { return { container: { position: 'relative', width: '100%', - borderRadius: '0px' + borderRadius: theme.spacing.unit / 2 + }, + containerSearchViewOpened: { + position: 'relative', + width: '100%', + borderRadius: `${theme.spacing.unit / 2}px ${theme.spacing.unit / 2}px 0 0` }, input: { border: 'none', padding: `0px ${theme.spacing.unit}px` }, - searchBar: { - height: '30px' + view: { + position: 'absolute', + width: '100%', + zIndex: 1 } }; }; -interface SearchBarDataProps { - value: string; +type SearchBarDataProps = { + searchValue: string; currentView: string; - open: boolean; -} + isPopoverOpen: boolean; + savedQueries: string[]; +} & SearchBarAutocompleteViewDataProps; interface SearchBarActionProps { onSearch: (value: string) => any; debounce?: number; onSetView: (currentView: string) => void; - openView: () => void; closeView: () => void; + saveRecentQuery: (query: string) => void; + loadRecentQueries: () => string[]; + saveQuery: (data: SearchBarAdvanceFormData) => void; + deleteSavedQuery: (id: number) => void; + openSearchView: () => void; + navigateTo: (uuid: string) => void; } type SearchBarProps = SearchBarDataProps & SearchBarActionProps & WithStyles; @@ -60,19 +75,44 @@ interface SearchBarState { value: string; } -export const renderRecentQueries = (text: string) => { + + +interface RenderRecentQueriesProps { + text: string | JSX.Element; + onSearch: (searchValue: string | JSX.Element) => void; +} + +export const RenderRecentQueries = (props: RenderRecentQueriesProps) => { + return + props.onSearch(props.text)} /> + ; +}; + +interface RenderAutocompleteItemsProps { + text: string | JSX.Element; + navigateTo: (uuid: string) => void; + uuid: string; +} + +export const RenderAutocompleteItems = (props: RenderAutocompleteItemsProps) => { return - + props.navigateTo(props.uuid)} /> ; }; +interface RenderSavedQueriesProps { + text: string | JSX.Element; + id: number; + deleteSavedQuery: (id: number) => void; + onSearch: (searchValue: string | JSX.Element) => void; +} -export const renderSavedQueries = (text: string) => { +export const RenderSavedQueries = (props: RenderSavedQueriesProps) => { return - + props.onSearch(props.text)} /> - + props.deleteSavedQuery(props.id)}> @@ -91,10 +131,10 @@ export const SearchBarView = withStyles(styles)( timeout: number; render() { - const { classes, currentView, openView, closeView, open } = this.props; - return closeView()}> - -
+ const { classes, currentView, openSearchView, closeView, isPopoverOpen } = this.props; + return + + openView()} + onClick={openSearchView} endAdornment={ @@ -112,19 +152,21 @@ export const SearchBarView = withStyles(styles)( } /> - {open && this.getView(currentView)} +
+ {isPopoverOpen && this.getView(currentView)} +
; } componentDidMount() { - this.setState({ value: this.props.value }); + this.setState({ value: this.props.searchValue }); } componentWillReceiveProps(nextProps: SearchBarProps) { - if (nextProps.value !== this.props.value) { - this.setState({ value: nextProps.value }); + if (nextProps.searchValue !== this.props.searchValue) { + this.setState({ value: nextProps.searchValue }); } } @@ -133,22 +175,28 @@ export const SearchBarView = withStyles(styles)( } getView = (currentView: string) => { + const { onSetView, loadRecentQueries, savedQueries, deleteSavedQuery, searchValue, searchResults, saveQuery, onSearch, navigateTo } = this.props; switch (currentView) { case SearchView.BASIC: - return ; + return ; case SearchView.ADVANCED: - return ; + return ; case SearchView.AUTOCOMPLETE: - return ; + return ; default: - return ; + return ; } } handleSubmit = (event: React.FormEvent) => { event.preventDefault(); clearTimeout(this.timeout); + this.props.saveRecentQuery(this.state.value); this.props.onSearch(this.state.value); + this.props.loadRecentQueries(); } handleChange = (event: React.ChangeEvent) => {