Add:All providers option for searching covers #1774

This commit is contained in:
advplyr 2023-05-14 13:43:20 -05:00
parent 84c16c4a39
commit 32bdae31a8
2 changed files with 19 additions and 7 deletions

View File

@ -128,7 +128,7 @@ export default {
}, },
providers() { providers() {
if (this.isPodcast) return this.$store.state.scanners.podcastProviders if (this.isPodcast) return this.$store.state.scanners.podcastProviders
return [...this.$store.state.scanners.providers, ...this.$store.state.scanners.coverOnlyProviders] return [{ text: 'All', value: 'all' }, ...this.$store.state.scanners.providers, ...this.$store.state.scanners.coverOnlyProviders]
}, },
searchTitleLabel() { searchTitleLabel() {
if (this.provider.startsWith('audible')) return this.$strings.LabelSearchTitleOrASIN if (this.provider.startsWith('audible')) return this.$strings.LabelSearchTitleOrASIN
@ -288,7 +288,7 @@ export default {
}, },
getSearchQuery() { getSearchQuery() {
var searchQuery = `provider=${this.provider}&title=${this.searchTitle}` var searchQuery = `provider=${this.provider}&title=${this.searchTitle}`
if (this.searchAuthor) searchQuery += `&author=${this.searchAuthor}` if (this.searchAuthor) searchQuery += `&author=${this.searchAuthor || ''}`
if (this.isPodcast) searchQuery += '&podcast=1' if (this.isPodcast) searchQuery += '&podcast=1'
return searchQuery return searchQuery
}, },

View File

@ -18,6 +18,8 @@ class BookFinder {
this.fantLab = new FantLab() this.fantLab = new FantLab()
this.audiobookCovers = new AudiobookCovers() this.audiobookCovers = new AudiobookCovers()
this.providers = ['google', 'itunes', 'openlibrary', 'fantlab', 'audiobookcovers', 'audible', 'audible.ca', 'audible.uk', 'audible.au', 'audible.fr', 'audible.de', 'audible.jp', 'audible.it', 'audible.in', 'audible.es']
this.verbose = false this.verbose = false
} }
@ -183,7 +185,7 @@ class BookFinder {
var books = [] var books = []
var maxTitleDistance = !isNaN(options.titleDistance) ? Number(options.titleDistance) : 4 var maxTitleDistance = !isNaN(options.titleDistance) ? Number(options.titleDistance) : 4
var maxAuthorDistance = !isNaN(options.authorDistance) ? Number(options.authorDistance) : 4 var maxAuthorDistance = !isNaN(options.authorDistance) ? Number(options.authorDistance) : 4
Logger.debug(`Book Search: title: "${title}", author: "${author}", provider: ${provider}`) Logger.debug(`Book Search: title: "${title}", author: "${author || ''}", provider: ${provider}`)
if (provider === 'google') { if (provider === 'google') {
books = await this.getGoogleBooksResults(title, author) books = await this.getGoogleBooksResults(title, author)
@ -222,19 +224,29 @@ class BookFinder {
} }
async findCovers(provider, title, author, options = {}) { async findCovers(provider, title, author, options = {}) {
var searchResults = await this.search(provider, title, author, options) let searchResults = []
if (provider === 'all') {
for (const providerString of this.providers) {
const providerResults = await this.search(providerString, title, author, options)
Logger.debug(`[BookFinder] Found ${providerResults.length} covers from ${providerString}`)
searchResults.push(...providerResults)
}
} else {
searchResults = await this.search(provider, title, author, options)
}
Logger.debug(`[BookFinder] FindCovers search results: ${searchResults.length}`) Logger.debug(`[BookFinder] FindCovers search results: ${searchResults.length}`)
var covers = [] const covers = []
searchResults.forEach((result) => { searchResults.forEach((result) => {
if (result.covers && result.covers.length) { if (result.covers && result.covers.length) {
covers = covers.concat(result.covers) covers.push(...result.covers)
} }
if (result.cover) { if (result.cover) {
covers.push(result.cover) covers.push(result.cover)
} }
}) })
return covers return [...(new Set(covers))]
} }
findChapters(asin, region) { findChapters(asin, region) {