mirror of
https://github.com/advplyr/audiobookshelf-app.git
synced 2025-06-20 20:05:44 +02:00
162 lines
5.3 KiB
Vue
162 lines
5.3 KiB
Vue
<template>
|
|
<div class="w-full h-full py-6 px-4">
|
|
<div class="flex items-center mb-2">
|
|
<p class="text-base font-semibold">{{ $strings.LabelFolder }}: {{ folderName }}</p>
|
|
<div class="flex-grow" />
|
|
|
|
<span v-if="dialogItems.length" class="material-symbols text-2xl" @click="showDialog = true">more_vert</span>
|
|
</div>
|
|
|
|
<p class="text-sm mb-4 text-fg-muted">{{ $strings.LabelMediaType }}: {{ mediaType }}</p>
|
|
|
|
<p class="mb-2 text-base text-fg">{{ $strings.HeaderLocalLibraryItems }} ({{ localLibraryItems.length }})</p>
|
|
|
|
<div class="w-full media-item-container overflow-y-auto">
|
|
<template v-for="localLibraryItem in localLibraryItems">
|
|
<nuxt-link :to="`/localMedia/item/${localLibraryItem.id}`" :key="localLibraryItem.id" class="flex my-1">
|
|
<div class="w-12 h-12 min-w-12 min-h-12 bg-primary">
|
|
<img v-if="localLibraryItem.coverPathSrc" :src="localLibraryItem.coverPathSrc" class="w-full h-full object-contain" />
|
|
</div>
|
|
<div class="flex-grow px-2">
|
|
<p class="text-sm">{{ localLibraryItem.media.metadata.title }}</p>
|
|
<p class="text-xs text-fg-muted">{{ getLocalLibraryItemSubText(localLibraryItem) }}</p>
|
|
</div>
|
|
<div class="w-12 h-12 flex items-center justify-center">
|
|
<span class="material-symbols text-xl text-fg-muted">arrow_right</span>
|
|
</div>
|
|
</nuxt-link>
|
|
</template>
|
|
</div>
|
|
|
|
<modals-dialog v-model="showDialog" :items="dialogItems" @action="dialogAction" />
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { Capacitor } from '@capacitor/core'
|
|
import { Dialog } from '@capacitor/dialog'
|
|
import { AbsFileSystem } from '@/plugins/capacitor'
|
|
|
|
export default {
|
|
asyncData({ params, query }) {
|
|
return {
|
|
folderId: params.id
|
|
}
|
|
},
|
|
data() {
|
|
return {
|
|
localLibraryItems: [],
|
|
folder: null,
|
|
removingFolder: false,
|
|
showDialog: false
|
|
}
|
|
},
|
|
computed: {
|
|
folderName() {
|
|
return this.folder?.name || null
|
|
},
|
|
mediaType() {
|
|
return this.folder?.mediaType
|
|
},
|
|
isInternalStorage() {
|
|
return this.folder?.id.startsWith('internal-')
|
|
},
|
|
dialogItems() {
|
|
if (this.isInternalStorage) return []
|
|
const items = []
|
|
items.push({
|
|
text: this.$strings.ButtonRemove,
|
|
value: 'remove'
|
|
})
|
|
return items
|
|
}
|
|
},
|
|
methods: {
|
|
getLocalLibraryItemSubText(localLibraryItem) {
|
|
if (!localLibraryItem) return ''
|
|
if (localLibraryItem.mediaType == 'book') {
|
|
const txts = []
|
|
if (localLibraryItem.media.ebookFile) {
|
|
txts.push(`${localLibraryItem.media.ebookFile.ebookFormat} ${this.$strings.LabelEbook}`)
|
|
}
|
|
if (localLibraryItem.media.tracks?.length) {
|
|
txts.push(`${localLibraryItem.media.tracks.length} ${this.$strings.LabelTracks}`)
|
|
}
|
|
return txts.join(' • ')
|
|
} else {
|
|
return `${localLibraryItem.media.episodes?.length || 0} ${this.$strings.HeaderEpisodes}`
|
|
}
|
|
},
|
|
dialogAction(action) {
|
|
console.log('Dialog action', action)
|
|
if (action == 'remove') {
|
|
this.removeFolder()
|
|
}
|
|
this.showDialog = false
|
|
},
|
|
async removeFolder() {
|
|
var deleteMessage = 'Are you sure you want to remove this folder? (does not delete anything in your file system)'
|
|
if (this.localLibraryItems.length) {
|
|
deleteMessage = `Are you sure you want to remove this folder and ${this.localLibraryItems.length} items? (does not delete anything in your file system)`
|
|
}
|
|
const { value } = await Dialog.confirm({
|
|
title: 'Confirm',
|
|
message: deleteMessage
|
|
})
|
|
if (value) {
|
|
this.removingFolder = true
|
|
await AbsFileSystem.removeFolder({ folderId: this.folderId })
|
|
this.removingFolder = false
|
|
this.$router.replace('/localMedia/folders')
|
|
}
|
|
},
|
|
async init() {
|
|
var folder = await this.$db.getLocalFolder(this.folderId)
|
|
this.folder = folder
|
|
|
|
var items = (await this.$db.getLocalLibraryItemsInFolder(this.folderId)) || []
|
|
console.log('Init folder', this.folderId, items)
|
|
this.localLibraryItems = items.map((lmi) => {
|
|
console.log('Local library item', JSON.stringify(lmi))
|
|
return {
|
|
...lmi,
|
|
coverPathSrc: lmi.coverContentUrl ? Capacitor.convertFileSrc(lmi.coverContentUrl) : null
|
|
}
|
|
})
|
|
},
|
|
newLocalLibraryItem(item) {
|
|
if (item.folderId == this.folderId) {
|
|
console.log('New local library item', item.id)
|
|
if (this.localLibraryItems.find((li) => li.id == item.id)) {
|
|
console.warn('Item already added', item.id)
|
|
return
|
|
}
|
|
|
|
var _item = {
|
|
...item,
|
|
coverPathSrc: item.coverContentUrl ? Capacitor.convertFileSrc(item.coverContentUrl) : null
|
|
}
|
|
this.localLibraryItems.push(_item)
|
|
}
|
|
}
|
|
},
|
|
mounted() {
|
|
this.$eventBus.$on('new-local-library-item', this.newLocalLibraryItem)
|
|
this.init()
|
|
},
|
|
beforeDestroy() {
|
|
this.$eventBus.$off('new-local-library-item', this.newLocalLibraryItem)
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.media-item-container {
|
|
height: calc(100vh - 210px);
|
|
max-height: calc(100vh - 210px);
|
|
}
|
|
.playerOpen .media-item-container {
|
|
height: calc(100vh - 310px);
|
|
max-height: calc(100vh - 310px);
|
|
}
|
|
</style>
|