Fix podcast episode playback session duration, use podcast episode plaintext description

This commit is contained in:
advplyr 2022-04-17 17:52:06 -05:00
parent 5d305c96ad
commit d69f6020c6
5 changed files with 30 additions and 7 deletions

View File

@ -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>

View File

@ -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
if (episodeId) {
this.duration = libraryItem.media.getEpisodeDuration(episodeId)
} else {
this.duration = libraryItem.media.duration this.duration = libraryItem.media.duration
}
this.mediaPlayer = mediaPlayer this.mediaPlayer = mediaPlayer

View File

@ -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')

View File

@ -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

View File

@ -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 || '',