angular2
Version:
Angular 2 - a web framework for modern web apps
144 lines • 24.9 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 __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var di_1 = require('angular2/src/core/di');
var compiler_1 = require('./compiler');
var lang_1 = require('angular2/src/facade/lang');
var view_manager_1 = require('angular2/src/core/linker/view_manager');
/**
* Represents an instance of a Component created via {@link DynamicComponentLoader}.
*
* `ComponentRef` provides access to the Component Instance as well other objects related to this
* Component Instance and allows you to destroy the Component Instance via the {@link #dispose}
* method.
*/
var ComponentRef = (function () {
function ComponentRef() {
}
Object.defineProperty(ComponentRef.prototype, "hostView", {
/**
* The {@link ViewRef} of the Host View of this Component instance.
*/
get: function () {
return this.location.internalElement.parentView.ref;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ComponentRef.prototype, "hostComponent", {
/**
* @internal
*
* The instance of the component.
*
* TODO(i): this api should be removed
*/
get: function () { return this.instance; },
enumerable: true,
configurable: true
});
return ComponentRef;
})();
exports.ComponentRef = ComponentRef;
var ComponentRef_ = (function (_super) {
__extends(ComponentRef_, _super);
/**
* TODO(i): refactor into public/private fields
*/
function ComponentRef_(location, instance, componentType, injector, _dispose) {
_super.call(this);
this._dispose = _dispose;
this.location = location;
this.instance = instance;
this.componentType = componentType;
this.injector = injector;
}
Object.defineProperty(ComponentRef_.prototype, "hostComponentType", {
/**
* @internal
*
* Returns the type of this Component instance.
*
* TODO(i): this api should be removed
*/
get: function () { return this.componentType; },
enumerable: true,
configurable: true
});
ComponentRef_.prototype.dispose = function () { this._dispose(); };
return ComponentRef_;
})(ComponentRef);
exports.ComponentRef_ = ComponentRef_;
/**
* Service for instantiating a Component and attaching it to a View at a specified location.
*/
var DynamicComponentLoader = (function () {
function DynamicComponentLoader() {
}
return DynamicComponentLoader;
})();
exports.DynamicComponentLoader = DynamicComponentLoader;
var DynamicComponentLoader_ = (function (_super) {
__extends(DynamicComponentLoader_, _super);
function DynamicComponentLoader_(_compiler, _viewManager) {
_super.call(this);
this._compiler = _compiler;
this._viewManager = _viewManager;
}
DynamicComponentLoader_.prototype.loadAsRoot = function (type, overrideSelector, injector, onDispose, projectableNodes) {
var _this = this;
return this._compiler.compileInHost(type).then(function (hostProtoViewRef) {
var hostViewRef = _this._viewManager.createRootHostView(hostProtoViewRef, overrideSelector, injector, projectableNodes);
var newLocation = _this._viewManager.getHostElement(hostViewRef);
var component = _this._viewManager.getComponent(newLocation);
var dispose = function () {
if (lang_1.isPresent(onDispose)) {
onDispose();
}
_this._viewManager.destroyRootHostView(hostViewRef);
};
return new ComponentRef_(newLocation, component, type, injector, dispose);
});
};
DynamicComponentLoader_.prototype.loadIntoLocation = function (type, hostLocation, anchorName, providers, projectableNodes) {
if (providers === void 0) { providers = null; }
if (projectableNodes === void 0) { projectableNodes = null; }
return this.loadNextToLocation(type, this._viewManager.getNamedElementInComponentView(hostLocation, anchorName), providers, projectableNodes);
};
DynamicComponentLoader_.prototype.loadNextToLocation = function (type, location, providers, projectableNodes) {
var _this = this;
if (providers === void 0) { providers = null; }
if (projectableNodes === void 0) { projectableNodes = null; }
return this._compiler.compileInHost(type).then(function (hostProtoViewRef) {
var viewContainer = _this._viewManager.getViewContainer(location);
var hostViewRef = viewContainer.createHostView(hostProtoViewRef, viewContainer.length, providers, projectableNodes);
var newLocation = _this._viewManager.getHostElement(hostViewRef);
var component = _this._viewManager.getComponent(newLocation);
var dispose = function () {
var index = viewContainer.indexOf(hostViewRef);
if (!hostViewRef.destroyed && index !== -1) {
viewContainer.remove(index);
}
};
return new ComponentRef_(newLocation, component, type, null, dispose);
});
};
DynamicComponentLoader_ = __decorate([
di_1.Injectable(),
__metadata('design:paramtypes', [compiler_1.Compiler, view_manager_1.AppViewManager])
], DynamicComponentLoader_);
return DynamicComponentLoader_;
})(DynamicComponentLoader);
exports.DynamicComponentLoader_ = DynamicComponentLoader_;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic_component_loader.js","sourceRoot":"","sources":["angular2/src/core/linker/dynamic_component_loader.ts"],"names":["ComponentRef","ComponentRef.constructor","ComponentRef.hostView","ComponentRef.hostComponent","ComponentRef_","ComponentRef_.constructor","ComponentRef_.hostComponentType","ComponentRef_.dispose","DynamicComponentLoader","DynamicComponentLoader.constructor","DynamicComponentLoader_","DynamicComponentLoader_.constructor","DynamicComponentLoader_.loadAsRoot","DynamicComponentLoader_.loadIntoLocation","DynamicComponentLoader_.loadNextToLocation"],"mappings":"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","sourcesContent":["import {Key, Injector, ResolvedProvider, Provider, provide, Injectable} from 'angular2/src/core/di';\nimport {Compiler} from './compiler';\nimport {isType, Type, stringify, isPresent} from 'angular2/src/facade/lang';\nimport {AppViewManager} from 'angular2/src/core/linker/view_manager';\nimport {ElementRef, ElementRef_} from './element_ref';\nimport {HostViewRef} from './view_ref';\n\n/**\n * Represents an instance of a Component created via {@link DynamicComponentLoader}.\n *\n * `ComponentRef` provides access to the Component Instance as well other objects related to this\n * Component Instance and allows you to destroy the Component Instance via the {@link #dispose}\n * method.\n */\nexport abstract class ComponentRef {\n  /**\n   * The injector provided {@link DynamicComponentLoader#loadAsRoot}.\n   *\n   * TODO(i): this api is useless and should be replaced by an injector retrieved from\n   *     the HostElementRef, which is currently not possible.\n   */\n  injector: Injector;\n\n  /**\n   * Location of the Host Element of this Component Instance.\n   */\n  location: ElementRef;\n\n  /**\n   * The instance of the Component.\n   */\n  instance: any;\n\n  /**\n   * The user defined component type, represented via the constructor function.\n   *\n   * <!-- TODO: customize wording for Dart docs -->\n   */\n  componentType: Type;\n\n  /**\n   * The {@link ViewRef} of the Host View of this Component instance.\n   */\n  get hostView(): HostViewRef {\n    return (<ElementRef_>this.location).internalElement.parentView.ref;\n  }\n\n  /**\n   * @internal\n   *\n   * The instance of the component.\n   *\n   * TODO(i): this api should be removed\n   */\n  get hostComponent(): any { return this.instance; }\n\n  /**\n   * Destroys the component instance and all of the data structures associated with it.\n   *\n   * TODO(i): rename to destroy to be consistent with AppViewManager and ViewContainerRef\n   */\n  abstract dispose();\n}\n\nexport class ComponentRef_ extends ComponentRef {\n  /**\n   * TODO(i): refactor into public/private fields\n   */\n  constructor(location: ElementRef, instance: any, componentType: Type, injector: Injector,\n              private _dispose: () => void) {\n    super();\n    this.location = location;\n    this.instance = instance;\n    this.componentType = componentType;\n    this.injector = injector;\n  }\n\n  /**\n   * @internal\n   *\n   * Returns the type of this Component instance.\n   *\n   * TODO(i): this api should be removed\n   */\n  get hostComponentType(): Type { return this.componentType; }\n\n  dispose() { this._dispose(); }\n}\n\n/**\n * Service for instantiating a Component and attaching it to a View at a specified location.\n */\nexport abstract class DynamicComponentLoader {\n  /**\n   * Creates an instance of a Component `type` and attaches it to the first element in the\n   * platform-specific global view that matches the component's selector.\n   *\n   * In a browser the platform-specific global view is the main DOM Document.\n   *\n   * If needed, the component's selector can be overridden via `overrideSelector`.\n   *\n   * You can optionally provide `injector` and this {@link Injector} will be used to instantiate the\n   * Component.\n   *\n   * To be notified when this Component instance is destroyed, you can also optionally provide\n   * `onDispose` callback.\n   *\n   * Returns a promise for the {@link ComponentRef} representing the newly created Component.\n   *\n   * ### Example\n   *\n   * ```\n   * @Component({\n   *   selector: 'child-component',\n   *   template: 'Child'\n   * })\n   * class ChildComponent {\n   * }\n   *\n   * @Component({\n   *   selector: 'my-app',\n   *   template: 'Parent (<child id=\"child\"></child>)'\n   * })\n   * class MyApp {\n   *   constructor(dcl: DynamicComponentLoader, injector: Injector) {\n   *     dcl.loadAsRoot(ChildComponent, '#child', injector);\n   *   }\n   * }\n   *\n   * bootstrap(MyApp);\n   * ```\n   *\n   * Resulting DOM:\n   *\n   * ```\n   * <my-app>\n   *   Parent (\n   *     <child id=\"child\">Child</child>\n   *   )\n   * </my-app>\n   * ```\n   */\n  abstract loadAsRoot(type: Type, overrideSelector: string, injector: Injector,\n                      onDispose?: () => void, projectableNodes?: any[][]): Promise<ComponentRef>;\n\n  /**\n   * Creates an instance of a Component and attaches it to a View Container located inside of the\n   * Component View of another Component instance.\n   *\n   * The targeted Component Instance is specified via its `hostLocation` {@link ElementRef}. The\n   * location within the Component View of this Component Instance is specified via `anchorName`\n   * Template Variable Name.\n   *\n   * You can optionally provide `providers` to configure the {@link Injector} provisioned for this\n   * Component Instance.\n   *\n   * Returns a promise for the {@link ComponentRef} representing the newly created Component.\n   *\n   * ### Example\n   *\n   * ```\n   * @Component({\n   *   selector: 'child-component',\n   *   template: 'Child'\n   * })\n   * class ChildComponent {\n   * }\n   *\n   * @Component({\n   *   selector: 'my-app',\n   *   template: 'Parent (<div #child></div>)'\n   * })\n   * class MyApp {\n   *   constructor(dcl: DynamicComponentLoader, elementRef: ElementRef) {\n   *     dcl.loadIntoLocation(ChildComponent, elementRef, 'child');\n   *   }\n   * }\n   *\n   * bootstrap(MyApp);\n   * ```\n   *\n   * Resulting DOM:\n   *\n   * ```\n   * <my-app>\n   *    Parent (\n   *      <div #child=\"\" class=\"ng-binding\"></div>\n   *      <child-component class=\"ng-binding\">Child</child-component>\n   *    )\n   * </my-app>\n   * ```\n   */\n  abstract loadIntoLocation(type: Type, hostLocation: ElementRef, anchorName: string,\n                            providers?: ResolvedProvider[],\n                            projectableNodes?: any[][]): Promise<ComponentRef>;\n\n  /**\n   * Creates an instance of a Component and attaches it to the View Container found at the\n   * `location` specified as {@link ElementRef}.\n   *\n   * You can optionally provide `providers` to configure the {@link Injector} provisioned for this\n   * Component Instance.\n   *\n   * Returns a promise for the {@link ComponentRef} representing the newly created Component.\n   *\n   *\n   * ### Example\n   *\n   * ```\n   * @Component({\n   *   selector: 'child-component',\n   *   template: 'Child'\n   * })\n   * class ChildComponent {\n   * }\n   *\n   * @Component({\n   *   selector: 'my-app',\n   *   template: 'Parent'\n   * })\n   * class MyApp {\n   *   constructor(dcl: DynamicComponentLoader, elementRef: ElementRef) {\n   *     dcl.loadNextToLocation(ChildComponent, elementRef);\n   *   }\n   * }\n   *\n   * bootstrap(MyApp);\n   * ```\n   *\n   * Resulting DOM:\n   *\n   * ```\n   * <my-app>Parent</my-app>\n   * <child-component>Child</child-component>\n   * ```\n   */\n  abstract loadNextToLocation(type: Type, location: ElementRef, providers?: ResolvedProvider[],\n                              projectableNodes?: any[][]): Promise<ComponentRef>;\n}\n\n@Injectable()\nexport class DynamicComponentLoader_ extends DynamicComponentLoader {\n  constructor(private _compiler: Compiler, private _viewManager: AppViewManager) { super(); }\n\n  loadAsRoot(type: Type, overrideSelector: string, injector: Injector, onDispose?: () => void,\n             projectableNodes?: any[][]): Promise<ComponentRef> {\n    return this._compiler.compileInHost(type).then(hostProtoViewRef => {\n      var hostViewRef = this._viewManager.createRootHostView(hostProtoViewRef, overrideSelector,\n                                                             injector, projectableNodes);\n      var newLocation = this._viewManager.getHostElement(hostViewRef);\n      var component = this._viewManager.getComponent(newLocation);\n\n      var dispose = () => {\n        if (isPresent(onDispose)) {\n          onDispose();\n        }\n        this._viewManager.destroyRootHostView(hostViewRef);\n      };\n      return new ComponentRef_(newLocation, component, type, injector, dispose);\n    });\n  }\n\n  loadIntoLocation(type: Type, hostLocation: ElementRef, anchorName: string,\n                   providers: ResolvedProvider[] = null,\n                   projectableNodes: any[][] = null): Promise<ComponentRef> {\n    return this.loadNextToLocation(\n        type, this._viewManager.getNamedElementInComponentView(hostLocation, anchorName), providers,\n        projectableNodes);\n  }\n\n  loadNextToLocation(type: Type, location: ElementRef, providers: ResolvedProvider[] = null,\n                     projectableNodes: any[][] = null): Promise<ComponentRef> {\n    return this._compiler.compileInHost(type).then(hostProtoViewRef => {\n      var viewContainer = this._viewManager.getViewContainer(location);\n      var hostViewRef = viewContainer.createHostView(hostProtoViewRef, viewContainer.length,\n                                                     providers, projectableNodes);\n      var newLocation = this._viewManager.getHostElement(hostViewRef);\n      var component = this._viewManager.getComponent(newLocation);\n\n      var dispose = () => {\n        var index = viewContainer.indexOf(hostViewRef);\n        if (!hostViewRef.destroyed && index !== -1) {\n          viewContainer.remove(index);\n        }\n      };\n      return new ComponentRef_(newLocation, component, type, null, dispose);\n    });\n  }\n}\n"]}