Parse and update author name on each update

This commit is contained in:
Mark Cooper 2021-08-25 06:38:32 -05:00
parent 6ca7e9e6a6
commit 81487d1dba
9 changed files with 65 additions and 41 deletions

View File

@ -115,6 +115,9 @@ export default {
}, },
methods: { methods: {
async submitForm() { async submitForm() {
if (this.isProcessing) {
return
}
this.isProcessing = true this.isProcessing = true
const updatePayload = { const updatePayload = {
book: this.details, book: this.details,

View File

@ -10,6 +10,10 @@ export default {
text: { text: {
type: String, type: String,
required: true required: true
},
direction: {
type: String,
default: 'right'
} }
}, },
data() { data() {
@ -21,11 +25,17 @@ export default {
methods: { methods: {
createTooltip() { createTooltip() {
var boxChow = this.$refs.box.getBoundingClientRect() var boxChow = this.$refs.box.getBoundingClientRect()
var top = boxChow.top var top = 0
var left = boxChow.left + boxChow.width + 4 var left = 0
if (this.direction === 'right') {
top = boxChow.top
left = boxChow.left + boxChow.width + 4
} else if (this.direction === 'bottom') {
top = boxChow.top + boxChow.height + 4
left = boxChow.left
}
var tooltip = document.createElement('div') var tooltip = document.createElement('div')
tooltip.className = 'absolute px-2 bg-black bg-opacity-60 py-1 text-white pointer-events-none text-xs' tooltip.className = 'absolute px-2 bg-black bg-opacity-90 py-1 text-white pointer-events-none text-xs rounded shadow-lg'
tooltip.style.top = top + 'px' tooltip.style.top = top + 'px'
tooltip.style.left = left + 'px' tooltip.style.left = left + 'px'
tooltip.style.zIndex = 100 tooltip.style.zIndex = 100

View File

@ -1,6 +1,6 @@
{ {
"name": "audiobookshelf-client", "name": "audiobookshelf-client",
"version": "0.9.74-beta", "version": "0.9.75-beta",
"description": "Audiobook manager and player", "description": "Audiobook manager and player",
"main": "index.js", "main": "index.js",
"scripts": { "scripts": {

View File

@ -13,7 +13,9 @@
<div class="mb-2"> <div class="mb-2">
<h1 class="text-2xl font-book leading-7">{{ title }}</h1> <h1 class="text-2xl font-book leading-7">{{ title }}</h1>
<h3 v-if="series" class="font-book text-gray-300 text-lg leading-7">{{ seriesText }}</h3> <h3 v-if="series" class="font-book text-gray-300 text-lg leading-7">{{ seriesText }}</h3>
<p class="text-sm text-gray-100 leading-7">by {{ author }}</p> <ui-tooltip :text="authorTooltipText" direction="bottom">
<p class="text-sm text-gray-100 leading-7">by {{ author }}</p>
</ui-tooltip>
</div> </div>
<div class="flex-grow" /> <div class="flex-grow" />
</div> </div>
@ -137,6 +139,16 @@ export default {
author() { author() {
return this.book.author || 'Unknown' return this.book.author || 'Unknown'
}, },
authorFL() {
return this.book.authorFL
},
authorLF() {
return this.book.authorLF
},
authorTooltipText() {
var txt = ['FL: ' + this.authorFL || 'Not Set', 'LF: ' + this.authorLF || 'Not Set']
return txt.join('\n')
},
series() { series() {
return this.book.series || null return this.book.series || null
}, },

View File

@ -1,6 +1,6 @@
{ {
"name": "audiobookshelf", "name": "audiobookshelf",
"version": "0.9.74-beta", "version": "0.9.75-beta",
"description": "Self-hosted audiobook server for managing and playing audiobooks.", "description": "Self-hosted audiobook server for managing and playing audiobooks.",
"main": "index.js", "main": "index.js",
"scripts": { "scripts": {

View File

@ -310,10 +310,6 @@ class Audiobook {
return hasUpdates return hasUpdates
} }
syncAuthorNames(audiobookData) {
return this.book.syncAuthorNames(audiobookData.authorFL, audiobookData.authorLF)
}
isSearchMatch(search) { isSearchMatch(search) {
return this.book.isSearchMatch(search.toLowerCase().trim()) return this.book.isSearchMatch(search.toLowerCase().trim())
} }

View File

@ -1,4 +1,6 @@
const Path = require('path') const Path = require('path')
const Logger = require('./Logger')
const parseAuthors = require('./utils/parseAuthors')
class Book { class Book {
constructor(book = null) { constructor(book = null) {
this.olid = null this.olid = null
@ -55,12 +57,29 @@ class Book {
} }
} }
setParseAuthor(author) {
if (!author) {
var hasUpdated = this.authorFL || this.authorLF
this.authorFL = null
this.authorLF = null
return hasUpdated
}
try {
var { authorLF, authorFL } = parseAuthors(author)
var hasUpdated = authorLF !== this.authorLF || authorFL !== this.authorFL
this.authorFL = authorFL || null
this.authorLF = authorLF || null
return hasUpdated
} catch (err) {
Logger.error('[Book] Parse authors failed', err)
return false
}
}
setData(data) { setData(data) {
this.olid = data.olid || null this.olid = data.olid || null
this.title = data.title || null this.title = data.title || null
this.author = data.author || null this.author = data.author || null
this.authorLF = data.authorLF || null
this.authorFL = data.authorFL || null
this.series = data.series || null this.series = data.series || null
this.volumeNumber = data.volumeNumber || null this.volumeNumber = data.volumeNumber || null
this.publishYear = data.publishYear || null this.publishYear = data.publishYear || null
@ -68,6 +87,10 @@ class Book {
this.cover = data.cover || null this.cover = data.cover || null
this.genres = data.genres || [] this.genres = data.genres || []
if (data.author) {
this.setParseAuthor(this.author)
}
// Use first image file as cover // Use first image file as cover
if (data.otherFiles && data.otherFiles.length) { if (data.otherFiles && data.otherFiles.length) {
var imageFile = data.otherFiles.find(f => f.filetype === 'image') var imageFile = data.otherFiles.find(f => f.filetype === 'image')
@ -90,6 +113,14 @@ class Book {
this.genres = payload['genres'] this.genres = payload['genres']
hasUpdates = true hasUpdates = true
} }
} else if (key === 'author') {
if (this.author !== payload.author) {
this.author = payload.author || null
hasUpdates = true
}
if (this.setParseAuthor(this.author)) {
hasUpdates = true
}
} else if (this[key] !== undefined && payload[key] !== this[key]) { } else if (this[key] !== undefined && payload[key] !== this[key]) {
this[key] = payload[key] this[key] = payload[key]
hasUpdates = true hasUpdates = true
@ -98,19 +129,6 @@ class Book {
return hasUpdates return hasUpdates
} }
syncAuthorNames(authorFL, authorLF) {
var hasUpdates = false
if (authorFL !== this.authorFL) {
this.authorFL = authorFL
hasUpdates = true
}
if (authorLF !== this.authorLF) {
this.authorLF = authorLF
hasUpdates = true
}
return hasUpdates
}
isSearchMatch(search) { isSearchMatch(search) {
return this._title.toLowerCase().includes(search) || this._author.toLowerCase().includes(search) || this._series.toLowerCase().includes(search) return this._title.toLowerCase().includes(search) || this._author.toLowerCase().includes(search) || this._series.toLowerCase().includes(search)
} }

View File

@ -1,4 +1,3 @@
const Path = require('path')
const Logger = require('./Logger') const Logger = require('./Logger')
const BookFinder = require('./BookFinder') const BookFinder = require('./BookFinder')
const Audiobook = require('./Audiobook') const Audiobook = require('./Audiobook')
@ -120,11 +119,6 @@ class Scanner {
hasUpdates = true hasUpdates = true
} }
if (audiobookData.author && existingAudiobook.syncAuthorNames(audiobookData)) {
Logger.info(`[Scanner] "${existingAudiobook.title}" author names updated, "${existingAudiobook.authorLF}"`)
hasUpdates = true
}
if (hasUpdates) { if (hasUpdates) {
Logger.info(`[Scanner] "${existingAudiobook.title}" was updated - saving`) Logger.info(`[Scanner] "${existingAudiobook.title}" was updated - saving`)
existingAudiobook.lastUpdate = Date.now() existingAudiobook.lastUpdate = Date.now()

View File

@ -1,7 +1,6 @@
const Path = require('path') const Path = require('path')
const dir = require('node-dir') const dir = require('node-dir')
const Logger = require('../Logger') const Logger = require('../Logger')
const parseAuthors = require('./parseAuthors')
const { cleanString } = require('./index') const { cleanString } = require('./index')
const AUDIOBOOK_PARTS_FORMATS = ['m4b', 'mp3'] const AUDIOBOOK_PARTS_FORMATS = ['m4b', 'mp3']
@ -75,14 +74,6 @@ async function getAllAudiobookFiles(abRootPath) {
parts: [], parts: [],
otherFiles: [] otherFiles: []
} }
if (author) {
var parsedAuthors = parseAuthors(author)
if (parsedAuthors) {
var { authorLF, authorFL } = parsedAuthors
audiobooks[path].authorLF = authorLF || null
audiobooks[path].authorFL = authorFL || null
}
}
} }
var filetype = getFileType(pathformat.ext) var filetype = getFileType(pathformat.ext)