angular2
Version:
Angular 2 - a web framework for modern web apps
107 lines • 22.4 kB
JavaScript
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);
};
import { Injectable } from 'angular2/src/core/di';
import { Compiler } from './compiler';
import { isPresent } from 'angular2/src/facade/lang';
import { AppViewManager } from '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.
*/
export class ComponentRef {
/**
* The {@link ViewRef} of the Host View of this Component instance.
*/
get hostView() {
return this.location.internalElement.parentView.ref;
}
/**
* @internal
*
* The instance of the component.
*
* TODO(i): this api should be removed
*/
get hostComponent() { return this.instance; }
}
export class ComponentRef_ extends ComponentRef {
/**
* TODO(i): refactor into public/private fields
*/
constructor(location, instance, componentType, injector, _dispose) {
super();
this._dispose = _dispose;
this.location = location;
this.instance = instance;
this.componentType = componentType;
this.injector = injector;
}
/**
* @internal
*
* Returns the type of this Component instance.
*
* TODO(i): this api should be removed
*/
get hostComponentType() { return this.componentType; }
dispose() { this._dispose(); }
}
/**
* Service for instantiating a Component and attaching it to a View at a specified location.
*/
export class DynamicComponentLoader {
}
export let DynamicComponentLoader_ = class extends DynamicComponentLoader {
constructor(_compiler, _viewManager) {
super();
this._compiler = _compiler;
this._viewManager = _viewManager;
}
loadAsRoot(type, overrideSelector, injector, onDispose, projectableNodes) {
return this._compiler.compileInHost(type).then(hostProtoViewRef => {
var hostViewRef = this._viewManager.createRootHostView(hostProtoViewRef, overrideSelector, injector, projectableNodes);
var newLocation = this._viewManager.getHostElement(hostViewRef);
var component = this._viewManager.getComponent(newLocation);
var dispose = () => {
if (isPresent(onDispose)) {
onDispose();
}
this._viewManager.destroyRootHostView(hostViewRef);
};
return new ComponentRef_(newLocation, component, type, injector, dispose);
});
}
loadIntoLocation(type, hostLocation, anchorName, providers = null, projectableNodes = null) {
return this.loadNextToLocation(type, this._viewManager.getNamedElementInComponentView(hostLocation, anchorName), providers, projectableNodes);
}
loadNextToLocation(type, location, providers = null, projectableNodes = null) {
return this._compiler.compileInHost(type).then(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 = () => {
var index = viewContainer.indexOf(hostViewRef);
if (!hostViewRef.destroyed && index !== -1) {
viewContainer.remove(index);
}
};
return new ComponentRef_(newLocation, component, type, null, dispose);
});
}
};
DynamicComponentLoader_ = __decorate([
Injectable(),
__metadata('design:paramtypes', [Compiler, AppViewManager])
], 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.hostView","ComponentRef.hostComponent","ComponentRef_","ComponentRef_.constructor","ComponentRef_.hostComponentType","ComponentRef_.dispose","DynamicComponentLoader","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"]}