owntone-server/web-src/src/components/TabsSearch.vue

84 lines
2.1 KiB
Vue
Raw Normal View History

<template>
<section v-if="spotify_enabled" class="section fd-remove-padding-bottom">
<div class="container">
<div class="columns is-centered">
<div class="column is-four-fifths">
<div class="tabs is-centered is-small is-toggle is-toggle-rounded">
<ul>
<li
:class="{
'is-active': $store.state.search_path === '/search/library'
}"
>
<a @click="search_library">
2022-05-20 07:44:22 -04:00
<mdicon class="icon is-small" name="bookshelf" size="16" />
<span v-text="$t('tabs.search.library')" />
</a>
</li>
<li
:class="{
'is-active': $store.state.search_path === '/search/spotify'
}"
>
<a @click="search_spotify">
2022-05-20 07:44:22 -04:00
<mdicon class="icon is-small" name="spotify" size="16" />
<span v-text="$t('tabs.search.spotify')" />
</a>
</li>
</ul>
</div>
</div>
</div>
</div>
</section>
</template>
<script>
import * as types from '@/store/mutation_types'
export default {
name: 'TabsSearch',
props: ['query'],
computed: {
spotify_enabled() {
return this.$store.state.spotify.webapi_token_valid
},
route_query: function () {
if (!this.query) {
return null
}
return {
type: 'track,artist,album,playlist,audiobook,podcast',
query: this.query,
limit: 3,
offset: 0
}
}
},
methods: {
search_library: function () {
this.$store.commit(types.SEARCH_PATH, '/search/library')
this.$router.push({
path: this.$store.state.search_path,
query: this.route_query
})
},
search_spotify: function () {
this.$store.commit(types.SEARCH_PATH, '/search/spotify')
this.$router.push({
path: this.$store.state.search_path,
query: this.route_query
})
}
}
}
</script>
<style></style>