UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

61 lines 11.9 kB
'use strict';"use strict"; 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 component_resolver_1 = require('./component_resolver'); var lang_1 = require('angular2/src/facade/lang'); /** * 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) { _super.call(this); this._compiler = _compiler; } DynamicComponentLoader_.prototype.loadAsRoot = function (type, overrideSelectorOrNode, injector, onDispose, projectableNodes) { return this._compiler.resolveComponent(type).then(function (componentFactory) { var componentRef = componentFactory.create(injector, projectableNodes, lang_1.isPresent(overrideSelectorOrNode) ? overrideSelectorOrNode : componentFactory.selector); if (lang_1.isPresent(onDispose)) { componentRef.onDestroy(onDispose); } return componentRef; }); }; DynamicComponentLoader_.prototype.loadNextToLocation = function (type, location, providers, projectableNodes) { if (providers === void 0) { providers = null; } if (projectableNodes === void 0) { projectableNodes = null; } return this._compiler.resolveComponent(type).then(function (componentFactory) { var contextInjector = location.parentInjector; var childInjector = lang_1.isPresent(providers) && providers.length > 0 ? di_1.ReflectiveInjector.fromResolvedProviders(providers, contextInjector) : contextInjector; return location.createComponent(componentFactory, location.length, childInjector, projectableNodes); }); }; DynamicComponentLoader_ = __decorate([ di_1.Injectable(), __metadata('design:paramtypes', [component_resolver_1.ComponentResolver]) ], DynamicComponentLoader_); return DynamicComponentLoader_; }(DynamicComponentLoader)); exports.DynamicComponentLoader_ = DynamicComponentLoader_; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic_component_loader.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/core/linker/dynamic_component_loader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,mBAKO,sBAAsB,CAAC,CAAA;AAC9B,mCAAgC,sBAAsB,CAAC,CAAA;AACvD,qBAAiD,0BAA0B,CAAC,CAAA;AAI5E;;GAEG;AACH;IAAA;IAiGA,CAAC;IAAD,6BAAC;AAAD,CAAC,AAjGD,IAiGC;AAjGqB,8BAAsB,yBAiG3C,CAAA;AAGD;IAA6C,2CAAsB;IACjE,iCAAoB,SAA4B;QAAI,iBAAO,CAAC;QAAxC,cAAS,GAAT,SAAS,CAAmB;IAAa,CAAC;IAE9D,4CAAU,GAAV,UAAW,IAAU,EAAE,sBAAoC,EAAE,QAAkB,EACpE,SAAsB,EAAE,gBAA0B;QAC3D,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAA,gBAAgB;YAChE,IAAI,YAAY,GAAG,gBAAgB,CAAC,MAAM,CACtC,QAAQ,EAAE,gBAAgB,EAC1B,gBAAS,CAAC,sBAAsB,CAAC,GAAG,sBAAsB,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YAC5F,EAAE,CAAC,CAAC,gBAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACzB,YAAY,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC;YACD,MAAM,CAAC,YAAY,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oDAAkB,GAAlB,UAAmB,IAAU,EAAE,QAA0B,EACtC,SAA8C,EAC9C,gBAAgC;QADhC,yBAA8C,GAA9C,gBAA8C;QAC9C,gCAAgC,GAAhC,uBAAgC;QACjD,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAA,gBAAgB;YAChE,IAAI,eAAe,GAAG,QAAQ,CAAC,cAAc,CAAC;YAC9C,IAAI,aAAa,GAAG,gBAAS,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC;gBACxC,uBAAkB,CAAC,qBAAqB,CAAC,SAAS,EAAE,eAAe,CAAC;gBACpE,eAAe,CAAC;YACxC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,gBAAgB,EAAE,QAAQ,CAAC,MAAM,EAAE,aAAa,EAChD,gBAAgB,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACL,CAAC;IA5BH;QAAC,eAAU,EAAE;;+BAAA;IA6Bb,8BAAC;AAAD,CAAC,AA5BD,CAA6C,sBAAsB,GA4BlE;AA5BY,+BAAuB,0BA4BnC,CAAA","sourcesContent":["import {\n  Injector,\n  ResolvedReflectiveProvider,\n  Injectable,\n  ReflectiveInjector\n} from 'angular2/src/core/di';\nimport {ComponentResolver} from './component_resolver';\nimport {isType, Type, stringify, isPresent} from 'angular2/src/facade/lang';\nimport {ComponentRef} from './component_factory';\nimport {ViewContainerRef} from './view_container_ref';\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, overrideSelectorOrNode: string | any, injector: Injector,\n                      onDispose?: () => void, projectableNodes?: any[][]): Promise<ComponentRef>;\n\n\n  /**\n   * Creates an instance of a Component and attaches it to the View Container found at the\n   * `location` specified as {@link ViewContainerRef}.\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, viewContainerRef: ViewContainerRef) {\n   *     dcl.loadNextToLocation(ChildComponent, viewContainerRef);\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: ViewContainerRef,\n                              providers?: ResolvedReflectiveProvider[],\n                              projectableNodes?: any[][]): Promise<ComponentRef>;\n}\n\n@Injectable()\nexport class DynamicComponentLoader_ extends DynamicComponentLoader {\n  constructor(private _compiler: ComponentResolver) { super(); }\n\n  loadAsRoot(type: Type, overrideSelectorOrNode: string | any, injector: Injector,\n             onDispose?: () => void, projectableNodes?: any[][]): Promise<ComponentRef> {\n    return this._compiler.resolveComponent(type).then(componentFactory => {\n      var componentRef = componentFactory.create(\n          injector, projectableNodes,\n          isPresent(overrideSelectorOrNode) ? overrideSelectorOrNode : componentFactory.selector);\n      if (isPresent(onDispose)) {\n        componentRef.onDestroy(onDispose);\n      }\n      return componentRef;\n    });\n  }\n\n  loadNextToLocation(type: Type, location: ViewContainerRef,\n                     providers: ResolvedReflectiveProvider[] = null,\n                     projectableNodes: any[][] = null): Promise<ComponentRef> {\n    return this._compiler.resolveComponent(type).then(componentFactory => {\n      var contextInjector = location.parentInjector;\n      var childInjector = isPresent(providers) && providers.length > 0 ?\n                              ReflectiveInjector.fromResolvedProviders(providers, contextInjector) :\n                              contextInjector;\n      return location.createComponent(componentFactory, location.length, childInjector,\n                                      projectableNodes);\n    });\n  }\n}\n"]}