2019-07-16 02:42:27 +10:00
|
|
|
const SearchBar = {
|
|
|
|
data: () => ({
|
|
|
|
searchTerm: undefined,
|
|
|
|
hidden: true,
|
|
|
|
error: false,
|
|
|
|
loading: false
|
|
|
|
}),
|
|
|
|
watch: {
|
|
|
|
'$route': function (route) {
|
|
|
|
if (route.name === 'search') {
|
|
|
|
this.searchTerm = route.query.query
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
find (searchTerm) {
|
|
|
|
this.$router.push({ name: 'search', query: { query: searchTerm } })
|
|
|
|
this.$refs.searchInput.focus()
|
|
|
|
},
|
|
|
|
toggleHidden () {
|
|
|
|
this.hidden = !this.hidden
|
|
|
|
this.$emit('toggled', this.hidden)
|
2019-08-01 03:39:35 +10:00
|
|
|
this.$nextTick(() => {
|
|
|
|
if (!this.hidden) {
|
|
|
|
this.$refs.searchInput.focus()
|
|
|
|
}
|
|
|
|
})
|
2019-07-16 02:42:27 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SearchBar
|