2016-08-30 14:17:37 -07:00
|
|
|
import {ApplicationRef, NgModule, enableProdMode} from '@angular/core';
|
2016-08-26 12:27:24 -07:00
|
|
|
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
|
|
|
|
|
2016-08-30 14:17:37 -07:00
|
|
|
import {bindAction, profile} from '../../util';
|
|
|
|
import {TreeNode, buildTree, emptyTree} from '../util';
|
2016-08-26 12:27:24 -07:00
|
|
|
|
2016-08-30 14:17:37 -07:00
|
|
|
import {AppModule, TreeComponent} from './tree';
|
2016-08-26 15:44:05 -07:00
|
|
|
|
2016-08-26 12:27:24 -07:00
|
|
|
export function main() {
|
2016-08-30 14:17:37 -07:00
|
|
|
var tree: TreeComponent;
|
2016-08-26 12:27:24 -07:00
|
|
|
var appRef: ApplicationRef;
|
|
|
|
|
|
|
|
function destroyDom() {
|
2016-08-30 14:17:37 -07:00
|
|
|
tree.data = emptyTree;
|
2016-08-26 12:27:24 -07:00
|
|
|
appRef.tick();
|
|
|
|
}
|
|
|
|
|
|
|
|
function createDom() {
|
2016-08-30 14:17:37 -07:00
|
|
|
tree.data = buildTree();
|
2016-08-26 12:27:24 -07:00
|
|
|
appRef.tick();
|
|
|
|
}
|
|
|
|
|
|
|
|
function noop() {}
|
|
|
|
|
|
|
|
function init() {
|
|
|
|
enableProdMode();
|
2016-08-26 15:44:05 -07:00
|
|
|
platformBrowserDynamic().bootstrapModule(AppModule).then((ref) => {
|
|
|
|
var injector = ref.injector;
|
|
|
|
appRef = injector.get(ApplicationRef);
|
|
|
|
|
2016-08-30 14:17:37 -07:00
|
|
|
tree = appRef.components[0].instance;
|
2016-08-26 15:44:05 -07:00
|
|
|
bindAction('#destroyDom', destroyDom);
|
|
|
|
bindAction('#createDom', createDom);
|
|
|
|
bindAction('#updateDomProfile', profile(createDom, noop, 'ng2-update'));
|
|
|
|
bindAction('#createDomProfile', profile(createDom, destroyDom, 'ng2-create'));
|
|
|
|
});
|
2016-08-26 12:27:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
init();
|
|
|
|
}
|