mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-13 00:06:30 +01:00
122 lines
3.8 KiB
Vue
122 lines
3.8 KiB
Vue
<template>
|
|
<div id="librariesTable" class="bg-bg rounded-md shadow-lg border border-white border-opacity-5 p-4 mb-8">
|
|
<div class="flex items-center mb-2">
|
|
<h1 class="text-xl">Libraries</h1>
|
|
<div class="mx-2 w-7 h-7 flex items-center justify-center rounded-full cursor-pointer hover:bg-white hover:bg-opacity-10 text-center" @click="clickAddLibrary">
|
|
<span class="material-icons" style="font-size: 1.4rem">add</span>
|
|
</div>
|
|
</div>
|
|
<draggable :list="libraryCopies" v-bind="dragOptions" class="list-group" draggable=".item" tag="div" @start="startDrag" @end="endDrag">
|
|
<template v-for="library in libraryCopies">
|
|
<div :key="library.id" class="item">
|
|
<modals-libraries-library-item :library="library" :selected="currentLibraryId === library.id" :show-edit="true" :dragging="drag" @edit="editLibrary" @sort="draggableSort" @click="setLibrary" />
|
|
</div>
|
|
</template>
|
|
</draggable>
|
|
<modals-edit-library-modal v-model="showLibraryModal" :library="selectedLibrary" />
|
|
|
|
<p class="text-xs mt-4 text-gray-200">*<strong>Force Re-Scan</strong> will scan all files again like a fresh scan. Audio file ID3 tags, OPF files, and text files will be probed/parsed and used for book details.</p>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import draggable from 'vuedraggable'
|
|
|
|
export default {
|
|
components: {
|
|
draggable
|
|
},
|
|
data() {
|
|
return {
|
|
libraryCopies: [],
|
|
currentOrder: [],
|
|
showLibraryModal: false,
|
|
selectedLibrary: null,
|
|
drag: false,
|
|
dragOptions: {
|
|
animation: 200,
|
|
group: 'description',
|
|
ghostClass: 'ghost'
|
|
},
|
|
orderTimeout: null
|
|
}
|
|
},
|
|
computed: {
|
|
currentLibrary() {
|
|
return this.$store.getters['libraries/getCurrentLibrary']
|
|
},
|
|
currentLibraryId() {
|
|
return this.currentLibrary ? this.currentLibrary.id : null
|
|
},
|
|
libraries() {
|
|
return this.$store.getters['libraries/getSortedLibraries']()
|
|
},
|
|
libraryScans() {
|
|
return this.$store.state.scanners.libraryScans
|
|
}
|
|
},
|
|
methods: {
|
|
startDrag() {
|
|
this.drag = true
|
|
clearTimeout(this.orderTimeout)
|
|
},
|
|
endDrag(e) {
|
|
this.drag = false
|
|
this.checkOrder()
|
|
},
|
|
checkOrder() {
|
|
clearTimeout(this.orderTimeout)
|
|
this.orderTimeout = setTimeout(() => {
|
|
this.saveOrder()
|
|
}, 500)
|
|
},
|
|
saveOrder() {
|
|
var _newOrder = 1
|
|
var currOrder = this.libraries.map((lib) => lib.id).join(',')
|
|
var libraryOrderData = this.libraryCopies.map((library) => {
|
|
return {
|
|
newOrder: _newOrder++,
|
|
oldOrder: library.displayOrder,
|
|
id: library.id
|
|
}
|
|
})
|
|
var newOrder = libraryOrderData.map((lib) => lib.id).join(',')
|
|
if (currOrder !== newOrder) {
|
|
this.$axios.$post('/api/libraries/order', libraryOrderData).then((libraries) => {
|
|
if (libraries && libraries.length) {
|
|
this.$toast.success('Library order saved', { timeout: 1500 })
|
|
this.$store.commit('libraries/set', libraries)
|
|
}
|
|
})
|
|
}
|
|
},
|
|
async setLibrary(library) {
|
|
await this.$store.dispatch('libraries/fetch', library.id)
|
|
this.$router.push(`/library/${library.id}`)
|
|
},
|
|
clickAddLibrary() {
|
|
this.selectedLibrary = null
|
|
this.showLibraryModal = true
|
|
},
|
|
editLibrary(library) {
|
|
this.selectedLibrary = library
|
|
this.showLibraryModal = true
|
|
},
|
|
init() {
|
|
this.libraryCopies = this.libraries.map((lib) => {
|
|
return { ...lib }
|
|
})
|
|
},
|
|
librariesUpdated() {
|
|
this.init()
|
|
}
|
|
},
|
|
mounted() {
|
|
this.$store.commit('libraries/addListener', { id: 'libraries-table', meth: this.librariesUpdated })
|
|
this.init()
|
|
},
|
|
beforeDestroy() {
|
|
this.$store.commit('libraries/removeListener', 'libraries-table')
|
|
}
|
|
}
|
|
</script> |