UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

152 lines 21.5 kB
'use strict';"use strict"; var collection_1 = require('angular2/src/facade/collection'); var exceptions_1 = require('angular2/src/facade/exceptions'); var lang_1 = require('angular2/src/facade/lang'); var profile_1 = require('../profile/profile'); /** * 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 #createComponent}, 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 a {@link ViewChild} query. */ var ViewContainerRef = (function () { function ViewContainerRef() { } Object.defineProperty(ViewContainerRef.prototype, "element", { /** * Anchor element that specifies the location of this container in the containing View. * <!-- TODO: rename to anchorElement --> */ get: function () { return exceptions_1.unimplemented(); }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef.prototype, "injector", { get: function () { return exceptions_1.unimplemented(); }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef.prototype, "parentInjector", { get: function () { return exceptions_1.unimplemented(); }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef.prototype, "length", { /** * Returns the number of Views currently attached to this container. */ get: function () { return exceptions_1.unimplemented(); }, enumerable: true, configurable: true }); ; return ViewContainerRef; }()); exports.ViewContainerRef = ViewContainerRef; var ViewContainerRef_ = (function () { function ViewContainerRef_(_element) { this._element = _element; /** @internal */ this._createComponentInContainerScope = profile_1.wtfCreateScope('ViewContainerRef#createComponent()'); /** @internal */ this._insertScope = profile_1.wtfCreateScope('ViewContainerRef#insert()'); /** @internal */ this._removeScope = profile_1.wtfCreateScope('ViewContainerRef#remove()'); /** @internal */ this._detachScope = profile_1.wtfCreateScope('ViewContainerRef#detach()'); } ViewContainerRef_.prototype.get = function (index) { return this._element.nestedViews[index].ref; }; Object.defineProperty(ViewContainerRef_.prototype, "length", { get: function () { var views = this._element.nestedViews; return lang_1.isPresent(views) ? views.length : 0; }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef_.prototype, "element", { get: function () { return this._element.elementRef; }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef_.prototype, "injector", { get: function () { return this._element.injector; }, enumerable: true, configurable: true }); Object.defineProperty(ViewContainerRef_.prototype, "parentInjector", { get: function () { return this._element.parentInjector; }, enumerable: true, configurable: true }); // TODO(rado): profile and decide whether bounds checks should be added // to the methods below. ViewContainerRef_.prototype.createEmbeddedView = function (templateRef, index) { if (index === void 0) { index = -1; } var viewRef = templateRef.createEmbeddedView(); this.insert(viewRef, index); return viewRef; }; ViewContainerRef_.prototype.createComponent = function (componentFactory, index, injector, projectableNodes) { if (index === void 0) { index = -1; } if (injector === void 0) { injector = null; } if (projectableNodes === void 0) { projectableNodes = null; } var s = this._createComponentInContainerScope(); var contextInjector = lang_1.isPresent(injector) ? injector : this._element.parentInjector; var componentRef = componentFactory.create(contextInjector, projectableNodes); this.insert(componentRef.hostView, index); return profile_1.wtfLeave(s, componentRef); }; // TODO(i): refactor insert+remove into move ViewContainerRef_.prototype.insert = function (viewRef, index) { if (index === void 0) { index = -1; } var s = this._insertScope(); if (index == -1) index = this.length; var viewRef_ = viewRef; this._element.attachView(viewRef_.internalView, index); return profile_1.wtfLeave(s, viewRef_); }; ViewContainerRef_.prototype.indexOf = function (viewRef) { return collection_1.ListWrapper.indexOf(this._element.nestedViews, viewRef.internalView); }; // TODO(i): rename to destroy ViewContainerRef_.prototype.remove = function (index) { if (index === void 0) { index = -1; } var s = this._removeScope(); if (index == -1) index = this.length - 1; var view = this._element.detachView(index); view.destroy(); // view is intentionally not returned to the client. profile_1.wtfLeave(s); }; // TODO(i): refactor insert+remove into move ViewContainerRef_.prototype.detach = function (index) { if (index === void 0) { index = -1; } var s = this._detachScope(); if (index == -1) index = this.length - 1; var view = this._element.detachView(index); return profile_1.wtfLeave(s, view.ref); }; ViewContainerRef_.prototype.clear = function () { for (var i = this.length - 1; i >= 0; i--) { this.remove(i); } }; return ViewContainerRef_; }()); exports.ViewContainerRef_ = ViewContainerRef_; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view_container_ref.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/core/linker/view_container_ref.ts"],"names":[],"mappings":"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","sourcesContent":["import {ListWrapper} from 'angular2/src/facade/collection';\nimport {unimplemented} from 'angular2/src/facade/exceptions';\nimport {Injector} from 'angular2/src/core/di/injector';\nimport {isPresent, isBlank} from 'angular2/src/facade/lang';\nimport {wtfCreateScope, wtfLeave, WtfScopeFn} from '../profile/profile';\n\nimport {AppElement} from './element';\n\nimport {ElementRef} from './element_ref';\nimport {TemplateRef, TemplateRef_} from './template_ref';\nimport {EmbeddedViewRef, ViewRef, ViewRef_} from './view_ref';\nimport {ComponentFactory, ComponentRef} from './component_factory';\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 #createComponent}, 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 a {@link ViewChild} query.\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 <ElementRef>unimplemented(); }\n\n  get injector(): Injector { return <Injector>unimplemented(); }\n\n  get parentInjector(): Injector { return <Injector>unimplemented(); }\n\n  /**\n   * Destroys all Views in this container.\n   */\n  abstract clear(): void;\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 <number>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 ComponentFactory} which can be\n   * obtained via {@link ComponentResolver#resolveComponent}.\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 the {@link Injector} that will be used as parent for the Component.\n   *\n   * Returns the {@link ComponentRef} of the Host View created for the newly instantiated Component.\n   */\n  abstract createComponent(componentFactory: ComponentFactory, index?: number, injector?: Injector,\n                           projectableNodes?: any[][]): ComponentRef;\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: ViewRef, index?: number): ViewRef;\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): ViewRef;\n}\n\nexport class ViewContainerRef_ implements ViewContainerRef {\n  constructor(private _element: AppElement) {}\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.elementRef; }\n\n  get injector(): Injector { return this._element.injector; }\n\n  get parentInjector(): Injector { return this._element.parentInjector; }\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    var viewRef: EmbeddedViewRef = templateRef.createEmbeddedView();\n    this.insert(viewRef, index);\n    return viewRef;\n  }\n\n  /** @internal */\n  _createComponentInContainerScope: WtfScopeFn =\n      wtfCreateScope('ViewContainerRef#createComponent()');\n\n  createComponent(componentFactory: ComponentFactory, index: number = -1, injector: Injector = null,\n                  projectableNodes: any[][] = null): ComponentRef {\n    var s = this._createComponentInContainerScope();\n    var contextInjector = isPresent(injector) ? injector : this._element.parentInjector;\n    var componentRef = componentFactory.create(contextInjector, projectableNodes);\n    this.insert(componentRef.hostView, index);\n    return wtfLeave(s, componentRef);\n  }\n\n  /** @internal */\n  _insertScope = wtfCreateScope('ViewContainerRef#insert()');\n\n  // TODO(i): refactor insert+remove into move\n  insert(viewRef: ViewRef, index: number = -1): ViewRef {\n    var s = this._insertScope();\n    if (index == -1) index = this.length;\n    var viewRef_ = <ViewRef_>viewRef;\n    this._element.attachView(viewRef_.internalView, index);\n    return wtfLeave(s, viewRef_);\n  }\n\n  indexOf(viewRef: ViewRef): number {\n    return ListWrapper.indexOf(this._element.nestedViews, (<ViewRef_>viewRef).internalView);\n  }\n\n  /** @internal */\n  _removeScope = wtfCreateScope('ViewContainerRef#remove()');\n\n  // TODO(i): rename to destroy\n  remove(index: number = -1): void {\n    var s = this._removeScope();\n    if (index == -1) index = this.length - 1;\n    var view = this._element.detachView(index);\n    view.destroy();\n    // view is intentionally not returned to the client.\n    wtfLeave(s);\n  }\n\n  /** @internal */\n  _detachScope = wtfCreateScope('ViewContainerRef#detach()');\n\n  // TODO(i): refactor insert+remove into move\n  detach(index: number = -1): ViewRef {\n    var s = this._detachScope();\n    if (index == -1) index = this.length - 1;\n    var view = this._element.detachView(index);\n    return wtfLeave(s, view.ref);\n  }\n\n  clear() {\n    for (var i = this.length - 1; i >= 0; i--) {\n      this.remove(i);\n    }\n  }\n}\n"]}