98 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			98 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | // #docregion
 | ||
|  | // #docregion lc-imports
 | ||
|  | import { | ||
|  |   OnChanges, SimpleChange, | ||
|  |   OnInit, | ||
|  |   // DoCheck,  // not demonstrated
 | ||
|  |   AfterContentInit, | ||
|  |   AfterContentChecked, | ||
|  |   AfterViewInit, | ||
|  |   AfterViewChecked, | ||
|  |   OnDestroy | ||
|  | } from 'angular2/core'; | ||
|  | // #docregion lc-imports
 | ||
|  | import {Component, Input, Output} from 'angular2/core'; | ||
|  | import {LoggerService}            from './logger.service'; | ||
|  | 
 | ||
|  | let nextId = 1; | ||
|  | 
 | ||
|  | @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 | ||
|  |   implements OnChanges, OnInit,AfterContentInit,AfterContentChecked, | ||
|  |              AfterViewInit, AfterViewChecked, OnDestroy { | ||
|  |   @Input()  name:string; | ||
|  | 
 | ||
|  |   private _afterContentCheckedCounter = 1; | ||
|  |   private _afterViewCheckedCounter = 1; | ||
|  |   private _id = nextId++; | ||
|  |   private _logger:LoggerService; | ||
|  |   private _onChangesCounter = 1; | ||
|  |   private _verb = 'initialized'; | ||
|  | 
 | ||
|  |   constructor(logger:LoggerService){ | ||
|  |     this._logger = logger; | ||
|  |   } | ||
|  | 
 | ||
|  |   // only called 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 (${this._onChangesCounter++}): ${changesMsgs.join('; ')}`); | ||
|  |     this._verb = 'changed'; // next time it will be a change
 | ||
|  |   } | ||
|  | 
 | ||
|  |   ngOnInit() { | ||
|  |     this._logIt(`onInit`); | ||
|  |   } | ||
|  | 
 | ||
|  |   ngAfterContentInit(){ | ||
|  |     this._logIt(`afterContentInit`); | ||
|  |   } | ||
|  | 
 | ||
|  |   // Called after every change detection check
 | ||
|  |   // of the component (directive) CONTENT
 | ||
|  |   // Beware! Called frequently!
 | ||
|  |   ngAfterContentChecked(){ | ||
|  |     let counter = this._afterContentCheckedCounter++; | ||
|  |     let msg = `afterContentChecked (${counter})`; | ||
|  |     this._logIt(msg); | ||
|  |   } | ||
|  | 
 | ||
|  |   ngAfterViewInit(){ | ||
|  |     this._logIt(`afterViewInit`); | ||
|  |   } | ||
|  | 
 | ||
|  |   // Called after every change detection check
 | ||
|  |   // of the component (directive) VIEW
 | ||
|  |   // Beware! Called frequently!
 | ||
|  | 
 | ||
|  |   ngAfterViewChecked(){ | ||
|  |     let counter = this._afterViewCheckedCounter++; | ||
|  |     let msg = `afterViewChecked (${counter})`; | ||
|  |     this._logIt(msg); | ||
|  |   } | ||
|  | 
 | ||
|  |   ngOnDestroy() { | ||
|  |     this._logIt(`onDestroy`); | ||
|  |   } | ||
|  | 
 | ||
|  |   private _logIt(msg:string){ | ||
|  |     // Don't tick or else
 | ||
|  |     // the AfterContentChecked and AfterViewChecked recurse.
 | ||
|  |     // Let parent call tick()
 | ||
|  |     this._logger.log(`#${this._id } ${msg}`, true); | ||
|  |   } | ||
|  | } |