/** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import {NgIf} from '@angular/common'; import {ComponentFactory, ComponentFactoryResolver, ComponentRef, ErrorHandler, Injector, NgModuleRef, RendererFactory2, Sanitizer, TemplateRef, ViewContainerRef, ɵArgumentType as ArgumentType, ɵBindingFlags as BindingFlags, ɵNodeFlags as NodeFlags, ɵViewDefinition as ViewDefinition, ɵViewFlags as ViewFlags, ɵand as anchorDef, ɵccf as createComponentFactory, ɵdid as directiveDef, ɵeld as elementDef, ɵinitServicesIfNeeded as initServicesIfNeeded, ɵted as textDef, ɵvid as viewDef} from '@angular/core'; import {SafeStyle, ɵDomRendererFactory2 as DomRendererFactory2, ɵDomSanitizerImpl as DomSanitizerImpl} from '@angular/platform-browser'; import {TreeNode, emptyTree} from '../util'; let trustedEmptyColor: SafeStyle; let trustedGreyColor: SafeStyle; export class TreeComponent { data: TreeNode = emptyTree; get bgColor() { return this.data.depth % 2 ? trustedEmptyColor : trustedGreyColor; } } let viewFlags = ViewFlags.None; function TreeComponent_Host(): ViewDefinition { return viewDef(viewFlags, [ elementDef(0, NodeFlags.None, null, null, 1, 'tree', null, null, null, null, TreeComponent_0), directiveDef(1, NodeFlags.Component, null, 0, TreeComponent, []), ]); } function TreeComponent_1() { return viewDef( viewFlags, [ elementDef( 0, NodeFlags.None, null, null, 1, 'tree', null, null, null, null, TreeComponent_0), directiveDef(1, NodeFlags.Component, null, 0, TreeComponent, [], {data: [0, 'data']}), ], (check, view) => { const cmp = view.component; check(view, 1, ArgumentType.Inline, cmp.data.left); }); } function TreeComponent_2() { return viewDef( viewFlags, [ elementDef( 0, NodeFlags.None, null, null, 1, 'tree', null, null, null, null, TreeComponent_0), directiveDef(1, NodeFlags.Component, null, 0, TreeComponent, [], {data: [0, 'data']}), ], (check, view) => { const cmp = view.component; check(view, 1, ArgumentType.Inline, cmp.data.left); }); } function TreeComponent_0(): ViewDefinition { return viewDef( viewFlags, [ elementDef( 0, NodeFlags.None, null, null, 1, 'span', null, [[BindingFlags.TypeElementStyle, 'backgroundColor', null]]), textDef(1, null, [' ', ' ']), anchorDef(NodeFlags.EmbeddedViews, null, null, 1, null, TreeComponent_1), directiveDef( 3, NodeFlags.None, null, 0, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}), anchorDef(NodeFlags.EmbeddedViews, null, null, 1, null, TreeComponent_2), directiveDef( 5, NodeFlags.None, null, 0, NgIf, [ViewContainerRef, TemplateRef], {ngIf: [0, 'ngIf']}), ], (check, view) => { const cmp = view.component; check(view, 3, ArgumentType.Inline, cmp.data.left != null); check(view, 5, ArgumentType.Inline, cmp.data.right != null); }, (check, view) => { const cmp = view.component; check(view, 0, ArgumentType.Inline, cmp.bgColor); check(view, 1, ArgumentType.Inline, cmp.data.value); }); } export class AppModule implements Injector, NgModuleRef { private sanitizer: DomSanitizerImpl; private componentFactory: ComponentFactory; private renderer2: RendererFactory2; componentRef: ComponentRef; constructor() { initServicesIfNeeded(); this.sanitizer = new DomSanitizerImpl(document); this.renderer2 = new DomRendererFactory2(null, null, null); trustedEmptyColor = this.sanitizer.bypassSecurityTrustStyle(''); trustedGreyColor = this.sanitizer.bypassSecurityTrustStyle('grey'); this.componentFactory = createComponentFactory('#root', TreeComponent, TreeComponent_Host, {}, {}, []); } get(token: any, notFoundValue: any = Injector.THROW_IF_NOT_FOUND): any { switch (token) { case RendererFactory2: return this.renderer2; case Sanitizer: return this.sanitizer; case ErrorHandler: return null; case NgModuleRef: return this; } return Injector.NULL.get(token, notFoundValue); } bootstrap() { this.componentRef = this.componentFactory.create(Injector.NULL, [], this.componentFactory.selector, this); } tick() { this.componentRef.changeDetectorRef.detectChanges(); } get injector() { return this; } get componentFactoryResolver(): ComponentFactoryResolver { return null; } get instance() { return this; } destroy() {} onDestroy(callback: () => void) {} }