UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

308 lines 47.2 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; import { Inject, Injectable } from 'angular2/src/core/di'; import { AnimationBuilder } from 'angular2/src/animate/animation_builder'; import { isPresent, isBlank, Json, RegExpWrapper, CONST_EXPR, stringify, StringWrapper, isArray } from 'angular2/src/facade/lang'; import { BaseException } from 'angular2/src/facade/exceptions'; import { DomSharedStylesHost } from './shared_styles_host'; import { EventManager } from './events/event_manager'; import { DOCUMENT } from './dom_tokens'; import { ViewEncapsulation } from 'angular2/src/core/metadata'; import { DOM } from 'angular2/src/platform/dom/dom_adapter'; import { camelCaseToDashCase } from './util'; const NAMESPACE_URIS = CONST_EXPR({ 'xlink': 'http://www.w3.org/1999/xlink', 'svg': 'http://www.w3.org/2000/svg' }); const TEMPLATE_COMMENT_TEXT = 'template bindings={}'; var TEMPLATE_BINDINGS_EXP = /^template bindings=(.*)$/g; export class DomRootRenderer { constructor(document, eventManager, sharedStylesHost, animate) { this.document = document; this.eventManager = eventManager; this.sharedStylesHost = sharedStylesHost; this.animate = animate; this._registeredComponents = new Map(); } renderComponent(componentProto) { var renderer = this._registeredComponents.get(componentProto.id); if (isBlank(renderer)) { renderer = new DomRenderer(this, componentProto); this._registeredComponents.set(componentProto.id, renderer); } return renderer; } } export let DomRootRenderer_ = class extends DomRootRenderer { constructor(_document, _eventManager, sharedStylesHost, animate) { super(_document, _eventManager, sharedStylesHost, animate); } }; DomRootRenderer_ = __decorate([ Injectable(), __param(0, Inject(DOCUMENT)), __metadata('design:paramtypes', [Object, EventManager, DomSharedStylesHost, AnimationBuilder]) ], DomRootRenderer_); export class DomRenderer { constructor(_rootRenderer, componentProto) { this._rootRenderer = _rootRenderer; this.componentProto = componentProto; this._styles = _flattenStyles(componentProto.id, componentProto.styles, []); if (componentProto.encapsulation !== ViewEncapsulation.Native) { this._rootRenderer.sharedStylesHost.addStyles(this._styles); } if (this.componentProto.encapsulation === ViewEncapsulation.Emulated) { this._contentAttr = _shimContentAttribute(componentProto.id); this._hostAttr = _shimHostAttribute(componentProto.id); } else { this._contentAttr = null; this._hostAttr = null; } } renderComponent(componentProto) { return this._rootRenderer.renderComponent(componentProto); } selectRootElement(selector) { var el = DOM.querySelector(this._rootRenderer.document, selector); if (isBlank(el)) { throw new BaseException(`The selector "${selector}" did not match any elements`); } DOM.clearNodes(el); return el; } createElement(parent, name) { var nsAndName = splitNamespace(name); var el = isPresent(nsAndName[0]) ? DOM.createElementNS(NAMESPACE_URIS[nsAndName[0]], nsAndName[1]) : DOM.createElement(nsAndName[1]); if (isPresent(this._contentAttr)) { DOM.setAttribute(el, this._contentAttr, ''); } if (isPresent(parent)) { DOM.appendChild(parent, el); } return el; } createViewRoot(hostElement) { var nodesParent; if (this.componentProto.encapsulation === ViewEncapsulation.Native) { nodesParent = DOM.createShadowRoot(hostElement); this._rootRenderer.sharedStylesHost.addHost(nodesParent); for (var i = 0; i < this._styles.length; i++) { DOM.appendChild(nodesParent, DOM.createStyleElement(this._styles[i])); } } else { if (isPresent(this._hostAttr)) { DOM.setAttribute(hostElement, this._hostAttr, ''); } nodesParent = hostElement; } return nodesParent; } createTemplateAnchor(parentElement) { var comment = DOM.createComment(TEMPLATE_COMMENT_TEXT); if (isPresent(parentElement)) { DOM.appendChild(parentElement, comment); } return comment; } createText(parentElement, value) { var node = DOM.createTextNode(value); if (isPresent(parentElement)) { DOM.appendChild(parentElement, node); } return node; } projectNodes(parentElement, nodes) { if (isBlank(parentElement)) return; appendNodes(parentElement, nodes); } attachViewAfter(node, viewRootNodes) { moveNodesAfterSibling(node, viewRootNodes); for (let i = 0; i < viewRootNodes.length; i++) this.animateNodeEnter(viewRootNodes[i]); } detachView(viewRootNodes) { for (var i = 0; i < viewRootNodes.length; i++) { var node = viewRootNodes[i]; DOM.remove(node); this.animateNodeLeave(node); } } destroyView(hostElement, viewAllNodes) { if (this.componentProto.encapsulation === ViewEncapsulation.Native && isPresent(hostElement)) { this._rootRenderer.sharedStylesHost.removeHost(DOM.getShadowRoot(hostElement)); } } listen(renderElement, name, callback) { return this._rootRenderer.eventManager.addEventListener(renderElement, name, decoratePreventDefault(callback)); } listenGlobal(target, name, callback) { return this._rootRenderer.eventManager.addGlobalEventListener(target, name, decoratePreventDefault(callback)); } setElementProperty(renderElement, propertyName, propertyValue) { DOM.setProperty(renderElement, propertyName, propertyValue); } setElementAttribute(renderElement, attributeName, attributeValue) { var attrNs; var nsAndName = splitNamespace(attributeName); if (isPresent(nsAndName[0])) { attributeName = nsAndName[0] + ':' + nsAndName[1]; attrNs = NAMESPACE_URIS[nsAndName[0]]; } if (isPresent(attributeValue)) { if (isPresent(attrNs)) { DOM.setAttributeNS(renderElement, attrNs, attributeName, attributeValue); } else { DOM.setAttribute(renderElement, attributeName, attributeValue); } } else { if (isPresent(attrNs)) { DOM.removeAttributeNS(renderElement, attrNs, nsAndName[1]); } else { DOM.removeAttribute(renderElement, attributeName); } } } setBindingDebugInfo(renderElement, propertyName, propertyValue) { var dashCasedPropertyName = camelCaseToDashCase(propertyName); if (DOM.isCommentNode(renderElement)) { var existingBindings = RegExpWrapper.firstMatch(TEMPLATE_BINDINGS_EXP, StringWrapper.replaceAll(DOM.getText(renderElement), /\n/g, '')); var parsedBindings = Json.parse(existingBindings[1]); parsedBindings[dashCasedPropertyName] = propertyValue; DOM.setText(renderElement, StringWrapper.replace(TEMPLATE_COMMENT_TEXT, '{}', Json.stringify(parsedBindings))); } else { this.setElementAttribute(renderElement, propertyName, propertyValue); } } setElementDebugInfo(renderElement, info) { } setElementClass(renderElement, className, isAdd) { if (isAdd) { DOM.addClass(renderElement, className); } else { DOM.removeClass(renderElement, className); } } setElementStyle(renderElement, styleName, styleValue) { if (isPresent(styleValue)) { DOM.setStyle(renderElement, styleName, stringify(styleValue)); } else { DOM.removeStyle(renderElement, styleName); } } invokeElementMethod(renderElement, methodName, args) { DOM.invoke(renderElement, methodName, args); } setText(renderNode, text) { DOM.setText(renderNode, text); } /** * Performs animations if necessary * @param node */ animateNodeEnter(node) { if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) { DOM.addClass(node, 'ng-enter'); this._rootRenderer.animate.css() .addAnimationClass('ng-enter-active') .start(node) .onComplete(() => { DOM.removeClass(node, 'ng-enter'); }); } } /** * If animations are necessary, performs animations then removes the element; otherwise, it just * removes the element. * @param node */ animateNodeLeave(node) { if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) { DOM.addClass(node, 'ng-leave'); this._rootRenderer.animate.css() .addAnimationClass('ng-leave-active') .start(node) .onComplete(() => { DOM.removeClass(node, 'ng-leave'); DOM.remove(node); }); } else { DOM.remove(node); } } } function moveNodesAfterSibling(sibling, nodes) { var parent = DOM.parentElement(sibling); if (nodes.length > 0 && isPresent(parent)) { var nextSibling = DOM.nextSibling(sibling); if (isPresent(nextSibling)) { for (var i = 0; i < nodes.length; i++) { DOM.insertBefore(nextSibling, nodes[i]); } } else { for (var i = 0; i < nodes.length; i++) { DOM.appendChild(parent, nodes[i]); } } } } function appendNodes(parent, nodes) { for (var i = 0; i < nodes.length; i++) { DOM.appendChild(parent, nodes[i]); } } function decoratePreventDefault(eventHandler) { return (event) => { var allowDefaultBehavior = eventHandler(event); if (allowDefaultBehavior === false) { // TODO(tbosch): move preventDefault into event plugins... DOM.preventDefault(event); } }; } var COMPONENT_REGEX = /%COMP%/g; export const COMPONENT_VARIABLE = '%COMP%'; export const HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`; export const CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`; function _shimContentAttribute(componentShortId) { return StringWrapper.replaceAll(CONTENT_ATTR, COMPONENT_REGEX, componentShortId); } function _shimHostAttribute(componentShortId) { return StringWrapper.replaceAll(HOST_ATTR, COMPONENT_REGEX, componentShortId); } function _flattenStyles(compId, styles, target) { for (var i = 0; i < styles.length; i++) { var style = styles[i]; if (isArray(style)) { _flattenStyles(compId, style, target); } else { style = StringWrapper.replaceAll(style, COMPONENT_REGEX, compId); target.push(style); } } return target; } var NS_PREFIX_RE = /^@([^:]+):(.+)/g; function splitNamespace(name) { if (name[0] != '@') { return [null, name]; } let match = RegExpWrapper.firstMatch(NS_PREFIX_RE, name); return [match[1], match[2]]; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom_renderer.js","sourceRoot":"","sources":["angular2/src/platform/dom/dom_renderer.ts"],"names":["DomRootRenderer","DomRootRenderer.constructor","DomRootRenderer.renderComponent","DomRootRenderer_","DomRootRenderer_.constructor","DomRenderer","DomRenderer.constructor","DomRenderer.renderComponent","DomRenderer.selectRootElement","DomRenderer.createElement","DomRenderer.createViewRoot","DomRenderer.createTemplateAnchor","DomRenderer.createText","DomRenderer.projectNodes","DomRenderer.attachViewAfter","DomRenderer.detachView","DomRenderer.destroyView","DomRenderer.listen","DomRenderer.listenGlobal","DomRenderer.setElementProperty","DomRenderer.setElementAttribute","DomRenderer.setBindingDebugInfo","DomRenderer.setElementDebugInfo","DomRenderer.setElementClass","DomRenderer.setElementStyle","DomRenderer.invokeElementMethod","DomRenderer.setText","DomRenderer.animateNodeEnter","DomRenderer.animateNodeLeave","moveNodesAfterSibling","appendNodes","decoratePreventDefault","_shimContentAttribute","_shimHostAttribute","_flattenStyles","splitNamespace"],"mappings":"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iBA,CAACA,QAAgBA;QAChCG,IAAIA,EAAEA,GAAGA,GAAGA,CAACA,aAAaA,CAACA,IAAIA,CAACA,aAAaA,CAACA,QAAQA,EAAEA,QAAQA,CAACA,CAACA;QAClEA,EAAEA,CAACA,CAACA,OAAOA,CAACA,EAAEA,CAACA,CAACA,CAACA,CAACA;YAChBA,MAAMA,IAAIA,aAAaA,CAACA,iBAAiBA,QAAQA,8BAA8BA,CAACA,CAACA;QACnFA,CAACA;QACDA,GAAGA,CAACA,UAAUA,CAACA,EAAEA,CAACA,CAACA;QACnBA,MAAMA,CAACA,EAAEA,CAACA;IACZA,CAACA;IAEDH,aAAaA,CAACA,MAAeA,EAAEA,IAAYA;QACzCI,IAAIA,SAASA,GAAGA,cAAcA,CAACA,IAAIA,CAACA,CAACA;QACrCA,IAAIA,EAAEA,GAAGA,SAASA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;YACnBA,GAAGA,CAACA,eAAeA,CAACA,cAAcA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA,EAAEA,SAASA,CAACA,CAACA,CAACA,CAACA;YAC/DA,GAAGA,CAACA,aAAaA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA,CAACA;QAC7CA,EAAEA,CAACA,CAACA,SAASA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA,CAACA;YACjCA,GAAGA,CAACA,YAAYA,CAACA,EAAEA,EAAEA,IAAIA,CAACA,YAAYA,EAAEA,EAAEA,CAACA,CAACA;QAC9CA,CAACA;QACDA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA;YACtBA,GAAGA,CAACA,WAAWA,CAACA,MAAMA,EAAEA,EAAEA,CAACA,CAACA;QAC9BA,CAACA;QACDA,MAAMA,CAACA,EAAEA,CAACA;IACZA,CAACA;IAEDJ,cAAcA,CAACA,WAAgBA;QAC7BK,IAAIA,WAAWA,CAACA;QAChBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,aAAaA,KAAKA,iBAAiBA,CAACA,MAAMA,CAACA,CAACA,CAACA;YA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","sourcesContent":["import {Inject, Injectable, OpaqueToken} from 'angular2/src/core/di';\nimport {AnimationBuilder} from 'angular2/src/animate/animation_builder';\nimport {\n  isPresent,\n  isBlank,\n  Json,\n  RegExpWrapper,\n  CONST_EXPR,\n  stringify,\n  StringWrapper,\n  isArray\n} from 'angular2/src/facade/lang';\n\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {DomSharedStylesHost} from './shared_styles_host';\n\nimport {\n  Renderer,\n  RootRenderer,\n  RenderComponentType,\n  RenderDebugInfo\n} from 'angular2/src/core/render/api';\n\nimport {EventManager} from './events/event_manager';\n\nimport {DOCUMENT} from './dom_tokens';\nimport {ViewEncapsulation} from 'angular2/src/core/metadata';\nimport {DOM} from 'angular2/src/platform/dom/dom_adapter';\nimport {camelCaseToDashCase} from './util';\n\nconst NAMESPACE_URIS =\n    CONST_EXPR({'xlink': 'http://www.w3.org/1999/xlink', 'svg': 'http://www.w3.org/2000/svg'});\nconst TEMPLATE_COMMENT_TEXT = 'template bindings={}';\nvar TEMPLATE_BINDINGS_EXP = /^template bindings=(.*)$/g;\n\nexport abstract class DomRootRenderer implements RootRenderer {\n  private _registeredComponents: Map<string, DomRenderer> = new Map<string, DomRenderer>();\n\n  constructor(public document: any, public eventManager: EventManager,\n              public sharedStylesHost: DomSharedStylesHost, public animate: AnimationBuilder) {}\n\n  renderComponent(componentProto: RenderComponentType): Renderer {\n    var renderer = this._registeredComponents.get(componentProto.id);\n    if (isBlank(renderer)) {\n      renderer = new DomRenderer(this, componentProto);\n      this._registeredComponents.set(componentProto.id, renderer);\n    }\n    return renderer;\n  }\n}\n\n@Injectable()\nexport class DomRootRenderer_ extends DomRootRenderer {\n  constructor(@Inject(DOCUMENT) _document: any, _eventManager: EventManager,\n              sharedStylesHost: DomSharedStylesHost, animate: AnimationBuilder) {\n    super(_document, _eventManager, sharedStylesHost, animate);\n  }\n}\n\nexport class DomRenderer implements Renderer {\n  private _contentAttr: string;\n  private _hostAttr: string;\n  private _styles: string[];\n\n  constructor(private _rootRenderer: DomRootRenderer, private componentProto: RenderComponentType) {\n    this._styles = _flattenStyles(componentProto.id, componentProto.styles, []);\n    if (componentProto.encapsulation !== ViewEncapsulation.Native) {\n      this._rootRenderer.sharedStylesHost.addStyles(this._styles);\n    }\n    if (this.componentProto.encapsulation === ViewEncapsulation.Emulated) {\n      this._contentAttr = _shimContentAttribute(componentProto.id);\n      this._hostAttr = _shimHostAttribute(componentProto.id);\n    } else {\n      this._contentAttr = null;\n      this._hostAttr = null;\n    }\n  }\n\n  renderComponent(componentProto: RenderComponentType): Renderer {\n    return this._rootRenderer.renderComponent(componentProto);\n  }\n\n  selectRootElement(selector: string): Element {\n    var el = DOM.querySelector(this._rootRenderer.document, selector);\n    if (isBlank(el)) {\n      throw new BaseException(`The selector \"${selector}\" did not match any elements`);\n    }\n    DOM.clearNodes(el);\n    return el;\n  }\n\n  createElement(parent: Element, name: string): Node {\n    var nsAndName = splitNamespace(name);\n    var el = isPresent(nsAndName[0]) ?\n                 DOM.createElementNS(NAMESPACE_URIS[nsAndName[0]], nsAndName[1]) :\n                 DOM.createElement(nsAndName[1]);\n    if (isPresent(this._contentAttr)) {\n      DOM.setAttribute(el, this._contentAttr, '');\n    }\n    if (isPresent(parent)) {\n      DOM.appendChild(parent, el);\n    }\n    return el;\n  }\n\n  createViewRoot(hostElement: any): any {\n    var nodesParent;\n    if (this.componentProto.encapsulation === ViewEncapsulation.Native) {\n      nodesParent = DOM.createShadowRoot(hostElement);\n      this._rootRenderer.sharedStylesHost.addHost(nodesParent);\n      for (var i = 0; i < this._styles.length; i++) {\n        DOM.appendChild(nodesParent, DOM.createStyleElement(this._styles[i]));\n      }\n    } else {\n      if (isPresent(this._hostAttr)) {\n        DOM.setAttribute(hostElement, this._hostAttr, '');\n      }\n      nodesParent = hostElement;\n    }\n    return nodesParent;\n  }\n\n  createTemplateAnchor(parentElement: any): any {\n    var comment = DOM.createComment(TEMPLATE_COMMENT_TEXT);\n    if (isPresent(parentElement)) {\n      DOM.appendChild(parentElement, comment);\n    }\n    return comment;\n  }\n\n  createText(parentElement: any, value: string): any {\n    var node = DOM.createTextNode(value);\n    if (isPresent(parentElement)) {\n      DOM.appendChild(parentElement, node);\n    }\n    return node;\n  }\n\n  projectNodes(parentElement: any, nodes: any[]) {\n    if (isBlank(parentElement)) return;\n    appendNodes(parentElement, nodes);\n  }\n\n  attachViewAfter(node: any, viewRootNodes: any[]) {\n    moveNodesAfterSibling(node, viewRootNodes);\n    for (let i = 0; i < viewRootNodes.length; i++) this.animateNodeEnter(viewRootNodes[i]);\n  }\n\n  detachView(viewRootNodes: any[]) {\n    for (var i = 0; i < viewRootNodes.length; i++) {\n      var node = viewRootNodes[i];\n      DOM.remove(node);\n      this.animateNodeLeave(node);\n    }\n  }\n\n  destroyView(hostElement: any, viewAllNodes: any[]) {\n    if (this.componentProto.encapsulation === ViewEncapsulation.Native && isPresent(hostElement)) {\n      this._rootRenderer.sharedStylesHost.removeHost(DOM.getShadowRoot(hostElement));\n    }\n  }\n\n  listen(renderElement: any, name: string, callback: Function): Function {\n    return this._rootRenderer.eventManager.addEventListener(renderElement, name,\n                                                            decoratePreventDefault(callback));\n  }\n\n  listenGlobal(target: string, name: string, callback: Function): Function {\n    return this._rootRenderer.eventManager.addGlobalEventListener(target, name,\n                                                                  decoratePreventDefault(callback));\n  }\n\n  setElementProperty(renderElement: any, propertyName: string, propertyValue: any): void {\n    DOM.setProperty(renderElement, propertyName, propertyValue);\n  }\n\n  setElementAttribute(renderElement: any, attributeName: string, attributeValue: string): void {\n    var attrNs;\n    var nsAndName = splitNamespace(attributeName);\n    if (isPresent(nsAndName[0])) {\n      attributeName = nsAndName[0] + ':' + nsAndName[1];\n      attrNs = NAMESPACE_URIS[nsAndName[0]];\n    }\n    if (isPresent(attributeValue)) {\n      if (isPresent(attrNs)) {\n        DOM.setAttributeNS(renderElement, attrNs, attributeName, attributeValue);\n      } else {\n        DOM.setAttribute(renderElement, attributeName, attributeValue);\n      }\n    } else {\n      if (isPresent(attrNs)) {\n        DOM.removeAttributeNS(renderElement, attrNs, nsAndName[1]);\n      } else {\n        DOM.removeAttribute(renderElement, attributeName);\n      }\n    }\n  }\n\n  setBindingDebugInfo(renderElement: any, propertyName: string, propertyValue: string): void {\n    var dashCasedPropertyName = camelCaseToDashCase(propertyName);\n    if (DOM.isCommentNode(renderElement)) {\n      var existingBindings = RegExpWrapper.firstMatch(\n          TEMPLATE_BINDINGS_EXP, StringWrapper.replaceAll(DOM.getText(renderElement), /\\n/g, ''));\n      var parsedBindings = Json.parse(existingBindings[1]);\n      parsedBindings[dashCasedPropertyName] = propertyValue;\n      DOM.setText(renderElement, StringWrapper.replace(TEMPLATE_COMMENT_TEXT, '{}',\n                                                       Json.stringify(parsedBindings)));\n    } else {\n      this.setElementAttribute(renderElement, propertyName, propertyValue);\n    }\n  }\n\n  setElementDebugInfo(renderElement: any, info: RenderDebugInfo) {}\n\n  setElementClass(renderElement: any, className: string, isAdd: boolean): void {\n    if (isAdd) {\n      DOM.addClass(renderElement, className);\n    } else {\n      DOM.removeClass(renderElement, className);\n    }\n  }\n\n  setElementStyle(renderElement: any, styleName: string, styleValue: string): void {\n    if (isPresent(styleValue)) {\n      DOM.setStyle(renderElement, styleName, stringify(styleValue));\n    } else {\n      DOM.removeStyle(renderElement, styleName);\n    }\n  }\n\n  invokeElementMethod(renderElement: any, methodName: string, args: any[]): void {\n    DOM.invoke(renderElement, methodName, args);\n  }\n\n  setText(renderNode: any, text: string): void { DOM.setText(renderNode, text); }\n\n  /**\n   * Performs animations if necessary\n   * @param node\n   */\n  animateNodeEnter(node: Node) {\n    if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {\n      DOM.addClass(node, 'ng-enter');\n      this._rootRenderer.animate.css()\n          .addAnimationClass('ng-enter-active')\n          .start(<HTMLElement>node)\n          .onComplete(() => { DOM.removeClass(node, 'ng-enter'); });\n    }\n  }\n\n\n  /**\n   * If animations are necessary, performs animations then removes the element; otherwise, it just\n   * removes the element.\n   * @param node\n   */\n  animateNodeLeave(node: Node) {\n    if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {\n      DOM.addClass(node, 'ng-leave');\n      this._rootRenderer.animate.css()\n          .addAnimationClass('ng-leave-active')\n          .start(<HTMLElement>node)\n          .onComplete(() => {\n            DOM.removeClass(node, 'ng-leave');\n            DOM.remove(node);\n          });\n    } else {\n      DOM.remove(node);\n    }\n  }\n}\n\nfunction moveNodesAfterSibling(sibling, nodes) {\n  var parent = DOM.parentElement(sibling);\n  if (nodes.length > 0 && isPresent(parent)) {\n    var nextSibling = DOM.nextSibling(sibling);\n    if (isPresent(nextSibling)) {\n      for (var i = 0; i < nodes.length; i++) {\n        DOM.insertBefore(nextSibling, nodes[i]);\n      }\n    } else {\n      for (var i = 0; i < nodes.length; i++) {\n        DOM.appendChild(parent, nodes[i]);\n      }\n    }\n  }\n}\n\nfunction appendNodes(parent, nodes) {\n  for (var i = 0; i < nodes.length; i++) {\n    DOM.appendChild(parent, nodes[i]);\n  }\n}\n\nfunction decoratePreventDefault(eventHandler: Function): Function {\n  return (event) => {\n    var allowDefaultBehavior = eventHandler(event);\n    if (allowDefaultBehavior === false) {\n      // TODO(tbosch): move preventDefault into event plugins...\n      DOM.preventDefault(event);\n    }\n  };\n}\n\nvar COMPONENT_REGEX = /%COMP%/g;\nexport const COMPONENT_VARIABLE = '%COMP%';\nexport const HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;\nexport const CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;\n\nfunction _shimContentAttribute(componentShortId: string): string {\n  return StringWrapper.replaceAll(CONTENT_ATTR, COMPONENT_REGEX, componentShortId);\n}\n\nfunction _shimHostAttribute(componentShortId: string): string {\n  return StringWrapper.replaceAll(HOST_ATTR, COMPONENT_REGEX, componentShortId);\n}\n\nfunction _flattenStyles(compId: string, styles: Array<any | any[]>, target: string[]): string[] {\n  for (var i = 0; i < styles.length; i++) {\n    var style = styles[i];\n    if (isArray(style)) {\n      _flattenStyles(compId, style, target);\n    } else {\n      style = StringWrapper.replaceAll(style, COMPONENT_REGEX, compId);\n      target.push(style);\n    }\n  }\n  return target;\n}\n\nvar NS_PREFIX_RE = /^@([^:]+):(.+)/g;\n\nfunction splitNamespace(name: string): string[] {\n  if (name[0] != '@') {\n    return [null, name];\n  }\n  let match = RegExpWrapper.firstMatch(NS_PREFIX_RE, name);\n  return [match[1], match[2]];\n}\n"]}