89 lines
2.1 KiB
TypeScript
89 lines
2.1 KiB
TypeScript
// #docregion
|
|
import {
|
|
Component, Input,
|
|
OnChanges, SimpleChange,
|
|
} from '@angular/core';
|
|
|
|
import { SpyDirective } from './spy.directive';
|
|
import { LoggerService } from './logger.service';
|
|
|
|
@Component({
|
|
selector: 'my-counter',
|
|
template: `
|
|
<div class="counter">
|
|
Counter = {{counter}}
|
|
|
|
<h5>-- Counter Change Log --</h5>
|
|
<div *ngFor="let chg of changeLog" mySpy>{{chg}}</div>
|
|
</div>
|
|
`,
|
|
styles: ['.counter {background: LightYellow; padding: 8px; margin-top: 8px}'],
|
|
directives: [SpyDirective]
|
|
})
|
|
export class MyCounterComponent implements OnChanges {
|
|
@Input() counter: number;
|
|
changeLog: string[] = [];
|
|
|
|
ngOnChanges(changes: {[propertyName: string]: SimpleChange}) {
|
|
|
|
// Empty the changeLog whenever counter goes to zero
|
|
// hint: this is a way to respond programmatically to external value changes.
|
|
if (this.counter === 0) {
|
|
this.changeLog.length = 0;
|
|
}
|
|
|
|
// A change to `counter` is the only change we care about
|
|
let chng = changes['counter'];
|
|
let cur = chng.currentValue;
|
|
let prev = JSON.stringify(chng.previousValue); // first time is {}; after is integer
|
|
this.changeLog.push(`counter: currentValue = ${cur}, previousValue = ${prev}`);
|
|
}
|
|
|
|
}
|
|
|
|
/***************************************/
|
|
|
|
@Component({
|
|
selector: 'counter-parent',
|
|
template: `
|
|
<div class="parent">
|
|
<h2>Counter Spy</h2>
|
|
|
|
<button (click)="updateCounter()">Update counter</button>
|
|
<button (click)="reset()">Reset Counter</button>
|
|
|
|
<my-counter [counter]="value"></my-counter>
|
|
|
|
<h4>-- Spy Lifecycle Hook Log --</h4>
|
|
<div *ngFor="let msg of spyLog">{{msg}}</div>
|
|
</div>
|
|
`,
|
|
styles: ['.parent {background: gold;}'],
|
|
directives: [MyCounterComponent],
|
|
providers: [LoggerService]
|
|
})
|
|
export class CounterParentComponent {
|
|
value: number;
|
|
spyLog: string[] = [];
|
|
|
|
private logger: LoggerService;
|
|
|
|
constructor(logger: LoggerService) {
|
|
this.logger = logger;
|
|
this.spyLog = logger.logs;
|
|
this.reset();
|
|
}
|
|
|
|
updateCounter() {
|
|
this.value += 1;
|
|
this.logger.tick();
|
|
}
|
|
|
|
reset() {
|
|
this.logger.log('-- reset --');
|
|
this.value = 0;
|
|
this.logger.tick();
|
|
}
|
|
}
|
|
|