angular2
Version:
Angular 2 - a web framework for modern web apps
323 lines • 46 kB
JavaScript
"use strict";
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
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); }
};
var di_1 = require('angular2/src/core/di');
var animation_builder_1 = require('angular2/src/animate/animation_builder');
var lang_1 = require('angular2/src/facade/lang');
var exceptions_1 = require('angular2/src/facade/exceptions');
var shared_styles_host_1 = require('./shared_styles_host');
var event_manager_1 = require('./events/event_manager');
var dom_tokens_1 = require('./dom_tokens');
var metadata_1 = require('angular2/src/core/metadata');
var dom_adapter_1 = require('angular2/src/platform/dom/dom_adapter');
var util_1 = require('./util');
var NAMESPACE_URIS = lang_1.CONST_EXPR({ 'xlink': 'http://www.w3.org/1999/xlink', 'svg': 'http://www.w3.org/2000/svg' });
var TEMPLATE_COMMENT_TEXT = 'template bindings={}';
var TEMPLATE_BINDINGS_EXP = /^template bindings=(.*)$/g;
var DomRootRenderer = (function () {
function DomRootRenderer(document, eventManager, sharedStylesHost, animate) {
this.document = document;
this.eventManager = eventManager;
this.sharedStylesHost = sharedStylesHost;
this.animate = animate;
this._registeredComponents = new Map();
}
DomRootRenderer.prototype.renderComponent = function (componentProto) {
var renderer = this._registeredComponents.get(componentProto.id);
if (lang_1.isBlank(renderer)) {
renderer = new DomRenderer(this, componentProto);
this._registeredComponents.set(componentProto.id, renderer);
}
return renderer;
};
return DomRootRenderer;
}());
exports.DomRootRenderer = DomRootRenderer;
var DomRootRenderer_ = (function (_super) {
__extends(DomRootRenderer_, _super);
function DomRootRenderer_(_document, _eventManager, sharedStylesHost, animate) {
_super.call(this, _document, _eventManager, sharedStylesHost, animate);
}
DomRootRenderer_ = __decorate([
di_1.Injectable(),
__param(0, di_1.Inject(dom_tokens_1.DOCUMENT)),
__metadata('design:paramtypes', [Object, event_manager_1.EventManager, shared_styles_host_1.DomSharedStylesHost, animation_builder_1.AnimationBuilder])
], DomRootRenderer_);
return DomRootRenderer_;
}(DomRootRenderer));
exports.DomRootRenderer_ = DomRootRenderer_;
var DomRenderer = (function () {
function DomRenderer(_rootRenderer, componentProto) {
this._rootRenderer = _rootRenderer;
this.componentProto = componentProto;
this._styles = _flattenStyles(componentProto.id, componentProto.styles, []);
if (componentProto.encapsulation !== metadata_1.ViewEncapsulation.Native) {
this._rootRenderer.sharedStylesHost.addStyles(this._styles);
}
if (this.componentProto.encapsulation === metadata_1.ViewEncapsulation.Emulated) {
this._contentAttr = _shimContentAttribute(componentProto.id);
this._hostAttr = _shimHostAttribute(componentProto.id);
}
else {
this._contentAttr = null;
this._hostAttr = null;
}
}
DomRenderer.prototype.selectRootElement = function (selectorOrNode, debugInfo) {
var el;
if (lang_1.isString(selectorOrNode)) {
el = dom_adapter_1.DOM.querySelector(this._rootRenderer.document, selectorOrNode);
if (lang_1.isBlank(el)) {
throw new exceptions_1.BaseException("The selector \"" + selectorOrNode + "\" did not match any elements");
}
}
else {
el = selectorOrNode;
}
dom_adapter_1.DOM.clearNodes(el);
return el;
};
DomRenderer.prototype.createElement = function (parent, name, debugInfo) {
var nsAndName = splitNamespace(name);
var el = lang_1.isPresent(nsAndName[0]) ?
dom_adapter_1.DOM.createElementNS(NAMESPACE_URIS[nsAndName[0]], nsAndName[1]) :
dom_adapter_1.DOM.createElement(nsAndName[1]);
if (lang_1.isPresent(this._contentAttr)) {
dom_adapter_1.DOM.setAttribute(el, this._contentAttr, '');
}
if (lang_1.isPresent(parent)) {
dom_adapter_1.DOM.appendChild(parent, el);
}
return el;
};
DomRenderer.prototype.createViewRoot = function (hostElement) {
var nodesParent;
if (this.componentProto.encapsulation === metadata_1.ViewEncapsulation.Native) {
nodesParent = dom_adapter_1.DOM.createShadowRoot(hostElement);
this._rootRenderer.sharedStylesHost.addHost(nodesParent);
for (var i = 0; i < this._styles.length; i++) {
dom_adapter_1.DOM.appendChild(nodesParent, dom_adapter_1.DOM.createStyleElement(this._styles[i]));
}
}
else {
if (lang_1.isPresent(this._hostAttr)) {
dom_adapter_1.DOM.setAttribute(hostElement, this._hostAttr, '');
}
nodesParent = hostElement;
}
return nodesParent;
};
DomRenderer.prototype.createTemplateAnchor = function (parentElement, debugInfo) {
var comment = dom_adapter_1.DOM.createComment(TEMPLATE_COMMENT_TEXT);
if (lang_1.isPresent(parentElement)) {
dom_adapter_1.DOM.appendChild(parentElement, comment);
}
return comment;
};
DomRenderer.prototype.createText = function (parentElement, value, debugInfo) {
var node = dom_adapter_1.DOM.createTextNode(value);
if (lang_1.isPresent(parentElement)) {
dom_adapter_1.DOM.appendChild(parentElement, node);
}
return node;
};
DomRenderer.prototype.projectNodes = function (parentElement, nodes) {
if (lang_1.isBlank(parentElement))
return;
appendNodes(parentElement, nodes);
};
DomRenderer.prototype.attachViewAfter = function (node, viewRootNodes) {
moveNodesAfterSibling(node, viewRootNodes);
for (var i = 0; i < viewRootNodes.length; i++)
this.animateNodeEnter(viewRootNodes[i]);
};
DomRenderer.prototype.detachView = function (viewRootNodes) {
for (var i = 0; i < viewRootNodes.length; i++) {
var node = viewRootNodes[i];
dom_adapter_1.DOM.remove(node);
this.animateNodeLeave(node);
}
};
DomRenderer.prototype.destroyView = function (hostElement, viewAllNodes) {
if (this.componentProto.encapsulation === metadata_1.ViewEncapsulation.Native && lang_1.isPresent(hostElement)) {
this._rootRenderer.sharedStylesHost.removeHost(dom_adapter_1.DOM.getShadowRoot(hostElement));
}
};
DomRenderer.prototype.listen = function (renderElement, name, callback) {
return this._rootRenderer.eventManager.addEventListener(renderElement, name, decoratePreventDefault(callback));
};
DomRenderer.prototype.listenGlobal = function (target, name, callback) {
return this._rootRenderer.eventManager.addGlobalEventListener(target, name, decoratePreventDefault(callback));
};
DomRenderer.prototype.setElementProperty = function (renderElement, propertyName, propertyValue) {
dom_adapter_1.DOM.setProperty(renderElement, propertyName, propertyValue);
};
DomRenderer.prototype.setElementAttribute = function (renderElement, attributeName, attributeValue) {
var attrNs;
var nsAndName = splitNamespace(attributeName);
if (lang_1.isPresent(nsAndName[0])) {
attributeName = nsAndName[0] + ':' + nsAndName[1];
attrNs = NAMESPACE_URIS[nsAndName[0]];
}
if (lang_1.isPresent(attributeValue)) {
if (lang_1.isPresent(attrNs)) {
dom_adapter_1.DOM.setAttributeNS(renderElement, attrNs, attributeName, attributeValue);
}
else {
dom_adapter_1.DOM.setAttribute(renderElement, attributeName, attributeValue);
}
}
else {
if (lang_1.isPresent(attrNs)) {
dom_adapter_1.DOM.removeAttributeNS(renderElement, attrNs, nsAndName[1]);
}
else {
dom_adapter_1.DOM.removeAttribute(renderElement, attributeName);
}
}
};
DomRenderer.prototype.setBindingDebugInfo = function (renderElement, propertyName, propertyValue) {
var dashCasedPropertyName = util_1.camelCaseToDashCase(propertyName);
if (dom_adapter_1.DOM.isCommentNode(renderElement)) {
var existingBindings = lang_1.RegExpWrapper.firstMatch(TEMPLATE_BINDINGS_EXP, lang_1.StringWrapper.replaceAll(dom_adapter_1.DOM.getText(renderElement), /\n/g, ''));
var parsedBindings = lang_1.Json.parse(existingBindings[1]);
parsedBindings[dashCasedPropertyName] = propertyValue;
dom_adapter_1.DOM.setText(renderElement, lang_1.StringWrapper.replace(TEMPLATE_COMMENT_TEXT, '{}', lang_1.Json.stringify(parsedBindings)));
}
else {
this.setElementAttribute(renderElement, propertyName, propertyValue);
}
};
DomRenderer.prototype.setElementClass = function (renderElement, className, isAdd) {
if (isAdd) {
dom_adapter_1.DOM.addClass(renderElement, className);
}
else {
dom_adapter_1.DOM.removeClass(renderElement, className);
}
};
DomRenderer.prototype.setElementStyle = function (renderElement, styleName, styleValue) {
if (lang_1.isPresent(styleValue)) {
dom_adapter_1.DOM.setStyle(renderElement, styleName, lang_1.stringify(styleValue));
}
else {
dom_adapter_1.DOM.removeStyle(renderElement, styleName);
}
};
DomRenderer.prototype.invokeElementMethod = function (renderElement, methodName, args) {
dom_adapter_1.DOM.invoke(renderElement, methodName, args);
};
DomRenderer.prototype.setText = function (renderNode, text) { dom_adapter_1.DOM.setText(renderNode, text); };
/**
* Performs animations if necessary
* @param node
*/
DomRenderer.prototype.animateNodeEnter = function (node) {
if (dom_adapter_1.DOM.isElementNode(node) && dom_adapter_1.DOM.hasClass(node, 'ng-animate')) {
dom_adapter_1.DOM.addClass(node, 'ng-enter');
this._rootRenderer.animate.css()
.addAnimationClass('ng-enter-active')
.start(node)
.onComplete(function () { dom_adapter_1.DOM.removeClass(node, 'ng-enter'); });
}
};
/**
* If animations are necessary, performs animations then removes the element; otherwise, it just
* removes the element.
* @param node
*/
DomRenderer.prototype.animateNodeLeave = function (node) {
if (dom_adapter_1.DOM.isElementNode(node) && dom_adapter_1.DOM.hasClass(node, 'ng-animate')) {
dom_adapter_1.DOM.addClass(node, 'ng-leave');
this._rootRenderer.animate.css()
.addAnimationClass('ng-leave-active')
.start(node)
.onComplete(function () {
dom_adapter_1.DOM.removeClass(node, 'ng-leave');
dom_adapter_1.DOM.remove(node);
});
}
else {
dom_adapter_1.DOM.remove(node);
}
};
return DomRenderer;
}());
exports.DomRenderer = DomRenderer;
function moveNodesAfterSibling(sibling, nodes) {
var parent = dom_adapter_1.DOM.parentElement(sibling);
if (nodes.length > 0 && lang_1.isPresent(parent)) {
var nextSibling = dom_adapter_1.DOM.nextSibling(sibling);
if (lang_1.isPresent(nextSibling)) {
for (var i = 0; i < nodes.length; i++) {
dom_adapter_1.DOM.insertBefore(nextSibling, nodes[i]);
}
}
else {
for (var i = 0; i < nodes.length; i++) {
dom_adapter_1.DOM.appendChild(parent, nodes[i]);
}
}
}
}
function appendNodes(parent, nodes) {
for (var i = 0; i < nodes.length; i++) {
dom_adapter_1.DOM.appendChild(parent, nodes[i]);
}
}
function decoratePreventDefault(eventHandler) {
return function (event) {
var allowDefaultBehavior = eventHandler(event);
if (allowDefaultBehavior === false) {
// TODO(tbosch): move preventDefault into event plugins...
dom_adapter_1.DOM.preventDefault(event);
}
};
}
var COMPONENT_REGEX = /%COMP%/g;
exports.COMPONENT_VARIABLE = '%COMP%';
exports.HOST_ATTR = "_nghost-" + exports.COMPONENT_VARIABLE;
exports.CONTENT_ATTR = "_ngcontent-" + exports.COMPONENT_VARIABLE;
function _shimContentAttribute(componentShortId) {
return lang_1.StringWrapper.replaceAll(exports.CONTENT_ATTR, COMPONENT_REGEX, componentShortId);
}
function _shimHostAttribute(componentShortId) {
return lang_1.StringWrapper.replaceAll(exports.HOST_ATTR, COMPONENT_REGEX, componentShortId);
}
function _flattenStyles(compId, styles, target) {
for (var i = 0; i < styles.length; i++) {
var style = styles[i];
if (lang_1.isArray(style)) {
_flattenStyles(compId, style, target);
}
else {
style = lang_1.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];
}
var match = lang_1.RegExpWrapper.firstMatch(NS_PREFIX_RE, name);
return [match[1], match[2]];
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom_renderer.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/platform/dom/dom_renderer.ts"],"names":[],"mappings":"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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  isString\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  selectRootElement(selectorOrNode: string | any, debugInfo: RenderDebugInfo): Element {\n    var el;\n    if (isString(selectorOrNode)) {\n      el = DOM.querySelector(this._rootRenderer.document, selectorOrNode);\n      if (isBlank(el)) {\n        throw new BaseException(`The selector \"${selectorOrNode}\" did not match any elements`);\n      }\n    } else {\n      el = selectorOrNode;\n    }\n    DOM.clearNodes(el);\n    return el;\n  }\n\n  createElement(parent: Element, name: string, debugInfo: RenderDebugInfo): 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, debugInfo: RenderDebugInfo): 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, debugInfo: RenderDebugInfo): 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  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"]}
;