angular2
Version:
Angular 2 - a web framework for modern web apps
95 lines • 18 kB
JavaScript
import { ListWrapper } from 'angular2/src/facade/collection';
import { unimplemented } from 'angular2/src/facade/exceptions';
import { isPresent } from 'angular2/src/facade/lang';
/**
* Represents a container where one or more Views can be attached.
*
* The container can contain two kinds of Views. Host Views, created by instantiating a
* {@link Component} via {@link #createHostView}, and Embedded Views, created by instantiating an
* {@link TemplateRef Embedded Template} via {@link #createEmbeddedView}.
*
* The location of the View Container within the containing View is specified by the Anchor
* `element`. Each View Container can have only one Anchor Element and each Anchor Element can only
* have a single View Container.
*
* Root elements of Views attached to this container become siblings of the Anchor Element in
* the Rendered View.
*
* To access a `ViewContainerRef` of an Element, you can either place a {@link Directive} injected
* with `ViewContainerRef` on the Element, or you obtain it via
* {@link AppViewManager#getViewContainer}.
*
* <!-- TODO(i): we are also considering ElementRef#viewContainer api -->
*/
export class ViewContainerRef {
/**
* Anchor element that specifies the location of this container in the containing View.
* <!-- TODO: rename to anchorElement -->
*/
get element() { return unimplemented(); }
/**
* Destroys all Views in this container.
*/
clear() {
for (var i = this.length - 1; i >= 0; i--) {
this.remove(i);
}
}
/**
* Returns the number of Views currently attached to this container.
*/
get length() { return unimplemented(); }
;
}
export class ViewContainerRef_ extends ViewContainerRef {
constructor(_element) {
super();
this._element = _element;
}
get(index) { return this._element.nestedViews[index].ref; }
get length() {
var views = this._element.nestedViews;
return isPresent(views) ? views.length : 0;
}
get element() { return this._element.ref; }
// TODO(rado): profile and decide whether bounds checks should be added
// to the methods below.
createEmbeddedView(templateRef, index = -1) {
if (index == -1)
index = this.length;
var vm = this._element.parentView.viewManager;
return vm.createEmbeddedViewInContainer(this._element.ref, index, templateRef);
}
createHostView(hostViewFactoryRef, index = -1, dynamicallyCreatedProviders = null, projectableNodes = null) {
if (index == -1)
index = this.length;
var vm = this._element.parentView.viewManager;
return vm.createHostViewInContainer(this._element.ref, index, hostViewFactoryRef, dynamicallyCreatedProviders, projectableNodes);
}
// TODO(i): refactor insert+remove into move
insert(viewRef, index = -1) {
if (index == -1)
index = this.length;
var vm = this._element.parentView.viewManager;
return vm.attachViewInContainer(this._element.ref, index, viewRef);
}
indexOf(viewRef) {
return ListWrapper.indexOf(this._element.nestedViews, viewRef.internalView);
}
// TODO(i): rename to destroy
remove(index = -1) {
if (index == -1)
index = this.length - 1;
var vm = this._element.parentView.viewManager;
return vm.destroyViewInContainer(this._element.ref, index);
// view is intentionally not returned to the client.
}
// TODO(i): refactor insert+remove into move
detach(index = -1) {
if (index == -1)
index = this.length - 1;
var vm = this._element.parentView.viewManager;
return vm.detachViewInContainer(this._element.ref, index);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view_container_ref.js","sourceRoot":"","sources":["angular2/src/core/linker/view_container_ref.ts"],"names":["ViewContainerRef","ViewContainerRef.element","ViewContainerRef.clear","ViewContainerRef.length","ViewContainerRef_","ViewContainerRef_.constructor","ViewContainerRef_.get","ViewContainerRef_.length","ViewContainerRef_.element","ViewContainerRef_.createEmbeddedView","ViewContainerRef_.createHostView","ViewContainerRef_.insert","ViewContainerRef_.indexOf","ViewContainerRef_.remove","ViewContainerRef_.detach"],"mappings":"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","sourcesContent":["import {ListWrapper} from 'angular2/src/facade/collection';\nimport {unimplemented} from 'angular2/src/facade/exceptions';\nimport {ResolvedProvider, Injectable} from 'angular2/src/core/di';\nimport {isPresent, isBlank} from 'angular2/src/facade/lang';\n\nimport {AppElement} from './element';\n\nimport {ElementRef, ElementRef_} from './element_ref';\nimport {TemplateRef, TemplateRef_} from './template_ref';\nimport {\n  EmbeddedViewRef,\n  HostViewRef,\n  HostViewFactoryRef,\n  HostViewFactoryRef_,\n  ViewRef,\n  ViewRef_\n} from './view_ref';\n\n/**\n * Represents a container where one or more Views can be attached.\n *\n * The container can contain two kinds of Views. Host Views, created by instantiating a\n * {@link Component} via {@link #createHostView}, and Embedded Views, created by instantiating an\n * {@link TemplateRef Embedded Template} via {@link #createEmbeddedView}.\n *\n * The location of the View Container within the containing View is specified by the Anchor\n * `element`. Each View Container can have only one Anchor Element and each Anchor Element can only\n * have a single View Container.\n *\n * Root elements of Views attached to this container become siblings of the Anchor Element in\n * the Rendered View.\n *\n * To access a `ViewContainerRef` of an Element, you can either place a {@link Directive} injected\n * with `ViewContainerRef` on the Element, or you obtain it via\n * {@link AppViewManager#getViewContainer}.\n *\n * <!-- TODO(i): we are also considering ElementRef#viewContainer api -->\n */\nexport abstract class ViewContainerRef {\n  /**\n   * Anchor element that specifies the location of this container in the containing View.\n   * <!-- TODO: rename to anchorElement -->\n   */\n  get element(): ElementRef { return unimplemented(); }\n\n  /**\n   * Destroys all Views in this container.\n   */\n  clear(): void {\n    for (var i = this.length - 1; i >= 0; i--) {\n      this.remove(i);\n    }\n  }\n\n  /**\n   * Returns the {@link ViewRef} for the View located in this container at the specified index.\n   */\n  abstract get(index: number): ViewRef;\n\n  /**\n   * Returns the number of Views currently attached to this container.\n   */\n  get length(): number { return unimplemented(); };\n\n  /**\n   * Instantiates an Embedded View based on the {@link TemplateRef `templateRef`} and inserts it\n   * into this container at the specified `index`.\n   *\n   * If `index` is not specified, the new View will be inserted as the last View in the container.\n   *\n   * Returns the {@link ViewRef} for the newly created View.\n   */\n  abstract createEmbeddedView(templateRef: TemplateRef, index?: number): EmbeddedViewRef;\n\n  /**\n   * Instantiates a single {@link Component} and inserts its Host View into this container at the\n   * specified `index`.\n   *\n   * The component is instantiated using its {@link ProtoViewRef `protoView`} which can be\n   * obtained via {@link Compiler#compileInHost}.\n   *\n   * If `index` is not specified, the new View will be inserted as the last View in the container.\n   *\n   * You can optionally specify `dynamicallyCreatedProviders`, which configure the {@link Injector}\n   * that will be created for the Host View.\n   *\n   * Returns the {@link HostViewRef} of the Host View created for the newly instantiated Component.\n   */\n  abstract createHostView(hostViewFactoryRef: HostViewFactoryRef, index?: number,\n                          dynamicallyCreatedProviders?: ResolvedProvider[],\n                          projectableNodes?: any[][]): HostViewRef;\n\n  /**\n   * Inserts a View identified by a {@link ViewRef} into the container at the specified `index`.\n   *\n   * If `index` is not specified, the new View will be inserted as the last View in the container.\n   *\n   * Returns the inserted {@link ViewRef}.\n   */\n  abstract insert(viewRef: EmbeddedViewRef, index?: number): EmbeddedViewRef;\n\n  /**\n   * Returns the index of the View, specified via {@link ViewRef}, within the current container or\n   * `-1` if this container doesn't contain the View.\n   */\n  abstract indexOf(viewRef: ViewRef): number;\n\n  /**\n   * Destroys a View attached to this container at the specified `index`.\n   *\n   * If `index` is not specified, the last View in the container will be removed.\n   */\n  abstract remove(index?: number): void;\n\n  /**\n   * Use along with {@link #insert} to move a View within the current container.\n   *\n   * If the `index` param is omitted, the last {@link ViewRef} is detached.\n   */\n  abstract detach(index?: number): EmbeddedViewRef;\n}\n\nexport class ViewContainerRef_ extends ViewContainerRef {\n  constructor(private _element: AppElement) { super(); }\n\n  get(index: number): EmbeddedViewRef { return this._element.nestedViews[index].ref; }\n  get length(): number {\n    var views = this._element.nestedViews;\n    return isPresent(views) ? views.length : 0;\n  }\n\n  get element(): ElementRef_ { return this._element.ref; }\n\n  // TODO(rado): profile and decide whether bounds checks should be added\n  // to the methods below.\n  createEmbeddedView(templateRef: TemplateRef, index: number = -1): EmbeddedViewRef {\n    if (index == -1) index = this.length;\n    var vm = this._element.parentView.viewManager;\n    return vm.createEmbeddedViewInContainer(this._element.ref, index, templateRef);\n  }\n\n  createHostView(hostViewFactoryRef: HostViewFactoryRef, index: number = -1,\n                 dynamicallyCreatedProviders: ResolvedProvider[] = null,\n                 projectableNodes: any[][] = null): HostViewRef {\n    if (index == -1) index = this.length;\n    var vm = this._element.parentView.viewManager;\n    return vm.createHostViewInContainer(this._element.ref, index, hostViewFactoryRef,\n                                        dynamicallyCreatedProviders, projectableNodes);\n  }\n\n  // TODO(i): refactor insert+remove into move\n  insert(viewRef: ViewRef, index: number = -1): EmbeddedViewRef {\n    if (index == -1) index = this.length;\n    var vm = this._element.parentView.viewManager;\n    return vm.attachViewInContainer(this._element.ref, index, viewRef);\n  }\n\n  indexOf(viewRef: ViewRef): number {\n    return ListWrapper.indexOf(this._element.nestedViews, (<ViewRef_>viewRef).internalView);\n  }\n\n  // TODO(i): rename to destroy\n  remove(index: number = -1): void {\n    if (index == -1) index = this.length - 1;\n    var vm = this._element.parentView.viewManager;\n    return vm.destroyViewInContainer(this._element.ref, index);\n    // view is intentionally not returned to the client.\n  }\n\n  // TODO(i): refactor insert+remove into move\n  detach(index: number = -1): EmbeddedViewRef {\n    if (index == -1) index = this.length - 1;\n    var vm = this._element.parentView.viewManager;\n    return vm.detachViewInContainer(this._element.ref, index);\n  }\n}\n"]}