<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 /> <div id="bookshelf" class="w-full h-full p-8 overflow-y-auto"> <div class="flex flex-wrap justify-center"> <template v-for="author in authors"> <nuxt-link :key="author.name" :to="`/library/${currentLibraryId}/bookshelf?filter=authors.${$encode(author.name)}`"> <cards-author-card :author="author" :width="160" :height="160" class="p-3" /> </nuxt-link> </template> </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') } return { libraryId } }, data() { return { loading: true, authors: [] } }, computed: { streamAudiobook() { return this.$store.state.streamAudiobook }, currentLibraryId() { return this.$store.state.libraries.currentLibraryId } }, methods: { async init() { this.authors = await this.$axios.$get(`/api/libraries/${this.currentLibraryId}/authors`).catch((error) => { console.error('Failed to load authors', error) return [] }) this.loading = false } }, mounted() { this.init() } } </script>