app/@overflow/commons/ui/directive/auto-height.directive.ts
crusader c1f532e2a9 ing
2018-09-29 00:34:38 +09:00

67 lines
1.8 KiB
TypeScript

// https://github.com/arthurvaverko/ngx-fill-height/tree/master/src/app/fill-height
import { Directive, AfterViewInit, Input, HostListener, ElementRef, ChangeDetectorRef, OnInit, OnDestroy } from '@angular/core';
@Directive({
selector: '[of-auto-height]'
})
export class AutoHeightDirective implements OnInit, OnDestroy, AfterViewInit {
@Input() key: string;
@Input() footerElement = null;
@HostListener('window:resize', ['$event'])
onResize(event) {
this.calculateAndSetElementHeight();
}
constructor(
private elementRef: ElementRef,
private changeDetector: ChangeDetectorRef,
) {
}
ngOnInit(): void {
}
ngAfterViewInit(): void {
this.calculateAndSetElementHeight();
}
ngOnDestroy(): void {
}
onVisible(event) {
console.log('visibilitychange');
}
/**
* forceCalculate
*/
public forceCalculate() {
this.calculateAndSetElementHeight();
}
private calculateAndSetElementHeight() {
this.changeDetector.detectChanges();
this.elementRef.nativeElement.style.overflow = 'auto';
const windowHeight = window.innerHeight;
const elementOffsetTop = this.getElementOffsetTop();
const elementMarginBottom = this.elementRef.nativeElement.style.marginBottom;
const footerElementMargin = this.getfooterElementMargin();
this.elementRef.nativeElement.style.height = windowHeight - footerElementMargin - elementOffsetTop + 'px';
console.log([windowHeight, elementOffsetTop, elementMarginBottom, footerElementMargin, this.elementRef.nativeElement.style.height]);
}
private getElementOffsetTop() {
return this.elementRef.nativeElement.getBoundingClientRect().top;
}
private getfooterElementMargin() {
if (!this.footerElement) { return 0; }
const footerStyle = window.getComputedStyle(this.footerElement);
return parseInt(footerStyle.height, 10);
}
}