mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-06 22:19:04 +01:00
Fix podcast episode playback session duration, use podcast episode plaintext description
This commit is contained in:
parent
5d305c96ad
commit
d69f6020c6
@ -10,9 +10,7 @@
|
|||||||
<p class="text-sm font-semibold">
|
<p class="text-sm font-semibold">
|
||||||
{{ title }}
|
{{ title }}
|
||||||
</p>
|
</p>
|
||||||
<p class="text-sm text-gray-200 episode-subtitle mt-1.5 mb-0.5">
|
<p class="text-sm text-gray-200 episode-subtitle mt-1.5 mb-0.5">{{ description }}</p>
|
||||||
{{ description }}
|
|
||||||
</p>
|
|
||||||
<div class="flex items-center pt-2">
|
<div class="flex items-center pt-2">
|
||||||
<div class="h-8 px-4 border border-white border-opacity-20 hover:bg-white hover:bg-opacity-10 rounded-full flex items-center justify-center cursor-pointer" :class="userIsFinished ? 'text-white text-opacity-40' : ''" @click="playClick">
|
<div class="h-8 px-4 border border-white border-opacity-20 hover:bg-white hover:bg-opacity-10 rounded-full flex items-center justify-center cursor-pointer" :class="userIsFinished ? 'text-white text-opacity-40' : ''" @click="playClick">
|
||||||
<span class="material-icons" :class="streamIsPlaying ? '' : 'text-success'">{{ streamIsPlaying ? 'pause' : 'play_arrow' }}</span>
|
<span class="material-icons" :class="streamIsPlaying ? '' : 'text-success'">{{ streamIsPlaying ? 'pause' : 'play_arrow' }}</span>
|
||||||
|
@ -136,9 +136,14 @@ class PlaybackSession {
|
|||||||
this.mediaMetadata = libraryItem.media.metadata.clone()
|
this.mediaMetadata = libraryItem.media.metadata.clone()
|
||||||
this.chapters = (libraryItem.media.chapters || []).map(c => ({ ...c })) // Only book mediaType has chapters
|
this.chapters = (libraryItem.media.chapters || []).map(c => ({ ...c })) // Only book mediaType has chapters
|
||||||
this.displayTitle = libraryItem.media.getPlaybackTitle(episodeId)
|
this.displayTitle = libraryItem.media.getPlaybackTitle(episodeId)
|
||||||
this.displayAuthor = libraryItem.media.getPlaybackAuthor(episodeId)
|
this.displayAuthor = libraryItem.media.getPlaybackAuthor()
|
||||||
this.coverPath = libraryItem.media.coverPath
|
this.coverPath = libraryItem.media.coverPath
|
||||||
this.duration = libraryItem.media.duration
|
|
||||||
|
if (episodeId) {
|
||||||
|
this.duration = libraryItem.media.getEpisodeDuration(episodeId)
|
||||||
|
} else {
|
||||||
|
this.duration = libraryItem.media.duration
|
||||||
|
}
|
||||||
|
|
||||||
this.mediaPlayer = mediaPlayer
|
this.mediaPlayer = mediaPlayer
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
const { stripHtml } = require('string-strip-html')
|
||||||
const { getId } = require('../../utils/index')
|
const { getId } = require('../../utils/index')
|
||||||
const AudioFile = require('../files/AudioFile')
|
const AudioFile = require('../files/AudioFile')
|
||||||
const AudioTrack = require('../files/AudioTrack')
|
const AudioTrack = require('../files/AudioTrack')
|
||||||
@ -73,7 +74,8 @@ class PodcastEpisode {
|
|||||||
episodeType: this.episodeType,
|
episodeType: this.episodeType,
|
||||||
title: this.title,
|
title: this.title,
|
||||||
subtitle: this.subtitle,
|
subtitle: this.subtitle,
|
||||||
description: this.description,
|
// description: this.description,
|
||||||
|
description: this.descriptionPlain, // Temporary stripping HTML until proper cleaning is implemented
|
||||||
enclosure: this.enclosure ? { ...this.enclosure } : null,
|
enclosure: this.enclosure ? { ...this.enclosure } : null,
|
||||||
pubDate: this.pubDate,
|
pubDate: this.pubDate,
|
||||||
audioFile: this.audioFile.toJSON(),
|
audioFile: this.audioFile.toJSON(),
|
||||||
@ -102,6 +104,10 @@ class PodcastEpisode {
|
|||||||
if (this.episode) return `${this.episode} - ${this.title}`
|
if (this.episode) return `${this.episode} - ${this.title}`
|
||||||
return this.title
|
return this.title
|
||||||
}
|
}
|
||||||
|
get descriptionPlain() {
|
||||||
|
if (!this.description) return ''
|
||||||
|
return stripHtml(this.description).result
|
||||||
|
}
|
||||||
|
|
||||||
setData(data, index = 1) {
|
setData(data, index = 1) {
|
||||||
this.id = getId('ep')
|
this.id = getId('ep')
|
||||||
|
@ -251,5 +251,11 @@ class Podcast {
|
|||||||
getPlaybackAuthor() {
|
getPlaybackAuthor() {
|
||||||
return this.metadata.author
|
return this.metadata.author
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getEpisodeDuration(episodeId) {
|
||||||
|
var episode = this.episodes.find(ep => ep.id == episodeId)
|
||||||
|
if (!episode) return 0
|
||||||
|
return episode.duration
|
||||||
|
}
|
||||||
}
|
}
|
||||||
module.exports = Podcast
|
module.exports = Podcast
|
@ -73,12 +73,19 @@ function extractEpisodeData(item) {
|
|||||||
Logger.error(`[podcastUtils] Invalid podcast episode data`)
|
Logger.error(`[podcastUtils] Invalid podcast episode data`)
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
var arrayFields = ['title', 'pubDate', 'description', 'itunes:episodeType', 'itunes:episode', 'itunes:author', 'itunes:duration', 'itunes:explicit', 'itunes:subtitle']
|
|
||||||
var episode = {
|
var episode = {
|
||||||
enclosure: {
|
enclosure: {
|
||||||
...item.enclosure[0]['$']
|
...item.enclosure[0]['$']
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (item['description']) {
|
||||||
|
episode.description = extractFirstArrayItem(item, 'description')
|
||||||
|
episode.descriptionPlain = stripHtml(episode.description || '').result
|
||||||
|
}
|
||||||
|
|
||||||
|
var arrayFields = ['title', 'pubDate', 'itunes:episodeType', 'itunes:episode', 'itunes:author', 'itunes:duration', 'itunes:explicit', 'itunes:subtitle']
|
||||||
arrayFields.forEach((key) => {
|
arrayFields.forEach((key) => {
|
||||||
var cleanKey = key.split(':').pop()
|
var cleanKey = key.split(':').pop()
|
||||||
episode[cleanKey] = extractFirstArrayItem(item, key)
|
episode[cleanKey] = extractFirstArrayItem(item, key)
|
||||||
@ -91,6 +98,7 @@ function cleanEpisodeData(data) {
|
|||||||
title: data.title,
|
title: data.title,
|
||||||
subtitle: data.subtitle || '',
|
subtitle: data.subtitle || '',
|
||||||
description: data.description || '',
|
description: data.description || '',
|
||||||
|
descriptionPlain: data.descriptionPlain || '',
|
||||||
pubDate: data.pubDate || '',
|
pubDate: data.pubDate || '',
|
||||||
episodeType: data.episodeType || '',
|
episodeType: data.episodeType || '',
|
||||||
episode: data.episode || '',
|
episode: data.episode || '',
|
||||||
|
Loading…
Reference in New Issue
Block a user