Added a "previous" button on player when watching playlist

Implements https://github.com/Chocobozzz/PeerTube/issues/3485
pull/3958/head
Poslovitch 2021-04-18 08:40:04 +00:00 committed by Chocobozzz
parent c29ce24256
commit 33d21a9b47
2 changed files with 31 additions and 0 deletions

View File

@ -137,6 +137,33 @@ export class VideoWatchPlaylistComponent {
this.onPlaylistVideosNearOfBottom(position) this.onPlaylistVideosNearOfBottom(position)
} }
findPreviousPlaylistVideo (position = this.currentPlaylistPosition): VideoPlaylistElement {
if (this.currentPlaylistPosition <= 1) {
// we have reached the top of the playlist: either loop or stop
if (this.loopPlaylist) {
this.currentPlaylistPosition = position = this.playlistPagination.totalItems
} else {
return
}
}
const previous = this.playlistElements.find(e => e.position === position)
if (!previous || !previous.video) {
return this.findPreviousPlaylistVideo(position - 1)
}
return previous
}
navigateToPreviousPlaylistVideo () {
const previous = this.findPreviousPlaylistVideo(this.currentPlaylistPosition - 1)
if (!previous) return
const start = previous.startTimestamp
const stop = previous.stopTimestamp
this.router.navigate([],{ queryParams: { playlistPosition: previous.position, start, stop } })
}
findNextPlaylistVideo (position = this.currentPlaylistPosition): VideoPlaylistElement { findNextPlaylistVideo (position = this.currentPlaylistPosition): VideoPlaylistElement {
if (this.currentPlaylistPosition >= this.playlistPagination.totalItems) { if (this.currentPlaylistPosition >= this.playlistPagination.totalItems) {
// we have reached the end of the playlist: either loop or stop // we have reached the end of the playlist: either loop or stop

View File

@ -799,6 +799,10 @@ export class VideoWatchComponent implements OnInit, OnDestroy {
common: { common: {
autoplay: this.isAutoplay(), autoplay: this.isAutoplay(),
nextVideo: () => this.zone.run(() => this.autoplayNext()), nextVideo: () => this.zone.run(() => this.autoplayNext()),
previousVideo: () => this.zone.run(() => {
// FIXME: Only show if this is a playlist
if (this.playlist) this.zone.run(() => this.videoWatchPlaylist.navigateToPreviousPlaylistVideo())
}),
playerElement: this.playerElement, playerElement: this.playerElement,
onPlayerElementChange: (element: HTMLVideoElement) => this.playerElement = element, onPlayerElementChange: (element: HTMLVideoElement) => this.playerElement = element,