angular2
Version:
Angular 2 - a web framework for modern web apps
320 lines • 49.9 kB
JavaScript
;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.renderComponent = function (componentProto) {
return this._rootRenderer.renderComponent(componentProto);
};
DomRenderer.prototype.selectRootElement = function (selector) {
var el = dom_adapter_1.DOM.querySelector(this._rootRenderer.document, selector);
if (lang_1.isBlank(el)) {
throw new exceptions_1.BaseException("The selector \"" + selector + "\" did not match any elements");
}
dom_adapter_1.DOM.clearNodes(el);
return el;
};
DomRenderer.prototype.createElement = function (parent, name) {
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) {
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) {
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.setElementDebugInfo = function (renderElement, info) { };
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":["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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CAACA,IAAIA,gBAASA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA;QAC1CA,IAAIA,WAAWA,GAAGA,iBAAGA,CAACA,WAAWA,CAACA,OAAOA,CAACA,CAACA;QAC3CA,EAAEA,CAACA,CAACA,gBAASA,CAACA,WAAWA,CAACA,CAACA,CAACA,CAACA;YAC3BA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,KAAKA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;gBACtCA,iBAAGA,CAACA,YAAYA,CAACA,WAAWA,EAAEA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA;YAC1CA,CAACA;QACHA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACNA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,KAAKA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;gBACtCA,iBAAGA,CAACA,WAAWA,CAACA,MAAMA,EAAEA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA;YACpCA,CAACA;QACHA,CAACA;IACHA,CAACA;AACHA,CAACA;AAED,qBAAqB,MAAM,EAAE,KAAK;IAChCC,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,KAAKA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;QACtCA,iBAAGA,CAACA,WAAWA,CAACA,MAAMA,EAAEA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA;IACpCA,CAACA;AACHA,CAACA;AAED,gCAAgC,YAAsB;IACpDC,MAAMA,CAACA,UAACA,KAAKA;QACXA,IAAIA,oBAAoBA,GAAGA,YAAYA,CAACA,KAAKA,CAACA,CAACA;QAC/CA,EAAEA,CAACA,CAACA,oBAAoBA,KAAKA,KAAKA,CAACA,CAACA,CAACA;YACnCA,0DAA0DA;YAC1DA,iBAAGA,CAACA,cAAcA,CAACA,KAAKA,CAACA,CAACA;QAC5BA,CAACA;IACHA,CAACA,CAACA;AACJA,CAACA;AAED,IAAI,eAAe,GAAG,SAAS,CAAC;AACnB,0BAAkB,GAAG,QAAQ,CAAC;AAC9B,iBAAS,GAAG,aAAW,0BAAoB,CAAC;AAC5C,oBAAY,GAAG,gBAAc,0BAAoB,CAAC;AAE/D,+BAA+B,gBAAwB;IACrDC,MAAMA,CAACA,oBAAaA,CAACA,UAAUA,CAACA,oBAAYA,EAAEA,eAAeA,EAAEA,gBAAgBA,CAACA,CAACA;AACnFA,CAACA;AAED,4BAA4B,gBAAwB;IAClDC,MAAMA,CAACA,oBAAaA,CAACA,UAAUA,CAACA,iBAASA,EAAEA,eAAeA,EAAEA,gBAAgBA,CAACA,CAACA;AAChFA,CAACA;AAED,wBAAwB,MAAc,EAAE,MAA0B,EAAE,MAAgB;IAClFC,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,MAAMA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;QACvCA,IAAIA,KAAKA,GAAGA,MAAMA,CAACA,CAACA,CAACA,CAACA;QACtBA,EAAEA,CAACA,CAACA,cAAOA,CAACA,KAAKA,CAACA,CAACA,CAACA,CAACA;YACnBA,cAAcA,CAACA,MAAMA,EAAEA,KAAKA,EAAEA,MAAMA,CAACA,CAACA;QACxCA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACNA,KAAKA,GAAGA,oBAAaA,CAACA,UAAUA,CAACA,KAAKA,EAAEA,eAAeA,EAAEA,MAAMA,CAACA,CAACA;YACjEA,MAAMA,CAACA,IAAIA,CAACA,KAAKA,CAACA,CAACA;QACrBA,CAACA;IACHA,CAACA;IACDA,MAAMA,CAACA,MAAMA,CAACA;AAChBA,CAACA;AAED,IAAI,YAAY,GAAG,iBAAiB,CAAC;AAErC,wBAAwB,IAAY;IAClCC,EAAEA,CAACA,CAACA,IAAIA,CAACA,CAACA,CAACA,IAAIA,GAAGA,CAACA,CAACA,CAACA;QACnBA,MAAMA,CAACA,CAACA,IAAIA,EAAEA,IAAIA,CAACA,CAACA;IACtBA,CAACA;IACDA,IAAIA,KAAKA,GAAGA,oBAAaA,CAACA,UAAUA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,CAACA;IACzDA,MAAMA,CAACA,CAACA,KAAKA,CAACA,CAACA,CAACA,EAAEA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA;AAC9BA,CAACA","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"]}