Skip to content
This repository has been archived by the owner on Apr 12, 2024. It is now read-only.

Commit

Permalink
fix(ngAnimate): don't close transitions when child transitions close
Browse files Browse the repository at this point in the history
Previously, non-angular CSS transitions / animations on child elements
would trigger the ngAnimate [transition|animation]end listener and
could close a running animation prematurely.

Closes #16210
  • Loading branch information
Narretz committed Sep 6, 2017
1 parent 7a5f06d commit 1391e99
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 0 deletions.
6 changes: 6 additions & 0 deletions src/ngAnimate/animateCss.js
Original file line number Diff line number Diff line change
Expand Up @@ -805,6 +805,12 @@ var $AnimateCssProvider = ['$animateProvider', /** @this */ function($animatePro
event.stopPropagation();
var ev = event.originalEvent || event;

if (ev.target !== node) {
// Since TransitionEvent / AnimationEvent bubble up,
// we have to ignore events by finished child animations
return;
}

// we now always use `Date.now()` due to the recent changes with
// event.timeStamp in Firefox, Webkit and Chrome (see #13494 for more info)
var timeStamp = ev.$manualTimeStamp || Date.now();
Expand Down
54 changes: 54 additions & 0 deletions test/ngAnimate/animateCssSpec.js
Original file line number Diff line number Diff line change
Expand Up @@ -532,6 +532,60 @@ describe('ngAnimate $animateCss', function() {
assertAnimationComplete(true);
}));

it('should not close a transition when a child element fires the transitionend event',
inject(function($animateCss) {

ss.addPossiblyPrefixedRule('.ng-enter', 'transition:4s linear all;');
ss.addPossiblyPrefixedRule('.non-angular-animation', 'transition:5s linear all;');

var child = angular.element('<div class="non-angular-animation"></div>');
element.append(child);

var animator = $animateCss(element, options);
animator.start();
triggerAnimationStartFrame();

browserTrigger(child, 'transitionend', {
timeStamp: Date.now(),
elapsedTime: 5,
bubbles: true
});

transitionProgress(element, 1);

assertAnimationComplete(false);

transitionProgress(element, 4);
assertAnimationComplete(true);
}));

it('should not close a keyframe animation when a child element fires the animationend event',
inject(function($animateCss) {

ss.addPossiblyPrefixedRule('.ng-enter', 'animation:animation 4s;');
ss.addPossiblyPrefixedRule('.non-angular-animation', 'animation:animation 5s;');

var child = angular.element('<div class="non-angular-animation"></div>');
element.append(child);

var animator = $animateCss(element, options);
animator.start();
triggerAnimationStartFrame();

browserTrigger(child, 'animationend', {
timeStamp: Date.now(),
elapsedTime: 5,
bubbles: true
});

keyframeProgress(element, 1);

assertAnimationComplete(false);

keyframeProgress(element, 4);
assertAnimationComplete(true);
}));

it('should use the highest keyframe duration value detected in the CSS class', inject(function($animateCss) {
ss.addPossiblyPrefixedRule('.ng-enter', 'animation:animation 1s, animation 2s, animation 3s;');

Expand Down

0 comments on commit 1391e99

Please sign in to comment.