1
0
mirror of https://github.com/bpatrik/pigallery2.git synced 2025-01-08 04:03:48 +02:00

Indicating if slideshow is running in query params #809

This commit is contained in:
Patrik J. Braun 2024-01-07 16:56:05 +01:00
parent acccde3054
commit 649e7a9a7e
7 changed files with 101 additions and 45 deletions

View File

@ -14,6 +14,7 @@ export const QueryParams = {
query: 'qs',
},
photo: 'p',
playback: 'play',
sharingKey_query: 'sk',
sharingKey_params: 'sharingKey',
directory: 'directory',

View File

@ -10,32 +10,35 @@ import {ContentLoaderService} from '../ui/gallery/contentLoader.service';
@Injectable()
export class QueryService {
constructor(
private shareService: ShareService,
private galleryService: ContentLoaderService
private shareService: ShareService,
private galleryService: ContentLoaderService
) {
}
getMediaStringId(media: MediaDTO): string {
if (this.galleryService.isSearchResult()) {
return Utils.concatUrls(
media.directory.path,
media.directory.name,
media.name
media.directory.path,
media.directory.name,
media.name
);
} else {
return media.name;
}
}
getParams(media?: MediaDTO): { [key: string]: string } {
getParams(lightbox?: { media?: MediaDTO, playing?: boolean }): { [key: string]: string } {
const query: { [key: string]: string } = {};
if (media) {
query[QueryParams.gallery.photo] = this.getMediaStringId(media);
if (lightbox?.media) {
query[QueryParams.gallery.photo] = this.getMediaStringId(lightbox?.media);
}
if (lightbox?.playing) {
query[QueryParams.gallery.playback] = 'true';
}
if (Config.Sharing.enabled === true) {
if (this.shareService.isSharing()) {
query[QueryParams.gallery.sharingKey_query] =
this.shareService.getSharingKey();
this.shareService.getSharingKey();
}
}
return query;
@ -48,14 +51,14 @@ export class QueryService {
if (Config.Sharing.enabled === true) {
if (this.shareService.isSharing()) {
params[QueryParams.gallery.sharingKey_query] =
this.shareService.getSharingKey();
this.shareService.getSharingKey();
}
}
if (
directory &&
directory.lastModified &&
directory.lastScanned &&
!directory.isPartial
directory &&
directory.lastModified &&
directory.lastScanned &&
!directory.isPartial
) {
params[QueryParams.gallery.knownLastModified] = directory.lastModified;
params[QueryParams.gallery.knownLastScanned] = directory.lastScanned;

View File

@ -192,7 +192,7 @@ export class GalleryGridComponent
photoClicked(media: MediaDTO): void {
this.router.navigate([], {
queryParams: this.queryService.getParams(media),
queryParams: this.queryService.getParams({media}),
});
}

View File

@ -180,7 +180,7 @@
(click)="nextMediaManuallyTriggered()">
<ng-icon name="ionChevronForwardOutline"></ng-icon>
<canvas
*ngIf="playBackState == PlayBackStates.Play"
*ngIf="slideShowRunning"
#canvas width="55px" height="55px"></canvas>
</div>
@ -211,17 +211,17 @@
*ngIf="zoom == 1 && activePhoto && activePhoto.gridMedia.isPhoto()">
<div class="controls-background rounded-start-top pe-1 pb-1">
<ng-icon
*ngIf="playBackState == PlayBackStates.Play"
*ngIf="slideShowRunning"
name="ionPauseOutline"
class=" highlight control-button button-active me-2 mb-2"
(click)="pause()"
(click)="pauseClicked()"
title="Pause" i18n-title></ng-icon>
<ng-icon
*ngIf="playBackState == PlayBackStates.Paused"
*ngIf="!slideShowRunning"
name="ionPlayOutline"
class="highlight control-button me-2 mb-2"
(click)="play()"
(click)="playClicked()"
title="Auto play" i18n-title></ng-icon>
</div>
</div>

View File

@ -16,11 +16,6 @@ import {FileSizePipe} from '../../../../pipes/FileSizePipe';
import {DatePipe} from '@angular/common';
import {LightBoxTitleTexts} from '../../../../../../common/config/public/ClientConfig';
export enum PlayBackStates {
Paused = 1,
Play = 2,
}
@Component({
selector: 'app-lightbox-controls',
@ -39,17 +34,17 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
@Output() toggleFullScreen = new EventEmitter();
@Output() nextPhoto = new EventEmitter();
@Output() previousPhoto = new EventEmitter();
@Output() togglePlayback = new EventEmitter<boolean>();
@Input() navigation = {hasPrev: true, hasNext: true};
@Input() activePhoto: GalleryPhotoComponent;
@Input() mediaElement: GalleryLightboxMediaComponent;
@Input() photoFrameDim = {width: 1, height: 1, aspect: 1};
@Input() slideShowRunning: boolean;
public readonly facesEnabled = Config.Faces.enabled;
public zoom = 1;
public playBackState: PlayBackStates = PlayBackStates.Paused;
public PlayBackStates = PlayBackStates;
public playBackDurations = [1, 2, 5, 10, 15, 20, 30, 60];
public selectedSlideshowSpeed: number = null;
public controllersDimmed = false;
@ -94,7 +89,7 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
if (this.zoom === zoom) {
return;
}
this.pause();
this.stopSlideShow();
this.drag.x = (this.drag.x / this.zoom) * zoom;
this.drag.y = (this.drag.y / this.zoom) * zoom;
this.prevDrag.x = this.drag.x;
@ -117,15 +112,19 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
}
ngOnDestroy(): void {
this.pause();
this.stopSlideShow();
if (this.visibilityTimer != null) {
clearTimeout(this.visibilityTimer);
this.visibilityTimer = null;
}
}
ngOnChanges(): void {
this.updateFaceContainerDim();
if (this.slideShowRunning) {
this.runSlideShow();
}
}
pan($event: { deltaY: number; deltaX: number; isFinal: boolean }): void {
@ -312,14 +311,19 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
this.ctx.stroke();
}
resetSlideshowTimer(): void {
if (this.playBackState == PlayBackStates.Play) {
this.play();
private resetSlideshowTimer(): void {
if (this.slideShowRunning === true) {
this.stopSlideShow();
this.runSlideShow();
}
}
public play(): void {
this.pause();
public runSlideShow(): void {
//timer already running, do not reset it.
if (this.timerSub) {
return;
}
this.stopSlideShow();
this.drawSliderProgress(0);
this.timerSub = interval(100)
.pipe(filter((t) => {
@ -328,7 +332,6 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
}))
.pipe(skip(1)) // do not skip to next photo right away
.subscribe(this.showNextMedia);
this.playBackState = PlayBackStates.Play;
}
public slideshowSpeedChanged() {
@ -340,12 +343,20 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
this.showControls();
}
public pause(): void {
public stopSlideShow(): void {
if (this.timerSub != null) {
this.timerSub.unsubscribe();
this.timerSub = null;
}
this.ctx = null;
this.playBackState = PlayBackStates.Paused;
}
playClicked() {
this.togglePlayback.emit(true);
}
pauseClicked() {
this.togglePlayback.emit(false);
}
resetZoom(): void {
@ -520,6 +531,7 @@ export class ControlsLightboxComponent implements OnDestroy, OnInit, OnChanges {
get BottomLeftTitle(): string {
return this.getText(Config.Gallery.Lightbox.Titles.bottomLeftTitle);
}
get BottomLeftSubtitle(): string {
return this.getText(Config.Gallery.Lightbox.Titles.bottomLeftSubtitle);
}

View File

@ -37,12 +37,14 @@
*ngIf="isOpen()"
#controls
[activePhoto]="activePhoto"
[slideShowRunning]="slideShowRunning"
(closed)="hide()"
[navigation]="navigation"
(nextPhoto)="nextImage()"
(previousPhoto)="prevImage()"
(toggleInfoPanel)="toggleInfoPanel()"
(toggleFullScreen)="toggleFullscreen()"
(togglePlayback)="togglePlayback($event)"
[photoFrameDim]="photoFrameDim"
[mediaElement]="mediaElement">
</app-lightbox-controls>

View File

@ -65,6 +65,7 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
photosChange: null,
route: null,
};
slideShowRunning: boolean;
constructor(
public fullScreenService: FullScreenService,
@ -105,10 +106,18 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
this.updatePhotoFrameDim();
this.subscription.route = this.route.queryParams.subscribe(
(params: Params) => {
const validPhoto = params[QueryParams.gallery.photo] &&
params[QueryParams.gallery.photo] !== '';
if (params[QueryParams.gallery.playback]) {
this.runSlideShow();
} else {
this.stopSlideShow();
}
this.delayedMediaShow = null;
if (
params[QueryParams.gallery.photo] &&
params[QueryParams.gallery.photo] !== ''
if (validPhoto
) {
this.delayedMediaShow = params[QueryParams.gallery.photo];
// photos are not yet available to show
@ -120,13 +129,28 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
this.delayedMediaShow = null;
this.hideLightbox();
}
}
);
}
private runSlideShow() {
if (!this.activePhoto && this.gridPhotoQL?.length > 0) {
this.navigateToPhoto(0);
}
this.slideShowRunning = true;
this.controls?.runSlideShow();
}
private stopSlideShow() {
this.slideShowRunning = false;
this.controls?.stopSlideShow();
}
ngOnDestroy(): void {
if (this.controls) {
this.controls.pause();
this.controls.stopSlideShow();
}
if (this.subscription.photosChange != null) {
this.subscription.photosChange.unsubscribe();
@ -186,12 +210,18 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
if (this.delayedMediaShow) {
this.onNavigateTo(this.delayedMediaShow);
}
if (this.slideShowRunning) {
this.runSlideShow();
}
}
);
if (this.delayedMediaShow) {
this.onNavigateTo(this.delayedMediaShow);
}
if (this.slideShowRunning) {
this.runSlideShow();
}
}
@HostListener('window:resize', ['$event'])
@ -213,7 +243,7 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
public prevImage(): void {
if (this.controls) {
this.controls.pause();
this.controls.stopSlideShow();
}
if (this.activePhotoId > 0) {
this.navigateToPhoto(this.activePhotoId - 1);
@ -410,14 +440,13 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
this.router
.navigate([], {
queryParams: this.queryService.getParams(
this.gridPhotoQL.get(photoIndex).gridMedia.media
{media: this.gridPhotoQL.get(photoIndex).gridMedia.media, playing: this.slideShowRunning}
),
})
.then(() => {
this.piTitleService.setMediaTitle(this.gridPhotoQL.get(photoIndex).gridMedia);
})
.catch(console.error);
}
private showPhoto(photoIndex: number, resize = true): void {
@ -434,7 +463,7 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
this.fullScreenService.exitFullScreen();
if (this.controls) {
this.controls.pause();
this.controls.stopSlideShow();
}
this.animating = true;
@ -531,5 +560,14 @@ export class GalleryLightboxComponent implements OnDestroy, OnInit {
}
return null;
}
togglePlayback(value: boolean): void {
if (this.slideShowRunning === value) {
return;
}
this.slideShowRunning = value;
// resets query. This side effect is to assign playback = true to the url
this.navigateToPhoto(this.activePhotoId);
}
}