angular2
Version:
Angular 2 - a web framework for modern web apps
131 lines • 24.7 kB
JavaScript
;var lang_1 = require('angular2/src/facade/lang');
var debug_node_1 = require('angular2/src/core/debug/debug_node');
var DebugDomRootRenderer = (function () {
function DebugDomRootRenderer(_delegate) {
this._delegate = _delegate;
}
DebugDomRootRenderer.prototype.renderComponent = function (componentProto) {
return new DebugDomRenderer(this, this._delegate.renderComponent(componentProto));
};
return DebugDomRootRenderer;
})();
exports.DebugDomRootRenderer = DebugDomRootRenderer;
var DebugDomRenderer = (function () {
function DebugDomRenderer(_rootRenderer, _delegate) {
this._rootRenderer = _rootRenderer;
this._delegate = _delegate;
}
DebugDomRenderer.prototype.renderComponent = function (componentType) {
return this._rootRenderer.renderComponent(componentType);
};
DebugDomRenderer.prototype.selectRootElement = function (selector) {
var nativeEl = this._delegate.selectRootElement(selector);
var debugEl = new debug_node_1.DebugElement(nativeEl, null);
debug_node_1.indexDebugNode(debugEl);
return nativeEl;
};
DebugDomRenderer.prototype.createElement = function (parentElement, name) {
var nativeEl = this._delegate.createElement(parentElement, name);
var debugEl = new debug_node_1.DebugElement(nativeEl, debug_node_1.getDebugNode(parentElement));
debugEl.name = name;
debug_node_1.indexDebugNode(debugEl);
return nativeEl;
};
DebugDomRenderer.prototype.createViewRoot = function (hostElement) { return this._delegate.createViewRoot(hostElement); };
DebugDomRenderer.prototype.createTemplateAnchor = function (parentElement) {
var comment = this._delegate.createTemplateAnchor(parentElement);
var debugEl = new debug_node_1.DebugNode(comment, debug_node_1.getDebugNode(parentElement));
debug_node_1.indexDebugNode(debugEl);
return comment;
};
DebugDomRenderer.prototype.createText = function (parentElement, value) {
var text = this._delegate.createText(parentElement, value);
var debugEl = new debug_node_1.DebugNode(text, debug_node_1.getDebugNode(parentElement));
debug_node_1.indexDebugNode(debugEl);
return text;
};
DebugDomRenderer.prototype.projectNodes = function (parentElement, nodes) {
var debugParent = debug_node_1.getDebugNode(parentElement);
if (lang_1.isPresent(debugParent) && debugParent instanceof debug_node_1.DebugElement) {
nodes.forEach(function (node) { debugParent.addChild(debug_node_1.getDebugNode(node)); });
}
return this._delegate.projectNodes(parentElement, nodes);
};
DebugDomRenderer.prototype.attachViewAfter = function (node, viewRootNodes) {
var debugNode = debug_node_1.getDebugNode(node);
if (lang_1.isPresent(debugNode)) {
var debugParent = debugNode.parent;
if (viewRootNodes.length > 0 && lang_1.isPresent(debugParent)) {
var debugViewRootNodes = [];
viewRootNodes.forEach(function (rootNode) { return debugViewRootNodes.push(debug_node_1.getDebugNode(rootNode)); });
debugParent.insertChildrenAfter(debugNode, debugViewRootNodes);
}
}
return this._delegate.attachViewAfter(node, viewRootNodes);
};
DebugDomRenderer.prototype.detachView = function (viewRootNodes) {
viewRootNodes.forEach(function (node) {
var debugNode = debug_node_1.getDebugNode(node);
if (lang_1.isPresent(debugNode) && lang_1.isPresent(debugNode.parent)) {
debugNode.parent.removeChild(debugNode);
}
});
return this._delegate.detachView(viewRootNodes);
};
DebugDomRenderer.prototype.destroyView = function (hostElement, viewAllNodes) {
viewAllNodes.forEach(function (node) { debug_node_1.removeDebugNodeFromIndex(debug_node_1.getDebugNode(node)); });
return this._delegate.destroyView(hostElement, viewAllNodes);
};
DebugDomRenderer.prototype.listen = function (renderElement, name, callback) {
var debugEl = debug_node_1.getDebugNode(renderElement);
if (lang_1.isPresent(debugEl)) {
debugEl.listeners.push(new debug_node_1.EventListener(name, callback));
}
return this._delegate.listen(renderElement, name, callback);
};
DebugDomRenderer.prototype.listenGlobal = function (target, name, callback) {
return this._delegate.listenGlobal(target, name, callback);
};
DebugDomRenderer.prototype.setElementProperty = function (renderElement, propertyName, propertyValue) {
var debugEl = debug_node_1.getDebugNode(renderElement);
if (lang_1.isPresent(debugEl) && debugEl instanceof debug_node_1.DebugElement) {
debugEl.properties.set(propertyName, propertyValue);
}
return this._delegate.setElementProperty(renderElement, propertyName, propertyValue);
};
DebugDomRenderer.prototype.setElementAttribute = function (renderElement, attributeName, attributeValue) {
var debugEl = debug_node_1.getDebugNode(renderElement);
if (lang_1.isPresent(debugEl) && debugEl instanceof debug_node_1.DebugElement) {
debugEl.attributes.set(attributeName, attributeValue);
}
return this._delegate.setElementAttribute(renderElement, attributeName, attributeValue);
};
/**
* Used only in debug mode to serialize property changes to comment nodes,
* such as <template> placeholders.
*/
DebugDomRenderer.prototype.setBindingDebugInfo = function (renderElement, propertyName, propertyValue) {
return this._delegate.setBindingDebugInfo(renderElement, propertyName, propertyValue);
};
/**
* Used only in development mode to set information needed by the DebugNode for this element.
*/
DebugDomRenderer.prototype.setElementDebugInfo = function (renderElement, info) {
var debugEl = debug_node_1.getDebugNode(renderElement);
debugEl.setDebugInfo(info);
return this._delegate.setElementDebugInfo(renderElement, info);
};
DebugDomRenderer.prototype.setElementClass = function (renderElement, className, isAdd) {
return this._delegate.setElementClass(renderElement, className, isAdd);
};
DebugDomRenderer.prototype.setElementStyle = function (renderElement, styleName, styleValue) {
return this._delegate.setElementStyle(renderElement, styleName, styleValue);
};
DebugDomRenderer.prototype.invokeElementMethod = function (renderElement, methodName, args) {
return this._delegate.invokeElementMethod(renderElement, methodName, args);
};
DebugDomRenderer.prototype.setText = function (renderNode, text) { return this._delegate.setText(renderNode, text); };
return DebugDomRenderer;
})();
exports.DebugDomRenderer = DebugDomRenderer;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"debug_renderer.js","sourceRoot":"","sources":["angular2/src/core/debug/debug_renderer.ts"],"names":["DebugDomRootRenderer","DebugDomRootRenderer.constructor","DebugDomRootRenderer.renderComponent","DebugDomRenderer","DebugDomRenderer.constructor","DebugDomRenderer.renderComponent","DebugDomRenderer.selectRootElement","DebugDomRenderer.createElement","DebugDomRenderer.createViewRoot","DebugDomRenderer.createTemplateAnchor","DebugDomRenderer.createText","DebugDomRenderer.projectNodes","DebugDomRenderer.attachViewAfter","DebugDomRenderer.detachView","DebugDomRenderer.destroyView","DebugDomRenderer.listen","DebugDomRenderer.listenGlobal","DebugDomRenderer.setElementProperty","DebugDomRenderer.setElementAttribute","DebugDomRenderer.setBindingDebugInfo","DebugDomRenderer.setElementDebugInfo","DebugDomRenderer.setElementClass","DebugDomRenderer.setElementStyle","DebugDomRenderer.invokeElementMethod","DebugDomRenderer.setText"],"mappings":"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BA;QAC7CS,IAAIA,SAASA,GAAGA,yBAAYA,CAACA,IAAIA,CAACA,CAACA;QACnCA,EAAEA,CAACA,CAACA,gBAASA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;YACzBA,IAAIA,WAAWA,GAAGA,SAASA,CAACA,MAAMA,CAACA;YACnCA,EAAEA,CAACA,CAACA,aAAaA,CAACA,MAAMA,GAAGA,CAACA,IAAIA,gBAASA,CAACA,WAAWA,CAACA,CAACA,CAACA,CAACA;gBACvDA,IAAIA,kBAAkBA,GAAGA,EAAEA,CAACA;gBAC5BA,aAAaA,CAACA,OAAOA,CAACA,UAACA,QAAQA,IAAKA,OAAAA,kBAAkBA,CAACA,IAAIA,CAACA,yBAAYA,CAACA,QAAQA,CAACA,CAACA,EAA/CA,CAA+CA,CAACA,CAACA;gBACrFA,WAAWA,CAACA,mBAAmBA,CAACA,SAASA,EAAEA,kBAAkBA,CAACA,CAACA;YACjEA,CAACA;QACHA,CAACA;QACDA,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA,eAAeA,CAACA,IAAIA,EAAEA,aAAaA,CAACA,CAACA;IAC7DA,CAACA;IAEDT,qCAAUA,GAAVA,UAAWA,aAAoBA;QAC7BU,aAAaA,CAACA,OAAOA,CAACA,UAACA,IAAIA;YACzBA,IAAIA,SAASA,GAAGA,yBAAYA,CAACA,IAAIA,CAACA,CAACA;YACnCA,EAAEA,CAACA,CAACA,gBAASA,CAACA,SAASA,CAACA,IAAIA,gBAASA,CAACA,SAASA,CAACA,MAAMA,CAACA,CAACA,CAACA,CAACA;gBACxDA,SAASA,CAACA,MAAMA,CAACA,WAAWA,CAACA,SAASA,CAACA,CAACA;YAC1CA,CAACA;QACHA,CAACA,CAACA,CAACA;QACHA,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA,UAAUA,CAACA,aAAaA,CAACA,CAACA;IAClDA,CAACA;IAEDV,sCAAWA,GAAXA,UAAYA,WAAgBA,EAAEA,YAAmBA;QAC/CW,YAAYA,CAACA,OAAOA,CAACA,UAACA,IAAIA,IAAOA,qCAAwBA,CAACA,yBAAYA,CAACA,IAAIA,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","sourcesContent":["import {isPresent} from 'angular2/src/facade/lang';\nimport {\n  Renderer,\n  RootRenderer,\n  RenderComponentType,\n  RenderDebugInfo\n} from 'angular2/src/core/render/api';\nimport {\n  DebugNode,\n  DebugElement,\n  EventListener,\n  getDebugNode,\n  indexDebugNode,\n  removeDebugNodeFromIndex\n} from 'angular2/src/core/debug/debug_node';\n\nexport class DebugDomRootRenderer implements RootRenderer {\n  constructor(private _delegate: RootRenderer) {}\n\n  renderComponent(componentProto: RenderComponentType): Renderer {\n    return new DebugDomRenderer(this, this._delegate.renderComponent(componentProto));\n  }\n}\n\nexport class DebugDomRenderer implements Renderer {\n  constructor(private _rootRenderer: DebugDomRootRenderer, private _delegate: Renderer) {}\n\n  renderComponent(componentType: RenderComponentType): Renderer {\n    return this._rootRenderer.renderComponent(componentType);\n  }\n\n  selectRootElement(selector: string): any {\n    var nativeEl = this._delegate.selectRootElement(selector);\n    var debugEl = new DebugElement(nativeEl, null);\n    indexDebugNode(debugEl);\n    return nativeEl;\n  }\n\n  createElement(parentElement: any, name: string): any {\n    var nativeEl = this._delegate.createElement(parentElement, name);\n    var debugEl = new DebugElement(nativeEl, getDebugNode(parentElement));\n    debugEl.name = name;\n    indexDebugNode(debugEl);\n    return nativeEl;\n  }\n\n  createViewRoot(hostElement: any): any { return this._delegate.createViewRoot(hostElement); }\n\n  createTemplateAnchor(parentElement: any): any {\n    var comment = this._delegate.createTemplateAnchor(parentElement);\n    var debugEl = new DebugNode(comment, getDebugNode(parentElement));\n    indexDebugNode(debugEl);\n    return comment;\n  }\n\n  createText(parentElement: any, value: string): any {\n    var text = this._delegate.createText(parentElement, value);\n    var debugEl = new DebugNode(text, getDebugNode(parentElement));\n    indexDebugNode(debugEl);\n    return text;\n  }\n\n  projectNodes(parentElement: any, nodes: any[]) {\n    var debugParent = getDebugNode(parentElement);\n    if (isPresent(debugParent) && debugParent instanceof DebugElement) {\n      nodes.forEach((node) => { debugParent.addChild(getDebugNode(node)); });\n    }\n    return this._delegate.projectNodes(parentElement, nodes);\n  }\n\n  attachViewAfter(node: any, viewRootNodes: any[]) {\n    var debugNode = getDebugNode(node);\n    if (isPresent(debugNode)) {\n      var debugParent = debugNode.parent;\n      if (viewRootNodes.length > 0 && isPresent(debugParent)) {\n        var debugViewRootNodes = [];\n        viewRootNodes.forEach((rootNode) => debugViewRootNodes.push(getDebugNode(rootNode)));\n        debugParent.insertChildrenAfter(debugNode, debugViewRootNodes);\n      }\n    }\n    return this._delegate.attachViewAfter(node, viewRootNodes);\n  }\n\n  detachView(viewRootNodes: any[]) {\n    viewRootNodes.forEach((node) => {\n      var debugNode = getDebugNode(node);\n      if (isPresent(debugNode) && isPresent(debugNode.parent)) {\n        debugNode.parent.removeChild(debugNode);\n      }\n    });\n    return this._delegate.detachView(viewRootNodes);\n  }\n\n  destroyView(hostElement: any, viewAllNodes: any[]) {\n    viewAllNodes.forEach((node) => { removeDebugNodeFromIndex(getDebugNode(node)); });\n    return this._delegate.destroyView(hostElement, viewAllNodes);\n  }\n\n  listen(renderElement: any, name: string, callback: Function) {\n    var debugEl = getDebugNode(renderElement);\n    if (isPresent(debugEl)) {\n      debugEl.listeners.push(new EventListener(name, callback));\n    }\n    return this._delegate.listen(renderElement, name, callback);\n  }\n\n  listenGlobal(target: string, name: string, callback: Function): Function {\n    return this._delegate.listenGlobal(target, name, callback);\n  }\n\n  setElementProperty(renderElement: any, propertyName: string, propertyValue: any) {\n    var debugEl = getDebugNode(renderElement);\n    if (isPresent(debugEl) && debugEl instanceof DebugElement) {\n      debugEl.properties.set(propertyName, propertyValue);\n    }\n    return this._delegate.setElementProperty(renderElement, propertyName, propertyValue);\n  }\n\n  setElementAttribute(renderElement: any, attributeName: string, attributeValue: string) {\n    var debugEl = getDebugNode(renderElement);\n    if (isPresent(debugEl) && debugEl instanceof DebugElement) {\n      debugEl.attributes.set(attributeName, attributeValue);\n    }\n    return this._delegate.setElementAttribute(renderElement, attributeName, attributeValue);\n  }\n\n  /**\n   * Used only in debug mode to serialize property changes to comment nodes,\n   * such as <template> placeholders.\n   */\n  setBindingDebugInfo(renderElement: any, propertyName: string, propertyValue: string) {\n    return this._delegate.setBindingDebugInfo(renderElement, propertyName, propertyValue);\n  }\n\n  /**\n   * Used only in development mode to set information needed by the DebugNode for this element.\n   */\n  setElementDebugInfo(renderElement: any, info: RenderDebugInfo) {\n    var debugEl = getDebugNode(renderElement);\n    debugEl.setDebugInfo(info);\n    return this._delegate.setElementDebugInfo(renderElement, info);\n  }\n\n  setElementClass(renderElement: any, className: string, isAdd: boolean) {\n    return this._delegate.setElementClass(renderElement, className, isAdd);\n  }\n\n  setElementStyle(renderElement: any, styleName: string, styleValue: string) {\n    return this._delegate.setElementStyle(renderElement, styleName, styleValue);\n  }\n\n  invokeElementMethod(renderElement: any, methodName: string, args: any[]) {\n    return this._delegate.invokeElementMethod(renderElement, methodName, args);\n  }\n\n  setText(renderNode: any, text: string) { return this._delegate.setText(renderNode, text); }\n}\n"]}