Now, using `ng.probe(element)` in the browser console returns a DebugElement when in dev mode. `ComponentFixture#debugElement` also returns a new DebugElement. Breaking Change: This is a breaking change for unit tests. The API for the DebugElement has changed. Now, there is a DebugElement or DebugNode for every node in the DOM, not only nodes with an ElementRef. `componentViewChildren` is removed, and `childNodes` is a list of ElementNodes corresponding to every child in the DOM. `query` no longer takes a scope parameter, since the entire rendered DOM is included in the `childNodes`. Before: ``` componentFixture.debugElement.componentViewChildren[0]; ``` After ``` // Depending on the DOM structure of your component, the // index may have changed or the first component child // may be a sub-child. componentFixture.debugElement.children[0]; ``` Before: ``` debugElement.query(By.css('div'), Scope.all()); ``` After: ``` debugElement.query(By.css('div')); ``` Before: ``` componentFixture.debugElement.elementRef; ``` After: ``` componentFixture.elementRef; ```
78 lines
2.8 KiB
TypeScript
78 lines
2.8 KiB
TypeScript
import {ViewEncapsulation} from 'angular2/src/core/metadata/view';
|
|
import {Injector} from 'angular2/src/core/di/injector';
|
|
|
|
export class RenderComponentType {
|
|
constructor(public id: string, public encapsulation: ViewEncapsulation,
|
|
public styles: Array<string | any[]>) {}
|
|
}
|
|
|
|
export class RenderDebugInfo {
|
|
constructor(public injector: Injector, public component: any, public providerTokens: any[],
|
|
public locals: Map<string, any>) {}
|
|
}
|
|
|
|
export interface ParentRenderer { renderComponent(componentType: RenderComponentType): Renderer; }
|
|
|
|
export abstract class Renderer implements ParentRenderer {
|
|
abstract renderComponent(componentType: RenderComponentType): Renderer;
|
|
|
|
abstract selectRootElement(selector: string): any;
|
|
|
|
abstract createElement(parentElement: any, name: string): any;
|
|
|
|
abstract createViewRoot(hostElement: any): any;
|
|
|
|
abstract createTemplateAnchor(parentElement: any): any;
|
|
|
|
abstract createText(parentElement: any, value: string): any;
|
|
|
|
abstract projectNodes(parentElement: any, nodes: any[]);
|
|
|
|
abstract attachViewAfter(node: any, viewRootNodes: any[]);
|
|
|
|
abstract detachView(viewRootNodes: any[]);
|
|
|
|
abstract destroyView(hostElement: any, viewAllNodes: any[]);
|
|
|
|
abstract listen(renderElement: any, name: string, callback: Function): Function;
|
|
|
|
abstract listenGlobal(target: string, name: string, callback: Function): Function;
|
|
|
|
abstract setElementProperty(renderElement: any, propertyName: string, propertyValue: any);
|
|
|
|
abstract setElementAttribute(renderElement: any, attributeName: string, attributeValue: string);
|
|
|
|
/**
|
|
* Used only in debug mode to serialize property changes to comment nodes,
|
|
* such as <template> placeholders.
|
|
*/
|
|
abstract setBindingDebugInfo(renderElement: any, propertyName: string, propertyValue: string);
|
|
|
|
abstract setElementDebugInfo(renderElement: any, info: RenderDebugInfo);
|
|
|
|
abstract setElementClass(renderElement: any, className: string, isAdd: boolean);
|
|
|
|
abstract setElementStyle(renderElement: any, styleName: string, styleValue: string);
|
|
|
|
abstract invokeElementMethod(renderElement: any, methodName: string, args: any[]);
|
|
|
|
abstract setText(renderNode: any, text: string);
|
|
}
|
|
|
|
/**
|
|
* 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 `DomRenderer`. Also available is `WebWorkerRenderer`.
|
|
*/
|
|
|
|
export abstract class RootRenderer implements ParentRenderer {
|
|
abstract renderComponent(componentType: RenderComponentType): Renderer;
|
|
}
|