| 
									
										
										
										
											2017-12-20 10:47:22 -08: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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  | import './ng_dev_mode'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-23 13:17:20 -08:00
										 |  |  | import {ChangeDetectionStrategy} from '../change_detection/constants'; | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  | import {Provider} from '../di/provider'; | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | import {NgModuleDef} from '../metadata/ng_module'; | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  | import {ViewEncapsulation} from '../metadata/view'; | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  | import {Mutable, Type} from '../type'; | 
					
						
							|  |  |  | import {noSideEffects} from '../util'; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  | import {NG_COMPONENT_DEF, NG_DIRECTIVE_DEF, NG_MODULE_DEF, NG_PIPE_DEF} from './fields'; | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | import {BaseDef, ComponentDef, ComponentDefFeature, ComponentQuery, ComponentTemplate, ComponentType, DirectiveDef, DirectiveDefFeature, DirectiveType, DirectiveTypesOrFactory, PipeDef, PipeType, PipeTypesOrFactory} from './interfaces/definition'; | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  | import {CssSelectorList, SelectorFlags} from './interfaces/projection'; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 15:25:32 -07:00
										 |  |  | export const EMPTY: {} = {}; | 
					
						
							|  |  |  | export const EMPTY_ARRAY: any[] = []; | 
					
						
							| 
									
										
										
										
											2018-08-13 19:39:18 -07:00
										 |  |  | if (typeof ngDevMode !== 'undefined' && ngDevMode) { | 
					
						
							|  |  |  |   Object.freeze(EMPTY); | 
					
						
							|  |  |  |   Object.freeze(EMPTY_ARRAY); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  | let _renderCompCount = 0; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Create a component definition object. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * # Example | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * class MyDirective { | 
					
						
							|  |  |  |  *   // Generated by Angular Template Compiler
 | 
					
						
							|  |  |  |  *   // [Symbol] syntax will not be supported by TypeScript until v2.7
 | 
					
						
							| 
									
										
										
										
											2018-01-27 13:07:03 -08:00
										 |  |  |  *   static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |  *     ... | 
					
						
							|  |  |  |  *   }); | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | export function defineComponent<T>(componentDefinition: { | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Directive type, needed to configure the injector. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   type: Type<T>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |   /** The selectors that will be used to match nodes to this component. */ | 
					
						
							|  |  |  |   selectors: CssSelectorList; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Factory method used to create an instance of directive. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-07-10 10:43:07 +02:00
										 |  |  |   factory: () => T; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * The number of nodes, local refs, and pipes in this component template. | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-08-20 13:03:03 -07:00
										 |  |  |    * Used to calculate the length of this component's LViewData array, so we | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |    * can pre-fill the array and set the binding start index. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   // TODO(kara): remove queries from this count
 | 
					
						
							|  |  |  |   consts: number; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * The number of bindings in this component template (including pure fn bindings). | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-08-20 13:03:03 -07:00
										 |  |  |    * Used to calculate the length of this component's LViewData array, so we | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |    * can pre-fill the array and set the host binding start index. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   vars: number; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-20 13:03:03 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * The number of host bindings (including pure fn bindings) in this component. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Used to calculate the length of the LViewData array for the *parent* component | 
					
						
							|  |  |  |    * of this component. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   hostVars?: number; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Static attributes to set on host element. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Even indices: attribute name | 
					
						
							|  |  |  |    * Odd indices: attribute value | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   attributes?: string[]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of input names. | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * The format is in: `{[actualPropertyName: string]:(string|[string, string])}`. | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * Given: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * class MyComponent { | 
					
						
							|  |  |  |    *   @Input() | 
					
						
							|  |  |  |    *   publicInput1: string; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    *   @Input('publicInput2') | 
					
						
							|  |  |  |    *   declaredInput2: string; | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * is described as: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   publicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   declaredInput2: ['declaredInput2', 'publicInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   minifiedPublicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   minifiedDeclaredInput2: [ 'publicInput2', 'declaredInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified, public, and declared names | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * of properties. | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * | 
					
						
							|  |  |  |    * NOTE: | 
					
						
							|  |  |  |    *  - Because declared and public name are usually same we only generate the array | 
					
						
							|  |  |  |    *    `['declared', 'public']` format when they differ. | 
					
						
							|  |  |  |    *  - The reason why this API and `outputs` API is not the same is that `NgOnChanges` has | 
					
						
							|  |  |  |    *    inconsistent behavior in that it uses declared names rather than minified or public. For | 
					
						
							|  |  |  |    *    this reason `NgOnChanges` will be deprecated and removed in future version and this | 
					
						
							|  |  |  |    *    API will be simplified to be consistent with `output`. | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |   inputs?: {[P in keyof T]?: string | [string, string]}; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of output names. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * The format is in: `{[actualPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: `{[minifiedPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified and non-minified names | 
					
						
							|  |  |  |    * of properties. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   outputs?: {[P in keyof T]?: string}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Function executed by the parent template to allow child directive to apply host bindings. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   hostBindings?: (directiveIndex: number, elementIndex: number) => void; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-10 10:43:07 +02:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Function to create instances of content queries associated with a given directive. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   contentQueries?: (() => void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Refreshes content queries associated with directives in a given view */ | 
					
						
							|  |  |  |   contentQueriesRefresh?: ((directiveIndex: number, queryIndex: number) => void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Defines the name that can be used in the template to assign this directive to a variable. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * See: {@link Directive.exportAs} | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   exportAs?: string; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Template function use for rendering DOM. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This function has following structure. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * function Template<T>(ctx:T, creationMode: boolean) { | 
					
						
							|  |  |  |    *   if (creationMode) { | 
					
						
							|  |  |  |    *     // Contains creation mode instructions.
 | 
					
						
							|  |  |  |    *   } | 
					
						
							|  |  |  |    *   // Contains binding update instructions
 | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Common instructions are: | 
					
						
							|  |  |  |    * Creation mode instructions: | 
					
						
							|  |  |  |    *  - `elementStart`, `elementEnd` | 
					
						
							|  |  |  |    *  - `text` | 
					
						
							|  |  |  |    *  - `container` | 
					
						
							|  |  |  |    *  - `listener` | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Binding update instructions: | 
					
						
							|  |  |  |    * - `bind` | 
					
						
							|  |  |  |    * - `elementAttribute` | 
					
						
							|  |  |  |    * - `elementProperty` | 
					
						
							|  |  |  |    * - `elementClass` | 
					
						
							|  |  |  |    * - `elementStyle` | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   template: ComponentTemplate<T>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 17:58:42 +02:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Additional set of instructions specific to view query processing. This could be seen as a | 
					
						
							|  |  |  |    * set of instruction to be inserted into the template function. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Query-related instructions need to be pulled out to a specific function as a timing of | 
					
						
							|  |  |  |    * execution is different as compared to all other instructions (after change detection hooks but | 
					
						
							|  |  |  |    * before view hooks). | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   viewQuery?: ComponentQuery<T>| null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * A list of optional features to apply. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * See: {@link NgOnChangesFeature}, {@link PublicFeature} | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   features?: ComponentDefFeature[]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Defines template and style encapsulation options available for Component's {@link Component}. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   encapsulation?: ViewEncapsulation; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Defines arbitrary developer-defined data to be stored on a renderer instance. | 
					
						
							|  |  |  |    * This is useful for renderers that delegate to other renderers. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * see: animation | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   data?: {[kind: string]: any}; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * A set of styles that the component needs to be present for component to render correctly. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   styles?: string[]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * The strategy that the default change detector uses to detect changes. | 
					
						
							|  |  |  |    * When set, takes effect the next time change detection is triggered. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   changeDetection?: ChangeDetectionStrategy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Defines the set of injectable objects that are visible to a Directive and its light DOM | 
					
						
							|  |  |  |    * children. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   providers?: Provider[]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Defines the set of injectable objects that are visible to its view DOM children. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   viewProviders?: Provider[]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Registry of directives and components that may be found in this component's view. | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-04-13 23:02:29 -07:00
										 |  |  |    * The property is either an array of `DirectiveDef`s or a function which returns the array of | 
					
						
							|  |  |  |    * `DirectiveDef`s. The function is necessary to be able to support forward declarations. | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |   directives?: DirectiveTypesOrFactory | null; | 
					
						
							| 
									
										
										
										
											2018-03-27 15:53:48 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Registry of pipes that may be found in this component's view. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * The property is either an array of `PipeDefs`s or a function which returns the array of | 
					
						
							|  |  |  |    * `PipeDefs`s. The function is necessary to be able to support forward declarations. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |   pipes?: PipeTypesOrFactory | null; | 
					
						
							| 
									
										
										
										
											2018-04-14 09:18:38 -07:00
										 |  |  | }): never { | 
					
						
							| 
									
										
										
										
											2018-01-23 18:39:09 -08:00
										 |  |  |   const type = componentDefinition.type; | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |   const typePrototype = type.prototype; | 
					
						
							| 
									
										
										
										
											2018-06-25 11:11:22 +02:00
										 |  |  |   const declaredInputs: {[key: string]: string} = {} as any; | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |   const def: Mutable<ComponentDef<any>, keyof ComponentDef<any>> = { | 
					
						
							| 
									
										
										
										
											2018-01-23 18:39:09 -08:00
										 |  |  |     type: type, | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |     diPublic: null, | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |     consts: componentDefinition.consts, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |     vars: componentDefinition.vars, | 
					
						
							| 
									
										
										
										
											2018-08-20 13:03:03 -07:00
										 |  |  |     hostVars: componentDefinition.hostVars || 0, | 
					
						
							| 
									
										
										
										
											2018-03-16 16:42:13 -07:00
										 |  |  |     factory: componentDefinition.factory, | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |     template: componentDefinition.template || null !, | 
					
						
							| 
									
										
										
										
											2018-03-16 16:42:13 -07:00
										 |  |  |     hostBindings: componentDefinition.hostBindings || null, | 
					
						
							| 
									
										
										
										
											2018-07-10 10:43:07 +02:00
										 |  |  |     contentQueries: componentDefinition.contentQueries || null, | 
					
						
							|  |  |  |     contentQueriesRefresh: componentDefinition.contentQueriesRefresh || null, | 
					
						
							| 
									
										
										
										
											2018-02-16 12:09:47 -08:00
										 |  |  |     attributes: componentDefinition.attributes || null, | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |     declaredInputs: declaredInputs, | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     inputs: null !,   // assigned in noSideEffects
 | 
					
						
							|  |  |  |     outputs: null !,  // assigned in noSideEffects
 | 
					
						
							| 
									
										
										
										
											2018-05-31 15:50:02 -07:00
										 |  |  |     exportAs: componentDefinition.exportAs || null, | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     onInit: typePrototype.ngOnInit || null, | 
					
						
							|  |  |  |     doCheck: typePrototype.ngDoCheck || null, | 
					
						
							|  |  |  |     afterContentInit: typePrototype.ngAfterContentInit || null, | 
					
						
							|  |  |  |     afterContentChecked: typePrototype.ngAfterContentChecked || null, | 
					
						
							|  |  |  |     afterViewInit: typePrototype.ngAfterViewInit || null, | 
					
						
							|  |  |  |     afterViewChecked: typePrototype.ngAfterViewChecked || null, | 
					
						
							|  |  |  |     onDestroy: typePrototype.ngOnDestroy || null, | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |     onPush: componentDefinition.changeDetection === ChangeDetectionStrategy.OnPush, | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     directiveDefs: null !,  // assigned in noSideEffects
 | 
					
						
							|  |  |  |     pipeDefs: null !,       // assigned in noSideEffects
 | 
					
						
							| 
									
										
										
										
											2018-06-19 17:58:42 +02:00
										 |  |  |     selectors: componentDefinition.selectors, | 
					
						
							|  |  |  |     viewQuery: componentDefinition.viewQuery || null, | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |     features: componentDefinition.features || null, | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     data: componentDefinition.data || {}, | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  |     // TODO(misko): convert ViewEncapsulation into const enum so that it can be used directly in the
 | 
					
						
							|  |  |  |     // next line. Also `None` should be 0 not 2.
 | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     encapsulation: componentDefinition.encapsulation || ViewEncapsulation.Emulated, | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  |     providers: EMPTY_ARRAY, | 
					
						
							|  |  |  |     viewProviders: EMPTY_ARRAY, | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |     id: 'c', | 
					
						
							|  |  |  |     styles: componentDefinition.styles || EMPTY_ARRAY, | 
					
						
							|  |  |  |     _: null as never, | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2018-10-12 15:49:42 -07:00
										 |  |  |   def._ = noSideEffects(() => { | 
					
						
							|  |  |  |     const directiveTypes = componentDefinition.directives !; | 
					
						
							|  |  |  |     const feature = componentDefinition.features; | 
					
						
							|  |  |  |     const pipeTypes = componentDefinition.pipes !; | 
					
						
							|  |  |  |     def.id += _renderCompCount++; | 
					
						
							|  |  |  |     def.inputs = invertObject(componentDefinition.inputs, declaredInputs), | 
					
						
							|  |  |  |     def.outputs = invertObject(componentDefinition.outputs), | 
					
						
							|  |  |  |     feature && feature.forEach((fn) => fn(def)); | 
					
						
							|  |  |  |     def.directiveDefs = directiveTypes ? | 
					
						
							|  |  |  |         () => (typeof directiveTypes === 'function' ? directiveTypes() : directiveTypes) | 
					
						
							|  |  |  |                   .map(extractDirectiveDef) : | 
					
						
							|  |  |  |         null; | 
					
						
							|  |  |  |     def.pipeDefs = pipeTypes ? | 
					
						
							|  |  |  |         () => (typeof pipeTypes === 'function' ? pipeTypes() : pipeTypes).map(extractPipeDef) : | 
					
						
							|  |  |  |         null; | 
					
						
							|  |  |  |   }) as never; | 
					
						
							| 
									
										
										
										
											2018-04-14 09:18:38 -07:00
										 |  |  |   return def as never; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  | export function extractDirectiveDef(type: DirectiveType<any>& ComponentType<any>): | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  |     DirectiveDef<any>|ComponentDef<any> { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   const def = getComponentDef(type) || getDirectiveDef(type); | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |   if (ngDevMode && !def) { | 
					
						
							|  |  |  |     throw new Error(`'${type.name}' is neither 'ComponentType' or 'DirectiveType'.`); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return def !; | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function extractPipeDef(type: PipeType<any>): PipeDef<any> { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   const def = getPipeDef(type); | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |   if (ngDevMode && !def) { | 
					
						
							|  |  |  |     throw new Error(`'${type.name}' is not a 'PipeType'.`); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return def !; | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function defineNgModule<T>(def: {type: T} & Partial<NgModuleDef<T>>): never { | 
					
						
							|  |  |  |   const res: NgModuleDef<T> = { | 
					
						
							| 
									
										
										
										
											2018-05-31 15:50:02 -07:00
										 |  |  |     type: def.type, | 
					
						
							| 
									
										
										
										
											2018-08-08 13:22:52 -07:00
										 |  |  |     bootstrap: def.bootstrap || EMPTY_ARRAY, | 
					
						
							|  |  |  |     declarations: def.declarations || EMPTY_ARRAY, | 
					
						
							|  |  |  |     imports: def.imports || EMPTY_ARRAY, | 
					
						
							|  |  |  |     exports: def.exports || EMPTY_ARRAY, | 
					
						
							| 
									
										
										
										
											2018-05-31 15:50:02 -07:00
										 |  |  |     transitiveCompileScopes: null, | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   return res as never; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-01-17 10:09:05 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  * Inverts an inputs or outputs lookup such that the keys, which were the | 
					
						
							|  |  |  |  * minified keys, are part of the values, and the values are parsed so that | 
					
						
							|  |  |  |  * the publicName of the property is the new key | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  * e.g. for | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  * ```
 | 
					
						
							|  |  |  |  * class Comp { | 
					
						
							|  |  |  |  *   @Input() | 
					
						
							|  |  |  |  *   propName1: string; | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  *   @Input('publicName') | 
					
						
							|  |  |  |  *   propName2: number; | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * will be serialized as | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ```
 | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  * { | 
					
						
							|  |  |  |  *   a0: 'propName1', | 
					
						
							|  |  |  |  *   b1: ['publicName', 'propName2'], | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * becomes | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * { | 
					
						
							|  |  |  |  *  'propName1': 'a0', | 
					
						
							|  |  |  |  *  'publicName': 'b1' | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Optionally the function can take `secondary` which will result in: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * { | 
					
						
							|  |  |  |  *  'propName1': 'a0', | 
					
						
							|  |  |  |  *  'propName2': 'b1' | 
					
						
							|  |  |  |  * } | 
					
						
							| 
									
										
										
										
											2018-03-12 11:18:50 -07:00
										 |  |  |  * ```
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | function invertObject(obj: any, secondary?: any): any { | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |   if (obj == null) return EMPTY; | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |   const newLookup: any = {}; | 
					
						
							|  |  |  |   for (const minifiedKey in obj) { | 
					
						
							|  |  |  |     if (obj.hasOwnProperty(minifiedKey)) { | 
					
						
							|  |  |  |       let publicName = obj[minifiedKey]; | 
					
						
							|  |  |  |       let declaredName = publicName; | 
					
						
							|  |  |  |       if (Array.isArray(publicName)) { | 
					
						
							|  |  |  |         declaredName = publicName[1]; | 
					
						
							|  |  |  |         publicName = publicName[0]; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       newLookup[publicName] = minifiedKey; | 
					
						
							|  |  |  |       if (secondary) { | 
					
						
							|  |  |  |         (secondary[declaredName] = minifiedKey); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |   return newLookup; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 17:01:22 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Create a base definition | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * # Example | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * class ShouldBeInherited { | 
					
						
							|  |  |  |  *   static ngBaseDef = defineBase({ | 
					
						
							|  |  |  |  *      ... | 
					
						
							|  |  |  |  *   }) | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * @param baseDefinition The base definition parameters | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | export function defineBase<T>(baseDefinition: { | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of input names. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * The format is in: `{[actualPropertyName: string]:(string|[string, string])}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Given: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * class MyComponent { | 
					
						
							|  |  |  |    *   @Input() | 
					
						
							|  |  |  |    *   publicInput1: string; | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    *   @Input('publicInput2') | 
					
						
							|  |  |  |    *   declaredInput2: string; | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * is described as: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   publicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   declaredInput2: ['declaredInput2', 'publicInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   minifiedPublicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   minifiedDeclaredInput2: [ 'declaredInput2', 'publicInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified, public, and declared names | 
					
						
							|  |  |  |    * of properties. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * NOTE: | 
					
						
							|  |  |  |    *  - Because declared and public name are usually same we only generate the array | 
					
						
							|  |  |  |    *    `['declared', 'public']` format when they differ. | 
					
						
							|  |  |  |    *  - The reason why this API and `outputs` API is not the same is that `NgOnChanges` has | 
					
						
							|  |  |  |    *    inconsistent behavior in that it uses declared names rather than minified or public. For | 
					
						
							|  |  |  |    *    this reason `NgOnChanges` will be deprecated and removed in future version and this | 
					
						
							|  |  |  |    *    API will be simplified to be consistent with `outputs`. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   inputs?: {[P in keyof T]?: string | [string, string]}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of output names. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * The format is in: `{[actualPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: `{[minifiedPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified and non-minified names | 
					
						
							|  |  |  |    * of properties. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   outputs?: {[P in keyof T]?: string}; | 
					
						
							|  |  |  | }): BaseDef<T> { | 
					
						
							|  |  |  |   const declaredInputs: {[P in keyof T]: P} = {} as any; | 
					
						
							|  |  |  |   return { | 
					
						
							|  |  |  |     inputs: invertObject(baseDefinition.inputs, declaredInputs), | 
					
						
							|  |  |  |     declaredInputs: declaredInputs, | 
					
						
							|  |  |  |     outputs: invertObject(baseDefinition.outputs), | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Create a directive definition object. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * # Example | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * class MyDirective { | 
					
						
							|  |  |  |  *   // Generated by Angular Template Compiler
 | 
					
						
							|  |  |  |  *   // [Symbol] syntax will not be supported by TypeScript until v2.7
 | 
					
						
							| 
									
										
										
										
											2018-01-27 13:07:03 -08:00
										 |  |  |  *   static ngDirectiveDef = defineDirective({ | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  |  *     ... | 
					
						
							|  |  |  |  *   }); | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | export const defineDirective = defineComponent as any as<T>(directiveDefinition: { | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Directive type, needed to configure the injector. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   type: Type<T>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |   /** The selectors that will be used to match nodes to this directive. */ | 
					
						
							|  |  |  |   selectors: CssSelectorList; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Factory method used to create an instance of directive. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-08-31 16:52:13 +02:00
										 |  |  |   factory: () => T; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Static attributes to set on host element. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Even indices: attribute name | 
					
						
							|  |  |  |    * Odd indices: attribute value | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   attributes?: string[]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of input names. | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * The format is in: `{[actualPropertyName: string]:(string|[string, string])}`. | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * Given: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * class MyComponent { | 
					
						
							|  |  |  |    *   @Input() | 
					
						
							|  |  |  |    *   publicInput1: string; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    *   @Input('publicInput2') | 
					
						
							|  |  |  |    *   declaredInput2: string; | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * is described as: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   publicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   declaredInput2: ['declaredInput2', 'publicInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * { | 
					
						
							|  |  |  |    *   minifiedPublicInput1: 'publicInput1', | 
					
						
							|  |  |  |    *   minifiedDeclaredInput2: [ 'publicInput2', 'declaredInput2'], | 
					
						
							|  |  |  |    * } | 
					
						
							|  |  |  |    * ```
 | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified, public, and declared names | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    * of properties. | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * | 
					
						
							|  |  |  |    * NOTE: | 
					
						
							|  |  |  |    *  - Because declared and public name are usually same we only generate the array | 
					
						
							|  |  |  |    *    `['declared', 'public']` format when they differ. | 
					
						
							|  |  |  |    *  - The reason why this API and `outputs` API is not the same is that `NgOnChanges` has | 
					
						
							|  |  |  |    *    inconsistent behavior in that it uses declared names rather than minified or public. For | 
					
						
							|  |  |  |    *    this reason `NgOnChanges` will be deprecated and removed in future version and this | 
					
						
							|  |  |  |    *    API will be simplified to be consistent with `output`. | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    */ | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |   inputs?: {[P in keyof T]?: string | [string, string]}; | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A map of output names. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * The format is in: `{[actualPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Which the minifier may translate to: `{[minifiedPropertyName: string]:string}`. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * This allows the render to re-construct the minified and non-minified names | 
					
						
							|  |  |  |    * of properties. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   outputs?: {[P in keyof T]?: string}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * A list of optional features to apply. | 
					
						
							|  |  |  |    * | 
					
						
							| 
									
										
										
										
											2018-06-18 08:05:06 -07:00
										 |  |  |    * See: {@link NgOnChangesFeature}, {@link PublicFeature}, {@link InheritDefinitionFeature} | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |    */ | 
					
						
							|  |  |  |   features?: DirectiveDefFeature[]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-20 13:03:03 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * The number of host bindings (including pure fn bindings) in this directive. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Used to calculate the length of the LViewData array for the *parent* component | 
					
						
							|  |  |  |    * of this directive. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   hostVars?: number; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Function executed by the parent template to allow child directive to apply host bindings. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   hostBindings?: (directiveIndex: number, elementIndex: number) => void; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-10 10:43:07 +02:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Function to create instances of content queries associated with a given directive. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   contentQueries?: (() => void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Refreshes content queries associated with directives in a given view */ | 
					
						
							|  |  |  |   contentQueriesRefresh?: ((directiveIndex: number, queryIndex: number) => void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 14:44:22 -07:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * Defines the name that can be used in the template to assign this directive to a variable. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * See: {@link Directive.exportAs} | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   exportAs?: string; | 
					
						
							| 
									
										
										
										
											2018-04-14 09:18:38 -07:00
										 |  |  | }) => never; | 
					
						
							| 
									
										
										
										
											2018-01-27 13:07:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Create a pipe definition object. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * # Example | 
					
						
							|  |  |  |  * ```
 | 
					
						
							|  |  |  |  * class MyPipe implements PipeTransform { | 
					
						
							|  |  |  |  *   // Generated by Angular Template Compiler
 | 
					
						
							|  |  |  |  *   static ngPipeDef = definePipe({ | 
					
						
							|  |  |  |  *     ... | 
					
						
							|  |  |  |  *   }); | 
					
						
							|  |  |  |  * } | 
					
						
							|  |  |  |  * ```
 | 
					
						
							| 
									
										
										
										
											2018-03-27 15:53:48 -07:00
										 |  |  |  * @param pipeDef Pipe definition generated by the compiler | 
					
						
							| 
									
										
										
										
											2018-01-27 13:07:03 -08:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-27 15:53:48 -07:00
										 |  |  | export function definePipe<T>(pipeDef: { | 
					
						
							|  |  |  |   /** Name of the pipe. Used for matching pipes in template to pipe defs. */ | 
					
						
							|  |  |  |   name: string, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Pipe class reference. Needed to extract pipe lifecycle hooks. */ | 
					
						
							|  |  |  |   type: Type<T>, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** A factory for creating a pipe instance. */ | 
					
						
							|  |  |  |   factory: () => T, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Whether the pipe is pure. */ | 
					
						
							|  |  |  |   pure?: boolean | 
					
						
							| 
									
										
										
										
											2018-04-14 09:18:38 -07:00
										 |  |  | }): never { | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  |   return (<PipeDef<T>>{ | 
					
						
							| 
									
										
										
										
											2018-03-27 15:53:48 -07:00
										 |  |  |     name: pipeDef.name, | 
					
						
							| 
									
										
										
										
											2018-05-13 18:29:45 +02:00
										 |  |  |     factory: pipeDef.factory, | 
					
						
							| 
									
										
										
										
											2018-03-27 15:53:48 -07:00
										 |  |  |     pure: pipeDef.pure !== false, | 
					
						
							|  |  |  |     onDestroy: pipeDef.type.prototype.ngOnDestroy || null | 
					
						
							| 
									
										
										
										
											2018-04-14 09:18:38 -07:00
										 |  |  |   }) as never; | 
					
						
							| 
									
										
										
										
											2018-02-16 12:09:47 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * The following getter methods retrieve the definition form the type. Currently the retrieval | 
					
						
							|  |  |  |  * honors inheritance, but in the future we may change the rule to require that definitions are | 
					
						
							|  |  |  |  * explicit. This would require some sort of migration strategy. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function getComponentDef<T>(type: any): ComponentDef<T>|null { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return (type as any)[NG_COMPONENT_DEF] || null; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function getDirectiveDef<T>(type: any): DirectiveDef<T>|null { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return (type as any)[NG_DIRECTIVE_DEF] || null; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function getPipeDef<T>(type: any): PipeDef<T>|null { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return (type as any)[NG_PIPE_DEF] || null; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 12:12:06 -07:00
										 |  |  | export function getNgModuleDef<T>(type: any): NgModuleDef<T>|null { | 
					
						
							| 
									
										
										
										
											2018-08-29 16:34:44 -07:00
										 |  |  |   return (type as any)[NG_MODULE_DEF] || null; | 
					
						
							|  |  |  | } |