| 
									
										
										
										
											2016-06-23 09:47:54 -07: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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | import {Inject, Injectable} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2016-07-11 16:04:32 -07:00
										 |  |  | import {TestComponentRenderer} from '@angular/core/testing'; | 
					
						
							| 
									
										
										
										
											2016-06-10 10:21:53 -07:00
										 |  |  | import {DOCUMENT} from '@angular/platform-browser'; | 
					
						
							| 
									
										
										
										
											2016-08-30 18:07:40 -07:00
										 |  |  | import {getDOM} from './private_import_platform-browser'; | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * A DOM based implementation of the TestComponentRenderer. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | @Injectable() | 
					
						
							|  |  |  | export class DOMTestComponentRenderer extends TestComponentRenderer { | 
					
						
							| 
									
										
										
										
											2016-06-08 15:45:15 -07:00
										 |  |  |   constructor(@Inject(DOCUMENT) private _doc: any /** TODO #9100 */) { super(); } | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   insertRootElement(rootElId: string) { | 
					
						
							| 
									
										
										
										
											2016-11-12 14:08:58 +01:00
										 |  |  |     const rootEl = <HTMLElement>getDOM().firstChild( | 
					
						
							| 
									
										
										
										
											2016-06-23 16:42:25 -07:00
										 |  |  |         getDOM().content(getDOM().createTemplate(`<div id="${rootElId}"></div>`))); | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // TODO(juliemr): can/should this be optional?
 | 
					
						
							| 
									
										
										
										
											2016-11-12 14:08:58 +01:00
										 |  |  |     const oldRoots = getDOM().querySelectorAll(this._doc, '[id^=root]'); | 
					
						
							| 
									
										
										
										
											2016-04-28 17:50:03 -07:00
										 |  |  |     for (let i = 0; i < oldRoots.length; i++) { | 
					
						
							|  |  |  |       getDOM().remove(oldRoots[i]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     getDOM().appendChild(this._doc.body, rootEl); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |