From c49a79c79835449f752a0a7ffea13eb7b41cd3e5 Mon Sep 17 00:00:00 2001 From: "k.triantafyllou" Date: Fri, 11 Mar 2022 01:07:44 +0200 Subject: [PATCH] Page Content make header sticky and send event in component to handle this event --- .../page-content/page-content.component.ts | 78 ++++++++++++++++--- 1 file changed, 66 insertions(+), 12 deletions(-) diff --git a/dashboard/sharedComponents/page-content/page-content.component.ts b/dashboard/sharedComponents/page-content/page-content.component.ts index 47f5a943..7229fc1f 100644 --- a/dashboard/sharedComponents/page-content/page-content.component.ts +++ b/dashboard/sharedComponents/page-content/page-content.component.ts @@ -1,24 +1,78 @@ -import {Component, OnInit} from "@angular/core"; +import {Component, ElementRef, EventEmitter, HostListener, OnDestroy, OnInit, Output, ViewChild} from "@angular/core"; +import {Subscription} from "rxjs"; + +declare var UIkit; @Component({ selector: '[page-content]', template: ` -
-
-
- +
+
+
+ +
+
+
+
-
- -
-
` }) -export class PageContentComponent implements OnInit{ - public offset: string; +export class PageContentComponent implements OnInit, OnDestroy { + private current; + private shouldSticky: boolean = false; + public offset: number; + public sticky: boolean = false; + @Output() + public stickyEmitter: EventEmitter = new EventEmitter(); + @ViewChild("header") public header: ElementRef; + private subscriptions: any[] = []; + + constructor() { + } + + @HostListener('window:scroll', ['$event.target']) // for window scroll events + scroll(e) { + let scroll = window.pageYOffset; + let previous = this.offset; + if (scroll > this.current) { + this.offset = 0; + } else { + this.offset = Number.parseInt(getComputedStyle(document.documentElement).getPropertyValue('--structure-header-height') + 1); + } + if (this.offset !== previous) { + UIkit.sticky(this.header.nativeElement, { + offset: this.offset + }); + } + this.current = scroll; + if(this.current > this.header.nativeElement.offsetTop + this.header.nativeElement.offsetHeight && this.shouldSticky) { + this.sticky = true; + this.stickyEmitter.emit(this.sticky); + } + } ngOnInit() { - this.offset = getComputedStyle(document.documentElement).getPropertyValue('--structure-header-height'); + if (typeof window !== "undefined") { + this.current = window.pageYOffset; + } + this.subscriptions.push(UIkit.util.on(document, 'active', '#page_content_header', (): void => { + this.shouldSticky = true; + })); + this.subscriptions.push(UIkit.util.on(document, 'inactive', '#page_content_header', (): void => { + this.sticky = false; + this.shouldSticky = false; + this.stickyEmitter.emit(this.sticky); + })); + } + + ngOnDestroy() { + this.subscriptions.forEach(subscription => { + if (subscription instanceof Subscription) { + subscription.unsubscribe(); + } else if (subscription instanceof Function) { + subscription(); + } + }); } }