| 
									
										
										
										
											2017-12-01 14:23:03 -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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * The goal here is to make sure that the browser DOM API is the Renderer. | 
					
						
							|  |  |  |  * We do this by defining a subset of DOM API to be the renderer and than | 
					
						
							|  |  |  |  * use that time for rendering. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * At runtime we can than use the DOM api directly, in server or web-worker | 
					
						
							|  |  |  |  * it will be easy to implement such API. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | import {ViewEncapsulation} from '../../metadata/view'; | 
					
						
							|  |  |  | import {RendererStyleFlags2, RendererType2} from '../../render/api'; | 
					
						
							| 
									
										
										
										
											2017-12-20 10:47:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // TODO: cleanup once the code is merged in angular/angular
 | 
					
						
							|  |  |  | export enum RendererStyleFlags3 { | 
					
						
							|  |  |  |   Important = 1 << 0, | 
					
						
							|  |  |  |   DashCase = 1 << 1 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 15:50:01 -08:00
										 |  |  | export type Renderer3 = ObjectOrientedRenderer3 | ProceduralRenderer3; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 18:05:41 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Object Oriented style of API needed to create elements and text nodes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This is the native browser API style, e.g. operations are methods on individual objects | 
					
						
							|  |  |  |  * like HTMLElement. With this style, no additional code is needed as a facade | 
					
						
							|  |  |  |  * (reducing payload size). | 
					
						
							|  |  |  |  * */ | 
					
						
							| 
									
										
										
										
											2017-12-14 15:50:01 -08:00
										 |  |  | export interface ObjectOrientedRenderer3 { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   createElement(tagName: string): RElement; | 
					
						
							| 
									
										
										
										
											2018-06-08 09:00:01 -07:00
										 |  |  |   createElementNS(namespace: string, tagName: string): RElement; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   createTextNode(data: string): RText; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   querySelector(selectors: string): RElement|null; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 17:14:58 +00:00
										 |  |  | /** Returns whether the `renderer` is a `ProceduralRenderer3` */ | 
					
						
							| 
									
										
										
										
											2018-02-06 20:08:46 -08:00
										 |  |  | export function isProceduralRenderer(renderer: ProceduralRenderer3 | ObjectOrientedRenderer3): | 
					
						
							|  |  |  |     renderer is ProceduralRenderer3 { | 
					
						
							|  |  |  |   return !!((renderer as any).listen); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 18:05:41 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Procedural style of API needed to create elements and text nodes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In non-native browser environments (e.g. platforms such as web-workers), this is the | 
					
						
							|  |  |  |  * facade that enables element manipulation. This also facilitates backwards compatibility | 
					
						
							|  |  |  |  * with Renderer2. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-14 15:50:01 -08:00
										 |  |  | export interface ProceduralRenderer3 { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   destroy(): void; | 
					
						
							|  |  |  |   createElement(name: string, namespace?: string|null): RElement; | 
					
						
							|  |  |  |   createText(value: string): RText; | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This property is allowed to be null / undefined, | 
					
						
							|  |  |  |    * in which case the view engine won't call it. | 
					
						
							|  |  |  |    * This is used as a performance optimization for production mode. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   destroyNode?: ((node: RNode) => void)|null; | 
					
						
							|  |  |  |   appendChild(parent: RElement, newChild: RNode): void; | 
					
						
							|  |  |  |   insertBefore(parent: RNode, newChild: RNode, refChild: RNode|null): void; | 
					
						
							|  |  |  |   removeChild(parent: RElement, oldChild: RNode): void; | 
					
						
							|  |  |  |   selectRootElement(selectorOrNode: string|any): RElement; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   setAttribute(el: RElement, name: string, value: string, namespace?: string|null): void; | 
					
						
							|  |  |  |   removeAttribute(el: RElement, name: string, namespace?: string|null): void; | 
					
						
							|  |  |  |   addClass(el: RElement, name: string): void; | 
					
						
							|  |  |  |   removeClass(el: RElement, name: string): void; | 
					
						
							|  |  |  |   setStyle( | 
					
						
							|  |  |  |       el: RElement, style: string, value: any, | 
					
						
							|  |  |  |       flags?: RendererStyleFlags2|RendererStyleFlags3): void; | 
					
						
							|  |  |  |   removeStyle(el: RElement, style: string, flags?: RendererStyleFlags2|RendererStyleFlags3): void; | 
					
						
							|  |  |  |   setProperty(el: RElement, name: string, value: any): void; | 
					
						
							|  |  |  |   setValue(node: RText, value: string): void; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // TODO(misko): Deprecate in favor of addEventListener/removeEventListener
 | 
					
						
							|  |  |  |   listen(target: RNode, eventName: string, callback: (event: any) => boolean | void): () => void; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export interface RendererFactory3 { | 
					
						
							| 
									
										
										
										
											2017-12-11 16:30:46 +01:00
										 |  |  |   createRenderer(hostElement: RElement|null, rendererType: RendererType2|null): Renderer3; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   begin?(): void; | 
					
						
							|  |  |  |   end?(): void; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-11 16:30:46 +01:00
										 |  |  | export const domRendererFactory3: RendererFactory3 = { | 
					
						
							|  |  |  |   createRenderer: (hostElement: RElement | null, rendererType: RendererType2 | null): | 
					
						
							|  |  |  |                       Renderer3 => { return document;} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 15:50:01 -08:00
										 |  |  | /** Subset of API needed for appending elements and text nodes. */ | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | export interface RNode { | 
					
						
							|  |  |  |   removeChild(oldChild: RNode): void; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Insert a child node. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Used exclusively for adding View root nodes into ViewAnchor location. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   insertBefore(newChild: RNode, refChild: RNode|null, isViewRoot: boolean): void; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * Append a child node. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Used exclusively for building up DOM which are static (ie not View roots) | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   appendChild(newChild: RNode): RNode; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Subset of API needed for writing attributes, properties, and setting up | 
					
						
							|  |  |  |  * listeners on Element. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | export interface RElement extends RNode { | 
					
						
							| 
									
										
										
										
											2017-12-14 18:05:41 -08:00
										 |  |  |   style: RCssStyleDeclaration; | 
					
						
							|  |  |  |   classList: RDomTokenList; | 
					
						
							| 
									
										
										
										
											2018-03-08 13:57:56 -08:00
										 |  |  |   className: string; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   setAttribute(name: string, value: string): void; | 
					
						
							|  |  |  |   removeAttribute(name: string): void; | 
					
						
							|  |  |  |   setAttributeNS(namespaceURI: string, qualifiedName: string, value: string): void; | 
					
						
							|  |  |  |   addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; | 
					
						
							|  |  |  |   removeEventListener(type: string, listener?: EventListener, options?: boolean): void; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   setProperty?(name: string, value: any): void; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 18:05:41 -08:00
										 |  |  | export interface RCssStyleDeclaration { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   removeProperty(propertyName: string): string; | 
					
						
							|  |  |  |   setProperty(propertyName: string, value: string|null, priority?: string): void; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-14 18:05:41 -08:00
										 |  |  | export interface RDomTokenList { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   add(token: string): void; | 
					
						
							|  |  |  |   remove(token: string): void; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export interface RText extends RNode { textContent: string|null; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-09 18:38:17 -08:00
										 |  |  | // Note: This hack is necessary so we don't erroneously get a circular dependency
 | 
					
						
							|  |  |  | // failure based on types.
 | 
					
						
							|  |  |  | export const unusedValueExportToPlacateAjd = 1; |