<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>