angular2
Version:
Angular 2 - a web framework for modern web apps
130 lines • 20.4 kB
JavaScript
;var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var collection_1 = require('angular2/src/facade/collection');
var exceptions_1 = require('angular2/src/facade/exceptions');
var lang_1 = require('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 -->
*/
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
});
/**
* Destroys all Views in this container.
*/
ViewContainerRef.prototype.clear = function () {
for (var i = this.length - 1; i >= 0; i--) {
this.remove(i);
}
};
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 (_super) {
__extends(ViewContainerRef_, _super);
function ViewContainerRef_(_element) {
_super.call(this);
this._element = _element;
}
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.ref; },
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; }
if (index == -1)
index = this.length;
var vm = this._element.parentView.viewManager;
return vm.createEmbeddedViewInContainer(this._element.ref, index, templateRef);
};
ViewContainerRef_.prototype.createHostView = function (hostViewFactoryRef, index, dynamicallyCreatedProviders, projectableNodes) {
if (index === void 0) { index = -1; }
if (dynamicallyCreatedProviders === void 0) { dynamicallyCreatedProviders = null; }
if (projectableNodes === void 0) { 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
ViewContainerRef_.prototype.insert = function (viewRef, index) {
if (index === void 0) { index = -1; }
if (index == -1)
index = this.length;
var vm = this._element.parentView.viewManager;
return vm.attachViewInContainer(this._element.ref, index, 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; }
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
ViewContainerRef_.prototype.detach = function (index) {
if (index === void 0) { index = -1; }
if (index == -1)
index = this.length - 1;
var vm = this._element.parentView.viewManager;
return vm.detachViewInContainer(this._element.ref, index);
};
return ViewContainerRef_;
})(ViewContainerRef);
exports.ViewContainerRef_ = ViewContainerRef_;
//# 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.constructor","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"]}