ohayolibs
Version:
Ohayo is a set of essential modules for ohayojp.
101 lines (87 loc) • 2.62 kB
text/typescript
import { DOCUMENT } from '@angular/common';
import {
ChangeDetectionStrategy,
ChangeDetectorRef,
Component,
ElementRef,
Inject,
Input,
OnDestroy,
OnInit,
ViewEncapsulation,
} from '@angular/core';
import { OhayoConfigService, InputNumber } from '@ohayo/util';
export class ErrorCollectComponent implements OnInit, OnDestroy {
private $time: any | null = null;
private formEl: HTMLFormElement | null;
freq: number;
offsetTop: number;
_hiden = true;
count = 0;
constructor(private el: ElementRef, private cdr: ChangeDetectorRef, private doc: any, configSrv: OhayoConfigService) {
configSrv.attach(this, 'errorCollect', { freq: 500, offsetTop: 65 + 64 + 8 * 2 });
}
private get errEls(): NodeListOf<HTMLElement> {
return this.formEl!.querySelectorAll('.ant-form-item-has-error');
}
private update(): void {
const count = this.errEls.length;
if (count === this.count) return;
this.count = count;
this._hiden = count === 0;
this.cdr.markForCheck();
}
_click(): boolean {
if (this.count === 0) return false;
// nz-form-control
const els = this.errEls;
const formItemEl = this.findParent(els[0], '[nz-form-control]') || els[0];
formItemEl.scrollIntoView(true);
// fix header height
this.doc.documentElement.scrollTop -= this.offsetTop;
return true;
}
private install(): void {
this.uninstall();
this.$time = setInterval(() => this.update(), this.freq);
this.update();
}
private uninstall(): void {
clearInterval(this.$time!);
}
private findParent(el: Element, selector: string): HTMLFormElement | null {
let retEl: HTMLFormElement | null = null;
while (el) {
if (el.querySelector(selector)) {
retEl = el as HTMLFormElement;
break;
}
el = el.parentElement as HTMLFormElement;
}
return retEl;
}
ngOnInit(): void {
this.formEl = this.findParent(this.el.nativeElement, 'form');
if (this.formEl === null) throw new Error('No found form element');
this.install();
}
ngOnDestroy(): void {
this.uninstall();
}
}