mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
The goal is to make implementing a renderer straight forward.
BREAKING_CHANGE:
- Renderer interface was redone / simplified.
- `DirectDomRenderer` was replaced by `DomRenderer`.
- `DirectDomRenderer.setImperativeComponentRootNodes` is replaced
by the following 2 steps:
1. `ViewManager.getComponentView(elementRef) -> ViewRef`
2. `DomRenderer.setComponentViewRootNodes(viewRef, rootNodes)`
- all `@View` annotations need to have a template, but the template
may be empty. Previously views that had a `renderer` property did
not have to have a `template`.
- `dynamicComponentLoader.loadIntoNewLocation` does no more allow
to pass an element, but requires a css selector.
Special syntax: `:document` can be used as prefix to search globally
on the document instead of in the provided parent view.
Part of #1675
49 lines
1.2 KiB
JavaScript
49 lines
1.2 KiB
JavaScript
import {List, ListWrapper} from 'angular2/src/facade/collection';
|
|
import {DOM} from 'angular2/src/dom/dom_adapter';
|
|
import {isPresent} from 'angular2/src/facade/lang';
|
|
import {resolveInternalDomView} from 'angular2/src/render/dom/view/view';
|
|
|
|
export class Log {
|
|
_result:List;
|
|
|
|
constructor() {
|
|
this._result = [];
|
|
}
|
|
|
|
add(value):void {
|
|
ListWrapper.push(this._result, value);
|
|
}
|
|
|
|
fn(value) {
|
|
return (a1 = null, a2 = null, a3 = null, a4 = null, a5 = null) => {
|
|
ListWrapper.push(this._result, value);
|
|
}
|
|
}
|
|
|
|
result():string {
|
|
return ListWrapper.join(this._result, "; ");
|
|
}
|
|
}
|
|
|
|
export function viewRootNodes(view):List {
|
|
return resolveInternalDomView(view.render).rootNodes;
|
|
}
|
|
|
|
export function queryView(view, selector:string) {
|
|
var rootNodes = viewRootNodes(view);
|
|
for (var i = 0; i < rootNodes.length; ++i) {
|
|
var res = DOM.querySelector(rootNodes[i], selector);
|
|
if (isPresent(res)) {
|
|
return res;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
export function dispatchEvent(element, eventType) {
|
|
DOM.dispatchEvent(element, DOM.createEvent(eventType));
|
|
}
|
|
|
|
export function el(html:string) {
|
|
return DOM.firstChild(DOM.content(DOM.createTemplate(html)));
|
|
}
|