mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-24 05:17:16 +02:00
parent
d1ed607647
commit
b7529b13e1
@ -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})
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
@ -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>
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user