| 
									
										
										
										
											2018-10-23 15:33:01 -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 {global} from '../util'; | 
					
						
							| 
									
										
										
										
											2018-11-15 08:43:56 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | import {assertDefined} from './assert'; | 
					
						
							|  |  |  | import {getComponent, getDirectives, getHostElement, getInjector, getPlayers, getRootComponents, getViewComponent, markDirty} from './global_utils_api'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * This file introduces series of globally accessible debug tools | 
					
						
							|  |  |  |  * to allow for the Angular debugging story to function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * To see this in action run the following command: | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-10-30 17:36:45 -07:00
										 |  |  |  *   bazel run --define=compile=aot | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  |  *   //packages/core/test/bundling/todo:devserver
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Then load `localhost:5432` and start using the console tools. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * This value reflects the property on the window where the dev | 
					
						
							| 
									
										
										
										
											2018-11-05 13:06:42 -08:00
										 |  |  |  * tools are patched (window.ng). | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  |  * */ | 
					
						
							| 
									
										
										
										
											2018-11-05 13:06:42 -08:00
										 |  |  | export const GLOBAL_PUBLISH_EXPANDO_KEY = 'ng'; | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * Publishes a collection of default debug tools onto `window._ng_`. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * These functions are available globally when Angular is in development | 
					
						
							|  |  |  |  * mode and are automatically stripped away from prod mode is on. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | let _published = false; | 
					
						
							|  |  |  | export function publishDefaultGlobalUtils() { | 
					
						
							|  |  |  |   if (!_published) { | 
					
						
							|  |  |  |     _published = true; | 
					
						
							|  |  |  |     publishGlobalUtil('getComponent', getComponent); | 
					
						
							| 
									
										
										
										
											2018-11-15 08:43:56 -08:00
										 |  |  |     publishGlobalUtil('getViewComponent', getViewComponent); | 
					
						
							|  |  |  |     publishGlobalUtil('getHostElement', getHostElement); | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  |     publishGlobalUtil('getInjector', getInjector); | 
					
						
							|  |  |  |     publishGlobalUtil('getRootComponents', getRootComponents); | 
					
						
							|  |  |  |     publishGlobalUtil('getDirectives', getDirectives); | 
					
						
							| 
									
										
										
										
											2018-11-07 13:03:11 -08:00
										 |  |  |     publishGlobalUtil('getPlayers', getPlayers); | 
					
						
							| 
									
										
										
										
											2018-11-15 08:43:56 -08:00
										 |  |  |     publishGlobalUtil('markDirty', markDirty); | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export declare type GlobalDevModeContainer = { | 
					
						
							|  |  |  |   [GLOBAL_PUBLISH_EXPANDO_KEY]: {[fnName: string]: Function}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Publishes the given function to `window.ngDevMode` so that it can be | 
					
						
							|  |  |  |  * used from the browser console when an application is not in production. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | export function publishGlobalUtil(name: string, fn: Function): void { | 
					
						
							|  |  |  |   const w = global as any as GlobalDevModeContainer; | 
					
						
							| 
									
										
										
										
											2018-11-15 08:43:56 -08:00
										 |  |  |   ngDevMode && assertDefined(fn, 'function not defined'); | 
					
						
							| 
									
										
										
										
											2018-10-23 15:33:01 -07:00
										 |  |  |   if (w) { | 
					
						
							|  |  |  |     let container = w[GLOBAL_PUBLISH_EXPANDO_KEY]; | 
					
						
							|  |  |  |     if (!container) { | 
					
						
							|  |  |  |       container = w[GLOBAL_PUBLISH_EXPANDO_KEY] = {}; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     container[name] = fn; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |