[6a3a178] | 1 | /**
|
---|
| 2 | * @license
|
---|
| 3 | * Copyright Google LLC All Rights Reserved.
|
---|
| 4 | *
|
---|
| 5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
| 6 | * found in the LICENSE file at https://angular.io/license
|
---|
| 7 | */
|
---|
| 8 | import { APP_ID, Inject, Injectable, RendererStyleFlags2, ViewEncapsulation } from '@angular/core';
|
---|
| 9 | import { EventManager } from './events/event_manager';
|
---|
| 10 | import { DomSharedStylesHost } from './shared_styles_host';
|
---|
| 11 | export const NAMESPACE_URIS = {
|
---|
| 12 | 'svg': 'http://www.w3.org/2000/svg',
|
---|
| 13 | 'xhtml': 'http://www.w3.org/1999/xhtml',
|
---|
| 14 | 'xlink': 'http://www.w3.org/1999/xlink',
|
---|
| 15 | 'xml': 'http://www.w3.org/XML/1998/namespace',
|
---|
| 16 | 'xmlns': 'http://www.w3.org/2000/xmlns/',
|
---|
| 17 | };
|
---|
| 18 | const COMPONENT_REGEX = /%COMP%/g;
|
---|
| 19 | const NG_DEV_MODE = typeof ngDevMode === 'undefined' || !!ngDevMode;
|
---|
| 20 | export const COMPONENT_VARIABLE = '%COMP%';
|
---|
| 21 | export const HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;
|
---|
| 22 | export const CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;
|
---|
| 23 | export function shimContentAttribute(componentShortId) {
|
---|
| 24 | return CONTENT_ATTR.replace(COMPONENT_REGEX, componentShortId);
|
---|
| 25 | }
|
---|
| 26 | export function shimHostAttribute(componentShortId) {
|
---|
| 27 | return HOST_ATTR.replace(COMPONENT_REGEX, componentShortId);
|
---|
| 28 | }
|
---|
| 29 | export function flattenStyles(compId, styles, target) {
|
---|
| 30 | for (let i = 0; i < styles.length; i++) {
|
---|
| 31 | let style = styles[i];
|
---|
| 32 | if (Array.isArray(style)) {
|
---|
| 33 | flattenStyles(compId, style, target);
|
---|
| 34 | }
|
---|
| 35 | else {
|
---|
| 36 | style = style.replace(COMPONENT_REGEX, compId);
|
---|
| 37 | target.push(style);
|
---|
| 38 | }
|
---|
| 39 | }
|
---|
| 40 | return target;
|
---|
| 41 | }
|
---|
| 42 | function decoratePreventDefault(eventHandler) {
|
---|
| 43 | // `DebugNode.triggerEventHandler` needs to know if the listener was created with
|
---|
| 44 | // decoratePreventDefault or is a listener added outside the Angular context so it can handle the
|
---|
| 45 | // two differently. In the first case, the special '__ngUnwrap__' token is passed to the unwrap
|
---|
| 46 | // the listener (see below).
|
---|
| 47 | return (event) => {
|
---|
| 48 | // Ivy uses '__ngUnwrap__' as a special token that allows us to unwrap the function
|
---|
| 49 | // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`. The debug_node
|
---|
| 50 | // can inspect the listener toString contents for the existence of this special token. Because
|
---|
| 51 | // the token is a string literal, it is ensured to not be modified by compiled code.
|
---|
| 52 | if (event === '__ngUnwrap__') {
|
---|
| 53 | return eventHandler;
|
---|
| 54 | }
|
---|
| 55 | const allowDefaultBehavior = eventHandler(event);
|
---|
| 56 | if (allowDefaultBehavior === false) {
|
---|
| 57 | // TODO(tbosch): move preventDefault into event plugins...
|
---|
| 58 | event.preventDefault();
|
---|
| 59 | event.returnValue = false;
|
---|
| 60 | }
|
---|
| 61 | return undefined;
|
---|
| 62 | };
|
---|
| 63 | }
|
---|
| 64 | let hasLoggedNativeEncapsulationWarning = false;
|
---|
| 65 | export class DomRendererFactory2 {
|
---|
| 66 | constructor(eventManager, sharedStylesHost, appId) {
|
---|
| 67 | this.eventManager = eventManager;
|
---|
| 68 | this.sharedStylesHost = sharedStylesHost;
|
---|
| 69 | this.appId = appId;
|
---|
| 70 | this.rendererByCompId = new Map();
|
---|
| 71 | this.defaultRenderer = new DefaultDomRenderer2(eventManager);
|
---|
| 72 | }
|
---|
| 73 | createRenderer(element, type) {
|
---|
| 74 | if (!element || !type) {
|
---|
| 75 | return this.defaultRenderer;
|
---|
| 76 | }
|
---|
| 77 | switch (type.encapsulation) {
|
---|
| 78 | case ViewEncapsulation.Emulated: {
|
---|
| 79 | let renderer = this.rendererByCompId.get(type.id);
|
---|
| 80 | if (!renderer) {
|
---|
| 81 | renderer = new EmulatedEncapsulationDomRenderer2(this.eventManager, this.sharedStylesHost, type, this.appId);
|
---|
| 82 | this.rendererByCompId.set(type.id, renderer);
|
---|
| 83 | }
|
---|
| 84 | renderer.applyToHost(element);
|
---|
| 85 | return renderer;
|
---|
| 86 | }
|
---|
| 87 | // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an enum
|
---|
| 88 | // value that is not known (but previously was the value for ViewEncapsulation.Native)
|
---|
| 89 | case 1:
|
---|
| 90 | case ViewEncapsulation.ShadowDom:
|
---|
| 91 | // TODO(FW-2290): remove the `case 1:` fallback logic and the warning in v12.
|
---|
| 92 | if ((typeof ngDevMode === 'undefined' || ngDevMode) &&
|
---|
| 93 | // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an
|
---|
| 94 | // enum value that is not known (but previously was the value for
|
---|
| 95 | // ViewEncapsulation.Native)
|
---|
| 96 | !hasLoggedNativeEncapsulationWarning && type.encapsulation === 1) {
|
---|
| 97 | hasLoggedNativeEncapsulationWarning = true;
|
---|
| 98 | console.warn('ViewEncapsulation.Native is no longer supported. Falling back to ViewEncapsulation.ShadowDom. The fallback will be removed in v12.');
|
---|
| 99 | }
|
---|
| 100 | return new ShadowDomRenderer(this.eventManager, this.sharedStylesHost, element, type);
|
---|
| 101 | default: {
|
---|
| 102 | if (!this.rendererByCompId.has(type.id)) {
|
---|
| 103 | const styles = flattenStyles(type.id, type.styles, []);
|
---|
| 104 | this.sharedStylesHost.addStyles(styles);
|
---|
| 105 | this.rendererByCompId.set(type.id, this.defaultRenderer);
|
---|
| 106 | }
|
---|
| 107 | return this.defaultRenderer;
|
---|
| 108 | }
|
---|
| 109 | }
|
---|
| 110 | }
|
---|
| 111 | begin() { }
|
---|
| 112 | end() { }
|
---|
| 113 | }
|
---|
| 114 | DomRendererFactory2.decorators = [
|
---|
| 115 | { type: Injectable }
|
---|
| 116 | ];
|
---|
| 117 | DomRendererFactory2.ctorParameters = () => [
|
---|
| 118 | { type: EventManager },
|
---|
| 119 | { type: DomSharedStylesHost },
|
---|
| 120 | { type: String, decorators: [{ type: Inject, args: [APP_ID,] }] }
|
---|
| 121 | ];
|
---|
| 122 | class DefaultDomRenderer2 {
|
---|
| 123 | constructor(eventManager) {
|
---|
| 124 | this.eventManager = eventManager;
|
---|
| 125 | this.data = Object.create(null);
|
---|
| 126 | }
|
---|
| 127 | destroy() { }
|
---|
| 128 | createElement(name, namespace) {
|
---|
| 129 | if (namespace) {
|
---|
| 130 | // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key
|
---|
| 131 | // will result in undefined, so we just return the namespace here.
|
---|
| 132 | return document.createElementNS(NAMESPACE_URIS[namespace] || namespace, name);
|
---|
| 133 | }
|
---|
| 134 | return document.createElement(name);
|
---|
| 135 | }
|
---|
| 136 | createComment(value) {
|
---|
| 137 | return document.createComment(value);
|
---|
| 138 | }
|
---|
| 139 | createText(value) {
|
---|
| 140 | return document.createTextNode(value);
|
---|
| 141 | }
|
---|
| 142 | appendChild(parent, newChild) {
|
---|
| 143 | parent.appendChild(newChild);
|
---|
| 144 | }
|
---|
| 145 | insertBefore(parent, newChild, refChild) {
|
---|
| 146 | if (parent) {
|
---|
| 147 | parent.insertBefore(newChild, refChild);
|
---|
| 148 | }
|
---|
| 149 | }
|
---|
| 150 | removeChild(parent, oldChild) {
|
---|
| 151 | if (parent) {
|
---|
| 152 | parent.removeChild(oldChild);
|
---|
| 153 | }
|
---|
| 154 | }
|
---|
| 155 | selectRootElement(selectorOrNode, preserveContent) {
|
---|
| 156 | let el = typeof selectorOrNode === 'string' ? document.querySelector(selectorOrNode) :
|
---|
| 157 | selectorOrNode;
|
---|
| 158 | if (!el) {
|
---|
| 159 | throw new Error(`The selector "${selectorOrNode}" did not match any elements`);
|
---|
| 160 | }
|
---|
| 161 | if (!preserveContent) {
|
---|
| 162 | el.textContent = '';
|
---|
| 163 | }
|
---|
| 164 | return el;
|
---|
| 165 | }
|
---|
| 166 | parentNode(node) {
|
---|
| 167 | return node.parentNode;
|
---|
| 168 | }
|
---|
| 169 | nextSibling(node) {
|
---|
| 170 | return node.nextSibling;
|
---|
| 171 | }
|
---|
| 172 | setAttribute(el, name, value, namespace) {
|
---|
| 173 | if (namespace) {
|
---|
| 174 | name = namespace + ':' + name;
|
---|
| 175 | // TODO(FW-811): Ivy may cause issues here because it's passing around
|
---|
| 176 | // full URIs for namespaces, therefore this lookup will fail.
|
---|
| 177 | const namespaceUri = NAMESPACE_URIS[namespace];
|
---|
| 178 | if (namespaceUri) {
|
---|
| 179 | el.setAttributeNS(namespaceUri, name, value);
|
---|
| 180 | }
|
---|
| 181 | else {
|
---|
| 182 | el.setAttribute(name, value);
|
---|
| 183 | }
|
---|
| 184 | }
|
---|
| 185 | else {
|
---|
| 186 | el.setAttribute(name, value);
|
---|
| 187 | }
|
---|
| 188 | }
|
---|
| 189 | removeAttribute(el, name, namespace) {
|
---|
| 190 | if (namespace) {
|
---|
| 191 | // TODO(FW-811): Ivy may cause issues here because it's passing around
|
---|
| 192 | // full URIs for namespaces, therefore this lookup will fail.
|
---|
| 193 | const namespaceUri = NAMESPACE_URIS[namespace];
|
---|
| 194 | if (namespaceUri) {
|
---|
| 195 | el.removeAttributeNS(namespaceUri, name);
|
---|
| 196 | }
|
---|
| 197 | else {
|
---|
| 198 | // TODO(FW-811): Since ivy is passing around full URIs for namespaces
|
---|
| 199 | // this could result in properties like `http://www.w3.org/2000/svg:cx="123"`,
|
---|
| 200 | // which is wrong.
|
---|
| 201 | el.removeAttribute(`${namespace}:${name}`);
|
---|
| 202 | }
|
---|
| 203 | }
|
---|
| 204 | else {
|
---|
| 205 | el.removeAttribute(name);
|
---|
| 206 | }
|
---|
| 207 | }
|
---|
| 208 | addClass(el, name) {
|
---|
| 209 | el.classList.add(name);
|
---|
| 210 | }
|
---|
| 211 | removeClass(el, name) {
|
---|
| 212 | el.classList.remove(name);
|
---|
| 213 | }
|
---|
| 214 | setStyle(el, style, value, flags) {
|
---|
| 215 | if (flags & (RendererStyleFlags2.DashCase | RendererStyleFlags2.Important)) {
|
---|
| 216 | el.style.setProperty(style, value, flags & RendererStyleFlags2.Important ? 'important' : '');
|
---|
| 217 | }
|
---|
| 218 | else {
|
---|
| 219 | el.style[style] = value;
|
---|
| 220 | }
|
---|
| 221 | }
|
---|
| 222 | removeStyle(el, style, flags) {
|
---|
| 223 | if (flags & RendererStyleFlags2.DashCase) {
|
---|
| 224 | el.style.removeProperty(style);
|
---|
| 225 | }
|
---|
| 226 | else {
|
---|
| 227 | // IE requires '' instead of null
|
---|
| 228 | // see https://github.com/angular/angular/issues/7916
|
---|
| 229 | el.style[style] = '';
|
---|
| 230 | }
|
---|
| 231 | }
|
---|
| 232 | setProperty(el, name, value) {
|
---|
| 233 | NG_DEV_MODE && checkNoSyntheticProp(name, 'property');
|
---|
| 234 | el[name] = value;
|
---|
| 235 | }
|
---|
| 236 | setValue(node, value) {
|
---|
| 237 | node.nodeValue = value;
|
---|
| 238 | }
|
---|
| 239 | listen(target, event, callback) {
|
---|
| 240 | NG_DEV_MODE && checkNoSyntheticProp(event, 'listener');
|
---|
| 241 | if (typeof target === 'string') {
|
---|
| 242 | return this.eventManager.addGlobalEventListener(target, event, decoratePreventDefault(callback));
|
---|
| 243 | }
|
---|
| 244 | return this.eventManager.addEventListener(target, event, decoratePreventDefault(callback));
|
---|
| 245 | }
|
---|
| 246 | }
|
---|
| 247 | const ɵ0 = () => '@'.charCodeAt(0);
|
---|
| 248 | const AT_CHARCODE = (ɵ0)();
|
---|
| 249 | function checkNoSyntheticProp(name, nameKind) {
|
---|
| 250 | if (name.charCodeAt(0) === AT_CHARCODE) {
|
---|
| 251 | throw new Error(`Unexpected synthetic ${nameKind} ${name} found. Please make sure that:
|
---|
| 252 | - Either \`BrowserAnimationsModule\` or \`NoopAnimationsModule\` are imported in your application.
|
---|
| 253 | - There is corresponding configuration for the animation named \`${name}\` defined in the \`animations\` field of the \`@Component\` decorator (see https://angular.io/api/core/Component#animations).`);
|
---|
| 254 | }
|
---|
| 255 | }
|
---|
| 256 | class EmulatedEncapsulationDomRenderer2 extends DefaultDomRenderer2 {
|
---|
| 257 | constructor(eventManager, sharedStylesHost, component, appId) {
|
---|
| 258 | super(eventManager);
|
---|
| 259 | this.component = component;
|
---|
| 260 | const styles = flattenStyles(appId + '-' + component.id, component.styles, []);
|
---|
| 261 | sharedStylesHost.addStyles(styles);
|
---|
| 262 | this.contentAttr = shimContentAttribute(appId + '-' + component.id);
|
---|
| 263 | this.hostAttr = shimHostAttribute(appId + '-' + component.id);
|
---|
| 264 | }
|
---|
| 265 | applyToHost(element) {
|
---|
| 266 | super.setAttribute(element, this.hostAttr, '');
|
---|
| 267 | }
|
---|
| 268 | createElement(parent, name) {
|
---|
| 269 | const el = super.createElement(parent, name);
|
---|
| 270 | super.setAttribute(el, this.contentAttr, '');
|
---|
| 271 | return el;
|
---|
| 272 | }
|
---|
| 273 | }
|
---|
| 274 | class ShadowDomRenderer extends DefaultDomRenderer2 {
|
---|
| 275 | constructor(eventManager, sharedStylesHost, hostEl, component) {
|
---|
| 276 | super(eventManager);
|
---|
| 277 | this.sharedStylesHost = sharedStylesHost;
|
---|
| 278 | this.hostEl = hostEl;
|
---|
| 279 | this.shadowRoot = hostEl.attachShadow({ mode: 'open' });
|
---|
| 280 | this.sharedStylesHost.addHost(this.shadowRoot);
|
---|
| 281 | const styles = flattenStyles(component.id, component.styles, []);
|
---|
| 282 | for (let i = 0; i < styles.length; i++) {
|
---|
| 283 | const styleEl = document.createElement('style');
|
---|
| 284 | styleEl.textContent = styles[i];
|
---|
| 285 | this.shadowRoot.appendChild(styleEl);
|
---|
| 286 | }
|
---|
| 287 | }
|
---|
| 288 | nodeOrShadowRoot(node) {
|
---|
| 289 | return node === this.hostEl ? this.shadowRoot : node;
|
---|
| 290 | }
|
---|
| 291 | destroy() {
|
---|
| 292 | this.sharedStylesHost.removeHost(this.shadowRoot);
|
---|
| 293 | }
|
---|
| 294 | appendChild(parent, newChild) {
|
---|
| 295 | return super.appendChild(this.nodeOrShadowRoot(parent), newChild);
|
---|
| 296 | }
|
---|
| 297 | insertBefore(parent, newChild, refChild) {
|
---|
| 298 | return super.insertBefore(this.nodeOrShadowRoot(parent), newChild, refChild);
|
---|
| 299 | }
|
---|
| 300 | removeChild(parent, oldChild) {
|
---|
| 301 | return super.removeChild(this.nodeOrShadowRoot(parent), oldChild);
|
---|
| 302 | }
|
---|
| 303 | parentNode(node) {
|
---|
| 304 | return this.nodeOrShadowRoot(super.parentNode(this.nodeOrShadowRoot(node)));
|
---|
| 305 | }
|
---|
| 306 | }
|
---|
| 307 | export { ɵ0 };
|
---|
| 308 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom_renderer.js","sourceRoot":"","sources":["../../../../../../../packages/platform-browser/src/dom/dom_renderer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {APP_ID, Inject, Injectable, Renderer2, RendererFactory2, RendererStyleFlags2, RendererType2, ViewEncapsulation} from '@angular/core';\n\nimport {EventManager} from './events/event_manager';\nimport {DomSharedStylesHost} from './shared_styles_host';\n\nexport const NAMESPACE_URIS: {[ns: string]: string} = {\n  'svg': 'http://www.w3.org/2000/svg',\n  'xhtml': 'http://www.w3.org/1999/xhtml',\n  'xlink': 'http://www.w3.org/1999/xlink',\n  'xml': 'http://www.w3.org/XML/1998/namespace',\n  'xmlns': 'http://www.w3.org/2000/xmlns/',\n};\n\nconst COMPONENT_REGEX = /%COMP%/g;\nconst NG_DEV_MODE = typeof ngDevMode === 'undefined' || !!ngDevMode;\n\nexport const COMPONENT_VARIABLE = '%COMP%';\nexport const HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;\nexport const CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;\n\nexport function shimContentAttribute(componentShortId: string): string {\n  return CONTENT_ATTR.replace(COMPONENT_REGEX, componentShortId);\n}\n\nexport function shimHostAttribute(componentShortId: string): string {\n  return HOST_ATTR.replace(COMPONENT_REGEX, componentShortId);\n}\n\nexport function flattenStyles(\n    compId: string, styles: Array<any|any[]>, target: string[]): string[] {\n  for (let i = 0; i < styles.length; i++) {\n    let style = styles[i];\n\n    if (Array.isArray(style)) {\n      flattenStyles(compId, style, target);\n    } else {\n      style = style.replace(COMPONENT_REGEX, compId);\n      target.push(style);\n    }\n  }\n  return target;\n}\n\nfunction decoratePreventDefault(eventHandler: Function): Function {\n  // `DebugNode.triggerEventHandler` needs to know if the listener was created with\n  // decoratePreventDefault or is a listener added outside the Angular context so it can handle the\n  // two differently. In the first case, the special '__ngUnwrap__' token is passed to the unwrap\n  // the listener (see below).\n  return (event: any) => {\n    // Ivy uses '__ngUnwrap__' as a special token that allows us to unwrap the function\n    // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`. The debug_node\n    // can inspect the listener toString contents for the existence of this special token. Because\n    // the token is a string literal, it is ensured to not be modified by compiled code.\n    if (event === '__ngUnwrap__') {\n      return eventHandler;\n    }\n\n    const allowDefaultBehavior = eventHandler(event);\n    if (allowDefaultBehavior === false) {\n      // TODO(tbosch): move preventDefault into event plugins...\n      event.preventDefault();\n      event.returnValue = false;\n    }\n\n    return undefined;\n  };\n}\n\nlet hasLoggedNativeEncapsulationWarning = false;\n\n@Injectable()\nexport class DomRendererFactory2 implements RendererFactory2 {\n  private rendererByCompId = new Map<string, Renderer2>();\n  private defaultRenderer: Renderer2;\n\n  constructor(\n      private eventManager: EventManager, private sharedStylesHost: DomSharedStylesHost,\n      @Inject(APP_ID) private appId: string) {\n    this.defaultRenderer = new DefaultDomRenderer2(eventManager);\n  }\n\n  createRenderer(element: any, type: RendererType2|null): Renderer2 {\n    if (!element || !type) {\n      return this.defaultRenderer;\n    }\n    switch (type.encapsulation) {\n      case ViewEncapsulation.Emulated: {\n        let renderer = this.rendererByCompId.get(type.id);\n        if (!renderer) {\n          renderer = new EmulatedEncapsulationDomRenderer2(\n              this.eventManager, this.sharedStylesHost, type, this.appId);\n          this.rendererByCompId.set(type.id, renderer);\n        }\n        (<EmulatedEncapsulationDomRenderer2>renderer).applyToHost(element);\n        return renderer;\n      }\n      // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an enum\n      // value that is not known (but previously was the value for ViewEncapsulation.Native)\n      case 1:\n      case ViewEncapsulation.ShadowDom:\n        // TODO(FW-2290): remove the `case 1:` fallback logic and the warning in v12.\n        if ((typeof ngDevMode === 'undefined' || ngDevMode) &&\n            // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an\n            // enum value that is not known (but previously was the value for\n            // ViewEncapsulation.Native)\n            !hasLoggedNativeEncapsulationWarning && type.encapsulation === 1) {\n          hasLoggedNativeEncapsulationWarning = true;\n          console.warn(\n              'ViewEncapsulation.Native is no longer supported. Falling back to ViewEncapsulation.ShadowDom. The fallback will be removed in v12.');\n        }\n\n        return new ShadowDomRenderer(this.eventManager, this.sharedStylesHost, element, type);\n      default: {\n        if (!this.rendererByCompId.has(type.id)) {\n          const styles = flattenStyles(type.id, type.styles, []);\n          this.sharedStylesHost.addStyles(styles);\n          this.rendererByCompId.set(type.id, this.defaultRenderer);\n        }\n        return this.defaultRenderer;\n      }\n    }\n  }\n\n  begin() {}\n  end() {}\n}\n\nclass DefaultDomRenderer2 implements Renderer2 {\n  data: {[key: string]: any} = Object.create(null);\n\n  constructor(private eventManager: EventManager) {}\n\n  destroy(): void {}\n\n  destroyNode: null;\n\n  createElement(name: string, namespace?: string): any {\n    if (namespace) {\n      // In cases where Ivy (not ViewEngine) is giving us the actual namespace, the look up by key\n      // will result in undefined, so we just return the namespace here.\n      return document.createElementNS(NAMESPACE_URIS[namespace] || namespace, name);\n    }\n\n    return document.createElement(name);\n  }\n\n  createComment(value: string): any {\n    return document.createComment(value);\n  }\n\n  createText(value: string): any {\n    return document.createTextNode(value);\n  }\n\n  appendChild(parent: any, newChild: any): void {\n    parent.appendChild(newChild);\n  }\n\n  insertBefore(parent: any, newChild: any, refChild: any): void {\n    if (parent) {\n      parent.insertBefore(newChild, refChild);\n    }\n  }\n\n  removeChild(parent: any, oldChild: any): void {\n    if (parent) {\n      parent.removeChild(oldChild);\n    }\n  }\n\n  selectRootElement(selectorOrNode: string|any, preserveContent?: boolean): any {\n    let el: any = typeof selectorOrNode === 'string' ? document.querySelector(selectorOrNode) :\n                                                       selectorOrNode;\n    if (!el) {\n      throw new Error(`The selector \"${selectorOrNode}\" did not match any elements`);\n    }\n    if (!preserveContent) {\n      el.textContent = '';\n    }\n    return el;\n  }\n\n  parentNode(node: any): any {\n    return node.parentNode;\n  }\n\n  nextSibling(node: any): any {\n    return node.nextSibling;\n  }\n\n  setAttribute(el: any, name: string, value: string, namespace?: string): void {\n    if (namespace) {\n      name = namespace + ':' + name;\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.setAttributeNS(namespaceUri, name, value);\n      } else {\n        el.setAttribute(name, value);\n      }\n    } else {\n      el.setAttribute(name, value);\n    }\n  }\n\n  removeAttribute(el: any, name: string, namespace?: string): void {\n    if (namespace) {\n      // TODO(FW-811): Ivy may cause issues here because it's passing around\n      // full URIs for namespaces, therefore this lookup will fail.\n      const namespaceUri = NAMESPACE_URIS[namespace];\n      if (namespaceUri) {\n        el.removeAttributeNS(namespaceUri, name);\n      } else {\n        // TODO(FW-811): Since ivy is passing around full URIs for namespaces\n        // this could result in properties like `http://www.w3.org/2000/svg:cx=\"123\"`,\n        // which is wrong.\n        el.removeAttribute(`${namespace}:${name}`);\n      }\n    } else {\n      el.removeAttribute(name);\n    }\n  }\n\n  addClass(el: any, name: string): void {\n    el.classList.add(name);\n  }\n\n  removeClass(el: any, name: string): void {\n    el.classList.remove(name);\n  }\n\n  setStyle(el: any, style: string, value: any, flags: RendererStyleFlags2): void {\n    if (flags & (RendererStyleFlags2.DashCase | RendererStyleFlags2.Important)) {\n      el.style.setProperty(style, value, flags & RendererStyleFlags2.Important ? 'important' : '');\n    } else {\n      el.style[style] = value;\n    }\n  }\n\n  removeStyle(el: any, style: string, flags: RendererStyleFlags2): void {\n    if (flags & RendererStyleFlags2.DashCase) {\n      el.style.removeProperty(style);\n    } else {\n      // IE requires '' instead of null\n      // see https://github.com/angular/angular/issues/7916\n      el.style[style] = '';\n    }\n  }\n\n  setProperty(el: any, name: string, value: any): void {\n    NG_DEV_MODE && checkNoSyntheticProp(name, 'property');\n    el[name] = value;\n  }\n\n  setValue(node: any, value: string): void {\n    node.nodeValue = value;\n  }\n\n  listen(target: 'window'|'document'|'body'|any, event: string, callback: (event: any) => boolean):\n      () => void {\n    NG_DEV_MODE && checkNoSyntheticProp(event, 'listener');\n    if (typeof target === 'string') {\n      return <() => void>this.eventManager.addGlobalEventListener(\n          target, event, decoratePreventDefault(callback));\n    }\n    return <() => void>this.eventManager.addEventListener(\n               target, event, decoratePreventDefault(callback)) as () => void;\n  }\n}\n\nconst AT_CHARCODE = (() => '@'.charCodeAt(0))();\nfunction checkNoSyntheticProp(name: string, nameKind: string) {\n  if (name.charCodeAt(0) === AT_CHARCODE) {\n    throw new Error(`Unexpected synthetic ${nameKind} ${name} found. Please make sure that:\n  - Either \\`BrowserAnimationsModule\\` or \\`NoopAnimationsModule\\` are imported in your application.\n  - There is corresponding configuration for the animation named \\`${\n        name}\\` defined in the \\`animations\\` field of the \\`@Component\\` decorator (see https://angular.io/api/core/Component#animations).`);\n  }\n}\n\nclass EmulatedEncapsulationDomRenderer2 extends DefaultDomRenderer2 {\n  private contentAttr: string;\n  private hostAttr: string;\n\n  constructor(\n      eventManager: EventManager, sharedStylesHost: DomSharedStylesHost,\n      private component: RendererType2, appId: string) {\n    super(eventManager);\n    const styles = flattenStyles(appId + '-' + component.id, component.styles, []);\n    sharedStylesHost.addStyles(styles);\n\n    this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n    this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n  }\n\n  applyToHost(element: any) {\n    super.setAttribute(element, this.hostAttr, '');\n  }\n\n  override createElement(parent: any, name: string): Element {\n    const el = super.createElement(parent, name);\n    super.setAttribute(el, this.contentAttr, '');\n    return el;\n  }\n}\n\nclass ShadowDomRenderer extends DefaultDomRenderer2 {\n  private shadowRoot: any;\n\n  constructor(\n      eventManager: EventManager, private sharedStylesHost: DomSharedStylesHost,\n      private hostEl: any, component: RendererType2) {\n    super(eventManager);\n    this.shadowRoot = (hostEl as any).attachShadow({mode: 'open'});\n    this.sharedStylesHost.addHost(this.shadowRoot);\n    const styles = flattenStyles(component.id, component.styles, []);\n    for (let i = 0; i < styles.length; i++) {\n      const styleEl = document.createElement('style');\n      styleEl.textContent = styles[i];\n      this.shadowRoot.appendChild(styleEl);\n    }\n  }\n\n  private nodeOrShadowRoot(node: any): any {\n    return node === this.hostEl ? this.shadowRoot : node;\n  }\n\n  override destroy() {\n    this.sharedStylesHost.removeHost(this.shadowRoot);\n  }\n\n  override appendChild(parent: any, newChild: any): void {\n    return super.appendChild(this.nodeOrShadowRoot(parent), newChild);\n  }\n  override insertBefore(parent: any, newChild: any, refChild: any): void {\n    return super.insertBefore(this.nodeOrShadowRoot(parent), newChild, refChild);\n  }\n  override removeChild(parent: any, oldChild: any): void {\n    return super.removeChild(this.nodeOrShadowRoot(parent), oldChild);\n  }\n  override parentNode(node: any): any {\n    return this.nodeOrShadowRoot(super.parentNode(this.nodeOrShadowRoot(node)));\n  }\n}\n"]} |
---|