mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-26 08:12:25 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="page" :class="streamAudiobook ? '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 = {
 | |
|       audiobooks: results && results.audiobooks.length ? results.audiobooks : 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: {
 | |
|     streamAudiobook() {
 | |
|       return this.$store.state.streamAudiobook
 | |
|     },
 | |
|     hasResults() {
 | |
|       return Object.values(this.results).find((r) => !!r)
 | |
|     }
 | |
|   },
 | |
|   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 = {
 | |
|         audiobooks: results && results.audiobooks.length ? results.audiobooks : 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>
 |