mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-06-14 01:16:52 +02:00
added backend logic
This commit is contained in:
parent
dbf1f88efa
commit
dd5da33a81
@ -14,6 +14,7 @@ const Logger = require('../Logger')
|
||||
* @property {string[]} metadataPrecedence
|
||||
* @property {number} markAsFinishedTimeRemaining Time remaining in seconds to mark as finished. (defaults to 10s)
|
||||
* @property {number} markAsFinishedPercentComplete Percent complete to mark as finished (0-100). If this is set it will be used over markAsFinishedTimeRemaining.
|
||||
* @property {boolean} listenAgainOrdered Order listen again items by progress or random
|
||||
*/
|
||||
|
||||
class Library extends Model {
|
||||
@ -61,7 +62,8 @@ class Library extends Model {
|
||||
autoScanCronExpression: null,
|
||||
podcastSearchRegion: 'us',
|
||||
markAsFinishedPercentComplete: null,
|
||||
markAsFinishedTimeRemaining: 10
|
||||
markAsFinishedTimeRemaining: 10,
|
||||
listenAgainOrdered: false
|
||||
}
|
||||
} else {
|
||||
return {
|
||||
@ -76,7 +78,8 @@ class Library extends Model {
|
||||
onlyShowLaterBooksInContinueSeries: false,
|
||||
metadataPrecedence: this.defaultMetadataPrecedence,
|
||||
markAsFinishedPercentComplete: null,
|
||||
markAsFinishedTimeRemaining: 10
|
||||
markAsFinishedTimeRemaining: 10,
|
||||
listenAgainOrdered: false
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -163,8 +163,9 @@ module.exports = {
|
||||
* @returns {Promise<{ items:oldLibraryItem[], count:number }>}
|
||||
*/
|
||||
async getMediaFinished(library, user, include, limit) {
|
||||
const sortBy = library.settings.listenAgainOrdered ? 'progress' : 'random'
|
||||
if (library.isBook) {
|
||||
const { libraryItems, count } = await libraryItemsBookFilters.getFilteredLibraryItems(library.id, user, 'progress', 'finished', 'random', true, false, include, limit, 0)
|
||||
const { libraryItems, count } = await libraryItemsBookFilters.getFilteredLibraryItems(library.id, user, 'progress', 'finished', sortBy, true, false, include, limit, 0)
|
||||
return {
|
||||
items: libraryItems.map((li) => {
|
||||
const oldLibraryItem = li.toOldJSONMinified()
|
||||
@ -179,7 +180,7 @@ module.exports = {
|
||||
count
|
||||
}
|
||||
} else {
|
||||
const { libraryItems, count } = await libraryItemsPodcastFilters.getFilteredPodcastEpisodes(library.id, user, 'progress', 'finished', 'random', true, limit, 0)
|
||||
const { libraryItems, count } = await libraryItemsPodcastFilters.getFilteredPodcastEpisodes(library.id, user, 'progress', 'finished', sortBy, true, limit, 0)
|
||||
return {
|
||||
count,
|
||||
items: libraryItems.map((li) => {
|
||||
|
Loading…
Reference in New Issue
Block a user