UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

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