Mercurial > hg > ugly-duckling
view src/app/visualisations/cross-hair-inspector.component.ts @ 413:24df6a0d61c8
No need for this opaque bodge anymore, base uses prop instead.
author | Lucas Thompson <dev@lucas.im> |
---|---|
date | Mon, 05 Jun 2017 14:27:16 +0100 |
parents | 40ea40ebc2b3 |
children | 95d1f10129a3 |
line wrap: on
line source
/** * Created by lucast on 01/06/2017. */ import { AfterViewInit, ChangeDetectionStrategy, Component, ContentChildren, Input, QueryList } from '@angular/core'; import { VerticalValueInspectorRenderer } from './waves-base.component'; import {VerticalScaleComponent} from './vertical-scale.component'; import { RenderLoopService, TaskRemover } from '../services/render-loop/render-loop.service'; @Component({ selector: 'ugly-cross-hair-inspector', template: '<ng-content></ng-content>', changeDetection: ChangeDetectionStrategy.OnPush }) export class CrossHairInspectorComponent extends VerticalScaleComponent implements AfterViewInit { @ContentChildren( VerticalValueInspectorRenderer ) inspectorRenderers: QueryList<VerticalValueInspectorRenderer>; @Input() unit: string; @Input() set isAnimated(isAnimated: boolean) { this.mIsAnimated = isAnimated; if (this.removers.length) { this.removers.forEach(remove => remove()); this.removers = []; } if (isAnimated) { this.addTasks(); } } private removers: TaskRemover[]; private mIsAnimated: boolean; constructor(private renderLoop: RenderLoopService) { super(); this.removers = []; } ngAfterViewInit(): void { super.ngAfterViewInit(); this.inspectorRenderers.forEach(renderer => { renderer.renderInspector(this.cachedRange, this.unit); }); this.addTasks(); } private addTasks(): void { if (this.inspectorRenderers && this.mIsAnimated) { this.inspectorRenderers.forEach(renderer => { this.removers.push( this.renderLoop.addPlayingTask(renderer.updatePosition) ); }); } } }