Skip to content

Commit

Permalink
fix($animate): retain inline styles for property-specific transition …
Browse files Browse the repository at this point in the history
…animations

Closes angular#7503
  • Loading branch information
matsko committed May 23, 2014
1 parent e9fad96 commit 32d5de4
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/ngAnimate/animate.js
Original file line number Diff line number Diff line change
Expand Up @@ -1433,7 +1433,7 @@ angular.module('ngAnimate', ['ng'])
//the jqLite object, so we're safe to use a single variable to house
//the styles since there is always only one element being animated
var oldStyle = node.getAttribute('style') || '';
node.setAttribute('style', oldStyle + ' ' + style);
node.setAttribute('style', oldStyle + '; ' + style);
}

var startTime = Date.now();
Expand Down
20 changes: 20 additions & 0 deletions test/ngAnimate/animateSpec.js
Original file line number Diff line number Diff line change
Expand Up @@ -1167,6 +1167,26 @@ describe("ngAnimate", function() {
expect(element.css('width')).toBe("200px");
}));

it("should NOT overwrite styles when a transition with a specific property is used",
inject(function($animate, $rootScope, $compile, $sniffer, $timeout) {

if(!$sniffer.transitions) return;

var style = '-webkit-transition: border linear .2s;' +
'transition: border linear .2s;';

ss.addRule('.on', style);
element = $compile(html('<div style="height:200px"></div>'))($rootScope);
$animate.addClass(element, 'on');

$animate.triggerReflow();

var now = Date.now();
browserTrigger(element,'transitionend', { timeStamp: now + 1000, elapsedTime: 1 });
browserTrigger(element,'transitionend', { timeStamp: now + 2000, elapsedTime: 2 });
expect(element.css('height')).toBe("200px");
}));


it("should animate for the highest duration",
inject(function($animate, $rootScope, $compile, $sniffer, $timeout) {
Expand Down

0 comments on commit 32d5de4

Please sign in to comment.