This patch ensures that if the NoopAnimationsModule is used then it will correctly report the associated `totalTime` property within the emitted AnimationEvent instance when an animation event trigger is fired. BREAKING CHANGE: When animation is trigged within a disabled zone, the associated event (which an instance of AnimationEvent) will no longer report the totalTime as 0 (it will emit the actual time of the animation). To detect if an animation event is reporting a disabled animation then the `event.disabled` property can be used instead. PR Close #22225
52 lines
1.6 KiB
TypeScript
52 lines
1.6 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 {ɵStyleData} from '@angular/animations';
|
|
import {AnimationEngineInstruction, AnimationTransitionInstructionType} from '../render/animation_engine_instruction';
|
|
import {AnimationTimelineInstruction} from './animation_timeline_instruction';
|
|
|
|
export interface AnimationTransitionInstruction extends AnimationEngineInstruction {
|
|
element: any;
|
|
triggerName: string;
|
|
isRemovalTransition: boolean;
|
|
fromState: string;
|
|
fromStyles: ɵStyleData;
|
|
toState: string;
|
|
toStyles: ɵStyleData;
|
|
timelines: AnimationTimelineInstruction[];
|
|
queriedElements: any[];
|
|
preStyleProps: Map<any, {[prop: string]: boolean}>;
|
|
postStyleProps: Map<any, {[prop: string]: boolean}>;
|
|
totalTime: number;
|
|
errors?: any[];
|
|
}
|
|
|
|
export function createTransitionInstruction(
|
|
element: any, triggerName: string, fromState: string, toState: string,
|
|
isRemovalTransition: boolean, fromStyles: ɵStyleData, toStyles: ɵStyleData,
|
|
timelines: AnimationTimelineInstruction[], queriedElements: any[],
|
|
preStyleProps: Map<any, {[prop: string]: boolean}>,
|
|
postStyleProps: Map<any, {[prop: string]: boolean}>, totalTime: number,
|
|
errors?: any[]): AnimationTransitionInstruction {
|
|
return {
|
|
type: AnimationTransitionInstructionType.TransitionAnimation,
|
|
element,
|
|
triggerName,
|
|
isRemovalTransition,
|
|
fromState,
|
|
fromStyles,
|
|
toState,
|
|
toStyles,
|
|
timelines,
|
|
queriedElements,
|
|
preStyleProps,
|
|
postStyleProps,
|
|
totalTime,
|
|
errors
|
|
};
|
|
}
|