UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

121 lines (103 loc) 3.67 kB
import {unimplemented} from 'angular2/src/facade/exceptions'; import {isPresent} from 'angular2/src/facade/lang'; import {ChangeDetectorRef} from '../change_detection/change_detector_ref'; import {AppView} from './view'; import {ChangeDetectionStrategy} from 'angular2/src/core/change_detection/constants'; export abstract class ViewRef extends ChangeDetectorRef { /** * @internal */ get changeDetectorRef(): ChangeDetectorRef { return <ChangeDetectorRef>unimplemented(); }; get destroyed(): boolean { return <boolean>unimplemented(); } abstract onDestroy(callback: Function); } /** * Represents an Angular View. * * <!-- TODO: move the next two paragraphs to the dev guide --> * A View is a fundamental building block of the application UI. It is the smallest grouping of * Elements which are created and destroyed together. * * Properties of elements in a View can change, but the structure (number and order) of elements in * a View cannot. Changing the structure of Elements can only be done by inserting, moving or * removing nested Views via a {@link ViewContainerRef}. Each View can contain many View Containers. * <!-- /TODO --> * * ### Example * * Given this template... * * ``` * Count: {{items.length}} * <ul> * <li *ngFor="let item of items">{{item}}</li> * </ul> * ``` * * ... we have two {@link ProtoViewRef}s: * * Outer {@link ProtoViewRef}: * ``` * Count: {{items.length}} * <ul> * <template ngFor let-item [ngForOf]="items"></template> * </ul> * ``` * * Inner {@link ProtoViewRef}: * ``` * <li>{{item}}</li> * ``` * * Notice that the original template is broken down into two separate {@link ProtoViewRef}s. * * The outer/inner {@link ProtoViewRef}s are then assembled into views like so: * * ``` * <!-- ViewRef: outer-0 --> * Count: 2 * <ul> * <template view-container-ref></template> * <!-- ViewRef: inner-1 --><li>first</li><!-- /ViewRef: inner-1 --> * <!-- ViewRef: inner-2 --><li>second</li><!-- /ViewRef: inner-2 --> * </ul> * <!-- /ViewRef: outer-0 --> * ``` */ export abstract class EmbeddedViewRef extends ViewRef { /** * Sets `value` of local variable called `variableName` in this View. */ abstract setLocal(variableName: string, value: any): void; /** * Checks whether this view has a local variable called `variableName`. */ abstract hasLocal(variableName: string): boolean; get rootNodes(): any[] { return <any[]>unimplemented(); }; /** * Destroys the view and all of the data structures associated with it. */ abstract destroy(); } export class ViewRef_ implements EmbeddedViewRef { constructor(private _view: AppView<any>) { this._view = _view; } get internalView(): AppView<any> { return this._view; } /** * Return `ChangeDetectorRef` */ get changeDetectorRef(): ChangeDetectorRef { return this; } get rootNodes(): any[] { return this._view.flatRootNodes; } setLocal(variableName: string, value: any): void { this._view.setLocal(variableName, value); } hasLocal(variableName: string): boolean { return this._view.hasLocal(variableName); } get destroyed(): boolean { return this._view.destroyed; } markForCheck(): void { this._view.markPathToRootAsCheckOnce(); } detach(): void { this._view.cdMode = ChangeDetectionStrategy.Detached; } detectChanges(): void { this._view.detectChanges(false); } checkNoChanges(): void { this._view.detectChanges(true); } reattach(): void { this._view.cdMode = ChangeDetectionStrategy.CheckAlways; this.markForCheck(); } onDestroy(callback: Function) { this._view.disposables.push(callback); } destroy() { this._view.destroy(); } }