1
0
mirror of https://github.com/bpatrik/pigallery2.git synced 2025-01-24 05:17:16 +02:00

Adding scroll to the top button #587, fixes #427

This commit is contained in:
Patrik J. Braun 2023-08-08 23:49:38 +02:00
parent d1ed607647
commit b7529b13e1
5 changed files with 53 additions and 9 deletions

View File

@ -29,6 +29,10 @@ export enum ThemeModes {
light = 1, dark, auto light = 1, dark, auto
} }
export enum ScrollUpModes {
never = 1, mobileOnly, always
}
export type TAGS = { export type TAGS = {
client?: true, client?: true,
priority?: ConfigPriority, priority?: ConfigPriority,
@ -739,6 +743,17 @@ export class NavBarConfig {
description: $localize`Ratio of the page height, you need to scroll to hide the navigation bar.`, description: $localize`Ratio of the page height, you need to scroll to hide the navigation bar.`,
}) })
NavbarHideDelay: number = 0.15; NavbarHideDelay: number = 0.15;
@ConfigProperty({
tags: {
name: $localize`Show scroll up button`,
priority: ConfigPriority.underTheHood
},
type: ScrollUpModes,
description: $localize`Set when the floating scroll-up button should be visible.`,
})
showScrollUpButton: ScrollUpModes = ScrollUpModes.mobileOnly;
} }
@SubConfigClass<TAGS>({tags: {client: true}, softReadonly: true}) @SubConfigClass<TAGS>({tags: {client: true}, softReadonly: true})

View File

@ -60,3 +60,17 @@ a.dropdown-item span, button.dropdown-item span, div.dropdown-item span {
a.dropdown-item span.badge, button.dropdown-item span.badge { a.dropdown-item span.badge, button.dropdown-item span.badge {
margin-left: -0.8rem; margin-left: -0.8rem;
} }
.btn-scroll-up {
position: fixed;
width: 3em;
height: 3em;
right: -3em;
bottom: 3em;
transition: 0.3s right;
z-index: 999;
}
.show-btn-scroll-up{
right: 1em;
}

View File

@ -204,3 +204,10 @@
<ng-content select="[navbar-appendix]"></ng-content> <ng-content select="[navbar-appendix]"></ng-content>
</div> </div>
<ng-content select="[body]"></ng-content> <ng-content select="[body]"></ng-content>
<button
*ngIf="enableScrollUpButton"
(click)="scrollUp()"
[class.show-btn-scroll-up]="!shouldHideNavbar && !navbarKeepTop"
class="btn btn-tertiary rounded-pill btn-scroll-up">
<span class="oi oi-chevron-top"></span>
</button>

View File

@ -6,13 +6,14 @@ import {Config} from '../../../../common/config/public/Config';
import {BehaviorSubject} from 'rxjs'; import {BehaviorSubject} from 'rxjs';
import {NotificationService} from '../../model/notification.service'; import {NotificationService} from '../../model/notification.service';
import {QueryService} from '../../model/query.service'; import {QueryService} from '../../model/query.service';
import {NavigationLinkTypes, ThemeModes} from '../../../../common/config/public/ClientConfig'; import {NavigationLinkTypes, ScrollUpModes, ThemeModes} from '../../../../common/config/public/ClientConfig';
import {SearchQueryDTO} from '../../../../common/entities/SearchQueryDTO'; import {SearchQueryDTO} from '../../../../common/entities/SearchQueryDTO';
import {Utils} from '../../../../common/Utils'; import {Utils} from '../../../../common/Utils';
import {PageHelper} from '../../model/page.helper'; import {PageHelper} from '../../model/page.helper';
import {BsDropdownDirective} from 'ngx-bootstrap/dropdown'; import {BsDropdownDirective} from 'ngx-bootstrap/dropdown';
import {LanguageComponent} from '../language/language.component'; import {LanguageComponent} from '../language/language.component';
import {ThemeService} from '../../model/theme.service'; import {ThemeService} from '../../model/theme.service';
import {DeviceDetectorService} from 'ngx-device-detector';
@Component({ @Component({
selector: 'app-frame', selector: 'app-frame',
@ -49,14 +50,17 @@ export class FrameComponent {
@ViewChild('languageSelector', {static: true}) languageSelector: LanguageComponent; @ViewChild('languageSelector', {static: true}) languageSelector: LanguageComponent;
ThemeModes = ThemeModes; ThemeModes = ThemeModes;
public readonly enableScrollUpButton: boolean;
constructor( constructor(
private authService: AuthenticationService, private authService: AuthenticationService,
public notificationService: NotificationService, public notificationService: NotificationService,
public queryService: QueryService, public queryService: QueryService,
private router: Router, private router: Router,
public themeService: ThemeService public themeService: ThemeService,
private deviceService: DeviceDetectorService
) { ) {
this.enableScrollUpButton = Config.Gallery.NavBar.showScrollUpButton === ScrollUpModes.always || (Config.Gallery.NavBar.showScrollUpButton === ScrollUpModes.mobileOnly && this.deviceService.isDesktop());
this.user = this.authService.user; this.user = this.authService.user;
} }
@ -106,7 +110,7 @@ export class FrameComponent {
const down = this.lastScroll.any < scrollPosition; const down = this.lastScroll.any < scrollPosition;
const upDelay = up && this.lastScroll.down > scrollPosition + window.innerHeight * Config.Gallery.NavBar.NavbarShowDelay; const upDelay = up && this.lastScroll.down > scrollPosition + window.innerHeight * Config.Gallery.NavBar.NavbarShowDelay;
const downDelay = down && this.lastScroll.up < scrollPosition - window.innerHeight * Config.Gallery.NavBar.NavbarHideDelay; const downDelay = down && this.lastScroll.up < scrollPosition - window.innerHeight * Config.Gallery.NavBar.NavbarHideDelay;
//we are the top where the navbar by default lives // We are the top where the navbar by default lives
if (this.navContainer.nativeElement.offsetHeight > scrollPosition) { if (this.navContainer.nativeElement.offsetHeight > scrollPosition) {
// do not force move navbar up when we are scrolling up from bottom // do not force move navbar up when we are scrolling up from bottom
if (this.shouldHideNavbar != false || scrollPosition <= 0) { if (this.shouldHideNavbar != false || scrollPosition <= 0) {
@ -141,5 +145,9 @@ export class FrameComponent {
this.lastScroll.any = scrollPosition; this.lastScroll.any = scrollPosition;
} }
scrollUp(): void {
PageHelper.ScrollY = 0;
}
} }

View File

@ -35,8 +35,8 @@ This is mostly btn-light
*/ */
.btn-tertiary, [data-bs-theme=light] .btn-tertiary { .btn-tertiary, [data-bs-theme=light] .btn-tertiary {
--bs-btn-color: #000; --bs-btn-color: #000;
--bs-btn-bg: #f8f9fa; --bs-btn-bg: var(--bs-body-bg);
--bs-btn-border-color: #f8f9fa; --bs-btn-border-color: var(--bs-border-color);
--bs-btn-hover-color: #000; --bs-btn-hover-color: #000;
--bs-btn-hover-bg: #d3d4d5; --bs-btn-hover-bg: #d3d4d5;
--bs-btn-hover-border-color: #c6c7c8; --bs-btn-hover-border-color: #c6c7c8;
@ -55,7 +55,7 @@ This is mostly btn-dark + border fix
*/ */
[data-bs-theme=dark] .btn-tertiary { [data-bs-theme=dark] .btn-tertiary {
--bs-btn-color: #fff; --bs-btn-color: #fff;
--bs-btn-bg: rgba(var(--bs-body-color-rgb), 0.03); --bs-btn-bg: var(--bs-body-bg);
--bs-btn-border-color: var(--bs-border-color); --bs-btn-border-color: var(--bs-border-color);
--bs-btn-hover-color: #fff; --bs-btn-hover-color: #fff;
--bs-btn-hover-bg: #424649; --bs-btn-hover-bg: #424649;