85 lines
2.4 KiB
TypeScript
85 lines
2.4 KiB
TypeScript
import {
|
|
OnChanges, SimpleChange,
|
|
OnInit,
|
|
DoCheck,
|
|
AfterContentInit,
|
|
AfterContentChecked,
|
|
AfterViewInit,
|
|
AfterViewChecked,
|
|
OnDestroy
|
|
} from '@angular/core';
|
|
import {Component, Input} from '@angular/core';
|
|
import {LoggerService} from './logger.service';
|
|
|
|
let nextId = 1;
|
|
|
|
// #docregion ngOnInit
|
|
export class PeekABoo implements OnInit {
|
|
constructor(private _logger: LoggerService) { }
|
|
|
|
// implement OnInit's `ngOnInit` method
|
|
ngOnInit() { this._logIt(`OnInit`); }
|
|
|
|
protected _logIt(msg: string) {
|
|
this._logger.log(`#${nextId++} ${msg}`);
|
|
}
|
|
}
|
|
// #enddocregion ngOnInit
|
|
|
|
@Component({
|
|
selector: 'peek-a-boo',
|
|
template: '<p>Now you see my hero, {{name}}</p>',
|
|
styles: ['p {background: LightYellow; padding: 8px}']
|
|
})
|
|
// Don't HAVE to mention the Lifecycle Hook interfaces
|
|
// unless we want typing and tool support.
|
|
export class PeekABooComponent extends PeekABoo implements
|
|
OnChanges, OnInit, DoCheck,
|
|
AfterContentInit, AfterContentChecked,
|
|
AfterViewInit, AfterViewChecked,
|
|
OnDestroy {
|
|
@Input() name: string;
|
|
|
|
private _verb = 'initialized';
|
|
|
|
constructor(logger: LoggerService) {
|
|
super(logger);
|
|
|
|
let is = this.name ? 'is' : 'is not';
|
|
this._logIt(`name ${is} known at construction`);
|
|
}
|
|
|
|
// only called for/if there is an @input variable set by parent.
|
|
ngOnChanges(changes: {[propertyName: string]: SimpleChange}) {
|
|
let changesMsgs: string[] = [];
|
|
for (let propName in changes) {
|
|
if (propName === 'name') {
|
|
let name = changes['name'].currentValue;
|
|
changesMsgs.push(`name ${this._verb} to "${name}"`);
|
|
} else {
|
|
changesMsgs.push(propName + ' ' + this._verb);
|
|
}
|
|
}
|
|
this._logIt(`OnChanges: ${changesMsgs.join('; ')}`);
|
|
this._verb = 'changed'; // next time it will be a change
|
|
}
|
|
|
|
// Beware! Called frequently!
|
|
// Called in every change detection cycle anywhere on the page
|
|
ngDoCheck() { this._logIt(`DoCheck`); }
|
|
|
|
ngAfterContentInit() { this._logIt(`AfterContentInit`); }
|
|
|
|
// Beware! Called frequently!
|
|
// Called in every change detection cycle anywhere on the page
|
|
ngAfterContentChecked() { this._logIt(`AfterContentChecked`); }
|
|
|
|
ngAfterViewInit() { this._logIt(`AfterViewInit`); }
|
|
|
|
// Beware! Called frequently!
|
|
// Called in every change detection cycle anywhere on the page
|
|
ngAfterViewChecked() { this._logIt(`AfterViewChecked`); }
|
|
|
|
ngOnDestroy() { this._logIt(`OnDestroy`); }
|
|
}
|