angular2
Version:
Angular 2 - a web framework for modern web apps
269 lines • 48.1 kB
JavaScript
import { isBlank, isPresent, StringWrapper } from 'angular2/src/facade/lang';
import { DefaultRenderView, DefaultRenderFragmentRef } from './view';
import { ViewEncapsulation } from 'angular2/src/core/metadata';
import { ListWrapper } from 'angular2/src/facade/collection';
export function encapsulateStyles(componentTemplate) {
var processedStyles = componentTemplate.styles;
if (componentTemplate.encapsulation === ViewEncapsulation.Emulated) {
processedStyles = ListWrapper.createFixedSize(componentTemplate.styles.length);
for (var i = 0; i < componentTemplate.styles.length; i++) {
processedStyles[i] = StringWrapper.replaceAll(componentTemplate.styles[i], COMPONENT_REGEX, componentTemplate.shortId);
}
}
return processedStyles;
}
export function createRenderView(componentTemplate, cmds, inplaceElement, nodeFactory) {
var view;
var eventDispatcher = (boundElementIndex, eventName, event) => view.dispatchRenderEvent(boundElementIndex, eventName, event);
var context = new BuildContext(eventDispatcher, nodeFactory, inplaceElement);
context.build(componentTemplate, cmds);
var fragments = [];
for (var i = 0; i < context.fragments.length; i++) {
fragments.push(new DefaultRenderFragmentRef(context.fragments[i]));
}
view = new DefaultRenderView(fragments, context.boundTextNodes, context.boundElements, context.nativeShadowRoots, context.globalEventAdders, context.rootContentInsertionPoints);
return view;
}
class BuildContext {
constructor(_eventDispatcher, factory, _inplaceElement) {
this._eventDispatcher = _eventDispatcher;
this.factory = factory;
this._inplaceElement = _inplaceElement;
this._builders = [];
this.globalEventAdders = [];
this.boundElements = [];
this.boundTextNodes = [];
this.nativeShadowRoots = [];
this.fragments = [];
this.rootContentInsertionPoints = [];
this.componentCount = 0;
this.isHost = isPresent((_inplaceElement));
}
build(template, cmds) {
this.enqueueRootBuilder(template, cmds);
this._build(this._builders[0]);
}
_build(builder) {
this._builders = [];
builder.build(this);
var enqueuedBuilders = this._builders;
for (var i = 0; i < enqueuedBuilders.length; i++) {
this._build(enqueuedBuilders[i]);
}
}
enqueueComponentBuilder(component) {
this.componentCount++;
this._builders.push(new RenderViewBuilder(component, null, component.template, component.template.commands));
}
enqueueFragmentBuilder(parentComponent, parentTemplate, commands) {
var rootNodes = [];
this.fragments.push(rootNodes);
this._builders.push(new RenderViewBuilder(parentComponent, rootNodes, parentTemplate, commands));
}
enqueueRootBuilder(template, cmds) {
var rootNodes = [];
this.fragments.push(rootNodes);
this._builders.push(new RenderViewBuilder(null, rootNodes, template, cmds));
}
consumeInplaceElement() {
var result = this._inplaceElement;
this._inplaceElement = null;
return result;
}
addEventListener(boundElementIndex, target, eventName) {
if (isPresent(target)) {
var handler = createEventHandler(boundElementIndex, `${target}:${eventName}`, this._eventDispatcher);
this.globalEventAdders.push(createGlobalEventAdder(target, eventName, handler, this.factory));
}
else {
var handler = createEventHandler(boundElementIndex, eventName, this._eventDispatcher);
this.factory.on(this.boundElements[boundElementIndex], eventName, handler);
}
}
}
function createEventHandler(boundElementIndex, eventName, eventDispatcher) {
return ($event) => eventDispatcher(boundElementIndex, eventName, $event);
}
function createGlobalEventAdder(target, eventName, eventHandler, nodeFactory) {
return () => nodeFactory.globalOn(target, eventName, eventHandler);
}
class RenderViewBuilder {
constructor(parentComponent, fragmentRootNodes, template, cmds) {
this.parentComponent = parentComponent;
this.fragmentRootNodes = fragmentRootNodes;
this.template = template;
this.cmds = cmds;
var rootNodesParent = isPresent(fragmentRootNodes) ? null : parentComponent.shadowRoot;
this.parentStack = [rootNodesParent];
}
build(context) {
var cmds = this.cmds;
for (var i = 0; i < cmds.length; i++) {
cmds[i].visit(this, context);
}
}
get parent() { return this.parentStack[this.parentStack.length - 1]; }
visitText(cmd, context) {
var text = context.factory.createText(cmd.value);
this._addChild(text, cmd.ngContentIndex, context);
if (cmd.isBound) {
context.boundTextNodes.push(text);
}
return null;
}
visitNgContent(cmd, context) {
if (isPresent(this.parentComponent)) {
if (this.parentComponent.isRoot) {
var insertionPoint = context.factory.createRootContentInsertionPoint();
if (this.parent instanceof Component) {
context.factory.appendChild(this.parent.shadowRoot, insertionPoint);
}
else {
context.factory.appendChild(this.parent, insertionPoint);
}
context.rootContentInsertionPoints.push(insertionPoint);
}
else {
var projectedNodes = this.parentComponent.project(cmd.index);
for (var i = 0; i < projectedNodes.length; i++) {
var node = projectedNodes[i];
this._addChild(node, cmd.ngContentIndex, context);
}
}
}
return null;
}
visitBeginElement(cmd, context) {
this.parentStack.push(this._beginElement(cmd, context, null));
return null;
}
visitEndElement(context) {
this._endElement();
return null;
}
visitBeginComponent(cmd, context) {
var templateId = cmd.templateId;
var tpl = context.factory.resolveComponentTemplate(templateId);
var el = this._beginElement(cmd, context, tpl);
var root = el;
if (tpl.encapsulation === ViewEncapsulation.Native) {
root = context.factory.createShadowRoot(el, templateId);
context.nativeShadowRoots.push(root);
}
var isRoot = context.componentCount === 0 && context.isHost;
var component = new Component(el, root, isRoot, tpl);
context.enqueueComponentBuilder(component);
this.parentStack.push(component);
return null;
}
visitEndComponent(context) {
this._endElement();
return null;
}
visitEmbeddedTemplate(cmd, context) {
var el = context.factory.createTemplateAnchor(cmd.attrNameAndValues);
this._addChild(el, cmd.ngContentIndex, context);
context.boundElements.push(el);
if (cmd.isMerged) {
context.enqueueFragmentBuilder(this.parentComponent, this.template, cmd.children);
}
return null;
}
_beginElement(cmd, context, componentTemplate) {
var el = context.consumeInplaceElement();
var attrNameAndValues = cmd.attrNameAndValues;
var templateEmulatedEncapsulation = this.template.encapsulation === ViewEncapsulation.Emulated;
var componentEmulatedEncapsulation = isPresent(componentTemplate) &&
componentTemplate.encapsulation === ViewEncapsulation.Emulated;
var newAttrLength = attrNameAndValues.length + (templateEmulatedEncapsulation ? 2 : 0) +
(componentEmulatedEncapsulation ? 2 : 0);
if (newAttrLength > attrNameAndValues.length) {
// Note: Need to clone attrNameAndValues to make it writable!
var newAttrNameAndValues = ListWrapper.createFixedSize(newAttrLength);
var attrIndex;
for (attrIndex = 0; attrIndex < attrNameAndValues.length; attrIndex++) {
newAttrNameAndValues[attrIndex] = attrNameAndValues[attrIndex];
}
if (templateEmulatedEncapsulation) {
newAttrNameAndValues[attrIndex++] = _shimContentAttribute(this.template.shortId);
newAttrNameAndValues[attrIndex++] = '';
}
if (componentEmulatedEncapsulation) {
newAttrNameAndValues[attrIndex++] = _shimHostAttribute(componentTemplate.shortId);
newAttrNameAndValues[attrIndex++] = '';
}
attrNameAndValues = newAttrNameAndValues;
}
if (isPresent(el)) {
context.factory.mergeElement(el, attrNameAndValues);
this.fragmentRootNodes.push(el);
}
else {
el = context.factory.createElement(cmd.name, attrNameAndValues);
this._addChild(el, cmd.ngContentIndex, context);
}
if (cmd.isBound) {
var boundElementIndex = context.boundElements.length;
context.boundElements.push(el);
for (var i = 0; i < cmd.eventTargetAndNames.length; i += 2) {
var target = cmd.eventTargetAndNames[i];
var eventName = cmd.eventTargetAndNames[i + 1];
context.addEventListener(boundElementIndex, target, eventName);
}
}
return el;
}
_endElement() { this.parentStack.pop(); }
_addChild(node, ngContentIndex, context) {
var parent = this.parent;
if (isPresent(parent)) {
if (parent instanceof Component) {
parent.addContentNode(ngContentIndex, node, context);
}
else {
context.factory.appendChild(parent, node);
}
}
else {
this.fragmentRootNodes.push(node);
}
}
}
class Component {
constructor(hostElement, shadowRoot, isRoot, template) {
this.hostElement = hostElement;
this.shadowRoot = shadowRoot;
this.isRoot = isRoot;
this.template = template;
this.contentNodesByNgContentIndex = [];
}
addContentNode(ngContentIndex, node, context) {
if (isBlank(ngContentIndex)) {
if (this.template.encapsulation === ViewEncapsulation.Native) {
context.factory.appendChild(this.hostElement, node);
}
}
else {
while (this.contentNodesByNgContentIndex.length <= ngContentIndex) {
this.contentNodesByNgContentIndex.push([]);
}
this.contentNodesByNgContentIndex[ngContentIndex].push(node);
}
}
project(ngContentIndex) {
return ngContentIndex < this.contentNodesByNgContentIndex.length ?
this.contentNodesByNgContentIndex[ngContentIndex] :
[];
}
}
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);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view_factory.js","sourceRoot":"","sources":["angular2/src/core/render/view_factory.ts"],"names":["encapsulateStyles","createRenderView","BuildContext","BuildContext.constructor","BuildContext.build","BuildContext._build","BuildContext.enqueueComponentBuilder","BuildContext.enqueueFragmentBuilder","BuildContext.enqueueRootBuilder","BuildContext.consumeInplaceElement","BuildContext.addEventListener","createEventHandler","createGlobalEventAdder","RenderViewBuilder","RenderViewBuilder.constructor","RenderViewBuilder.build","RenderViewBuilder.parent","RenderViewBuilder.visitText","RenderViewBuilder.visitNgContent","RenderViewBuilder.visitBeginElement","RenderViewBuilder.visitEndElement","RenderViewBuilder.visitBeginComponent","RenderViewBuilder.visitEndComponent","RenderViewBuilder.visitEmbeddedTemplate","RenderViewBuilder._beginElement","RenderViewBuilder._endElement","RenderViewBuilder._addChild","Component","Component.constructor","Component.addContentNode","Component.project","_shimContentAttribute","_shimHostAttribute"],"mappings":"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ACjEA,CAACA;YACDA,EAAEA,CAACA,CAACA,6BAA6BA,CAACA,CAACA,CAACA;gBAClCA,oBAAoBA,CAACA,SAASA,EAAEA,CAACA,GAAGA,qBAAqBA,CAACA,IAAIA,CAACA,QAAQA,CAACA,OAAOA,CAACA,CAACA;gBACjFA,oBAAoBA,CAACA,SAASA,EAAEA,CAACA,GAAGA,EAAEA,CAACA;YACzCA,CAACA;YACDA,EAAEA,CAACA,CAACA,8BAA8BA,CAACA,CAACA,CAACA;gBACnCA,oBAAoBA,CAACA,SAASA,EAAEA,CAACA,GAAGA,kBAAkBA,CAACA,iBAAiBA,CAACA,OAAOA,CAACA,CAACA;gBAClFA,oBAAoBA,CAACA,SAASA,EAAEA,CAACA,GAAGA,EAAEA,CAACA;YACzCA,CAACA;YACDA,iBAAiBA,GAAGA,oBAAoBA,CAACA;QAC3CA,CAACA;QACDA,EAAEA,CAACA,CAACA,SAASA,CAACA,EAAEA,CAACA,CAACA,CAACA,CAACA;YAClBA,OAAOA,CAACA,OAAOA,CAACA,YAAYA,CAACA,EAAEA,EAAEA,iBAAiBA,CAACA,CAACA;YACpDA,IAAIA,CAACA,iBAAiBA,CAACA,IAAIA,CAACA,EAAEA,CAACA,CAACA;QAClCA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACNA,EAAEA,GAAGA,OAAOA,CAACA,OAAOA,CAACA,aAAaA,CAACA,GAAGA,CAACA,IAAIA,EAAEA,iBAAiBA,CAACA,CAACA;YAChEA,IAAIA,CAACA,SAASA,CAACA,EAAEA,EAAEA,GAAGA,CAACA,cAAcA,EAAEA,OAAOA,CAACA,CAACA;QAClDA,CAACA;QACDA,EAAEA,CAACA,CAACA,GAAGA,CAACA,OAAOA,CAACA,CAACA,CAACA;YAChBA,IAAIA,iBAAiBA,GAAGA,OAAOA,CAACA,aAAaA,CAACA,MAAMA,CAACA;YACrDA,OAAOA,CAACA,aAAaA,CAACA,IAAIA,CAACA,EAAEA,CAACA,CAACA;YAC/BA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,GAAGA,CAACA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","sourcesContent":["import {isBlank, isPresent, StringWrapper} from 'angular2/src/facade/lang';\nimport {\n  RenderEventDispatcher,\n  RenderTemplateCmd,\n  RenderCommandVisitor,\n  RenderBeginElementCmd,\n  RenderBeginComponentCmd,\n  RenderNgContentCmd,\n  RenderTextCmd,\n  RenderEmbeddedTemplateCmd,\n  RenderComponentTemplate\n} from './api';\nimport {DefaultRenderView, DefaultRenderFragmentRef} from './view';\nimport {ViewEncapsulation} from 'angular2/src/core/metadata';\nimport {ListWrapper} from 'angular2/src/facade/collection';\n\n\nexport function encapsulateStyles(componentTemplate: RenderComponentTemplate): string[] {\n  var processedStyles = componentTemplate.styles;\n  if (componentTemplate.encapsulation === ViewEncapsulation.Emulated) {\n    processedStyles = ListWrapper.createFixedSize(componentTemplate.styles.length);\n    for (var i = 0; i < componentTemplate.styles.length; i++) {\n      processedStyles[i] = StringWrapper.replaceAll(componentTemplate.styles[i], COMPONENT_REGEX,\n                                                    componentTemplate.shortId);\n    }\n  }\n  return processedStyles;\n}\n\nexport function createRenderView(componentTemplate: RenderComponentTemplate,\n                                 cmds: RenderTemplateCmd[], inplaceElement: any,\n                                 nodeFactory: NodeFactory<any>): DefaultRenderView<any> {\n  var view: DefaultRenderView<any>;\n  var eventDispatcher = (boundElementIndex: number, eventName: string, event: any) =>\n      view.dispatchRenderEvent(boundElementIndex, eventName, event);\n  var context = new BuildContext(eventDispatcher, nodeFactory, inplaceElement);\n  context.build(componentTemplate, cmds);\n  var fragments: DefaultRenderFragmentRef<any>[] = [];\n  for (var i = 0; i < context.fragments.length; i++) {\n    fragments.push(new DefaultRenderFragmentRef(context.fragments[i]));\n  }\n  view = new DefaultRenderView<any>(fragments, context.boundTextNodes, context.boundElements,\n                                    context.nativeShadowRoots, context.globalEventAdders,\n                                    context.rootContentInsertionPoints);\n  return view;\n}\n\nexport interface NodeFactory<N> {\n  resolveComponentTemplate(templateId: string): RenderComponentTemplate;\n  createTemplateAnchor(attrNameAndValues: string[]): N;\n  createElement(name: string, attrNameAndValues: string[]): N;\n  createRootContentInsertionPoint(): N;\n  mergeElement(existing: N, attrNameAndValues: string[]);\n  createShadowRoot(host: N, templateId: string): N;\n  createText(value: string): N;\n  appendChild(parent: N, child: N);\n  on(element: N, eventName: string, callback: Function);\n  globalOn(target: string, eventName: string, callback: Function): Function;\n}\n\nclass BuildContext<N> {\n  constructor(private _eventDispatcher: Function, public factory: NodeFactory<N>,\n              private _inplaceElement: N) {\n    this.isHost = isPresent((_inplaceElement));\n  }\n  private _builders: RenderViewBuilder<N>[] = [];\n\n  globalEventAdders: Function[] = [];\n  boundElements: N[] = [];\n  boundTextNodes: N[] = [];\n  nativeShadowRoots: N[] = [];\n  fragments: N[][] = [];\n  rootContentInsertionPoints: N[] = [];\n  componentCount: number = 0;\n  isHost: boolean;\n\n  build(template: RenderComponentTemplate, cmds: RenderTemplateCmd[]) {\n    this.enqueueRootBuilder(template, cmds);\n    this._build(this._builders[0]);\n  }\n\n  private _build(builder: RenderViewBuilder<N>) {\n    this._builders = [];\n    builder.build(this);\n    var enqueuedBuilders = this._builders;\n    for (var i = 0; i < enqueuedBuilders.length; i++) {\n      this._build(enqueuedBuilders[i]);\n    }\n  }\n\n  enqueueComponentBuilder(component: Component<N>) {\n    this.componentCount++;\n    this._builders.push(\n        new RenderViewBuilder<N>(component, null, component.template, component.template.commands));\n  }\n\n  enqueueFragmentBuilder(parentComponent: Component<N>, parentTemplate: RenderComponentTemplate,\n                         commands: RenderTemplateCmd[]) {\n    var rootNodes = [];\n    this.fragments.push(rootNodes);\n    this._builders.push(\n        new RenderViewBuilder<N>(parentComponent, rootNodes, parentTemplate, commands));\n  }\n\n  enqueueRootBuilder(template: RenderComponentTemplate, cmds: RenderTemplateCmd[]) {\n    var rootNodes = [];\n    this.fragments.push(rootNodes);\n    this._builders.push(new RenderViewBuilder<N>(null, rootNodes, template, cmds));\n  }\n\n  consumeInplaceElement(): N {\n    var result = this._inplaceElement;\n    this._inplaceElement = null;\n    return result;\n  }\n\n  addEventListener(boundElementIndex: number, target: string, eventName: string) {\n    if (isPresent(target)) {\n      var handler =\n          createEventHandler(boundElementIndex, `${target}:${eventName}`, this._eventDispatcher);\n      this.globalEventAdders.push(createGlobalEventAdder(target, eventName, handler, this.factory));\n    } else {\n      var handler = createEventHandler(boundElementIndex, eventName, this._eventDispatcher);\n      this.factory.on(this.boundElements[boundElementIndex], eventName, handler);\n    }\n  }\n}\n\n\nfunction createEventHandler(boundElementIndex: number, eventName: string,\n                            eventDispatcher: Function): Function {\n  return ($event) => eventDispatcher(boundElementIndex, eventName, $event);\n}\n\nfunction createGlobalEventAdder(target: string, eventName: string, eventHandler: Function,\n                                nodeFactory: NodeFactory<any>): Function {\n  return () => nodeFactory.globalOn(target, eventName, eventHandler);\n}\n\nclass RenderViewBuilder<N> implements RenderCommandVisitor {\n  parentStack: Array<N | Component<N>>;\n\n  constructor(public parentComponent: Component<N>, public fragmentRootNodes: N[],\n              public template: RenderComponentTemplate, public cmds: RenderTemplateCmd[]) {\n    var rootNodesParent = isPresent(fragmentRootNodes) ? null : parentComponent.shadowRoot;\n    this.parentStack = [rootNodesParent];\n  }\n\n  build(context: BuildContext<N>) {\n    var cmds = this.cmds;\n    for (var i = 0; i < cmds.length; i++) {\n      cmds[i].visit(this, context);\n    }\n  }\n\n  get parent(): N | Component<N> { return this.parentStack[this.parentStack.length - 1]; }\n\n  visitText(cmd: RenderTextCmd, context: BuildContext<N>): any {\n    var text = context.factory.createText(cmd.value);\n    this._addChild(text, cmd.ngContentIndex, context);\n    if (cmd.isBound) {\n      context.boundTextNodes.push(text);\n    }\n    return null;\n  }\n  visitNgContent(cmd: RenderNgContentCmd, context: BuildContext<N>): any {\n    if (isPresent(this.parentComponent)) {\n      if (this.parentComponent.isRoot) {\n        var insertionPoint = context.factory.createRootContentInsertionPoint();\n        if (this.parent instanceof Component) {\n          context.factory.appendChild((<Component<N>>this.parent).shadowRoot, insertionPoint);\n        } else {\n          context.factory.appendChild(<N>this.parent, insertionPoint);\n        }\n        context.rootContentInsertionPoints.push(insertionPoint);\n      } else {\n        var projectedNodes = this.parentComponent.project(cmd.index);\n        for (var i = 0; i < projectedNodes.length; i++) {\n          var node = projectedNodes[i];\n          this._addChild(node, cmd.ngContentIndex, context);\n        }\n      }\n    }\n    return null;\n  }\n  visitBeginElement(cmd: RenderBeginElementCmd, context: BuildContext<N>): any {\n    this.parentStack.push(this._beginElement(cmd, context, null));\n    return null;\n  }\n  visitEndElement(context: BuildContext<N>): any {\n    this._endElement();\n    return null;\n  }\n  visitBeginComponent(cmd: RenderBeginComponentCmd, context: BuildContext<N>): any {\n    var templateId = cmd.templateId;\n    var tpl = context.factory.resolveComponentTemplate(templateId);\n    var el = this._beginElement(cmd, context, tpl);\n    var root = el;\n\n    if (tpl.encapsulation === ViewEncapsulation.Native) {\n      root = context.factory.createShadowRoot(el, templateId);\n      context.nativeShadowRoots.push(root);\n    }\n    var isRoot = context.componentCount === 0 && context.isHost;\n    var component = new Component(el, root, isRoot, tpl);\n    context.enqueueComponentBuilder(component);\n    this.parentStack.push(component);\n    return null;\n  }\n  visitEndComponent(context: BuildContext<N>): any {\n    this._endElement();\n    return null;\n  }\n  visitEmbeddedTemplate(cmd: RenderEmbeddedTemplateCmd, context: BuildContext<N>): any {\n    var el = context.factory.createTemplateAnchor(cmd.attrNameAndValues);\n    this._addChild(el, cmd.ngContentIndex, context);\n    context.boundElements.push(el);\n    if (cmd.isMerged) {\n      context.enqueueFragmentBuilder(this.parentComponent, this.template, cmd.children);\n    }\n    return null;\n  }\n\n  private _beginElement(cmd: RenderBeginElementCmd, context: BuildContext<N>,\n                        componentTemplate: RenderComponentTemplate): N {\n    var el: N = context.consumeInplaceElement();\n    var attrNameAndValues = cmd.attrNameAndValues;\n    var templateEmulatedEncapsulation = this.template.encapsulation === ViewEncapsulation.Emulated;\n    var componentEmulatedEncapsulation =\n        isPresent(componentTemplate) &&\n        componentTemplate.encapsulation === ViewEncapsulation.Emulated;\n    var newAttrLength = attrNameAndValues.length + (templateEmulatedEncapsulation ? 2 : 0) +\n                        (componentEmulatedEncapsulation ? 2 : 0);\n    if (newAttrLength > attrNameAndValues.length) {\n      // Note: Need to clone attrNameAndValues to make it writable!\n      var newAttrNameAndValues = ListWrapper.createFixedSize(newAttrLength);\n      var attrIndex;\n      for (attrIndex = 0; attrIndex < attrNameAndValues.length; attrIndex++) {\n        newAttrNameAndValues[attrIndex] = attrNameAndValues[attrIndex];\n      }\n      if (templateEmulatedEncapsulation) {\n        newAttrNameAndValues[attrIndex++] = _shimContentAttribute(this.template.shortId);\n        newAttrNameAndValues[attrIndex++] = '';\n      }\n      if (componentEmulatedEncapsulation) {\n        newAttrNameAndValues[attrIndex++] = _shimHostAttribute(componentTemplate.shortId);\n        newAttrNameAndValues[attrIndex++] = '';\n      }\n      attrNameAndValues = newAttrNameAndValues;\n    }\n    if (isPresent(el)) {\n      context.factory.mergeElement(el, attrNameAndValues);\n      this.fragmentRootNodes.push(el);\n    } else {\n      el = context.factory.createElement(cmd.name, attrNameAndValues);\n      this._addChild(el, cmd.ngContentIndex, context);\n    }\n    if (cmd.isBound) {\n      var boundElementIndex = context.boundElements.length;\n      context.boundElements.push(el);\n      for (var i = 0; i < cmd.eventTargetAndNames.length; i += 2) {\n        var target = cmd.eventTargetAndNames[i];\n        var eventName = cmd.eventTargetAndNames[i + 1];\n        context.addEventListener(boundElementIndex, target, eventName);\n      }\n    }\n    return el;\n  }\n\n  private _endElement() { this.parentStack.pop(); }\n\n  private _addChild(node: N, ngContentIndex: number, context: BuildContext<N>) {\n    var parent = this.parent;\n    if (isPresent(parent)) {\n      if (parent instanceof Component) {\n        parent.addContentNode(ngContentIndex, node, context);\n      } else {\n        context.factory.appendChild(<N>parent, node);\n      }\n    } else {\n      this.fragmentRootNodes.push(node);\n    }\n  }\n}\n\nclass Component<N> {\n  private contentNodesByNgContentIndex: N[][] = [];\n\n  constructor(public hostElement: N, public shadowRoot: N, public isRoot: boolean,\n              public template: RenderComponentTemplate) {}\n  addContentNode(ngContentIndex: number, node: N, context: BuildContext<N>) {\n    if (isBlank(ngContentIndex)) {\n      if (this.template.encapsulation === ViewEncapsulation.Native) {\n        context.factory.appendChild(this.hostElement, node);\n      }\n    } else {\n      while (this.contentNodesByNgContentIndex.length <= ngContentIndex) {\n        this.contentNodesByNgContentIndex.push([]);\n      }\n      this.contentNodesByNgContentIndex[ngContentIndex].push(node);\n    }\n  }\n  project(ngContentIndex: number): N[] {\n    return ngContentIndex < this.contentNodesByNgContentIndex.length ?\n               this.contentNodesByNgContentIndex[ngContentIndex] :\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"]}