mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-16 10:58:16 +01:00
94 lines
3.0 KiB
Vue
94 lines
3.0 KiB
Vue
<template>
|
|
<div class="page" :class="streamLibraryItem ? 'streaming' : ''">
|
|
<div class="flex h-full">
|
|
<app-side-rail class="hidden md:block" />
|
|
<div class="flex-grow">
|
|
<app-book-shelf-toolbar is-home page="search" :search-query="query" />
|
|
<app-book-shelf-categorized v-if="hasResults" ref="bookshelf" search :results="results" />
|
|
<div v-else class="w-full py-16">
|
|
<p class="text-xl text-center">No Search results for "{{ query }}"</p>
|
|
<div class="flex justify-center">
|
|
<ui-btn class="w-52 my-4" @click="back">Back</ui-btn>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
async asyncData({ store, params, redirect, query, app }) {
|
|
var libraryId = params.library
|
|
var library = await store.dispatch('libraries/fetch', libraryId)
|
|
if (!library) {
|
|
return redirect('/oops?message=Library not found')
|
|
}
|
|
var query = query.q
|
|
var results = await app.$axios.$get(`/api/libraries/${libraryId}/search?q=${query}`).catch((error) => {
|
|
console.error('Failed to search library', error)
|
|
return null
|
|
})
|
|
results = {
|
|
podcasts: results && results.podcast ? results.podcast : null,
|
|
books: results && results.book ? results.book : null,
|
|
authors: results && results.authors.length ? results.authors : null,
|
|
series: results && results.series.length ? results.series : null,
|
|
tags: results && results.tags.length ? results.tags : null
|
|
}
|
|
return {
|
|
libraryId,
|
|
results,
|
|
query
|
|
}
|
|
},
|
|
data() {
|
|
return {}
|
|
},
|
|
watch: {
|
|
'$route.query'(newVal, oldVal) {
|
|
if (newVal && newVal.q && newVal.q !== this.query) {
|
|
this.query = newVal.q
|
|
this.search()
|
|
}
|
|
}
|
|
},
|
|
computed: {
|
|
streamLibraryItem() {
|
|
return this.$store.state.streamLibraryItem
|
|
},
|
|
hasResults() {
|
|
return Object.values(this.results).find((r) => !!r && r.length)
|
|
}
|
|
},
|
|
methods: {
|
|
async search() {
|
|
var results = await this.$axios.$get(`/api/libraries/${this.libraryId}/search?q=${this.query}`).catch((error) => {
|
|
console.error('Failed to search library', error)
|
|
return null
|
|
})
|
|
this.results = {
|
|
podcasts: results && results.podcast ? results.podcast : null,
|
|
books: results && results.book ? results.book : null,
|
|
authors: results && results.authors.length ? results.authors : null,
|
|
series: results && results.series.length ? results.series : null,
|
|
tags: results && results.tags.length ? results.tags : null
|
|
}
|
|
this.$nextTick(() => {
|
|
if (this.$refs.bookshelf) {
|
|
this.$refs.bookshelf.setShelvesFromSearch()
|
|
}
|
|
})
|
|
},
|
|
async back() {
|
|
var popped = await this.$store.dispatch('popRoute')
|
|
if (popped) this.$store.commit('setIsRoutingBack', true)
|
|
var backTo = popped || '/'
|
|
this.$router.push(backTo)
|
|
}
|
|
},
|
|
mounted() {},
|
|
beforeDestroy() {}
|
|
}
|
|
</script>
|