mirror of
https://github.com/owntone/owntone-server.git
synced 2025-07-19 21:48:59 -04:00
58 lines
1.4 KiB
Vue
58 lines
1.4 KiB
Vue
<template>
|
|
<tabs-audiobooks />
|
|
<content-with-heading>
|
|
<template #options>
|
|
<list-index-buttons :indices="albums.indices" />
|
|
</template>
|
|
<template #heading>
|
|
<pane-title :content="heading" />
|
|
</template>
|
|
<template #content>
|
|
<list-albums :items="albums" />
|
|
</template>
|
|
</content-with-heading>
|
|
</template>
|
|
|
|
<script>
|
|
import ContentWithHeading from '@/templates/ContentWithHeading.vue'
|
|
import { GroupedList } from '@/lib/GroupedList'
|
|
import ListAlbums from '@/components/ListAlbums.vue'
|
|
import ListIndexButtons from '@/components/ListIndexButtons.vue'
|
|
import PaneTitle from '@/components/PaneTitle.vue'
|
|
import TabsAudiobooks from '@/components/TabsAudiobooks.vue'
|
|
import library from '@/api/library'
|
|
|
|
export default {
|
|
name: 'PageAudiobookAlbums',
|
|
components: {
|
|
ContentWithHeading,
|
|
ListAlbums,
|
|
ListIndexButtons,
|
|
PaneTitle,
|
|
TabsAudiobooks
|
|
},
|
|
beforeRouteEnter(to, from, next) {
|
|
library.albums('audiobook').then((albums) => {
|
|
next((vm) => {
|
|
vm.albums = new GroupedList(albums, {
|
|
index: { field: 'name_sort', type: String }
|
|
})
|
|
})
|
|
})
|
|
},
|
|
data() {
|
|
return {
|
|
albums: new GroupedList()
|
|
}
|
|
},
|
|
computed: {
|
|
heading() {
|
|
return {
|
|
subtitle: [{ count: this.albums.count, key: 'data.audiobooks' }],
|
|
title: this.$t('page.audiobooks.albums.title')
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|