angular2
Version:
Angular 2 - a web framework for modern web apps
288 lines • 50.9 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") return Reflect.decorate(decorators, target, key, desc);
switch (arguments.length) {
case 2: return decorators.reduceRight(function(o, d) { return (d && d(o)) || o; }, target);
case 3: return decorators.reduceRight(function(o, d) { return (d && d(target, key)), void 0; }, void 0);
case 4: return decorators.reduceRight(function(o, d) { return (d && d(target, key, o)) || o; }, desc);
}
};
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, RegExpWrapper, CONST_EXPR, stringify } from 'angular2/src/facade/lang';
import { BaseException } from 'angular2/src/facade/exceptions';
import { DomSharedStylesHost } from './shared_styles_host';
import { wtfLeave, wtfCreateScope } from 'angular2/src/core/profile/profile';
import { Renderer, RenderViewWithFragments } from 'angular2/core';
import { EventManager } from './events/event_manager';
import { DOCUMENT } from './dom_tokens';
import { createRenderView, encapsulateStyles } from 'angular2/src/core/render/view_factory';
import { DefaultProtoViewRef } from 'angular2/src/core/render/view';
import { camelCaseToDashCase } from './util';
import { ViewEncapsulation } from 'angular2/src/core/metadata';
import { DOM } from 'angular2/src/platform/dom/dom_adapter';
const NAMESPACE_URIS = CONST_EXPR({ 'xlink': 'http://www.w3.org/1999/xlink', 'svg': 'http://www.w3.org/2000/svg' });
export class DomRenderer extends Renderer {
getNativeElementSync(location) {
return resolveInternalDomView(location.renderView).boundElements[location.boundElementIndex];
}
getRootNodes(fragment) { return resolveInternalDomFragment(fragment); }
attachFragmentAfterFragment(previousFragmentRef, fragmentRef) {
var previousFragmentNodes = resolveInternalDomFragment(previousFragmentRef);
if (previousFragmentNodes.length > 0) {
var sibling = previousFragmentNodes[previousFragmentNodes.length - 1];
let nodes = resolveInternalDomFragment(fragmentRef);
moveNodesAfterSibling(sibling, nodes);
this.animateNodesEnter(nodes);
}
}
/**
* Iterates through all nodes being added to the DOM and animates them if necessary
* @param nodes
*/
animateNodesEnter(nodes) {
for (let i = 0; i < nodes.length; i++)
this.animateNodeEnter(nodes[i]);
}
attachFragmentAfterElement(elementRef, fragmentRef) {
var parentView = resolveInternalDomView(elementRef.renderView);
var element = parentView.boundElements[elementRef.boundElementIndex];
var nodes = resolveInternalDomFragment(fragmentRef);
moveNodesAfterSibling(element, nodes);
this.animateNodesEnter(nodes);
}
hydrateView(viewRef) { resolveInternalDomView(viewRef).hydrate(); }
dehydrateView(viewRef) { resolveInternalDomView(viewRef).dehydrate(); }
createTemplateAnchor(attrNameAndValues) {
return this.createElement('script', attrNameAndValues);
}
createText(value) { return DOM.createTextNode(isPresent(value) ? value : ''); }
appendChild(parent, child) { DOM.appendChild(parent, child); }
setElementProperty(location, propertyName, propertyValue) {
var view = resolveInternalDomView(location.renderView);
DOM.setProperty(view.boundElements[location.boundElementIndex], propertyName, propertyValue);
}
setElementAttribute(location, attributeName, attributeValue) {
var view = resolveInternalDomView(location.renderView);
var element = view.boundElements[location.boundElementIndex];
var dashCasedAttributeName = camelCaseToDashCase(attributeName);
if (isPresent(attributeValue)) {
DOM.setAttribute(element, dashCasedAttributeName, stringify(attributeValue));
}
else {
DOM.removeAttribute(element, dashCasedAttributeName);
}
}
setElementClass(location, className, isAdd) {
var view = resolveInternalDomView(location.renderView);
var element = view.boundElements[location.boundElementIndex];
if (isAdd) {
DOM.addClass(element, className);
}
else {
DOM.removeClass(element, className);
}
}
setElementStyle(location, styleName, styleValue) {
var view = resolveInternalDomView(location.renderView);
var element = view.boundElements[location.boundElementIndex];
var dashCasedStyleName = camelCaseToDashCase(styleName);
if (isPresent(styleValue)) {
DOM.setStyle(element, dashCasedStyleName, stringify(styleValue));
}
else {
DOM.removeStyle(element, dashCasedStyleName);
}
}
invokeElementMethod(location, methodName, args) {
var view = resolveInternalDomView(location.renderView);
var element = view.boundElements[location.boundElementIndex];
DOM.invoke(element, methodName, args);
}
setText(viewRef, textNodeIndex, text) {
var view = resolveInternalDomView(viewRef);
DOM.setText(view.boundTextNodes[textNodeIndex], text);
}
setEventDispatcher(viewRef, dispatcher) {
resolveInternalDomView(viewRef).setEventDispatcher(dispatcher);
}
}
export let DomRenderer_ = class extends DomRenderer {
constructor(_eventManager, _domSharedStylesHost, _animate, document) {
super();
this._eventManager = _eventManager;
this._domSharedStylesHost = _domSharedStylesHost;
this._animate = _animate;
this._componentTpls = new Map();
/** @internal */
this._createRootHostViewScope = wtfCreateScope('DomRenderer#createRootHostView()');
/** @internal */
this._createViewScope = wtfCreateScope('DomRenderer#createView()');
/** @internal */
this._detachFragmentScope = wtfCreateScope('DomRenderer#detachFragment()');
this._document = document;
}
registerComponentTemplate(template) {
this._componentTpls.set(template.id, template);
if (template.encapsulation !== ViewEncapsulation.Native) {
var encapsulatedStyles = encapsulateStyles(template);
this._domSharedStylesHost.addStyles(encapsulatedStyles);
}
}
createProtoView(componentTemplateId, cmds) {
return new DefaultProtoViewRef(this._componentTpls.get(componentTemplateId), cmds);
}
resolveComponentTemplate(templateId) {
return this._componentTpls.get(templateId);
}
createRootHostView(hostProtoViewRef, fragmentCount, hostElementSelector) {
var s = this._createRootHostViewScope();
var element = DOM.querySelector(this._document, hostElementSelector);
if (isBlank(element)) {
wtfLeave(s);
throw new BaseException(`The selector "${hostElementSelector}" did not match any elements`);
}
return wtfLeave(s, this._createView(hostProtoViewRef, element));
}
createView(protoViewRef, fragmentCount) {
var s = this._createViewScope();
return wtfLeave(s, this._createView(protoViewRef, null));
}
_createView(protoViewRef, inplaceElement) {
var dpvr = protoViewRef;
var view = createRenderView(dpvr.template, dpvr.cmds, inplaceElement, this);
var sdRoots = view.nativeShadowRoots;
for (var i = 0; i < sdRoots.length; i++) {
this._domSharedStylesHost.addHost(sdRoots[i]);
}
return new RenderViewWithFragments(view, view.fragments);
}
destroyView(viewRef) {
var view = viewRef;
var sdRoots = view.nativeShadowRoots;
for (var i = 0; i < sdRoots.length; i++) {
this._domSharedStylesHost.removeHost(sdRoots[i]);
}
}
animateNodeEnter(node) {
if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {
DOM.addClass(node, 'ng-enter');
this._animate.css()
.addAnimationClass('ng-enter-active')
.start(node)
.onComplete(() => { DOM.removeClass(node, 'ng-enter'); });
}
}
animateNodeLeave(node) {
if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {
DOM.addClass(node, 'ng-leave');
this._animate.css()
.addAnimationClass('ng-leave-active')
.start(node)
.onComplete(() => {
DOM.removeClass(node, 'ng-leave');
DOM.remove(node);
});
}
else {
DOM.remove(node);
}
}
detachFragment(fragmentRef) {
var s = this._detachFragmentScope();
var fragmentNodes = resolveInternalDomFragment(fragmentRef);
for (var i = 0; i < fragmentNodes.length; i++) {
this.animateNodeLeave(fragmentNodes[i]);
}
wtfLeave(s);
}
createElement(name, attrNameAndValues) {
var nsAndName = splitNamespace(name);
var el = isPresent(nsAndName[0]) ?
DOM.createElementNS(NAMESPACE_URIS[nsAndName[0]], nsAndName[1]) :
DOM.createElement(nsAndName[1]);
this._setAttributes(el, attrNameAndValues);
return el;
}
mergeElement(existing, attrNameAndValues) {
DOM.clearNodes(existing);
this._setAttributes(existing, attrNameAndValues);
}
_setAttributes(node, attrNameAndValues) {
for (var attrIdx = 0; attrIdx < attrNameAndValues.length; attrIdx += 2) {
var attrNs;
var attrName = attrNameAndValues[attrIdx];
var nsAndName = splitNamespace(attrName);
if (isPresent(nsAndName[0])) {
attrName = nsAndName[0] + ':' + nsAndName[1];
attrNs = NAMESPACE_URIS[nsAndName[0]];
}
var attrValue = attrNameAndValues[attrIdx + 1];
if (isPresent(attrNs)) {
DOM.setAttributeNS(node, attrNs, attrName, attrValue);
}
else {
DOM.setAttribute(node, nsAndName[1], attrValue);
}
}
}
createRootContentInsertionPoint() {
return DOM.createComment('root-content-insertion-point');
}
createShadowRoot(host, templateId) {
var sr = DOM.createShadowRoot(host);
var tpl = this._componentTpls.get(templateId);
for (var i = 0; i < tpl.styles.length; i++) {
DOM.appendChild(sr, DOM.createStyleElement(tpl.styles[i]));
}
return sr;
}
on(element, eventName, callback) {
this._eventManager.addEventListener(element, eventName, decoratePreventDefault(callback));
}
globalOn(target, eventName, callback) {
return this._eventManager.addGlobalEventListener(target, eventName, decoratePreventDefault(callback));
}
};
DomRenderer_ = __decorate([
Injectable(),
__param(3, Inject(DOCUMENT)),
__metadata('design:paramtypes', [EventManager, DomSharedStylesHost, AnimationBuilder, Object])
], DomRenderer_);
function resolveInternalDomView(viewRef) {
return viewRef;
}
function resolveInternalDomFragment(fragmentRef) {
return fragmentRef.nodes;
}
function moveNodesAfterSibling(sibling, nodes) {
if (nodes.length > 0 && isPresent(DOM.parentElement(sibling))) {
for (var i = 0; i < nodes.length; i++) {
DOM.insertBefore(sibling, nodes[i]);
}
DOM.insertBefore(nodes[0], sibling);
}
}
function decoratePreventDefault(eventHandler) {
return (event) => {
var allowDefaultBehavior = eventHandler(event);
if (!allowDefaultBehavior) {
// TODO(tbosch): move preventDefault into event plugins...
DOM.preventDefault(event);
}
};
}
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":["DomRenderer","DomRenderer.getNativeElementSync","DomRenderer.getRootNodes","DomRenderer.attachFragmentAfterFragment","DomRenderer.animateNodesEnter","DomRenderer.attachFragmentAfterElement","DomRenderer.hydrateView","DomRenderer.dehydrateView","DomRenderer.createTemplateAnchor","DomRenderer.createText","DomRenderer.appendChild","DomRenderer.setElementProperty","DomRenderer.setElementAttribute","DomRenderer.setElementClass","DomRenderer.setElementStyle","DomRenderer.invokeElementMethod","DomRenderer.setText","DomRenderer.setEventDispatcher","DomRenderer_","DomRenderer_.constructor","DomRenderer_.registerComponentTemplate","DomRenderer_.createProtoView","DomRenderer_.resolveComponentTemplate","DomRenderer_.createRootHostView","DomRenderer_.createView","DomRenderer_._createView","DomRenderer_.destroyView","DomRenderer_.animateNodeEnter","DomRenderer_.animateNodeLeave","DomRenderer_.detachFragment","DomRenderer_.createElement","DomRenderer_.mergeElement","DomRenderer_._setAttributes","DomRenderer_.createRootContentInsertionPoint","DomRenderer_.createShadowRoot","DomRenderer_.on","DomRenderer_.globalOn","resolveInternalDomView","resolveInternalDomFragment","moveNodesAfterSibling","decoratePreventDefault","splitNamespace"],"mappings":"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AACA,iBAAiBA,CAACA;iBACpCA,KAAKA,CAAcA,IAAIA,CAACA;iBACxBA,UAAUA,CAACA;gBACVA,GAAGA,CAACA,WAAWA,CAACA,IAAIA,EAAEA,UAAUA,CAACA,CAACA;gBAClCA,GAAGA,CAACA,MAAMA,CAACA,IAAIA,CAACA,CAACA;YACnBA,CAACA,CAACA,CAACA;QACTA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACNA,GAAGA,CAACA,MAAMA,CAACA,IAAIA,CAACA,CAACA;QACnBA,CAACA;IACHA,CAACA;IAIDV,cAAcA,CAACA,WAA8BA;QAC3CW,IAAIA,CAACA,GAAGA,IAAIA,CAACA,oBAAoBA,EAAEA,CAACA;QACpCA,IAAIA,aAAaA,GAAGA,0BAA0BA,CAACA,WAAWA,CAACA,CAACA;QAC5DA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,aAAaA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YAC9CA,IAAIA,CAACA,gBAAgBA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA,CAACA;QAC1CA,CAACA;QACDA,QAAQA,CAACA,CAACA,CAACA,CAACA;IACdA,CAACA;IACDX,aAAaA,CAACA,IAAYA,EAAEA,iBAA2BA;QACrDY,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,IAAIA,CAACA,cAAcA,CAACA,EAAEA,EAAEA,iBAAiBA,CAACA,CAACA;QAC3CA,MAAMA,CAACA,EAAEA,CAACA;IACZA,CAACA;IACDZ,YAAYA,CAACA,QAAcA,EAAEA,iBAA2BA;QACtDa,GAAGA,CAACA,UAAUA,CAACA,QAAQA,CAACA,CAACA;QACzBA,IAAIA,CAACA,cAAcA,CAACA,QAAQA,EAAEA,iBAAiBA,CAACA,CAACA;IACnDA,CAACA;IACOb,cAAcA,CAACA,IAAUA,EAAEA,iBAA2BA;QAC5Dc,GAAGA,CAACA,CAACA,GAAGA,CAACA,OAAOA,GAAGA,CAACA,EAAEA,OAAOA,GAAGA,iBAAiBA,CAACA,MAAMA,EAAEA,OAAOA,IAAIA,CAACA,EAAEA,CAACA;YACvEA,IAAIA,MAAMA,CAACA;YACXA,IAAIA,QAAQA,GAAGA,iBAAiBA,CAACA,OAAOA,CAACA,CAACA;YAC1CA,IAAIA,SAASA,GAAGA,cAAcA,CAACA,QAAQA,CAACA,CAACA;YACzCA,EAAEA,CAACA,CAACA,SAASA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;gBAC5BA,QAAQA,GAAGA,SAASA,CAACA,CAACA,CAACA,GAAGA,GAAGA,GAAGA,SAASA,CAACA,CAACA,CAACA,CAACA;gBAC7CA,MAAMA,GAAGA,cAAcA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA,CAACA;YACxCA,CAACA;YACDA,IAAIA,SAASA,GAAGA,iBAAiBA,CAACA,OAAOA,GAAGA,CAACA,CAACA,CAACA;YAC/CA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA;gBACtBA,GAAGA,CAACA,cAAcA,CAACA,IAAIA,EAAEA,MAAMA,EAAEA,QAAQA,EAAEA,SAASA,CAACA,CAACA;YACxDA,CAACA;YAACA,IAAIA,CAACA,CAACA;gBACNA,GAAGA,CAACA,YAAYA,CAACA,IAAIA,EAAEA,SAASA,CAACA,CAACA,CAACA,EAAEA,SAASA,CAACA,CAACA;YAClDA,CAACA;QACHA,CAACA;IACHA,CAACA;IACDd,+BAA+BA;QAC7Be,MAAMA,CAACA,GAAGA,CAACA,aAAaA,CAACA,8BAA8BA,CAACA,CAACA;IAC3DA,CAACA;IACDf,gBAAgBA,CAACA,IAAUA,EAAEA,UAAkBA;QAC7CgB,IAAIA,EAAEA,GAAGA,GAAGA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,CAACA;QACpCA,IAAIA,GAAGA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,GAAGA,CAACA,UAAUA,CAACA,CAACA;QAC9CA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,GAAGA,CAACA,MAAMA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YAC3CA,GAAGA,CAACA,WAAWA,CAACA,EAAEA,EAAEA,GAAGA,CAACA,kBAAkBA,CAACA,GAAGA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;QAC7DA,CAACA;QACDA,MAAMA,CAACA,EAAEA,CAACA;IACZA,CAACA;IACDhB,EAAEA,CAACA,OAAaA,EAAEA,SAAiBA,EAAEA,QAAkBA;QACrDiB,IAAIA,CAACA,aAAaA,CAACA,gBAAgBA,CAAcA,OAAOA,EAAEA,SAASA,EAC/BA,sBAAsBA,CAACA,QAAQA,CAACA,CAACA,CAACA;IACxEA,CAACA;IACDjB,QAAQA,CAACA,MAAcA,EAAEA,SAAiBA,EAAEA,QAAkBA;QAC5DkB,MAAMA,CAACA,IAAIA,CAACA,aAAaA,CAACA,sBAAsBA,CAACA,MAAMA,EAAEA,SAASA,EACjBA,sBAAsBA,CAACA,QAAQA,CAACA,CAACA,CAACA;IACrFA,CAACA;AACHlB,CAACA;AAvJD;IAAC,UAAU,EAAE;IAQC,WAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;;iBA+I9B;AAED,gCAAgC,OAAsB;IACpDmB,MAAMA,CAA0BA,OAAOA,CAACA;AAC1CA,CAACA;AAED,oCAAoC,WAA8B;IAChEC,MAAMA,CAAkCA,WAAYA,CAACA,KAAKA,CAACA;AAC7DA,CAACA;AAED,+BAA+B,OAAO,EAAE,KAAK;IAC3CC,EAAEA,CAACA,CAACA,KAAKA,CAACA,MAAMA,GAAGA,CAACA,IAAIA,SAASA,CAACA,GAAGA,CAACA,aAAaA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA,CAACA;QAC9DA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,KAAKA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YACtCA,GAAGA,CAACA,YAAYA,CAACA,OAAOA,EAAEA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA;QACtCA,CAACA;QACDA,GAAGA,CAACA,YAAYA,CAACA,KAAKA,CAACA,CAACA,CAACA,EAAEA,OAAOA,CAACA,CAACA;IACtCA,CAACA;AACHA,CAACA;AAED,gCAAgC,YAAsB;IACpDC,MAAMA,CAACA,CAACA,KAAKA;QACXA,IAAIA,oBAAoBA,GAAGA,YAAYA,CAACA,KAAKA,CAACA,CAACA;QAC/CA,EAAEA,CAACA,CAACA,CAACA,oBAAoBA,CAACA,CAACA,CAACA;YAC1BA,0DAA0DA;YAC1DA,GAAGA,CAACA,cAAcA,CAACA,KAAKA,CAACA,CAACA;QAC5BA,CAACA;IACHA,CAACA,CAACA;AACJA,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,aAAaA,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';\n\nimport {\n  isPresent,\n  isBlank,\n  RegExpWrapper,\n  CONST_EXPR,\n  stringify,\n  StringWrapper\n} from 'angular2/src/facade/lang';\n\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {DomSharedStylesHost} from './shared_styles_host';\nimport {WtfScopeFn, wtfLeave, wtfCreateScope} from 'angular2/src/core/profile/profile';\n\nimport {\n  Renderer,\n  RenderProtoViewRef,\n  RenderViewRef,\n  RenderElementRef,\n  RenderFragmentRef,\n  RenderViewWithFragments,\n  RenderTemplateCmd,\n  RenderEventDispatcher,\n  RenderComponentTemplate\n} from 'angular2/core';\n\nimport {EventManager} from './events/event_manager';\n\nimport {DOCUMENT} from './dom_tokens';\nimport {\n  createRenderView,\n  NodeFactory,\n  encapsulateStyles\n} from 'angular2/src/core/render/view_factory';\nimport {\n  DefaultRenderView,\n  DefaultRenderFragmentRef,\n  DefaultProtoViewRef\n} from 'angular2/src/core/render/view';\nimport {camelCaseToDashCase} from './util';\nimport {ViewEncapsulation} from 'angular2/src/core/metadata';\n\n// TODO move it once DomAdapter is moved\nimport {DOM} from 'angular2/src/platform/dom/dom_adapter';\n\nconst NAMESPACE_URIS =\n    CONST_EXPR({'xlink': 'http://www.w3.org/1999/xlink', 'svg': 'http://www.w3.org/2000/svg'});\n\nexport abstract class DomRenderer extends Renderer implements NodeFactory<Node> {\n  abstract registerComponentTemplate(template: RenderComponentTemplate);\n\n  abstract resolveComponentTemplate(templateId: string): RenderComponentTemplate;\n\n  abstract createProtoView(componentTemplateId: string,\n                           cmds: RenderTemplateCmd[]): RenderProtoViewRef;\n\n  abstract createRootHostView(hostProtoViewRef: RenderProtoViewRef, fragmentCount: number,\n                              hostElementSelector: string): RenderViewWithFragments;\n\n  abstract createView(protoViewRef: RenderProtoViewRef,\n                      fragmentCount: number): RenderViewWithFragments;\n\n  abstract destroyView(viewRef: RenderViewRef);\n\n  abstract createRootContentInsertionPoint();\n\n  getNativeElementSync(location: RenderElementRef): any {\n    return resolveInternalDomView(location.renderView).boundElements[location.boundElementIndex];\n  }\n\n  getRootNodes(fragment: RenderFragmentRef): Node[] { return resolveInternalDomFragment(fragment); }\n\n  attachFragmentAfterFragment(previousFragmentRef: RenderFragmentRef,\n                              fragmentRef: RenderFragmentRef) {\n    var previousFragmentNodes = resolveInternalDomFragment(previousFragmentRef);\n    if (previousFragmentNodes.length > 0) {\n      var sibling = previousFragmentNodes[previousFragmentNodes.length - 1];\n      let nodes = resolveInternalDomFragment(fragmentRef);\n      moveNodesAfterSibling(sibling, nodes);\n      this.animateNodesEnter(nodes);\n    }\n  }\n\n  /**\n   * Iterates through all nodes being added to the DOM and animates them if necessary\n   * @param nodes\n   */\n  animateNodesEnter(nodes: Node[]) {\n    for (let i = 0; i < nodes.length; i++) this.animateNodeEnter(nodes[i]);\n  }\n\n  /**\n   * Performs animations if necessary\n   * @param node\n   */\n  abstract animateNodeEnter(node: Node);\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  abstract animateNodeLeave(node: Node);\n\n  attachFragmentAfterElement(elementRef: RenderElementRef, fragmentRef: RenderFragmentRef) {\n    var parentView = resolveInternalDomView(elementRef.renderView);\n    var element = parentView.boundElements[elementRef.boundElementIndex];\n    var nodes = resolveInternalDomFragment(fragmentRef);\n    moveNodesAfterSibling(element, nodes);\n    this.animateNodesEnter(nodes);\n  }\n\n  abstract detachFragment(fragmentRef: RenderFragmentRef);\n\n  hydrateView(viewRef: RenderViewRef) { resolveInternalDomView(viewRef).hydrate(); }\n\n  dehydrateView(viewRef: RenderViewRef) { resolveInternalDomView(viewRef).dehydrate(); }\n\n  createTemplateAnchor(attrNameAndValues: string[]): Node {\n    return this.createElement('script', attrNameAndValues);\n  }\n  abstract createElement(name: string, attrNameAndValues: string[]): Node;\n  abstract mergeElement(existing: Node, attrNameAndValues: string[]);\n  abstract createShadowRoot(host: Node, templateId: string): Node;\n  createText(value: string): Node { return DOM.createTextNode(isPresent(value) ? value : ''); }\n  appendChild(parent: Node, child: Node) { DOM.appendChild(parent, child); }\n  abstract on(element: Node, eventName: string, callback: Function);\n  abstract globalOn(target: string, eventName: string, callback: Function): Function;\n\n  setElementProperty(location: RenderElementRef, propertyName: string, propertyValue: any): void {\n    var view = resolveInternalDomView(location.renderView);\n    DOM.setProperty(<Element>view.boundElements[location.boundElementIndex], propertyName,\n                    propertyValue);\n  }\n\n  setElementAttribute(location: RenderElementRef, attributeName: string,\n                      attributeValue: string): void {\n    var view = resolveInternalDomView(location.renderView);\n    var element = view.boundElements[location.boundElementIndex];\n    var dashCasedAttributeName = camelCaseToDashCase(attributeName);\n    if (isPresent(attributeValue)) {\n      DOM.setAttribute(element, dashCasedAttributeName, stringify(attributeValue));\n    } else {\n      DOM.removeAttribute(element, dashCasedAttributeName);\n    }\n  }\n\n  setElementClass(location: RenderElementRef, className: string, isAdd: boolean): void {\n    var view = resolveInternalDomView(location.renderView);\n    var element = view.boundElements[location.boundElementIndex];\n    if (isAdd) {\n      DOM.addClass(element, className);\n    } else {\n      DOM.removeClass(element, className);\n    }\n  }\n\n  setElementStyle(location: RenderElementRef, styleName: string, styleValue: string): void {\n    var view = resolveInternalDomView(location.renderView);\n    var element = view.boundElements[location.boundElementIndex];\n    var dashCasedStyleName = camelCaseToDashCase(styleName);\n    if (isPresent(styleValue)) {\n      DOM.setStyle(element, dashCasedStyleName, stringify(styleValue));\n    } else {\n      DOM.removeStyle(element, dashCasedStyleName);\n    }\n  }\n\n  invokeElementMethod(location: RenderElementRef, methodName: string, args: any[]): void {\n    var view = resolveInternalDomView(location.renderView);\n    var element = <Element>view.boundElements[location.boundElementIndex];\n    DOM.invoke(element, methodName, args);\n  }\n\n  setText(viewRef: RenderViewRef, textNodeIndex: number, text: string): void {\n    var view = resolveInternalDomView(viewRef);\n    DOM.setText(view.boundTextNodes[textNodeIndex], text);\n  }\n\n  setEventDispatcher(viewRef: RenderViewRef, dispatcher: RenderEventDispatcher): void {\n    resolveInternalDomView(viewRef).setEventDispatcher(dispatcher);\n  }\n}\n\n@Injectable()\nexport class DomRenderer_ extends DomRenderer {\n  private _componentTpls: Map<string, RenderComponentTemplate> =\n      new Map<string, RenderComponentTemplate>();\n  private _document;\n\n  constructor(private _eventManager: EventManager,\n              private _domSharedStylesHost: DomSharedStylesHost, private _animate: AnimationBuilder,\n              @Inject(DOCUMENT) document) {\n    super();\n    this._document = document;\n  }\n\n  registerComponentTemplate(template: RenderComponentTemplate) {\n    this._componentTpls.set(template.id, template);\n    if (template.encapsulation !== ViewEncapsulation.Native) {\n      var encapsulatedStyles = encapsulateStyles(template);\n      this._domSharedStylesHost.addStyles(encapsulatedStyles);\n    }\n  }\n\n  createProtoView(componentTemplateId: string, cmds: RenderTemplateCmd[]): RenderProtoViewRef {\n    return new DefaultProtoViewRef(this._componentTpls.get(componentTemplateId), cmds);\n  }\n\n  resolveComponentTemplate(templateId: string): RenderComponentTemplate {\n    return this._componentTpls.get(templateId);\n  }\n\n  /** @internal */\n  _createRootHostViewScope: WtfScopeFn = wtfCreateScope('DomRenderer#createRootHostView()');\n  createRootHostView(hostProtoViewRef: RenderProtoViewRef, fragmentCount: number,\n                     hostElementSelector: string): RenderViewWithFragments {\n    var s = this._createRootHostViewScope();\n    var element = DOM.querySelector(this._document, hostElementSelector);\n    if (isBlank(element)) {\n      wtfLeave(s);\n      throw new BaseException(`The selector \"${hostElementSelector}\" did not match any elements`);\n    }\n    return wtfLeave(s, this._createView(hostProtoViewRef, element));\n  }\n\n  /** @internal */\n  _createViewScope = wtfCreateScope('DomRenderer#createView()');\n  createView(protoViewRef: RenderProtoViewRef, fragmentCount: number): RenderViewWithFragments {\n    var s = this._createViewScope();\n    return wtfLeave(s, this._createView(protoViewRef, null));\n  }\n\n  private _createView(protoViewRef: RenderProtoViewRef,\n                      inplaceElement: HTMLElement): RenderViewWithFragments {\n    var dpvr = <DefaultProtoViewRef>protoViewRef;\n    var view = createRenderView(dpvr.template, dpvr.cmds, inplaceElement, this);\n    var sdRoots = view.nativeShadowRoots;\n    for (var i = 0; i < sdRoots.length; i++) {\n      this._domSharedStylesHost.addHost(sdRoots[i]);\n    }\n    return new RenderViewWithFragments(view, view.fragments);\n  }\n\n  destroyView(viewRef: RenderViewRef) {\n    var view = <DefaultRenderView<Node>>viewRef;\n    var sdRoots = view.nativeShadowRoots;\n    for (var i = 0; i < sdRoots.length; i++) {\n      this._domSharedStylesHost.removeHost(sdRoots[i]);\n    }\n  }\n\n  animateNodeEnter(node: Node) {\n    if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {\n      DOM.addClass(node, 'ng-enter');\n      this._animate.css()\n          .addAnimationClass('ng-enter-active')\n          .start(<HTMLElement>node)\n          .onComplete(() => { DOM.removeClass(node, 'ng-enter'); });\n    }\n  }\n\n  animateNodeLeave(node: Node) {\n    if (DOM.isElementNode(node) && DOM.hasClass(node, 'ng-animate')) {\n      DOM.addClass(node, 'ng-leave');\n      this._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  /** @internal */\n  _detachFragmentScope = wtfCreateScope('DomRenderer#detachFragment()');\n  detachFragment(fragmentRef: RenderFragmentRef) {\n    var s = this._detachFragmentScope();\n    var fragmentNodes = resolveInternalDomFragment(fragmentRef);\n    for (var i = 0; i < fragmentNodes.length; i++) {\n      this.animateNodeLeave(fragmentNodes[i]);\n    }\n    wtfLeave(s);\n  }\n  createElement(name: string, attrNameAndValues: 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    this._setAttributes(el, attrNameAndValues);\n    return el;\n  }\n  mergeElement(existing: Node, attrNameAndValues: string[]) {\n    DOM.clearNodes(existing);\n    this._setAttributes(existing, attrNameAndValues);\n  }\n  private _setAttributes(node: Node, attrNameAndValues: string[]) {\n    for (var attrIdx = 0; attrIdx < attrNameAndValues.length; attrIdx += 2) {\n      var attrNs;\n      var attrName = attrNameAndValues[attrIdx];\n      var nsAndName = splitNamespace(attrName);\n      if (isPresent(nsAndName[0])) {\n        attrName = nsAndName[0] + ':' + nsAndName[1];\n        attrNs = NAMESPACE_URIS[nsAndName[0]];\n      }\n      var attrValue = attrNameAndValues[attrIdx + 1];\n      if (isPresent(attrNs)) {\n        DOM.setAttributeNS(node, attrNs, attrName, attrValue);\n      } else {\n        DOM.setAttribute(node, nsAndName[1], attrValue);\n      }\n    }\n  }\n  createRootContentInsertionPoint(): Node {\n    return DOM.createComment('root-content-insertion-point');\n  }\n  createShadowRoot(host: Node, templateId: string): Node {\n    var sr = DOM.createShadowRoot(host);\n    var tpl = this._componentTpls.get(templateId);\n    for (var i = 0; i < tpl.styles.length; i++) {\n      DOM.appendChild(sr, DOM.createStyleElement(tpl.styles[i]));\n    }\n    return sr;\n  }\n  on(element: Node, eventName: string, callback: Function) {\n    this._eventManager.addEventListener(<HTMLElement>element, eventName,\n                                        decoratePreventDefault(callback));\n  }\n  globalOn(target: string, eventName: string, callback: Function): Function {\n    return this._eventManager.addGlobalEventListener(target, eventName,\n                                                     decoratePreventDefault(callback));\n  }\n}\n\nfunction resolveInternalDomView(viewRef: RenderViewRef): DefaultRenderView<Node> {\n  return <DefaultRenderView<Node>>viewRef;\n}\n\nfunction resolveInternalDomFragment(fragmentRef: RenderFragmentRef): Node[] {\n  return (<DefaultRenderFragmentRef<Node>>fragmentRef).nodes;\n}\n\nfunction moveNodesAfterSibling(sibling, nodes) {\n  if (nodes.length > 0 && isPresent(DOM.parentElement(sibling