| 
									
										
										
										
											2018-04-06 12:52:17 -07: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-12-13 15:51:47 -08:00
										 |  |  | import {AttributeMarker, ViewEncapsulation} from '@angular/compiler/src/core'; | 
					
						
							| 
									
										
										
										
											2018-08-20 15:20:12 +02:00
										 |  |  | import {setup} from '@angular/compiler/test/aot/test_util'; | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  | import {compile, expectEmit} from './mock_compile'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('compiler compliance: styling', () => { | 
					
						
							|  |  |  |   const angularFiles = setup({ | 
					
						
							| 
									
										
										
										
											2018-08-01 09:52:34 +02:00
										 |  |  |     compileAngular: false, | 
					
						
							|  |  |  |     compileFakeCore: true, | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |     compileAnimations: false, | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  |   describe('@Component.styles', () => { | 
					
						
							|  |  |  |     it('should pass in the component metadata styles into the component definition and shim them using style encapsulation', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: "my-component", | 
					
						
							|  |  |  |                   styles: ["div.foo { color: red; }", ":host p:nth-child(even) { --webkit-transition: 1s linear all; }"], | 
					
						
							|  |  |  |                   template: "..." | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = | 
					
						
							|  |  |  |              'styles: ["div.foo[_ngcontent-%COMP%] { color: red; }", "[_nghost-%COMP%]   p[_ngcontent-%COMP%]:nth-child(even) { --webkit-transition: 1s linear all; }"]'; | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should pass in styles, but skip shimming the styles if the view encapsulation signals not to', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2019-01-07 16:35:06 -08:00
										 |  |  |                 import {Component, NgModule, ViewEncapsulation} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: "my-component", | 
					
						
							| 
									
										
										
										
											2019-01-07 16:35:06 -08:00
										 |  |  |                   encapsulation: ViewEncapsulation.None, | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  |                   styles: ["div.tall { height: 123px; }", ":host.small p { height:5px; }"], | 
					
						
							|  |  |  |                   template: "..." | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = 'div.tall { height: 123px; }", ":host.small p { height:5px; }'; | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should pass in the component metadata styles into the component definition but skip shimming when style encapsulation is set to native', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							| 
									
										
										
										
											2019-01-07 16:35:06 -08:00
										 |  |  |                 import {Component, NgModule, ViewEncapsulation} from '@angular/core'; | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							| 
									
										
										
										
											2019-01-07 16:35:06 -08:00
										 |  |  |                   encapsulation: ViewEncapsulation.Native, | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  |                   selector: "my-component", | 
					
						
							|  |  |  |                   styles: ["div.cool { color: blue; }", ":host.nice p { color: gold; }"], | 
					
						
							|  |  |  |                   template: "..." | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-15 16:00:55 +01:00
										 |  |  |          const template = `
 | 
					
						
							|  |  |  |          MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							|  |  |  |            … | 
					
						
							|  |  |  |            styles: ["div.cool { color: blue; }", ":host.nice p { color: gold; }"], | 
					
						
							|  |  |  |            encapsulation: 1 | 
					
						
							|  |  |  |          }) | 
					
						
							|  |  |  |          `;
 | 
					
						
							| 
									
										
										
										
											2018-07-31 11:14:06 -07:00
										 |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-05 15:23:59 -07:00
										 |  |  |   describe('@Component.animations', () => { | 
					
						
							|  |  |  |     it('should pass in the component metadata animations into the component definition', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: "my-component", | 
					
						
							|  |  |  |                   animations: [{name: 'foo123'}, {name: 'trigger123'}], | 
					
						
							|  |  |  |                   template: "" | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |         MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							|  |  |  |           type: MyComponent, | 
					
						
							|  |  |  |           selectors:[["my-component"]], | 
					
						
							|  |  |  |           factory:function MyComponent_Factory(t){ | 
					
						
							|  |  |  |             return new (t || MyComponent)(); | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           consts: 0, | 
					
						
							|  |  |  |           vars: 0, | 
					
						
							|  |  |  |           template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |           }, | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |           encapsulation: 2, | 
					
						
							| 
									
										
										
										
											2018-10-16 11:09:04 -07:00
										 |  |  |           data: { | 
					
						
							| 
									
										
										
										
											2018-12-05 15:56:36 -08:00
										 |  |  |             animation: [{name: 'foo123'}, {name: 'trigger123'}] | 
					
						
							| 
									
										
										
										
											2018-10-16 11:09:04 -07:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-09-05 15:23:59 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |       `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should include animations even if the provided array is empty', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: "my-component", | 
					
						
							|  |  |  |                   animations: [], | 
					
						
							|  |  |  |                   template: "" | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |         MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							|  |  |  |           type: MyComponent, | 
					
						
							|  |  |  |           selectors:[["my-component"]], | 
					
						
							|  |  |  |           factory:function MyComponent_Factory(t){ | 
					
						
							|  |  |  |             return new (t || MyComponent)(); | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           consts: 0, | 
					
						
							|  |  |  |           vars: 0, | 
					
						
							|  |  |  |           template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |           }, | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |           encapsulation: 2, | 
					
						
							| 
									
										
										
										
											2018-10-16 11:09:04 -07:00
										 |  |  |           data: { | 
					
						
							| 
									
										
										
										
											2018-12-05 15:56:36 -08:00
										 |  |  |             animation: [] | 
					
						
							| 
									
										
										
										
											2018-10-16 11:09:04 -07:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2018-09-05 15:23:59 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |       `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 18:50:57 -07:00
										 |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should generate any animation triggers into the component template', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: "my-component", | 
					
						
							|  |  |  |                   template: \`
 | 
					
						
							|  |  |  |                     <div [@foo]='exp'></div> | 
					
						
							|  |  |  |                     <div @bar></div> | 
					
						
							|  |  |  |                     <div [@baz]></div>\`,
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |         … | 
					
						
							|  |  |  |         MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							|  |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-12-05 15:56:36 -08:00
										 |  |  |           consts: 3, | 
					
						
							| 
									
										
										
										
											2019-01-15 13:46:15 -08:00
										 |  |  |           vars: 3, | 
					
						
							| 
									
										
										
										
											2018-09-06 18:50:57 -07:00
										 |  |  |           template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-12-21 11:53:18 -08:00
										 |  |  |               $r3$.ɵelement(0, "div"); | 
					
						
							| 
									
										
										
										
											2019-01-15 13:46:15 -08:00
										 |  |  |               $r3$.ɵelement(1, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelement(2, "div"); | 
					
						
							| 
									
										
										
										
											2018-09-06 18:50:57 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-12-05 15:56:36 -08:00
										 |  |  |               $r3$.ɵelementProperty(0, "@foo", $r3$.ɵbind(ctx.exp)); | 
					
						
							| 
									
										
										
										
											2019-01-15 13:46:15 -08:00
										 |  |  |               $r3$.ɵelementProperty(1, "@bar", $r3$.ɵbind(undefined)); | 
					
						
							|  |  |  |               $r3$.ɵelementProperty(2, "@baz", $r3$.ɵbind(undefined)); | 
					
						
							| 
									
										
										
										
											2018-09-06 18:50:57 -07:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |           }, | 
					
						
							|  |  |  |           encapsulation: 2 | 
					
						
							| 
									
										
										
										
											2018-09-06 18:50:57 -07:00
										 |  |  |         }); | 
					
						
							|  |  |  |       `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-05 15:23:59 -07:00
										 |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-12-06 15:57:52 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should generate animation listeners', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |             import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @Component({ | 
					
						
							|  |  |  |               selector: 'my-cmp', | 
					
						
							|  |  |  |               template: \`
 | 
					
						
							|  |  |  |                 <div [@myAnimation]="exp" | 
					
						
							|  |  |  |                   (@myAnimation.start)="onStart($event)" | 
					
						
							|  |  |  |                   (@myAnimation.done)="onDone($event)"></div> | 
					
						
							|  |  |  |               \`,
 | 
					
						
							|  |  |  |               animations: [trigger( | 
					
						
							|  |  |  |                    'myAnimation', | 
					
						
							|  |  |  |                    [transition( | 
					
						
							|  |  |  |                        '* => state', | 
					
						
							|  |  |  |                        [style({'opacity': '0'}), animate(500, style({'opacity': '1'}))])])], | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             class MyComponent { | 
					
						
							|  |  |  |               exp: any; | 
					
						
							|  |  |  |               startEvent: any; | 
					
						
							|  |  |  |               doneEvent: any; | 
					
						
							|  |  |  |               onStart(event: any) { this.startEvent = event; } | 
					
						
							|  |  |  |               onDone(event: any) { this.doneEvent = event; } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |             export class MyModule {} | 
					
						
							|  |  |  |           `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |         … | 
					
						
							|  |  |  |         MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							|  |  |  |           … | 
					
						
							|  |  |  |           consts: 1, | 
					
						
							|  |  |  |           vars: 1, | 
					
						
							|  |  |  |           template: function MyComponent_Template(rf, ctx) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2019-01-15 13:46:15 -08:00
										 |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							| 
									
										
										
										
											2019-01-03 18:24:21 -08:00
										 |  |  |               $r3$.ɵlistener("@myAnimation.start", function MyComponent_Template_div_animation_myAnimation_start_0_listener($event) { return ctx.onStart($event); }); | 
					
						
							|  |  |  |               $r3$.ɵlistener("@myAnimation.done", function MyComponent_Template_div_animation_myAnimation_done_0_listener($event) { return ctx.onDone($event); }); | 
					
						
							| 
									
										
										
										
											2018-12-06 15:57:52 -08:00
										 |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementProperty(0, "@myAnimation", $r3$.ɵbind(ctx.exp)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           encapsulation: 2, | 
					
						
							|  |  |  |           … | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2019-01-03 18:24:21 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should generate animation host binding and listener code for directives', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |             import {Directive, Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @Directive({ | 
					
						
							|  |  |  |               selector: '[my-anim-dir]', | 
					
						
							|  |  |  |               animations: [ | 
					
						
							|  |  |  |                 {name: 'myAnim'} | 
					
						
							|  |  |  |               ], | 
					
						
							|  |  |  |               host: { | 
					
						
							|  |  |  |                 '[@myAnim]': 'myAnimState', | 
					
						
							|  |  |  |                 '(@myAnim.start)': 'onStart()', | 
					
						
							|  |  |  |                 '(@myAnim.done)': 'onDone()' | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             class MyAnimDir { | 
					
						
							|  |  |  |               onStart() {} | 
					
						
							|  |  |  |               onDone() {} | 
					
						
							|  |  |  |               myAnimState = '123'; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @Component({ | 
					
						
							|  |  |  |               selector: 'my-cmp', | 
					
						
							|  |  |  |               template: \`
 | 
					
						
							|  |  |  |                 <div my-anim-dir></div> | 
					
						
							|  |  |  |               \`
 | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             class MyComponent { | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @NgModule({declarations: [MyComponent, MyAnimDir]}) | 
					
						
							|  |  |  |             export class MyModule {} | 
					
						
							|  |  |  |           `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |         MyAnimDir.ngDirectiveDef = $r3$.ɵdefineDirective({ | 
					
						
							|  |  |  |           … | 
					
						
							|  |  |  |           hostBindings: function MyAnimDir_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵallocHostVars(1); | 
					
						
							| 
									
										
										
										
											2019-01-17 11:09:13 -08:00
										 |  |  |               $r3$.ɵcomponentHostSyntheticListener("@myAnim.start", function MyAnimDir_animation_myAnim_start_HostBindingHandler($event) { return ctx.onStart(); }); | 
					
						
							|  |  |  |               $r3$.ɵcomponentHostSyntheticListener("@myAnim.done", function MyAnimDir_animation_myAnim_done_HostBindingHandler($event) { return ctx.onDone(); }); | 
					
						
							| 
									
										
										
										
											2019-01-03 18:24:21 -08:00
										 |  |  |             } if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵcomponentHostSyntheticProperty(elIndex, "@myAnim", $r3$.ɵbind(ctx.myAnimState), null, true); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           … | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-09-05 15:23:59 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |   describe('[style] and [style.prop]', () => { | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |     it('should create style instructions on the element', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div [style]="myStyleExp"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myStyleExp = [{color:'red'}, {color:'blue', duration:1000}] | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |           template: function MyComponent_Template(rf, $ctx$) { | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							| 
									
										
										
										
											2018-09-05 17:13:17 +02:00
										 |  |  |               $r3$.ɵelementStyling(null, null, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |               $r3$.ɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |               $r3$.ɵelementStylingMap(0, null, $ctx$.myStyleExp); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-16 11:11:33 -08:00
										 |  |  |     it('should correctly count the total slots required when style/class bindings include interpolation', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component-with-interpolation', | 
					
						
							|  |  |  |                   template: \`
 | 
					
						
							|  |  |  |                     <div class="foo foo-{{ fooId }}"></div> | 
					
						
							|  |  |  |                   \`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponentWithInterpolation { | 
					
						
							|  |  |  |                   fooId = '123'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component-with-muchos-interpolation', | 
					
						
							|  |  |  |                   template: \`
 | 
					
						
							|  |  |  |                     <div class="foo foo-{{ fooId }}-{{ fooUsername }}"></div> | 
					
						
							|  |  |  |                   \`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponentWithMuchosInterpolation { | 
					
						
							|  |  |  |                   fooId = '123'; | 
					
						
							|  |  |  |                   fooUsername = 'superfoo'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component-without-interpolation', | 
					
						
							|  |  |  |                   template: \`
 | 
					
						
							|  |  |  |                     <div [class]="exp"></div> | 
					
						
							|  |  |  |                   \`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponentWithoutInterpolation { | 
					
						
							|  |  |  |                   exp = 'bar'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponentWithInterpolation, MyComponentWithMuchosInterpolation, MyComponentWithoutInterpolation]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							|  |  |  |         … | 
					
						
							|  |  |  |           consts: 1, | 
					
						
							|  |  |  |           vars: 1, | 
					
						
							|  |  |  |           template: function MyComponentWithInterpolation_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $r3$.ɵinterpolation1("foo foo-", $ctx$.fooId, "")); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         … | 
					
						
							|  |  |  |           consts: 1, | 
					
						
							|  |  |  |           vars: 2, | 
					
						
							|  |  |  |           template: function MyComponentWithMuchosInterpolation_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $r3$.ɵinterpolation2("foo foo-", $ctx$.fooId, "-", $ctx$.fooUsername, "")); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         … | 
					
						
							|  |  |  |           consts: 1, | 
					
						
							|  |  |  |           vars: 0, | 
					
						
							|  |  |  |           template: function MyComponentWithoutInterpolation_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $ctx$.exp); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |     it('should place initial, multi, singular and application followed by attribute style instructions in the template code in that order', | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div style="opacity:1"
 | 
					
						
							|  |  |  |                                    [attr.style]="'border-width: 10px'" | 
					
						
							|  |  |  |                                    [style.width]="myWidth" | 
					
						
							|  |  |  |                                    [style]="myStyleExp" | 
					
						
							|  |  |  |                                    [style.height]="myHeight"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myStyleExp = [{color:'red'}, {color:'blue', duration:1000}] | 
					
						
							|  |  |  |                   myWidth = '100px'; | 
					
						
							|  |  |  |                   myHeight = '100px'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $_c0$ = [${AttributeMarker.Styles}, "opacity", "1", ${AttributeMarker.SelectOnly}, "style"]; | 
					
						
							|  |  |  |           const $_c1$ = ["width", "height"]; | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-08-03 12:20:27 -07:00
										 |  |  |           MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |               type: MyComponent, | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |               selectors:[["my-component"]], | 
					
						
							| 
									
										
										
										
											2018-07-16 16:36:31 -07:00
										 |  |  |               factory:function MyComponent_Factory(t){ | 
					
						
							|  |  |  |                 return new (t || MyComponent)(); | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |               }, | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |               consts: 1, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |               vars: 1, | 
					
						
							|  |  |  |               template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |                 if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |                   $r3$.ɵelementStart(0, "div", $_c0$); | 
					
						
							|  |  |  |                   $r3$.ɵelementStyling(null, $_c1$, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementStylingMap(0, null, $ctx$.myStyleExp); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |                   $r3$.ɵelementStyleProp(0, 0, $ctx$.myWidth); | 
					
						
							|  |  |  |                   $r3$.ɵelementStyleProp(0, 1, $ctx$.myHeight); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementStylingApply(0); | 
					
						
							| 
									
										
										
										
											2018-09-05 17:13:17 +02:00
										 |  |  |                   $r3$.ɵelementAttribute(0, "style", $r3$.ɵbind("border-width: 10px"), $r3$.ɵsanitizeStyle); | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |               }, | 
					
						
							|  |  |  |               encapsulation: 2 | 
					
						
							| 
									
										
										
										
											2018-06-19 12:45:00 -07:00
										 |  |  |             }); | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should assign a sanitizer instance to the element style allocation instruction if any url-based properties are detected', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div [style.background-image]="myImage">\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myImage = 'url(foo.jpg)'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $_c0$ = ["background-image"]; | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |           export class MyComponent { | 
					
						
							|  |  |  |               constructor() { | 
					
						
							|  |  |  |                   this.myImage = 'url(foo.jpg)'; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:20:27 -07:00
										 |  |  |           MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |             type: MyComponent, | 
					
						
							|  |  |  |             selectors: [["my-component"]], | 
					
						
							| 
									
										
										
										
											2018-07-16 16:36:31 -07:00
										 |  |  |             factory: function MyComponent_Factory(t) { | 
					
						
							|  |  |  |               return new (t || MyComponent)(); | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |             consts: 1, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |             vars: 0, | 
					
						
							|  |  |  |             template:  function MyComponent_Template(rf, ctx) { | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |               if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                 $r3$.ɵelementStart(0, "div"); | 
					
						
							| 
									
										
										
										
											2018-09-05 17:13:17 +02:00
										 |  |  |                 $r3$.ɵelementStyling(null, _c0, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                 $r3$.ɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |               } | 
					
						
							|  |  |  |               if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-09-27 15:07:51 -07:00
										 |  |  |                 $r3$.ɵelementStyleProp(0, 0, ctx.myImage); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                 $r3$.ɵelementStylingApply(0); | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |             }, | 
					
						
							|  |  |  |             encapsulation: 2 | 
					
						
							| 
									
										
										
										
											2018-07-11 10:58:18 -07:00
										 |  |  |           }); | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							| 
									
										
										
										
											2018-10-11 14:06:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should support [style.foo.suffix] style bindings with a suffix', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |              import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              @Component({ | 
					
						
							|  |  |  |                selector: 'my-component', | 
					
						
							|  |  |  |                template: \`<div [style.font-size.px]="12">\`
 | 
					
						
							|  |  |  |              }) | 
					
						
							|  |  |  |              export class MyComponent { | 
					
						
							|  |  |  |              } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |              @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |              export class MyModule {} | 
					
						
							|  |  |  |          `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $e0_styles$ = ["font-size"]; | 
					
						
							| 
									
										
										
										
											2018-10-11 14:06:23 +02:00
										 |  |  |           … | 
					
						
							|  |  |  |           template:  function MyComponent_Template(rf, ctx) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(null, _c0); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(0, 0, 12, "px"); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('[class]', () => { | 
					
						
							|  |  |  |     it('should create class styling instructions on the element', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div [class]="myClassExp"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                   myClassExp = {'foo':true} | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |           template: function MyComponent_Template(rf, $ctx$) { | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |               $r3$.ɵelementStylingMap(0,$ctx$.myClassExp); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should place initial, multi, singular and application followed by attribute class instructions in the template code in that order', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div class="grape"
 | 
					
						
							|  |  |  |                                    [attr.class]="'banana'" | 
					
						
							|  |  |  |                                    [class.apple]="yesToApple" | 
					
						
							|  |  |  |                                    [class]="myClassExp" | 
					
						
							|  |  |  |                                    [class.orange]="yesToOrange"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myClassExp = {a:true, b:true}; | 
					
						
							|  |  |  |                   yesToApple = true; | 
					
						
							|  |  |  |                   yesToOrange = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $e0_attrs$ = [${AttributeMarker.Classes}, "grape", ${AttributeMarker.SelectOnly}, "class"]; | 
					
						
							|  |  |  |           const $e0_bindings$ = ["apple", "orange"]; | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-08-03 12:20:27 -07:00
										 |  |  |           MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |               type: MyComponent, | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |               selectors:[["my-component"]], | 
					
						
							| 
									
										
										
										
											2018-07-16 16:36:31 -07:00
										 |  |  |               factory:function MyComponent_Factory(t){ | 
					
						
							|  |  |  |                 return new (t || MyComponent)(); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |               }, | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |               consts: 1, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |               vars: 1, | 
					
						
							|  |  |  |               template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-08-20 15:20:12 +02:00
										 |  |  |                   $r3$.ɵelementStart(0, "div", $e0_attrs$); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |                   $r3$.ɵelementStyling($e0_bindings$); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementEnd(); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementStylingMap(0, $ctx$.myClassExp); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |                   $r3$.ɵelementClassProp(0, 0, $ctx$.yesToApple); | 
					
						
							|  |  |  |                   $r3$.ɵelementClassProp(0, 1, $ctx$.yesToOrange); | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |                   $r3$.ɵelementAttribute(0, "class", $r3$.ɵbind("banana")); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |               }, | 
					
						
							|  |  |  |               encapsulation: 2 | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |             }); | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should not generate the styling apply instruction if there are only static style/class attributes', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |                   template: \`<div class="    foo  "
 | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                                    style="width:100px" | 
					
						
							|  |  |  |                                    [attr.class]="'round'" | 
					
						
							|  |  |  |                                    [attr.style]="'height:100px'"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $e0_attrs$ = [${AttributeMarker.Classes}, "foo", ${AttributeMarker.Styles}, "width", "100px", ${AttributeMarker.SelectOnly}, "class", "style"]; | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-08-03 12:20:27 -07:00
										 |  |  |           MyComponent.ngComponentDef = $r3$.ɵdefineComponent({ | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |               type: MyComponent, | 
					
						
							| 
									
										
										
										
											2018-07-12 15:10:55 -07:00
										 |  |  |               selectors:[["my-component"]], | 
					
						
							| 
									
										
										
										
											2018-07-16 16:36:31 -07:00
										 |  |  |               factory:function MyComponent_Factory(t){ | 
					
						
							|  |  |  |                 return new (t || MyComponent)(); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |               }, | 
					
						
							| 
									
										
										
										
											2018-08-16 18:53:21 -07:00
										 |  |  |               consts: 1, | 
					
						
							| 
									
										
										
										
											2018-08-18 11:14:50 -07:00
										 |  |  |               vars: 2, | 
					
						
							|  |  |  |               template:  function MyComponent_Template(rf, $ctx$) { | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2019-01-16 11:11:33 -08:00
										 |  |  |                   $r3$.ɵelement(0, "div", $e0_attrs$); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-08-14 16:48:58 -07:00
										 |  |  |                   $r3$.ɵelementAttribute(0, "class", $r3$.ɵbind("round")); | 
					
						
							| 
									
										
										
										
											2018-09-05 17:13:17 +02:00
										 |  |  |                   $r3$.ɵelementAttribute(0, "style", $r3$.ɵbind("height:100px"), $r3$.ɵsanitizeStyle); | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-11-19 18:48:14 +01:00
										 |  |  |               }, | 
					
						
							|  |  |  |               encapsulation: 2 | 
					
						
							| 
									
										
										
										
											2018-07-11 09:56:47 -07:00
										 |  |  |             }); | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-09-26 23:14:24 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('[style] mixed with [class]', () => { | 
					
						
							|  |  |  |     it('should combine [style] and [class] bindings into a single instruction', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div [style]="myStyleExp" [class]="myClassExp"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myStyleExp = [{color:'red'}, {color:'blue', duration:1000}] | 
					
						
							|  |  |  |                   myClassExp = 'foo bar apple'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |           template: function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(null, null, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $ctx$.myClassExp, $ctx$.myStyleExp); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-19 09:30:41 -07:00
										 |  |  |     it('should stamp out pipe definitions in the creation block if used by styling bindings', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`<div [style]="myStyleExp | stylePipe" [class]="myClassExp | classPipe"></div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myStyleExp = [{color:'red'}, {color:'blue', duration:1000}] | 
					
						
							|  |  |  |                   myClassExp = 'foo bar apple'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							|  |  |  |           template: function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(null, null, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							|  |  |  |               $r3$.ɵpipe(1, "classPipe"); | 
					
						
							|  |  |  |               $r3$.ɵpipe(2, "stylePipe"); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $r3$.ɵpipeBind1(1, 0, $ctx$.myClassExp), $r3$.ɵpipeBind1(2, 2, $ctx$.myStyleExp)); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							| 
									
										
										
										
											2018-10-22 15:16:03 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should properly offset multiple style pipe references for styling bindings', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: \`
 | 
					
						
							|  |  |  |                     <div [class]="{}" | 
					
						
							|  |  |  |                          [class.foo]="fooExp | pipe:2000" | 
					
						
							|  |  |  |                          [style]="myStyleExp | pipe:1000" | 
					
						
							|  |  |  |                          [style.bar]="barExp | pipe:3000" | 
					
						
							|  |  |  |                          [style.baz]="bazExp | pipe:4000"> | 
					
						
							|  |  |  |                          {{ item }}</div>\`
 | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myStyleExp = {}; | 
					
						
							|  |  |  |                   fooExp = 'foo'; | 
					
						
							|  |  |  |                   barExp = 'bar'; | 
					
						
							|  |  |  |                   bazExp = 'baz'; | 
					
						
							|  |  |  |                   items = [1,2,3]; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $e0_classBindings$ = ["foo"]; | 
					
						
							|  |  |  |           const $e0_styleBindings$ = ["bar", "baz"]; | 
					
						
							|  |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-10-22 15:16:03 -07:00
										 |  |  |           template: function MyComponent_Template(rf, $ctx$) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStart(0, "div"); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               $r3$.ɵelementStyling($e0_classBindings$, $e0_styleBindings$, $r3$.ɵdefaultStyleSanitizer); | 
					
						
							| 
									
										
										
										
											2018-10-22 15:16:03 -07:00
										 |  |  |               $r3$.ɵpipe(1, "pipe"); | 
					
						
							|  |  |  |               $r3$.ɵpipe(2, "pipe"); | 
					
						
							|  |  |  |               $r3$.ɵpipe(3, "pipe"); | 
					
						
							|  |  |  |               $r3$.ɵpipe(4, "pipe"); | 
					
						
							|  |  |  |               $r3$.ɵtext(5); | 
					
						
							|  |  |  |               $r3$.ɵelementEnd(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(0, $e2_styling$, $r3$.ɵpipeBind2(1, 1, $ctx$.myStyleExp, 1000)); | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(0, 0, $r3$.ɵpipeBind2(2, 4, $ctx$.barExp, 3000)); | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(0, 1, $r3$.ɵpipeBind2(3, 7, $ctx$.bazExp, 4000)); | 
					
						
							|  |  |  |               $r3$.ɵelementClassProp(0, 0, $r3$.ɵpipeBind2(4, 10, $ctx$.fooExp, 2000)); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(0); | 
					
						
							|  |  |  |               $r3$.ɵtextBinding(5, $r3$.ɵinterpolation1(" ", $ctx$.item, "")); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2018-09-26 23:14:24 -07:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   describe('@Component host styles/classes', () => { | 
					
						
							|  |  |  |     it('should generate style/class instructions for a host component creation definition', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule, HostBinding} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: '', | 
					
						
							|  |  |  |                   host: { | 
					
						
							|  |  |  |                     'style': 'width:200px; height:500px', | 
					
						
							|  |  |  |                     'class': 'foo baz' | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   @HostBinding('style') | 
					
						
							|  |  |  |                   myStyle = {width:'100px'}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class') | 
					
						
							|  |  |  |                   myClass = {bar:false}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('style.color') | 
					
						
							|  |  |  |                   myColorProp = 'red'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class.foo') | 
					
						
							|  |  |  |                   myFooClass = 'red'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $e0_attrs$ = [${AttributeMarker.Classes}, "foo", "baz", ${AttributeMarker.Styles}, "width", "200px", "height", "500px"]; | 
					
						
							|  |  |  |           const $e0_classBindings$ = ["foo"]; | 
					
						
							|  |  |  |           const $e0_styleBindings$ = ["color"]; | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |           hostBindings: function MyComponent_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               $r3$.ɵelementHostAttrs(ctx, $e0_attrs$); | 
					
						
							|  |  |  |               $r3$.ɵelementStyling($e0_classBindings$, $e0_styleBindings$, $r3$.ɵdefaultStyleSanitizer, ctx); | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(elIndex, ctx.myClass, ctx.myStyle, ctx); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               $r3$.ɵelementStyleProp(elIndex, 0, ctx.myColorProp, null, ctx); | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |               $r3$.ɵelementClassProp(elIndex, 0, ctx.myFooClass, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |           }, | 
					
						
							|  |  |  |           consts: 0, | 
					
						
							|  |  |  |           vars: 0, | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should generate style/class instructions for multiple host binding definitions', () => { | 
					
						
							|  |  |  |       const files = { | 
					
						
							|  |  |  |         app: { | 
					
						
							|  |  |  |           'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Component, NgModule, HostBinding} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: '', | 
					
						
							|  |  |  |                   host: { | 
					
						
							|  |  |  |                     '[style.height.pt]': 'myHeightProp', | 
					
						
							|  |  |  |                     '[class.bar]': 'myBarClass' | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                   myHeightProp = 20; | 
					
						
							|  |  |  |                   myBarClass = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('style') | 
					
						
							|  |  |  |                   myStyle = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('style.width') | 
					
						
							|  |  |  |                   myWidthProp = '500px'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class.foo') | 
					
						
							|  |  |  |                   myFooClass = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class') | 
					
						
							|  |  |  |                   myClasses = {a:true, b:true}; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const template = `
 | 
					
						
							|  |  |  |           const _c0 = ["bar", "foo"]; | 
					
						
							|  |  |  |           const _c1 = ["height", "width"]; | 
					
						
							|  |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |           hostBindings: function MyComponent_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(_c0, _c1, $r3$.ɵdefaultStyleSanitizer, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(elIndex, ctx.myClasses, ctx.myStyle, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(elIndex, 0, ctx.myHeightProp, "pt", ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(elIndex, 1, ctx.myWidthProp, null, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementClassProp(elIndex, 0, ctx.myBarClass, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementClassProp(elIndex, 1, ctx.myFooClass, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |           }, | 
					
						
							|  |  |  |           consts: 0, | 
					
						
							|  |  |  |           vars: 0, | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const result = compile(files, angularFiles); | 
					
						
							|  |  |  |       expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should generate styling instructions for multiple directives that contain host binding definitions', | 
					
						
							|  |  |  |        () => { | 
					
						
							|  |  |  |          const files = { | 
					
						
							|  |  |  |            app: { | 
					
						
							|  |  |  |              'spec.ts': `
 | 
					
						
							|  |  |  |                 import {Directive, Component, NgModule, HostBinding} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-02 15:26:57 -08:00
										 |  |  |                 @Directive({selector: '[myClassDir]'}) | 
					
						
							|  |  |  |                 export class ClassDirective { | 
					
						
							|  |  |  |                   @HostBinding('class') | 
					
						
							|  |  |  |                   myClassMap = {red: true}; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |                 @Directive({selector: '[myWidthDir]'}) | 
					
						
							|  |  |  |                 export class WidthDirective { | 
					
						
							|  |  |  |                   @HostBinding('style.width') | 
					
						
							|  |  |  |                   myWidth = 200; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class.foo') | 
					
						
							|  |  |  |                   myFooClass = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Directive({selector: '[myHeightDir]'}) | 
					
						
							|  |  |  |                 export class HeightDirective { | 
					
						
							|  |  |  |                   @HostBinding('style.height') | 
					
						
							|  |  |  |                   myHeight = 200; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   @HostBinding('class.bar') | 
					
						
							|  |  |  |                   myBarClass = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 @Component({ | 
					
						
							|  |  |  |                   selector: 'my-component', | 
					
						
							|  |  |  |                   template: ' | 
					
						
							| 
									
										
										
										
											2018-12-02 15:26:57 -08:00
										 |  |  |                     <div myWidthDir myHeightDir myClassDir></div> | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |                   ', | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 export class MyComponent { | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-02 15:26:57 -08:00
										 |  |  |                 @NgModule({declarations: [MyComponent, WidthDirective, HeightDirective, ClassDirective]}) | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |                 export class MyModule {} | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |            } | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const template = `
 | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           const $widthDir_classes$ = ["foo"]; | 
					
						
							|  |  |  |           const $widthDir_styles$ = ["width"]; | 
					
						
							|  |  |  |           const $heightDir_classes$ = ["bar"]; | 
					
						
							|  |  |  |           const $heightDir_styles$ = ["height"]; | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-12-02 15:26:57 -08:00
										 |  |  |           function ClassDirective_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							|  |  |  |               $r3$.ɵelementStyling(null, null, null, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStylingMap(elIndex, ctx.myClassMap, null, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |           function WidthDirective_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               $r3$.ɵelementStyling($widthDir_classes$, $widthDir_styles$, null, ctx); | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(elIndex, 0, ctx.myWidth, null, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementClassProp(elIndex, 0, ctx.myFooClass, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           } | 
					
						
							|  |  |  |           … | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |           function HeightDirective_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |             if (rf & 1) { | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               $r3$.ɵelementStyling($heightDir_classes$, $heightDir_styles$, null, ctx); | 
					
						
							| 
									
										
										
										
											2018-11-20 15:20:19 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (rf & 2) { | 
					
						
							|  |  |  |               $r3$.ɵelementStyleProp(elIndex, 0, ctx.myHeight, null, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementClassProp(elIndex, 0, ctx.myBarClass, ctx); | 
					
						
							|  |  |  |               $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-11-16 15:22:12 +01:00
										 |  |  |           } | 
					
						
							|  |  |  |           … | 
					
						
							|  |  |  |           `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          const result = compile(files, angularFiles); | 
					
						
							|  |  |  |          expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   it('should count only non-style and non-class host bindings on Components', () => { | 
					
						
							|  |  |  |     const files = { | 
					
						
							|  |  |  |       app: { | 
					
						
							|  |  |  |         'spec.ts': `
 | 
					
						
							|  |  |  |           import {Component, NgModule, HostBinding} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @Component({ | 
					
						
							|  |  |  |             selector: 'my-component', | 
					
						
							|  |  |  |             template: '', | 
					
						
							|  |  |  |             host: { | 
					
						
							|  |  |  |               'style': 'width:200px; height:500px', | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |               'class': 'foo baz', | 
					
						
							|  |  |  |               'title': 'foo title' | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |             } | 
					
						
							|  |  |  |           }) | 
					
						
							|  |  |  |           export class MyComponent { | 
					
						
							|  |  |  |             @HostBinding('style') | 
					
						
							|  |  |  |             myStyle = {width:'100px'}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('class') | 
					
						
							|  |  |  |             myClass = {bar:false}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('id') | 
					
						
							|  |  |  |             id = 'some id'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('title') | 
					
						
							|  |  |  |             title = 'some title'; | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |             @Input('name') | 
					
						
							|  |  |  |             name = ''; | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @NgModule({declarations: [MyComponent]}) | 
					
						
							|  |  |  |           export class MyModule {} | 
					
						
							|  |  |  |         `
 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const template = `
 | 
					
						
							| 
									
										
										
										
											2019-01-11 14:03:37 -08:00
										 |  |  |       const $_c0$ = ["title", "foo title", ${AttributeMarker.Classes}, "foo", "baz", ${AttributeMarker.Styles}, "width", "200px", "height", "500px"]; | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |       … | 
					
						
							|  |  |  |       hostBindings: function MyComponent_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |         if (rf & 1) { | 
					
						
							|  |  |  |           $r3$.ɵallocHostVars(2); | 
					
						
							| 
									
										
										
										
											2018-12-13 15:51:47 -08:00
										 |  |  |           $r3$.ɵelementHostAttrs(ctx, $_c0$); | 
					
						
							|  |  |  |           $r3$.ɵelementStyling(null, null, $r3$.ɵdefaultStyleSanitizer, ctx); | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-12-10 14:51:28 -08:00
										 |  |  |           $r3$.ɵelementProperty(elIndex, "id", $r3$.ɵbind(ctx.id), null, true); | 
					
						
							|  |  |  |           $r3$.ɵelementProperty(elIndex, "title", $r3$.ɵbind(ctx.title), null, true); | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |           $r3$.ɵelementStylingMap(elIndex, ctx.myClass, ctx.myStyle, ctx); | 
					
						
							|  |  |  |           $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-01-11 14:03:37 -08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |     `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const result = compile(files, angularFiles); | 
					
						
							|  |  |  |     expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   it('should count only non-style and non-class host bindings on Directives', () => { | 
					
						
							|  |  |  |     const files = { | 
					
						
							|  |  |  |       app: { | 
					
						
							|  |  |  |         'spec.ts': `
 | 
					
						
							|  |  |  |           import {Directive, Component, NgModule, HostBinding} from '@angular/core'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           @Directive({selector: '[myWidthDir]'}) | 
					
						
							|  |  |  |           export class WidthDirective { | 
					
						
							|  |  |  |             @HostBinding('style.width') | 
					
						
							|  |  |  |             myWidth = 200; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('class.foo') | 
					
						
							|  |  |  |             myFooClass = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('id') | 
					
						
							|  |  |  |             id = 'some id'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             @HostBinding('title') | 
					
						
							|  |  |  |             title = 'some title'; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         `
 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const template = `
 | 
					
						
							|  |  |  |       const $_c0$ = ["foo"]; | 
					
						
							|  |  |  |       const $_c1$ = ["width"]; | 
					
						
							|  |  |  |       … | 
					
						
							|  |  |  |       hostBindings: function WidthDirective_HostBindings(rf, ctx, elIndex) { | 
					
						
							|  |  |  |         if (rf & 1) { | 
					
						
							|  |  |  |           $r3$.ɵallocHostVars(2); | 
					
						
							|  |  |  |           $r3$.ɵelementStyling($_c0$, $_c1$, null, ctx); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (rf & 2) { | 
					
						
							| 
									
										
										
										
											2018-12-10 14:51:28 -08:00
										 |  |  |           $r3$.ɵelementProperty(elIndex, "id", $r3$.ɵbind(ctx.id), null, true); | 
					
						
							|  |  |  |           $r3$.ɵelementProperty(elIndex, "title", $r3$.ɵbind(ctx.title), null, true); | 
					
						
							| 
									
										
										
										
											2018-11-30 17:34:36 -08:00
										 |  |  |           $r3$.ɵelementStyleProp(elIndex, 0, ctx.myWidth, null, ctx); | 
					
						
							|  |  |  |           $r3$.ɵelementClassProp(elIndex, 0, ctx.myFooClass, ctx); | 
					
						
							|  |  |  |           $r3$.ɵelementStylingApply(elIndex, ctx); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const result = compile(files, angularFiles); | 
					
						
							|  |  |  |     expectEmit(result.source, template, 'Incorrect template'); | 
					
						
							|  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2018-04-06 12:52:17 -07:00
										 |  |  | }); |