WithStyles,
Tooltip,
InputAdornment, Input,
- List, ListItem, ListItemText, ListItemSecondaryAction
+ List, ListItem, ListItemText, ListItemSecondaryAction, Button
} from '@material-ui/core';
import SearchIcon from '@material-ui/icons/Search';
import { RemoveIcon } from '~/components/icon/icon';
+import { connect } from 'react-redux';
+import { RootState } from '~/store/store';
+import { Dispatch } from 'redux';
+import { goToView } from '~/store/structured-search/structured-search-actions';
+import { SearchView } from '~/store/structured-search/structured-search-reducer';
type CssRules = 'container' | 'input' | 'advanced' | 'searchQueryList' | 'list' | 'searchView' | 'searchBar';
justifyContent: 'flex-end',
paddingRight: theme.spacing.unit * 2,
paddingBottom: theme.spacing.unit,
- fontSize: '14px'
+ fontSize: '14px',
+ cursor: 'pointer'
},
searchQueryList: {
padding: `${theme.spacing.unit / 2}px ${theme.spacing.unit}px `,
interface SearchBarDataProps {
value: string;
+ currentView: string;
}
interface SearchBarActionProps {
onSearch: (value: string) => any;
debounce?: number;
+ onSetView: (currentView: string) => void;
}
type SearchBarProps = SearchBarDataProps & SearchBarActionProps & WithStyles<CssRules>;
isSearchViewOpen: boolean;
}
+const mapStateToProps = ({ structuredSearch }: RootState) => {
+ return {
+ currentView: structuredSearch.currentView
+ };
+};
+
+const mapDispatchToProps = (dispatch: Dispatch) => ({
+ onSetView: (currentView: string) => {
+ dispatch<any>(goToView(currentView));
+ }
+});
+
export const DEFAULT_SEARCH_DEBOUNCE = 1000;
-export const SearchBar = withStyles(styles)(
+export const SearchBar = connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(
class extends React.Component<SearchBarProps> {
state: SearchBarState = {
value: "",
timeout: number;
render() {
- const { classes } = this.props;
- return <Paper className={classes.container} onBlur={this.closeSearchView}>
+ const { classes, currentView } = this.props;
+ return <Paper className={classes.container} >
<form onSubmit={this.handleSubmit} className={classes.searchBar}>
<Input
autoComplete={''}
value={this.state.value}
fullWidth={true}
disableUnderline={true}
- onFocus={this.openSearchView}
+ onClick={this.toggleSearchView}
endAdornment={
<InputAdornment position="end">
<Tooltip title='Search'>
</Tooltip>
</InputAdornment>
} />
- {this.state.isSearchViewOpen && <Paper className={classes.searchView}>
- <div className={classes.searchQueryList}>Saved search queries</div>
- <List component="nav" className={classes.list}>
- {this.renderSavedQueries('Test')}
- {this.renderSavedQueries('Demo')}
- </List>
- <div className={classes.searchQueryList}>Recent search queries</div>
- <List component="nav" className={classes.list}>
- {this.renderRecentQueries('cos')}
- {this.renderRecentQueries('testtest')}
- </List>
- <div className={classes.advanced}>Advanced search</div>
- </Paper>}
+ {this.state.isSearchViewOpen && this.getView(currentView)}
</form>
</Paper>;
}
clearTimeout(this.timeout);
}
- closeSearchView = () =>
- this.setState({ isSearchViewOpen: false })
-
-
- openSearchView = () =>
- this.setState({ isSearchViewOpen: true })
+ toggleSearchView = () =>
+ this.setState({ isSearchViewOpen: !this.state.isSearchViewOpen })
+ getView = (currentView: string) => {
+ switch (currentView) {
+ case SearchView.BASIC:
+ return <Paper className={this.props.classes.searchView}>
+ <div className={this.props.classes.searchQueryList}>Saved search queries</div>
+ <List component="nav" className={this.props.classes.list}>
+ {this.renderSavedQueries('Test')}
+ {this.renderSavedQueries('Demo')}
+ </List>
+ <div className={this.props.classes.searchQueryList}>Recent search queries</div>
+ <List component="nav" className={this.props.classes.list}>
+ {this.renderRecentQueries('cos')}
+ {this.renderRecentQueries('testtest')}
+ </List>
+ <div className={this.props.classes.advanced} onClick={() => this.props.onSetView(SearchView.ADVANCED)}>Advanced search</div>
+ </Paper>;
+ case SearchView.ADVANCED:
+ return <Paper>
+ <List component="nav" className={this.props.classes.list}>
+ {this.renderRecentQueries('ADVANCED VIEW')}
+ </List>
+ <Button onClick={() => this.props.onSetView(SearchView.BASIC)}>Back</Button>
+ </Paper>;
+ case SearchView.AUTOCOMPLETE:
+ return <Paper>
+ <List component="nav" className={this.props.classes.list}>
+ {this.renderRecentQueries('AUTOCOMPLETE VIEW')}
+ </List>
+ </Paper>;
+ default:
+ return '';
+ }
+ }
renderRecentQueries = (text: string) =>
<ListItem button>
() => this.props.onSearch(this.state.value),
this.props.debounce || DEFAULT_SEARCH_DEBOUNCE
);
-
+ if (event.target.value.length > 0) {
+ this.props.onSetView(SearchView.AUTOCOMPLETE);
+ } else {
+ this.props.onSetView(SearchView.BASIC);
+ }
}
}
-);
+));