| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @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
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  | import {RenderFlags} from '@angular/core/src/render3'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  | import {defineComponent, defineDirective} from '../../src/render3/index'; | 
					
						
							| 
									
										
										
										
											2018-03-21 15:10:34 -07:00
										 |  |  | import {NO_CHANGE, bind, container, containerRefreshEnd, containerRefreshStart, elementAttribute, elementClassNamed, elementEnd, elementProperty, elementStart, elementStyleNamed, embeddedViewEnd, embeddedViewStart, interpolation1, interpolation2, interpolation3, interpolation4, interpolation5, interpolation6, interpolation7, interpolation8, interpolationV, load, loadDirective, projection, projectionDef, text, textBinding} from '../../src/render3/instructions'; | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  | import {LViewFlags} from '../../src/render3/interfaces/view'; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 20:31:24 -07:00
										 |  |  | import {ComponentFixture, containerEl, renderToHtml} from './render_util'; | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-03 11:42:48 +01:00
										 |  |  | describe('render3 integration test', () => { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('render', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should render basic template', () => { | 
					
						
							|  |  |  |       expect(renderToHtml(Template, {})).toEqual('<span title="Hello">Greetings</span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'span', ['title', 'Hello']); | 
					
						
							|  |  |  |           { text(1, 'Greetings'); } | 
					
						
							|  |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should render and update basic "Hello, World" template', () => { | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'World')).toEqual('<h1>Hello, World!</h1>'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'New World')).toEqual('<h1>Hello, New World!</h1>'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'h1'); | 
					
						
							|  |  |  |           { text(1); } | 
					
						
							|  |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(1, interpolation1('Hello, ', ctx, '!')); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('text bindings', () => { | 
					
						
							|  |  |  |     it('should render "undefined" as "" when used with `bind()`', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, name: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           text(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(0, bind(name)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'benoit')).toEqual('benoit'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, undefined)).toEqual(''); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should render "null" as "" when used with `bind()`', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, name: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           text(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(0, bind(name)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'benoit')).toEqual('benoit'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, null)).toEqual(''); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support creation-time values in text nodes', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, value: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           text(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(0, rf & RenderFlags.Create ? value : NO_CHANGE); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'once')).toEqual('once'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'twice')).toEqual('once'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('Siblings update', () => { | 
					
						
							|  |  |  |     it('should handle a flat list of static/bound text nodes', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, name: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           text(0, 'Hello '); | 
					
						
							|  |  |  |           text(1); | 
					
						
							|  |  |  |           text(2, '!'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(1, bind(name)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'world')).toEqual('Hello world!'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'monde')).toEqual('Hello monde!'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle a list of static/bound text nodes as element children', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, name: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'b'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             text(1, 'Hello '); | 
					
						
							|  |  |  |             text(2); | 
					
						
							|  |  |  |             text(3, '!'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(2, bind(name)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'world')).toEqual('<b>Hello world!</b>'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'mundo')).toEqual('<b>Hello mundo!</b>'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should render/update text node as a child of a deep list of elements', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, name: string) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'b'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(1, 'b'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               elementStart(2, 'b'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |               { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |                 elementStart(3, 'b'); | 
					
						
							|  |  |  |                 { text(4); } | 
					
						
							|  |  |  |                 elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           textBinding(4, interpolation1('Hello ', name, '!')); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'world')).toEqual('<b><b><b><b>Hello world!</b></b></b></b>'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'mundo')).toEqual('<b><b><b><b>Hello mundo!</b></b></b></b>'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should update 2 sibling elements', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, id: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'b'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(1, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							|  |  |  |             elementStart(2, 'span', ['class', 'foo']); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             {} | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           elementAttribute(2, 'id', bind(id)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'foo')) | 
					
						
							|  |  |  |           .toEqual('<b><span></span><span class="foo" id="foo"></span></b>'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, 'bar')) | 
					
						
							|  |  |  |           .toEqual('<b><span></span><span class="foo" id="bar"></span></b>'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle sibling text node after element with child text node', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementStart(0, 'p'); | 
					
						
							|  |  |  |           { text(1, 'hello'); } | 
					
						
							|  |  |  |           elementEnd(); | 
					
						
							|  |  |  |           text(2, 'world'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(renderToHtml(Template, null)).toEqual('<p>hello</p>world'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('basic components', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class TodoComponent { | 
					
						
							|  |  |  |       value = ' one'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2018-01-22 15:27:21 -08:00
										 |  |  |         type: TodoComponent, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |         selectors: [['todo']], | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         template: function TodoTemplate(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'p'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               text(1, 'Todo'); | 
					
						
							|  |  |  |               text(2); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             textBinding(2, bind(ctx.value)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         }, | 
					
						
							|  |  |  |         factory: () => new TodoComponent | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |     const defs = [TodoComponent]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     it('should support a basic component template', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'todo'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, null, defs)).toEqual('<todo><p>Todo one</p></todo>'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support a component template with sibling', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'todo'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2018-03-21 15:10:34 -07:00
										 |  |  |           text(1, 'two'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, null, defs)).toEqual('<todo><p>Todo one</p></todo>two'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support a component template with component sibling', () => { | 
					
						
							|  |  |  |       /** | 
					
						
							|  |  |  |        * <todo></todo> | 
					
						
							|  |  |  |        * <todo></todo> | 
					
						
							|  |  |  |        */ | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'todo'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(1, 'todo'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, null, defs)) | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           .toEqual('<todo><p>Todo one</p></todo><todo><p>Todo one</p></todo>'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support a component with binding on host element', () => { | 
					
						
							|  |  |  |       let cmptInstance: TodoComponentHostBinding|null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class TodoComponentHostBinding { | 
					
						
							|  |  |  |         title = 'one'; | 
					
						
							|  |  |  |         static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2018-01-22 15:27:21 -08:00
										 |  |  |           type: TodoComponentHostBinding, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |           selectors: [['todo']], | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           template: function TodoComponentHostBindingTemplate( | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |               rf: RenderFlags, ctx: TodoComponentHostBinding) { | 
					
						
							|  |  |  |             if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               text(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |               textBinding(0, bind(ctx.title)); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           }, | 
					
						
							|  |  |  |           factory: () => cmptInstance = new TodoComponentHostBinding, | 
					
						
							| 
									
										
										
										
											2017-12-20 16:26:07 -08:00
										 |  |  |           hostBindings: function(directiveIndex: number, elementIndex: number): void { | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             // host bindings
 | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementProperty( | 
					
						
							| 
									
										
										
										
											2018-03-21 15:10:34 -07:00
										 |  |  |                 elementIndex, 'title', | 
					
						
							|  |  |  |                 bind(loadDirective<TodoComponentHostBinding>(directiveIndex).title)); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'todo'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |       const defs = [TodoComponentHostBinding]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, {}, defs)).toEqual('<todo title="one">one</todo>'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       cmptInstance !.title = 'two'; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, {}, defs)).toEqual('<todo title="two">two</todo>'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 20:31:24 -07:00
										 |  |  |     it('should support root component with host attribute', () => { | 
					
						
							|  |  |  |       class HostAttributeComp { | 
					
						
							|  |  |  |         static ngComponentDef = defineComponent({ | 
					
						
							|  |  |  |           type: HostAttributeComp, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |           selectors: [['host-attr-comp']], | 
					
						
							| 
									
										
										
										
											2018-03-16 20:31:24 -07:00
										 |  |  |           factory: () => new HostAttributeComp(), | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           template: (rf: RenderFlags, ctx: HostAttributeComp) => {}, | 
					
						
							| 
									
										
										
										
											2018-03-16 20:31:24 -07:00
										 |  |  |           attributes: ['role', 'button'] | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const fixture = new ComponentFixture(HostAttributeComp); | 
					
						
							|  |  |  |       expect(fixture.hostElement.getAttribute('role')).toEqual('button'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     it('should support component with bindings in template', () => { | 
					
						
							|  |  |  |       /** <p> {{ name }} </p>*/ | 
					
						
							|  |  |  |       class MyComp { | 
					
						
							|  |  |  |         name = 'Bess'; | 
					
						
							|  |  |  |         static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2018-01-22 15:27:21 -08:00
										 |  |  |           type: MyComp, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |           selectors: [['comp']], | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           template: function MyCompTemplate(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |             if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               elementStart(0, 'p'); | 
					
						
							|  |  |  |               { text(1); } | 
					
						
							|  |  |  |               elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |               textBinding(1, bind(ctx.name)); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           }, | 
					
						
							|  |  |  |           factory: () => new MyComp | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'comp'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |       expect(renderToHtml(Template, null, [MyComp])).toEqual('<comp><p>Bess</p></comp>'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support a component with sub-views', () => { | 
					
						
							|  |  |  |       /** | 
					
						
							|  |  |  |        * % if (condition) { | 
					
						
							|  |  |  |        *   <div>text</div> | 
					
						
							|  |  |  |        * % } | 
					
						
							|  |  |  |        */ | 
					
						
							|  |  |  |       class MyComp { | 
					
						
							|  |  |  |         condition: boolean; | 
					
						
							|  |  |  |         static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2018-01-22 15:27:21 -08:00
										 |  |  |           type: MyComp, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |           selectors: [['comp']], | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           template: function MyCompTemplate(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |             if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |               container(0); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |               containerRefreshStart(0); | 
					
						
							|  |  |  |               { | 
					
						
							|  |  |  |                 if (ctx.condition) { | 
					
						
							|  |  |  |                   let rf1 = embeddedViewStart(0); | 
					
						
							|  |  |  |                   if (rf1 & RenderFlags.Create) { | 
					
						
							|  |  |  |                     elementStart(0, 'div'); | 
					
						
							|  |  |  |                     { text(1, 'text'); } | 
					
						
							|  |  |  |                     elementEnd(); | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                   embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |               containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           factory: () => new MyComp, | 
					
						
							|  |  |  |           inputs: {condition: 'condition'} | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /** <comp [condition]="condition"></comp> */ | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |           elementStart(0, 'comp'); | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           elementProperty(0, 'condition', bind(ctx.condition)); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |       const defs = [MyComp]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(Template, {condition: true}, defs)) | 
					
						
							|  |  |  |           .toEqual('<comp><div>text</div></comp>'); | 
					
						
							|  |  |  |       expect(renderToHtml(Template, {condition: false}, defs)).toEqual('<comp></comp>'); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |   describe('tree', () => { | 
					
						
							|  |  |  |     interface Tree { | 
					
						
							|  |  |  |       beforeLabel?: string; | 
					
						
							|  |  |  |       subTrees?: Tree[]; | 
					
						
							|  |  |  |       afterLabel?: string; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     interface ParentCtx { | 
					
						
							|  |  |  |       beforeTree: Tree; | 
					
						
							|  |  |  |       projectedTree: Tree; | 
					
						
							|  |  |  |       afterTree: Tree; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |     function showLabel(rf: RenderFlags, ctx: {label: string | undefined}) { | 
					
						
							|  |  |  |       if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |         container(0); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |         containerRefreshStart(0); | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           if (ctx.label != null) { | 
					
						
							|  |  |  |             let rf1 = embeddedViewStart(0); | 
					
						
							|  |  |  |             if (rf1 & RenderFlags.Create) { | 
					
						
							|  |  |  |               text(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf1 & RenderFlags.Update) { | 
					
						
							|  |  |  |               textBinding(0, bind(ctx.label)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |     function showTree(rf: RenderFlags, ctx: {tree: Tree}) { | 
					
						
							|  |  |  |       if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |         container(0); | 
					
						
							|  |  |  |         container(1); | 
					
						
							|  |  |  |         container(2); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |       containerRefreshStart(0); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |         { showLabel(rf0, {label: ctx.tree.beforeLabel}); } | 
					
						
							| 
									
										
										
										
											2018-02-06 17:27:16 -08:00
										 |  |  |         embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |       containerRefreshEnd(); | 
					
						
							|  |  |  |       containerRefreshStart(1); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       { | 
					
						
							|  |  |  |         for (let subTree of ctx.tree.subTrees || []) { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |           { showTree(rf0, {tree: subTree}); } | 
					
						
							| 
									
										
										
										
											2018-02-06 17:27:16 -08:00
										 |  |  |           embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |       containerRefreshEnd(); | 
					
						
							|  |  |  |       containerRefreshStart(2); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |         { showLabel(rf0, {label: ctx.tree.afterLabel}); } | 
					
						
							| 
									
										
										
										
											2018-02-06 17:27:16 -08:00
										 |  |  |         embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |       containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class ChildComponent { | 
					
						
							|  |  |  |       beforeTree: Tree; | 
					
						
							|  |  |  |       afterTree: Tree; | 
					
						
							|  |  |  |       static ngComponentDef = defineComponent({ | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |         selectors: [['child']], | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |         type: ChildComponent, | 
					
						
							|  |  |  |         template: function ChildComponentTemplate( | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             rf: RenderFlags, ctx: {beforeTree: Tree, afterTree: Tree}) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             projectionDef(0); | 
					
						
							|  |  |  |             container(1); | 
					
						
							|  |  |  |             projection(2, 0); | 
					
						
							|  |  |  |             container(3); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           containerRefreshStart(1); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |             { showTree(rf0, {tree: ctx.beforeTree}); } | 
					
						
							| 
									
										
										
										
											2018-02-06 17:27:16 -08:00
										 |  |  |             embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           containerRefreshEnd(); | 
					
						
							|  |  |  |           containerRefreshStart(3); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |             { showTree(rf0, {tree: ctx.afterTree}); } | 
					
						
							| 
									
										
										
										
											2018-02-06 17:27:16 -08:00
										 |  |  |             embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         factory: () => new ChildComponent, | 
					
						
							|  |  |  |         inputs: {beforeTree: 'beforeTree', afterTree: 'afterTree'} | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |     function parentTemplate(rf: RenderFlags, ctx: ParentCtx) { | 
					
						
							|  |  |  |       if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |         elementStart(0, 'child'); | 
					
						
							| 
									
										
										
										
											2018-03-21 15:10:34 -07:00
										 |  |  |         { container(1); } | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |         elementEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |         elementProperty(0, 'beforeTree', bind(ctx.beforeTree)); | 
					
						
							|  |  |  |         elementProperty(0, 'afterTree', bind(ctx.afterTree)); | 
					
						
							|  |  |  |         containerRefreshStart(1); | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           const rf0 = embeddedViewStart(0); | 
					
						
							|  |  |  |           { showTree(rf0, {tree: ctx.projectedTree}); } | 
					
						
							|  |  |  |           embeddedViewEnd(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should work with a tree', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const ctx: ParentCtx = { | 
					
						
							|  |  |  |         beforeTree: {subTrees: [{beforeLabel: 'a'}]}, | 
					
						
							|  |  |  |         projectedTree: {beforeLabel: 'p'}, | 
					
						
							|  |  |  |         afterTree: {afterLabel: 'z'} | 
					
						
							|  |  |  |       }; | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |       const defs = [ChildComponent]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(parentTemplate, ctx, defs)).toEqual('<child>apz</child>'); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       ctx.projectedTree = {subTrees: [{}, {}, {subTrees: [{}, {}]}, {}]}; | 
					
						
							|  |  |  |       ctx.beforeTree.subTrees !.push({afterLabel: 'b'}); | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(parentTemplate, ctx, defs)).toEqual('<child>abz</child>'); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       ctx.projectedTree.subTrees ![1].afterLabel = 'h'; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(parentTemplate, ctx, defs)).toEqual('<child>abhz</child>'); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  |       ctx.beforeTree.subTrees !.push({beforeLabel: 'c'}); | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |       expect(renderToHtml(parentTemplate, ctx, defs)).toEqual('<child>abchz</child>'); | 
					
						
							| 
									
										
										
										
											2018-01-25 15:32:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // To check the context easily:
 | 
					
						
							|  |  |  |       // console.log(JSON.stringify(ctx));
 | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |   describe('element bindings', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('elementAttribute', () => { | 
					
						
							|  |  |  |       it('should support attribute bindings', () => { | 
					
						
							|  |  |  |         const ctx: {title: string | null} = {title: 'Hello'}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementAttribute(0, 'title', bind(ctx.title)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // initial binding
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)).toEqual('<span title="Hello"></span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // update binding
 | 
					
						
							|  |  |  |         ctx.title = 'Hi!'; | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)).toEqual('<span title="Hi!"></span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // remove attribute
 | 
					
						
							|  |  |  |         ctx.title = null; | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)).toEqual('<span></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should stringify values used attribute bindings', () => { | 
					
						
							|  |  |  |         const ctx: {title: any} = {title: NaN}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementAttribute(0, 'title', bind(ctx.title)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)).toEqual('<span title="NaN"></span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ctx.title = {toString: () => 'Custom toString'}; | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)).toEqual('<span title="Custom toString"></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should update bindings', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, c: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'b'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementAttribute(0, 'a', interpolationV(c)); | 
					
						
							|  |  |  |             elementAttribute(0, 'a0', bind(c[1])); | 
					
						
							|  |  |  |             elementAttribute(0, 'a1', interpolation1(c[0], c[1], c[16])); | 
					
						
							|  |  |  |             elementAttribute(0, 'a2', interpolation2(c[0], c[1], c[2], c[3], c[16])); | 
					
						
							|  |  |  |             elementAttribute(0, 'a3', interpolation3(c[0], c[1], c[2], c[3], c[4], c[5], c[16])); | 
					
						
							|  |  |  |             elementAttribute( | 
					
						
							|  |  |  |                 0, 'a4', interpolation4(c[0], c[1], c[2], c[3], c[4], c[5], c[6], c[7], c[16])); | 
					
						
							|  |  |  |             elementAttribute( | 
					
						
							|  |  |  |                 0, 'a5', | 
					
						
							|  |  |  |                 interpolation5(c[0], c[1], c[2], c[3], c[4], c[5], c[6], c[7], c[8], c[9], c[16])); | 
					
						
							|  |  |  |             elementAttribute( | 
					
						
							|  |  |  |                 0, 'a6', interpolation6( | 
					
						
							|  |  |  |                              c[0], c[1], c[2], c[3], c[4], c[5], c[6], c[7], c[8], c[9], c[10], | 
					
						
							|  |  |  |                              c[11], c[16])); | 
					
						
							|  |  |  |             elementAttribute( | 
					
						
							|  |  |  |                 0, 'a7', interpolation7( | 
					
						
							|  |  |  |                              c[0], c[1], c[2], c[3], c[4], c[5], c[6], c[7], c[8], c[9], c[10], | 
					
						
							|  |  |  |                              c[11], c[12], c[13], c[16])); | 
					
						
							|  |  |  |             elementAttribute( | 
					
						
							|  |  |  |                 0, 'a8', interpolation8( | 
					
						
							|  |  |  |                              c[0], c[1], c[2], c[3], c[4], c[5], c[6], c[7], c[8], c[9], c[10], | 
					
						
							|  |  |  |                              c[11], c[12], c[13], c[14], c[15], c[16])); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |         let args = ['(', 0, 'a', 1, 'b', 2, 'c', 3, 'd', 4, 'e', 5, 'f', 6, 'g', 7, ')']; | 
					
						
							|  |  |  |         expect(renderToHtml(Template, args)) | 
					
						
							|  |  |  |             .toEqual( | 
					
						
							|  |  |  |                 '<b a="(0a1b2c3d4e5f6g7)" a0="0" a1="(0)" a2="(0a1)" a3="(0a1b2)" a4="(0a1b2c3)" a5="(0a1b2c3d4)" a6="(0a1b2c3d4e5)" a7="(0a1b2c3d4e5f6)" a8="(0a1b2c3d4e5f6g7)"></b>'); | 
					
						
							|  |  |  |         args = args.reverse(); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, args)) | 
					
						
							|  |  |  |             .toEqual( | 
					
						
							|  |  |  |                 '<b a=")7g6f5e4d3c2b1a0(" a0="7" a1=")7(" a2=")7g6(" a3=")7g6f5(" a4=")7g6f5e4(" a5=")7g6f5e4d3(" a6=")7g6f5e4d3c2(" a7=")7g6f5e4d3c2b1(" a8=")7g6f5e4d3c2b1a0("></b>'); | 
					
						
							|  |  |  |         args = args.reverse(); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, args)) | 
					
						
							|  |  |  |             .toEqual( | 
					
						
							|  |  |  |                 '<b a="(0a1b2c3d4e5f6g7)" a0="0" a1="(0)" a2="(0a1)" a3="(0a1b2)" a4="(0a1b2c3)" a5="(0a1b2c3d4)" a6="(0a1b2c3d4e5)" a7="(0a1b2c3d4e5f6)" a8="(0a1b2c3d4e5f6g7)"></b>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should not update DOM if context has not changed', () => { | 
					
						
							|  |  |  |         const ctx: {title: string | null} = {title: 'Hello'}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             container(1); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementAttribute(0, 'title', bind(ctx.title)); | 
					
						
							|  |  |  |             containerRefreshStart(1); | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |               if (true) { | 
					
						
							|  |  |  |                 let rf1 = embeddedViewStart(1); | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                   if (rf1 & RenderFlags.Create) { | 
					
						
							|  |  |  |                     elementStart(0, 'b'); | 
					
						
							|  |  |  |                     {} | 
					
						
							|  |  |  |                     elementEnd(); | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                   elementAttribute(0, 'title', bind(ctx.title)); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |                 embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |             containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // initial binding
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)) | 
					
						
							|  |  |  |             .toEqual('<span title="Hello"><b title="Hello"></b></span>'); | 
					
						
							|  |  |  |         // update DOM manually
 | 
					
						
							|  |  |  |         containerEl.querySelector('b') !.setAttribute('title', 'Goodbye'); | 
					
						
							|  |  |  |         // refresh with same binding
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)) | 
					
						
							|  |  |  |             .toEqual('<span title="Hello"><b title="Goodbye"></b></span>'); | 
					
						
							|  |  |  |         // refresh again with same binding
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, ctx)) | 
					
						
							|  |  |  |             .toEqual('<span title="Hello"><b title="Goodbye"></b></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       it('should support host attribute bindings', () => { | 
					
						
							|  |  |  |         let hostBindingDir: HostBindingDir; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         class HostBindingDir { | 
					
						
							|  |  |  |           /* @HostBinding('attr.aria-label') */ | 
					
						
							|  |  |  |           label = 'some label'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           static ngDirectiveDef = defineDirective({ | 
					
						
							|  |  |  |             type: HostBindingDir, | 
					
						
							| 
									
										
										
										
											2018-03-29 16:41:45 -07:00
										 |  |  |             selectors: [['', 'hostBindingDir', '']], | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  |             factory: function HostBindingDir_Factory() { | 
					
						
							|  |  |  |               return hostBindingDir = new HostBindingDir(); | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             hostBindings: function HostBindingDir_HostBindings(dirIndex: number, elIndex: number) { | 
					
						
							| 
									
										
										
										
											2018-03-21 15:10:34 -07:00
										 |  |  |               elementAttribute( | 
					
						
							|  |  |  |                   elIndex, 'aria-label', bind(loadDirective<HostBindingDir>(dirIndex).label)); | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |             elementStart(0, 'div', ['hostBindingDir', '']); | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  |             elementEnd(); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 12:58:41 -07:00
										 |  |  |         const defs = [HostBindingDir]; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |         expect(renderToHtml(Template, {}, defs)) | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  |             .toEqual(`<div aria-label="some label" hostbindingdir=""></div>`); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         hostBindingDir !.label = 'other label'; | 
					
						
							| 
									
										
										
										
											2018-03-25 21:32:39 -07:00
										 |  |  |         expect(renderToHtml(Template, {}, defs)) | 
					
						
							| 
									
										
										
										
											2018-02-16 11:36:50 -08:00
										 |  |  |             .toEqual(`<div aria-label="other label" hostbindingdir=""></div>`); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('elementStyle', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should support binding to styles', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementStyleNamed(0, 'border-color', bind(ctx)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 'red')).toEqual('<span style="border-color: red;"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 'green')) | 
					
						
							|  |  |  |             .toEqual('<span style="border-color: green;"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, null)).toEqual('<span></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should support binding to styles with suffix', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementStyleNamed(0, 'font-size', bind(ctx), 'px'); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, '100')).toEqual('<span style="font-size: 100px;"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 200)).toEqual('<span style="font-size: 200px;"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, null)).toEqual('<span></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('elementClass', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should support CSS class toggle', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span'); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementClassNamed(0, 'active', bind(ctx)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, true)).toEqual('<span class="active"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, false)).toEqual('<span class=""></span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // truthy values
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 'a_string')).toEqual('<span class="active"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 10)).toEqual('<span class="active"></span>'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // falsy values
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, '')).toEqual('<span class=""></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, 0)).toEqual('<span class=""></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should work correctly with existing static classes', () => { | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |           if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |             elementStart(0, 'span', ['class', 'existing']); | 
					
						
							|  |  |  |             elementEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |             elementClassNamed(0, 'active', bind(ctx)); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         expect(renderToHtml(Template, true)).toEqual('<span class="existing active"></span>'); | 
					
						
							|  |  |  |         expect(renderToHtml(Template, false)).toEqual('<span class="existing"></span>'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |   describe('template data', () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should re-use template data and node data', () => { | 
					
						
							|  |  |  |       /** | 
					
						
							|  |  |  |        *  % if (condition) { | 
					
						
							|  |  |  |        *    <div></div> | 
					
						
							|  |  |  |        *  % } | 
					
						
							|  |  |  |        */ | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |       function Template(rf: RenderFlags, ctx: any) { | 
					
						
							|  |  |  |         if (rf & RenderFlags.Create) { | 
					
						
							| 
									
										
										
										
											2018-02-06 16:11:20 -08:00
										 |  |  |           container(0); | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |         if (rf & RenderFlags.Update) { | 
					
						
							|  |  |  |           containerRefreshStart(0); | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             if (ctx.condition) { | 
					
						
							|  |  |  |               let rf1 = embeddedViewStart(0); | 
					
						
							|  |  |  |               if (rf1 & RenderFlags.Create) { | 
					
						
							|  |  |  |                 elementStart(0, 'div'); | 
					
						
							|  |  |  |                 elementEnd(); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               embeddedViewEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-04-10 20:57:09 -07:00
										 |  |  |           containerRefreshEnd(); | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-10 18:19:16 -08:00
										 |  |  |       expect((Template as any).ngPrivateData).toBeUndefined(); | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       renderToHtml(Template, {condition: true}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-10 18:19:16 -08:00
										 |  |  |       const oldTemplateData = (Template as any).ngPrivateData; | 
					
						
							|  |  |  |       const oldContainerData = (oldTemplateData as any).data[0]; | 
					
						
							|  |  |  |       const oldElementData = oldContainerData.data[0][0]; | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |       expect(oldContainerData).not.toBeNull(); | 
					
						
							|  |  |  |       expect(oldElementData).not.toBeNull(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       renderToHtml(Template, {condition: false}); | 
					
						
							|  |  |  |       renderToHtml(Template, {condition: true}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-10 18:19:16 -08:00
										 |  |  |       const newTemplateData = (Template as any).ngPrivateData; | 
					
						
							|  |  |  |       const newContainerData = (oldTemplateData as any).data[0]; | 
					
						
							|  |  |  |       const newElementData = oldContainerData.data[0][0]; | 
					
						
							| 
									
										
										
										
											2017-12-08 11:48:54 -08:00
										 |  |  |       expect(newTemplateData === oldTemplateData).toBe(true); | 
					
						
							|  |  |  |       expect(newContainerData === oldContainerData).toBe(true); | 
					
						
							|  |  |  |       expect(newElementData === oldElementData).toBe(true); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-01 14:23:03 -08:00
										 |  |  | }); |