Fix playlist element scrolling

This commit is contained in:
Chocobozzz 2022-03-01 11:11:12 +01:00
parent 7bde625050
commit 19e7a90045
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
5 changed files with 29 additions and 16 deletions

View File

@ -4,6 +4,7 @@
@use '_miniature' as *; @use '_miniature' as *;
.playlist { .playlist {
position: relative;
min-width: 200px; min-width: 200px;
max-width: 470px; max-width: 470px;
height: 66vh; height: 66vh;

View File

@ -1,9 +1,10 @@
import { Component, EventEmitter, Input, Output } from '@angular/core' import { Component, EventEmitter, Input, Output } from '@angular/core'
import { Router } from '@angular/router' import { Router } from '@angular/router'
import { AuthService, ComponentPagination, HooksService, Notifier, SessionStorageService, UserService } from '@app/core' import { AuthService, ComponentPagination, HooksService, Notifier, SessionStorageService, UserService } from '@app/core'
import { isInViewport } from '@app/helpers'
import { VideoPlaylist, VideoPlaylistElement, VideoPlaylistService } from '@app/shared/shared-video-playlist' import { VideoPlaylist, VideoPlaylistElement, VideoPlaylistService } from '@app/shared/shared-video-playlist'
import { peertubeSessionStorage } from '@root-helpers/peertube-web-storage'
import { getBoolOrDefault } from '@root-helpers/local-storage-utils' import { getBoolOrDefault } from '@root-helpers/local-storage-utils'
import { peertubeSessionStorage } from '@root-helpers/peertube-web-storage'
import { VideoPlaylistPrivacy } from '@shared/models' import { VideoPlaylistPrivacy } from '@shared/models'
@Component({ @Component({
@ -132,7 +133,12 @@ export class VideoWatchPlaylistComponent {
this.videoFound.emit(playlistElement.video.uuid) this.videoFound.emit(playlistElement.video.uuid)
setTimeout(() => { setTimeout(() => {
document.querySelector('.element-' + this.currentPlaylistPosition).scrollIntoView(false) const element = document.querySelector<HTMLElement>('.element-' + this.currentPlaylistPosition)
const container = document.querySelector<HTMLElement>('.playlist')
if (isInViewport(element, container)) return
container.scrollTop = element.offsetTop
}) })
return return

View File

@ -11,11 +11,7 @@
<img class="placeholder-image" *ngIf="playerPlaceholderImgSrc" [src]="playerPlaceholderImgSrc" alt="Placeholder image" i18n-alt> <img class="placeholder-image" *ngIf="playerPlaceholderImgSrc" [src]="playerPlaceholderImgSrc" alt="Placeholder image" i18n-alt>
</div> </div>
<my-video-watch-playlist <my-video-watch-playlist #videoWatchPlaylist [playlist]="playlist" (videoFound)="onPlaylistVideoFound($event)"></my-video-watch-playlist>
#videoWatchPlaylist
[playlist]="playlist" class="playlist"
(videoFound)="onPlaylistVideoFound($event)"
></my-video-watch-playlist>
<my-plugin-placeholder pluginId="player-next"></my-plugin-placeholder> <my-plugin-placeholder pluginId="player-next"></my-plugin-placeholder>
</div> </div>

View File

@ -6,14 +6,24 @@ function scrollToTop (behavior: 'auto' | 'smooth' = 'auto') {
}) })
} }
function isInViewport (el: HTMLElement) { function isInViewport (el: HTMLElement, container: HTMLElement = document.documentElement) {
const bounding = el.getBoundingClientRect() const boundingEl = el.getBoundingClientRect()
return ( const boundingContainer = container.getBoundingClientRect()
bounding.top >= 0 &&
bounding.left >= 0 && const relativePos = {
bounding.bottom <= (window.innerHeight || document.documentElement.clientHeight) && top: 0,
bounding.right <= (window.innerWidth || document.documentElement.clientWidth) left: 0,
) bottom: 0,
right: 0
}
relativePos.top = boundingEl.top - boundingContainer.top
relativePos.left = boundingEl.left - boundingContainer.left
return relativePos.top >= 0 &&
relativePos.left >= 0 &&
boundingEl.bottom <= boundingContainer.bottom &&
boundingEl.right <= boundingContainer.right
} }
function isXPercentInViewport (el: HTMLElement, percentVisible: number) { function isXPercentInViewport (el: HTMLElement, percentVisible: number) {

View File

@ -2,6 +2,6 @@ export * from './channel'
export * from './date' export * from './date'
export * from './html' export * from './html'
export * from './object' export * from './object'
export * from './ui' export * from './dom'
export * from './upload' export * from './upload'
export * from './url' export * from './url'