| 
									
										
										
										
											2018-08-06 14:09:38 -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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import {Injector} from '../di/injector'; | 
					
						
							|  |  |  | import {Renderer2, RendererType2} from '../render/api'; | 
					
						
							|  |  |  | import {DebugContext} from '../view'; | 
					
						
							|  |  |  | import {DebugRenderer2, DebugRendererFactory2} from '../view/services'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import * as di from './di'; | 
					
						
							| 
									
										
										
										
											2018-08-29 13:52:03 -07:00
										 |  |  | import {_getViewData} from './instructions'; | 
					
						
							| 
									
										
										
										
											2018-10-04 20:40:39 -07:00
										 |  |  | import {TNodeFlags} from './interfaces/node'; | 
					
						
							|  |  |  | import {CONTEXT, LViewData, TVIEW} from './interfaces/view'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Adapts the DebugRendererFactory2 to create a DebugRenderer2 specific for IVY. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The created DebugRenderer know how to create a Debug Context specific to IVY. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | export class Render3DebugRendererFactory2 extends DebugRendererFactory2 { | 
					
						
							|  |  |  |   createRenderer(element: any, renderData: RendererType2|null): Renderer2 { | 
					
						
							|  |  |  |     const renderer = super.createRenderer(element, renderData) as DebugRenderer2; | 
					
						
							|  |  |  |     renderer.debugContextFactory = () => new Render3DebugContext(_getViewData()); | 
					
						
							|  |  |  |     return renderer; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Stores context information about view nodes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Used in tests to retrieve information those nodes. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class Render3DebugContext implements DebugContext { | 
					
						
							|  |  |  |   readonly nodeIndex: number|null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   constructor(private viewData: LViewData) { | 
					
						
							|  |  |  |     // The LNode will be created next and appended to viewData
 | 
					
						
							|  |  |  |     this.nodeIndex = viewData ? viewData.length : null; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get view(): any { return this.viewData; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get injector(): Injector { | 
					
						
							|  |  |  |     if (this.nodeIndex !== null) { | 
					
						
							| 
									
										
										
										
											2018-09-28 21:26:45 -07:00
										 |  |  |       const tNode = this.view[TVIEW].data[this.nodeIndex]; | 
					
						
							| 
									
										
										
										
											2018-10-02 21:12:26 -07:00
										 |  |  |       return new di.NodeInjector(tNode, this.view); | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |     return Injector.NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get component(): any { | 
					
						
							|  |  |  |     // TODO(vicb): why/when
 | 
					
						
							|  |  |  |     if (this.nodeIndex === null) { | 
					
						
							|  |  |  |       return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const tView = this.view[TVIEW]; | 
					
						
							|  |  |  |     const components: number[]|null = tView.components; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return (components && components.indexOf(this.nodeIndex) == -1) ? | 
					
						
							|  |  |  |         null : | 
					
						
							|  |  |  |         this.view[this.nodeIndex].data[CONTEXT]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // TODO(vicb): add view providers when supported
 | 
					
						
							|  |  |  |   get providerTokens(): any[] { | 
					
						
							|  |  |  |     // TODO(vicb): why/when
 | 
					
						
							| 
									
										
										
										
											2018-10-08 16:04:46 -07:00
										 |  |  |     const directiveDefs = this.view[TVIEW].data; | 
					
						
							| 
									
										
										
										
											2018-10-04 20:40:39 -07:00
										 |  |  |     if (this.nodeIndex === null || directiveDefs == null) { | 
					
						
							|  |  |  |       return []; | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-04 20:40:39 -07:00
										 |  |  |     const currentTNode = this.view[TVIEW].data[this.nodeIndex]; | 
					
						
							|  |  |  |     const dirStart = currentTNode >> TNodeFlags.DirectiveStartingIndexShift; | 
					
						
							|  |  |  |     const dirEnd = dirStart + (currentTNode & TNodeFlags.DirectiveCountMask); | 
					
						
							|  |  |  |     return directiveDefs.slice(dirStart, dirEnd); | 
					
						
							| 
									
										
										
										
											2018-08-06 14:09:38 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get references(): {[key: string]: any} { | 
					
						
							|  |  |  |     // TODO(vicb): implement retrieving references
 | 
					
						
							|  |  |  |     throw new Error('Not implemented yet in ivy'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get context(): any { | 
					
						
							|  |  |  |     if (this.nodeIndex === null) { | 
					
						
							|  |  |  |       return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     const lNode = this.view[this.nodeIndex]; | 
					
						
							|  |  |  |     return lNode.view[CONTEXT]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get componentRenderElement(): any { throw new Error('Not implemented in ivy'); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   get renderNode(): any { throw new Error('Not implemented in ivy'); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // TODO(vicb): check previous implementation
 | 
					
						
							|  |  |  |   logError(console: Console, ...values: any[]): void { console.error(...values); } | 
					
						
							| 
									
										
										
										
											2018-08-29 13:52:03 -07:00
										 |  |  | } |