| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @license | 
					
						
							|  |  |  |  * Copyright Google Inc. All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Use of this source code is governed by an MIT-style license that can be | 
					
						
							|  |  |  |  * found in the LICENSE file at https://angular.io/license
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-25 17:41:08 -08:00
										 |  |  | import {CommonModule} from '@angular/common'; | 
					
						
							| 
									
										
										
										
											2018-11-27 16:04:27 +01:00
										 |  |  | import {Compiler, Component, Injectable, Injector, NgModule, NgModuleFactory} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  | import {BrowserModule} from '@angular/platform-browser'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // #docregion SimpleExample
 | 
					
						
							|  |  |  | @Component({selector: 'hello-world', template: 'Hello World!'}) | 
					
						
							|  |  |  | class HelloWorld { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'ng-component-outlet-simple-example', | 
					
						
							|  |  |  |   template: `<ng-container *ngComponentOutlet="HelloWorld"></ng-container>` | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | class NgTemplateOutletSimpleExample { | 
					
						
							|  |  |  |   // This field is necessary to expose HelloWorld to the template.
 | 
					
						
							|  |  |  |   HelloWorld = HelloWorld; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // #enddocregion
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // #docregion CompleteExample
 | 
					
						
							|  |  |  | @Injectable() | 
					
						
							|  |  |  | class Greeter { | 
					
						
							| 
									
										
										
										
											2017-01-09 11:54:25 -08:00
										 |  |  |   suffix = '!'; | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'complete-component', | 
					
						
							|  |  |  |   template: `Complete: <ng-content></ng-content> <ng-content></ng-content>{{ greeter.suffix }}` | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | class CompleteComponent { | 
					
						
							|  |  |  |   constructor(public greeter: Greeter) {} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'ng-component-outlet-complete-example', | 
					
						
							|  |  |  |   template: `
 | 
					
						
							|  |  |  |     <ng-container *ngComponentOutlet="CompleteComponent;  | 
					
						
							|  |  |  |                                       injector: myInjector;  | 
					
						
							|  |  |  |                                       content: myContent"></ng-container>` | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | class NgTemplateOutletCompleteExample { | 
					
						
							|  |  |  |   // This field is necessary to expose CompleteComponent to the template.
 | 
					
						
							|  |  |  |   CompleteComponent = CompleteComponent; | 
					
						
							|  |  |  |   myInjector: Injector; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   myContent = [[document.createTextNode('Ahoj')], [document.createTextNode('Svet')]]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   constructor(injector: Injector) { | 
					
						
							| 
									
										
										
										
											2018-11-27 16:04:27 +01:00
										 |  |  |     this.myInjector = | 
					
						
							|  |  |  |         Injector.create({providers: [{provide: Greeter, deps: []}], parent: injector}); | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // #enddocregion
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-25 17:41:08 -08:00
										 |  |  | // #docregion NgModuleFactoryExample
 | 
					
						
							|  |  |  | @Component({selector: 'other-module-component', template: `Other Module Component!`}) | 
					
						
							|  |  |  | class OtherModuleComponent { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'ng-component-outlet-other-module-example', | 
					
						
							|  |  |  |   template: `
 | 
					
						
							|  |  |  |     <ng-container *ngComponentOutlet="OtherModuleComponent; | 
					
						
							|  |  |  |                                       ngModuleFactory: myModule;"></ng-container>` | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | class NgTemplateOutletOtherModuleExample { | 
					
						
							|  |  |  |   // This field is necessary to expose OtherModuleComponent to the template.
 | 
					
						
							|  |  |  |   OtherModuleComponent = OtherModuleComponent; | 
					
						
							|  |  |  |   myModule: NgModuleFactory<any>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   constructor(compiler: Compiler) { this.myModule = compiler.compileModuleSync(OtherModule); } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // #enddocregion
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | @Component({ | 
					
						
							|  |  |  |   selector: 'example-app', | 
					
						
							|  |  |  |   template: `<ng-component-outlet-simple-example></ng-component-outlet-simple-example>
 | 
					
						
							|  |  |  |              <hr/> | 
					
						
							| 
									
										
										
										
											2017-01-25 17:41:08 -08:00
										 |  |  |              <ng-component-outlet-complete-example></ng-component-outlet-complete-example> | 
					
						
							|  |  |  |              <hr/> | 
					
						
							|  |  |  |              <ng-component-outlet-other-module-example></ng-component-outlet-other-module-example>` | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  | }) | 
					
						
							|  |  |  | class ExampleApp { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @NgModule({ | 
					
						
							|  |  |  |   imports: [BrowserModule], | 
					
						
							|  |  |  |   declarations: [ | 
					
						
							| 
									
										
										
										
											2017-01-25 17:41:08 -08:00
										 |  |  |     ExampleApp, NgTemplateOutletSimpleExample, NgTemplateOutletCompleteExample, | 
					
						
							|  |  |  |     NgTemplateOutletOtherModuleExample, HelloWorld, CompleteComponent | 
					
						
							| 
									
										
										
										
											2016-09-01 14:00:14 +03:00
										 |  |  |   ], | 
					
						
							|  |  |  |   entryComponents: [HelloWorld, CompleteComponent], | 
					
						
							|  |  |  |   bootstrap: [ExampleApp] | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class AppModule { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-01-25 17:41:08 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | @NgModule({ | 
					
						
							|  |  |  |   imports: [CommonModule], | 
					
						
							|  |  |  |   declarations: [OtherModuleComponent], | 
					
						
							|  |  |  |   entryComponents: [OtherModuleComponent] | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | export class OtherModule { | 
					
						
							| 
									
										
										
										
											2018-11-27 16:04:27 +01:00
										 |  |  | } |