* feat(animations): support animation trigger template callbacks * refactor(animations): deport TCB away from animation-land forever
		
			
				
	
	
		
			80 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * @license
 | |
|  * Copyright Google Inc. All Rights Reserved.
 | |
|  *
 | |
|  * Use of this source code is governed by an MIT-style license that can be
 | |
|  * found in the LICENSE file at https://angular.io/license
 | |
|  */
 | |
| 
 | |
| import {AnimationMetadata, animate, group, sequence, style, transition, trigger} from '@angular/core';
 | |
| import {AsyncTestCompleter, beforeEach, beforeEachProviders, ddescribe, describe, expect, iit, inject, it, xdescribe, xit} from '@angular/core/testing/testing_internal';
 | |
| 
 | |
| import {StringMapWrapper} from '../../../platform-browser-dynamic/src/facade/collection';
 | |
| import {AnimationCompiler, CompiledAnimationTriggerResult} from '../../src/animation/animation_compiler';
 | |
| import {CompileAnimationEntryMetadata, CompileDirectiveMetadata, CompileTemplateMetadata, CompileTypeMetadata} from '../../src/compile_metadata';
 | |
| import {CompileMetadataResolver} from '../../src/metadata_resolver';
 | |
| 
 | |
| export function main() {
 | |
|   describe('RuntimeAnimationCompiler', () => {
 | |
|     var resolver: any /** TODO #9100 */;
 | |
|     beforeEach(
 | |
|         inject([CompileMetadataResolver], (res: CompileMetadataResolver) => { resolver = res; }));
 | |
| 
 | |
|     var compiler = new AnimationCompiler();
 | |
| 
 | |
|     var compileAnimations =
 | |
|         (component: CompileDirectiveMetadata): CompiledAnimationTriggerResult => {
 | |
|           var result = compiler.compileComponent(component, []);
 | |
|           return result.triggers[0];
 | |
|         };
 | |
| 
 | |
|     var compileTriggers = (input: any[]) => {
 | |
|       var entries: CompileAnimationEntryMetadata[] = input.map(entry => {
 | |
|         var animationTriggerData = trigger(entry[0], entry[1]);
 | |
|         return resolver.getAnimationEntryMetadata(animationTriggerData);
 | |
|       });
 | |
| 
 | |
|       var component = CompileDirectiveMetadata.create({
 | |
|         type: new CompileTypeMetadata({name: 'myCmp'}),
 | |
|         template: new CompileTemplateMetadata({animations: entries})
 | |
|       });
 | |
| 
 | |
|       return compileAnimations(component);
 | |
|     };
 | |
| 
 | |
|     var compileSequence = (seq: AnimationMetadata) => {
 | |
|       return compileTriggers([['myAnimation', [transition('state1 => state2', seq)]]]);
 | |
|     };
 | |
| 
 | |
|     it('should throw an exception containing all the inner animation parser errors', () => {
 | |
|       var animation = sequence([
 | |
|         style({'color': 'red'}), animate(1000, style({'font-size': '100px'})),
 | |
|         style({'color': 'blue'}), animate(1000, style(':missing_state')), style({'color': 'gold'}),
 | |
|         animate(1000, style('broken_state'))
 | |
|       ]);
 | |
| 
 | |
|       var capturedErrorMessage: string;
 | |
|       try {
 | |
|         compileSequence(animation);
 | |
|       } catch (e) {
 | |
|         capturedErrorMessage = e.message;
 | |
|       }
 | |
| 
 | |
|       expect(capturedErrorMessage)
 | |
|           .toMatch(/Unable to apply styles due to missing a state: "missing_state"/g);
 | |
| 
 | |
|       expect(capturedErrorMessage)
 | |
|           .toMatch(/Animation states via styles must be prefixed with a ":"/);
 | |
|     });
 | |
| 
 | |
|     it('should throw an error when two or more animation triggers contain the same name', () => {
 | |
|       var t1Data: any[] = [];
 | |
|       var t2Data: any[] = [];
 | |
| 
 | |
|       expect(() => {
 | |
|         compileTriggers([['myTrigger', t1Data], ['myTrigger', t2Data]]);
 | |
|       }).toThrowError(/The animation trigger "myTrigger" has already been registered on "myCmp"/);
 | |
|     });
 | |
|   });
 | |
| }
 |