UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

153 lines (148 loc) 26.7 kB
import { unimplemented } from 'angular2/src/facade/exceptions'; /** * Represents an Angular ProtoView in the Rendering Context. * * When you implement a custom {@link Renderer}, `RenderProtoViewRef` specifies what Render View * your renderer should create. * * `RenderProtoViewRef` is a counterpart to {@link ProtoViewRef} available in the Application * Context. But unlike `ProtoViewRef`, `RenderProtoViewRef` contains all static nested Proto Views * that are recursively merged into a single Render Proto View. * * <!-- TODO: this is created by Renderer#createProtoView in the new compiler --> */ export class RenderProtoViewRef { } /** * Represents a list of sibling Nodes that can be moved by the {@link Renderer} independently of * other Render Fragments. * * Any {@link RenderView} has one Render Fragment. * * Additionally any View with an Embedded View that contains a {@link NgContent View Projection} * results in additional Render Fragment. */ /* <div>foo</div> {{bar}} <div>foo</div> -> view 1 / fragment 1 <ul> <template ng-for> <li>{{fg}}</li> -> view 2 / fragment 1 </template> </ul> {{bar}} <div>foo</div> -> view 1 / fragment 1 <ul> <template ng-if> <li><ng-content></></li> -> view 1 / fragment 2 </template> <template ng-for> <li><ng-content></></li> -> <li></li> -> view 1 / fragment 2 + view 2 / fragment 1..n-1 </template> </ul> {{bar}} */ // TODO(i): refactor into an interface export class RenderFragmentRef { } /** * Represents an Angular View in the Rendering Context. * * `RenderViewRef` specifies to the {@link Renderer} what View to update or destroy. * * Unlike a {@link ViewRef} available in the Application Context, Render View contains all the * static Component Views that have been recursively merged into a single Render View. * * Each `RenderViewRef` contains one or more {@link RenderFragmentRef Render Fragments}, these * Fragments are created, hydrated, dehydrated and destroyed as a single unit together with the * View. */ // TODO(i): refactor into an interface export class RenderViewRef { } export class RenderTemplateCmd { } export class RenderBeginCmd extends RenderTemplateCmd { get ngContentIndex() { return unimplemented(); } ; get isBound() { return unimplemented(); } ; } export class RenderTextCmd extends RenderBeginCmd { get value() { return unimplemented(); } ; } export class RenderNgContentCmd extends RenderTemplateCmd { // The index of this NgContent element get index() { return unimplemented(); } ; // The index of the NgContent element into which this // NgContent element should be projected (if any) get ngContentIndex() { return unimplemented(); } ; } export class RenderBeginElementCmd extends RenderBeginCmd { get name() { return unimplemented(); } ; get attrNameAndValues() { return unimplemented(); } ; get eventTargetAndNames() { return unimplemented(); } ; } export class RenderBeginComponentCmd extends RenderBeginElementCmd { get templateId() { return unimplemented(); } ; } export class RenderEmbeddedTemplateCmd extends RenderBeginElementCmd { get isMerged() { return unimplemented(); } ; get children() { return unimplemented(); } ; } /** * Container class produced by a {@link Renderer} when creating a Render View. * * An instance of `RenderViewWithFragments` contains a {@link RenderViewRef} and an array of * {@link RenderFragmentRef}s belonging to this Render View. */ // TODO(i): refactor this by RenderViewWithFragments and adding fragments directly to RenderViewRef export class RenderViewWithFragments { constructor( /** * Reference to the {@link RenderViewRef}. */ viewRef, /** * Array of {@link RenderFragmentRef}s ordered in the depth-first order. */ fragmentRefs) { this.viewRef = viewRef; this.fragmentRefs = fragmentRefs; } } export class RenderComponentTemplate { constructor(id, shortId, encapsulation, commands, styles) { this.id = id; this.shortId = shortId; this.encapsulation = encapsulation; this.commands = commands; this.styles = styles; } } /** * Injectable service that provides a low-level interface for modifying the UI. * * Use this service to bypass Angular's templating and make custom UI changes that can't be * expressed declaratively. For example if you need to set a property or an attribute whose name is * not statically known, use {@link #setElementProperty} or {@link #setElementAttribute} * respectively. * * If you are implementing a custom renderer, you must implement this interface. * * The default Renderer implementation is {@link DomRenderer}. Also see {@link WebWorkerRenderer}. */ export class Renderer { } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["angular2/src/core/render/api.ts"],"names":["RenderProtoViewRef","RenderFragmentRef","RenderViewRef","RenderTemplateCmd","RenderBeginCmd","RenderBeginCmd.ngContentIndex","RenderBeginCmd.isBound","RenderTextCmd","RenderTextCmd.value","RenderNgContentCmd","RenderNgContentCmd.index","RenderNgContentCmd.ngContentIndex","RenderBeginElementCmd","RenderBeginElementCmd.name","RenderBeginElementCmd.attrNameAndValues","RenderBeginElementCmd.eventTargetAndNames","RenderBeginComponentCmd","RenderBeginComponentCmd.templateId","RenderEmbeddedTemplateCmd","RenderEmbeddedTemplateCmd.isMerged","RenderEmbeddedTemplateCmd.children","RenderViewWithFragments","RenderViewWithFragments.constructor","RenderComponentTemplate","RenderComponentTemplate.constructor","Renderer"],"mappings":"OAAO,EAAC,aAAa,EAAC,MAAM,gCAAgC;AAI5D;;;;;;;;;;;;GAYG;AACH;AAAiCA,CAACA;AAElC;;;;;;;;GAQG;AACH;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,sCAAsC;AACtC;AAAgCC,CAACA;AAGjC;;;;;;;;;;;GAWG;AACH,sCAAsC;AACtC;AAA4BC,CAACA;AAE7B;AAEAC,CAACA;AAED,oCAA6C,iBAAiB;IAC5DC,IAAIA,cAAcA,KAAaC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;IACxDD,IAAIA,OAAOA,KAAcE,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AACpDF,CAACA;AAED,mCAA4C,cAAc;IACxDG,IAAIA,KAAKA,KAAaC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AACjDD,CAACA;AAED,wCAAiD,iBAAiB;IAChEE,sCAAsCA;IACtCA,IAAIA,KAAKA,KAAaC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;IAC/CD,qDAAqDA;IACrDA,iDAAiDA;IACjDA,IAAIA,cAAcA,KAAaE,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AAC1DF,CAACA;AAED,2CAAoD,cAAc;IAChEG,IAAIA,IAAIA,KAAaC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;IAC9CD,IAAIA,iBAAiBA,KAAeE,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;IAC7DF,IAAIA,mBAAmBA,KAAeG,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AACjEH,CAACA;AAED,6CAAsD,qBAAqB;IACzEI,IAAIA,UAAUA,KAAaC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AACtDD,CAACA;AAED,+CAAwD,qBAAqB;IAC3EE,IAAIA,QAAQA,KAAcC,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;IACnDD,IAAIA,QAAQA,KAA0BE,MAAMA,CAACA,aAAaA,EAAEA,CAACA,CAACA,CAACA;;AACjEF,CAACA;AAaD;;;;;GAKG;AACH,mGAAmG;AACnG;IACEG;QACIA;;WAEGA;QACIA,OAAsBA;QAC7BA;;WAEGA;QACIA,YAAiCA;QAJjCC,YAAOA,GAAPA,OAAOA,CAAeA;QAItBA,iBAAYA,GAAZA,YAAYA,CAAqBA;IAAGA,CAACA;AAClDD,CAACA;AA0BD;IACEE,YAAmBA,EAAUA,EAASA,OAAeA,EAASA,aAAgCA,EAC3EA,QAA6BA,EAASA,MAAgBA;QADtDC,OAAEA,GAAFA,EAAEA,CAAQA;QAASA,YAAOA,GAAPA,OAAOA,CAAQA;QAASA,kBAAaA,GAAbA,aAAaA,CAAmBA;QAC3EA,aAAQA,GAARA,QAAQA,CAAqBA;QAASA,WAAMA,GAANA,MAAMA,CAAUA;IAAGA,CAACA;AAC/ED,CAACA;AAED;;;;;;;;;;;GAWG;AACH;AA4JAE,CAACA;AAAA","sourcesContent":["import {unimplemented} from 'angular2/src/facade/exceptions';\nimport {Map} from 'angular2/src/facade/collection';\nimport {ViewEncapsulation} from 'angular2/src/core/metadata';\n\n/**\n * Represents an Angular ProtoView in the Rendering Context.\n *\n * When you implement a custom {@link Renderer}, `RenderProtoViewRef` specifies what Render View\n * your renderer should create.\n *\n * `RenderProtoViewRef` is a counterpart to {@link ProtoViewRef} available in the Application\n * Context. But unlike `ProtoViewRef`, `RenderProtoViewRef` contains all static nested Proto Views\n * that are recursively merged into a single Render Proto View.\n\n *\n * <!-- TODO: this is created by Renderer#createProtoView in the new compiler -->\n */\nexport class RenderProtoViewRef {}\n\n/**\n * Represents a list of sibling Nodes that can be moved by the {@link Renderer} independently of\n * other Render Fragments.\n *\n * Any {@link RenderView} has one Render Fragment.\n *\n * Additionally any View with an Embedded View that contains a {@link NgContent View Projection}\n * results in additional Render Fragment.\n */\n/*\n  <div>foo</div>\n  {{bar}}\n\n\n  <div>foo</div> -> view 1 / fragment 1\n  <ul>\n    <template ng-for>\n      <li>{{fg}}</li> -> view 2 / fragment 1\n    </template>\n  </ul>\n  {{bar}}\n\n\n  <div>foo</div> -> view 1 / fragment 1\n  <ul>\n    <template ng-if>\n      <li><ng-content></></li> -> view 1 / fragment 2\n    </template>\n    <template ng-for>\n      <li><ng-content></></li> ->\n      <li></li>                -> view 1 / fragment 2 + view 2 / fragment 1..n-1\n    </template>\n  </ul>\n  {{bar}}\n */\n// TODO(i): refactor into an interface\nexport class RenderFragmentRef {}\n\n\n/**\n * Represents an Angular View in the Rendering Context.\n *\n * `RenderViewRef` specifies to the {@link Renderer} what View to update or destroy.\n *\n * Unlike a {@link ViewRef} available in the Application Context, Render View contains all the\n * static Component Views that have been recursively merged into a single Render View.\n *\n * Each `RenderViewRef` contains one or more {@link RenderFragmentRef Render Fragments}, these\n * Fragments are created, hydrated, dehydrated and destroyed as a single unit together with the\n * View.\n */\n// TODO(i): refactor into an interface\nexport class RenderViewRef {}\n\nexport abstract class RenderTemplateCmd {\n  abstract visit(visitor: RenderCommandVisitor, context: any): any;\n}\n\nexport abstract class RenderBeginCmd extends RenderTemplateCmd {\n  get ngContentIndex(): number { return unimplemented(); };\n  get isBound(): boolean { return unimplemented(); };\n}\n\nexport abstract class RenderTextCmd extends RenderBeginCmd {\n  get value(): string { return unimplemented(); };\n}\n\nexport abstract class RenderNgContentCmd extends RenderTemplateCmd {\n  // The index of this NgContent element\n  get index(): number { return unimplemented(); };\n  // The index of the NgContent element into which this\n  // NgContent element should be projected (if any)\n  get ngContentIndex(): number { return unimplemented(); };\n}\n\nexport abstract class RenderBeginElementCmd extends RenderBeginCmd {\n  get name(): string { return unimplemented(); };\n  get attrNameAndValues(): string[] { return unimplemented(); };\n  get eventTargetAndNames(): string[] { return unimplemented(); };\n}\n\nexport abstract class RenderBeginComponentCmd extends RenderBeginElementCmd {\n  get templateId(): string { return unimplemented(); };\n}\n\nexport abstract class RenderEmbeddedTemplateCmd extends RenderBeginElementCmd {\n  get isMerged(): boolean { return unimplemented(); };\n  get children(): RenderTemplateCmd[] { return unimplemented(); };\n}\n\nexport interface RenderCommandVisitor {\n  visitText(cmd: RenderTextCmd, context: any): any;\n  visitNgContent(cmd: RenderNgContentCmd, context: any): any;\n  visitBeginElement(cmd: RenderBeginElementCmd, context: any): any;\n  visitEndElement(context: any): any;\n  visitBeginComponent(cmd: RenderBeginComponentCmd, context: any): any;\n  visitEndComponent(context: any): any;\n  visitEmbeddedTemplate(cmd: RenderEmbeddedTemplateCmd, context: any): any;\n}\n\n\n/**\n * Container class produced by a {@link Renderer} when creating a Render View.\n *\n * An instance of `RenderViewWithFragments` contains a {@link RenderViewRef} and an array of\n * {@link RenderFragmentRef}s belonging to this Render View.\n */\n// TODO(i): refactor this by RenderViewWithFragments and adding fragments directly to RenderViewRef\nexport class RenderViewWithFragments {\n  constructor(\n      /**\n       * Reference to the {@link RenderViewRef}.\n       */\n      public viewRef: RenderViewRef,\n      /**\n       * Array of {@link RenderFragmentRef}s ordered in the depth-first order.\n       */\n      public fragmentRefs: RenderFragmentRef[]) {}\n}\n\n/**\n * Represents an Element that is part of a {@link RenderViewRef Render View}.\n *\n * `RenderElementRef` is a counterpart to {@link ElementRef} available in the Application Context.\n *\n * When using `Renderer` from the Application Context, `ElementRef` can be used instead of\n * `RenderElementRef`.\n */\nexport interface RenderElementRef {\n  /**\n   * Reference to the Render View that contains this Element.\n   */\n  renderView: RenderViewRef;\n\n  /**\n   * @internal\n   *\n   * Index of the Element (in the depth-first order) inside the Render View.\n   *\n   * This index is used internally by Angular to locate elements.\n   */\n  boundElementIndex: number;\n}\n\nexport class RenderComponentTemplate {\n  constructor(public id: string, public shortId: string, public encapsulation: ViewEncapsulation,\n              public commands: RenderTemplateCmd[], public styles: string[]) {}\n}\n\n/**\n * Injectable service that provides a low-level interface for modifying the UI.\n *\n * Use this service to bypass Angular's templating and make custom UI changes that can't be\n * expressed declaratively. For example if you need to set a property or an attribute whose name is\n * not statically known, use {@link #setElementProperty} or {@link #setElementAttribute}\n * respectively.\n *\n * If you are implementing a custom renderer, you must implement this interface.\n *\n * The default Renderer implementation is {@link DomRenderer}. Also see {@link WebWorkerRenderer}.\n */\nexport abstract class Renderer {\n  /**\n   * Registers a component template represented as arrays of {@link RenderTemplateCmd}s and styles\n   * with the Renderer.\n   *\n   * Once a template is registered it can be referenced via {@link RenderBeginComponentCmd} when\n   * {@link #createProtoView creating Render ProtoView}.\n   */\n  abstract registerComponentTemplate(template: RenderComponentTemplate);\n\n  /**\n   * Creates a {@link RenderProtoViewRef} from an array of {@link RenderTemplateCmd}`s.\n   */\n  abstract createProtoView(componentTemplateId: string,\n                           cmds: RenderTemplateCmd[]): RenderProtoViewRef;\n\n  /**\n   * Creates a Root Host View based on the provided `hostProtoViewRef`.\n   *\n   * `fragmentCount` is the number of nested {@link RenderFragmentRef}s in this View. This parameter\n   * is non-optional so that the renderer can create a result synchronously even when application\n   * runs in a different context (e.g. in a Web Worker).\n   *\n   * `hostElementSelector` is a (CSS) selector for querying the main document to find the Host\n   * Element. The newly created Root Host View should be attached to this element.\n   *\n   * Returns an instance of {@link RenderViewWithFragments}, representing the Render View.\n   */\n  abstract createRootHostView(hostProtoViewRef: RenderProtoViewRef, fragmentCount: number,\n                              hostElementSelector: string): RenderViewWithFragments;\n\n  /**\n   * Creates a Render View based on the provided `protoViewRef`.\n   *\n   * `fragmentCount` is the number of nested {@link RenderFragmentRef}s in this View. This parameter\n   * is non-optional so that the renderer can create a result synchronously even when application\n   * runs in a different context (e.g. in a Web Worker).\n   *\n   * Returns an instance of {@link RenderViewWithFragments}, representing the Render View.\n   */\n  abstract createView(protoViewRef: RenderProtoViewRef,\n                      fragmentCount: number): RenderViewWithFragments;\n\n  /**\n   * Destroys a Render View specified via `viewRef`.\n   *\n   * This operation should be performed only on a View that has already been dehydrated and\n   * all of its Render Fragments have been detached.\n   *\n   * Destroying a View indicates to the Renderer that this View is not going to be referenced in any\n   * future operations. If the Renderer created any renderer-specific objects for this View, these\n   * objects should now be destroyed to prevent memory leaks.\n   */\n  abstract destroyView(viewRef: RenderViewRef);\n\n  /**\n   * Attaches the Nodes of a Render Fragment after the last Node of `previousFragmentRef`.\n   */\n  abstract attachFragmentAfterFragment(previousFragmentRef: RenderFragmentRef,\n                                       fragmentRef: RenderFragmentRef);\n\n  /**\n   * Attaches the Nodes of the Render Fragment after an Element.\n   */\n  abstract attachFragmentAfterElement(elementRef: RenderElementRef, fragmentRef: RenderFragmentRef);\n\n  /**\n   * Detaches the Nodes of a Render Fragment from their parent.\n   *\n   * This operations should be called only on a View that has been already\n   * {@link #dehydrateView dehydrated}.\n   */\n  abstract detachFragment(fragmentRef: RenderFragmentRef);\n\n  /**\n   * Notifies a custom Renderer to initialize a Render View.\n   *\n   * This method is called by Angular after a Render View has been created, or when a previously\n   * dehydrated Render View is about to be reused.\n   */\n  abstract hydrateView(viewRef: RenderViewRef);\n\n  /**\n   * Notifies a custom Renderer that a Render View is no longer active.\n   *\n   * This method is called by Angular before a Render View will be destroyed, or when a hydrated\n   * Render View is about to be put into a pool for future reuse.\n   */\n  abstract dehydrateView(viewRef: RenderViewRef);\n\n  /**\n   * Returns the underlying native element at the specified `location`, or `null` if direct access\n   * to native elements is not supported (e.g. when the application runs in a web worker).\n   *\n   * <div class=\"callout is-critical\">\n   *   <header>Use with caution</header>\n   *   <p>\n   *    Use this api as the last resort when direct access to DOM is needed. Use templating and\n   *    data-binding, or other {@link Renderer} methods instead.\n   *   </p>\n   *   <p>\n   *    Relying on direct DOM access creates tight coupling between your application and rendering\n   *    layers which will make it impossible to separate the two and deploy your application into a\n   *    web worker.\n   *   </p>\n   * </div>\n   */\n  abstract getNativeElementSync(location: RenderElementRef): any;\n\n  /**\n   * Sets a property on the Element specified via `location`.\n   */\n  abstract setElementProperty(location: RenderElementRef, propertyName: string, propertyValue: any);\n\n  /**\n   * Sets an attribute on the Element specified via `location`.\n   *\n   * If `attributeValue` is `null`, the attribute is removed.\n   */\n  abstract setElementAttribute(location: RenderElementRef, attributeName: string,\n                               attributeValue: string);\n\n  /**\n   * Sets a (CSS) class on the Element specified via `location`.\n   *\n   * `isAdd` specifies if the class should be added or removed.\n   */\n  abstract setElementClass(location: RenderElementRef, className: string, isAdd: boolean);\n\n  /**\n   * Sets a (CSS) inline style on the Element specified via `location`.\n   *\n   * If `styleValue` is `null`, the style is removed.\n   */\n  abstract setElementStyle(location: RenderElementRef, styleName: string, styleValue: string);\n\n  /**\n   * Calls a method on the Element specified via `location`.\n   */\n  abstract invokeElementMethod(location: RenderElementRef, methodName: string, args: any[]);\n\n  /**\n   * Sets the value of an interpolated TextNode at the specified index to the `text` value.\n   *\n   * `textNodeIndex` is the depth-first index of the Node among interpolated Nodes in the Render\n   * View.\n   */\n  abstract setText(viewRef: RenderViewRef, textNodeIndex: number, text: string);\n\n  /**\n   * Sets a dispatcher to relay all events triggered in the given Render View.\n   *\n   * Each Render View can have only one Event Dispatcher, if this method is called multiple times,\n   * the last provided dispatcher will be used.\n   */\n  abstract setEventDispatcher(viewRef: RenderViewRef, dispatcher: RenderEventDispatcher);\n}\n\n/**\n * A dispatcher that relays all events that occur in a Render View.\n *\n * Use {@link Renderer#setEventDispatcher} to register a dispatcher for a particular Render View.\n */\nexport interface RenderEventDispatcher {\n  /**\n   * Called when Event called `eventName` was triggered on an Element with an Event Binding for this\n   * Event.\n   *\n   * `elementIndex` specifies the depth-first index of the Element in the Render View.\n   *\n   * `locals` is a map for local variable to value mapping that should be used when evaluating the\n   * Event Binding expression.\n   *\n   * Returns `false` if `preventDefault` should be called to stop the default behavior of the Event\n   * in the Rendering Context.\n   */\n  dispatchRenderEvent(elementIndex: number, eventName: string, locals: Map<string, any>): boolean;\n}\n"]}