From 262aad014e973d5d3fb58e6a8b82eb7034fc3552 Mon Sep 17 00:00:00 2001 From: NickBolles Date: Sun, 3 Apr 2016 23:38:35 -0500 Subject: [PATCH] Fix(ng-animate-ref): copy contextual styling to clone Copy all contextual styling to the cloned element. The list of properties that are copied is derived from https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_animated_properties Closes #12402 --- src/ngAnimate/animateCssDriver.js | 118 +++++++++++++++++++++++++++++- 1 file changed, 116 insertions(+), 2 deletions(-) diff --git a/src/ngAnimate/animateCssDriver.js b/src/ngAnimate/animateCssDriver.js index b018ca3a49dd..00992667d6c1 100644 --- a/src/ngAnimate/animateCssDriver.js +++ b/src/ngAnimate/animateCssDriver.js @@ -9,6 +9,114 @@ var $$AnimateCssDriverProvider = ['$$animationProvider', function($$animationPro var NG_OUT_ANCHOR_CLASS_NAME = 'ng-anchor-out'; var NG_IN_ANCHOR_CLASS_NAME = 'ng-anchor-in'; + + var ANIMATED_PROPS = [ + 'MozOutlineRadius', + 'MozOutlineRadiusBottomleft', + 'MozOutlineRadiusBottomright', + 'MozOutlineRadiusTopleft', + 'MozOutlineRadiusTopright', + 'WebkitTextStroke', + 'WebkitTextStrokeColor', + 'WebkitTouchCallout', + 'backdropFilter', + 'background', + 'backgroundColor', + 'backgroundPosition', + 'backgroundSize', + 'border', + 'borderBottom', + 'borderBottomColor', + 'borderBottomLeftRadius', + 'borderBottomRightRadius', + 'borderBottomWidth', + 'borderColor', + 'borderLeft', + 'borderLeftColor', + 'borderLeftWidth', + 'borderRadius', + 'borderRight', + 'borderRightColor', + 'borderRightWidth', + 'borderTop', + 'borderTopColor', + 'borderTopLeftRadius', + 'borderTopRightRadius', + 'borderTopWidth', + 'borderWidth', + 'bottom', + 'boxShadow', + 'clip', + 'clipPath', + 'color', + 'columnCount', + 'columnGap', + 'columnRule', + 'columnRuleColor', + 'columnRuleWidth', + 'columnWidth', + 'columns', + 'filter', + 'flex', + 'flexBasis', + 'flexGrow', + 'flexShrink', + 'font', + 'fontSize', + 'fontSizeAdjust', + 'fontStretch', + 'fontWeight', + 'gridColumnGap', + 'gridGap', + 'gridRowGap', + 'letterSpacing', + 'lineHeight', + 'margin', + 'marginBottom', + 'marginLeft', + 'marginRight', + 'marginTop', + 'mask', + 'maskPosition', + 'maskSize', + 'maxHeight', + 'maxWidth', + 'minHeight', + 'minWidth', + 'motionOffset', + 'motionRotation', + 'objectPosition', + 'opacity', + 'order', + 'outline', + 'outlineColor', + 'outlineOffset', + 'outlineWidth', + 'padding', + 'paddingBottom', + 'paddingLeft', + 'paddingRight', + 'paddingTop', + 'perspective', + 'perspectiveOrigin', + 'scrollSnapCoordinate', + 'scrollSnapDestination', + 'shapeImageThreshold', + 'shapeMargin', + 'shapeOutside', + 'textDecoration', + 'textDecorationColor', + 'textEmphasis', + 'textEmphasisColor', + 'textIndent', + 'textShadow', + 'transform', + 'transformOrigin', + 'verticalAlign', + 'wordSpacing', + 'zIndex' + ]; + function isDocumentFragment(node) { return node.parentNode && node.parentNode.nodeType === 11; } @@ -121,11 +229,13 @@ var $$AnimateCssDriverProvider = ['$$animationProvider', function($$animationPro function calculateAnchorStyles(anchor) { var styles = {}; - var coords = getDomNode(anchor).getBoundingClientRect(); + var domNode = getDomNode(anchor); + var computedStyle = domNode.currentStyle || $window.getComputedStyle(domNode) || []; + var coords = domNode.getBoundingClientRect(); // we iterate directly since safari messes up and doesn't return // all the keys for the coords object when iterated - forEach(['width','height','top','left'], function(key) { + forEach(['width','height','top','left', 'color'], function(key) { var value = coords[key]; switch (key) { case 'top': @@ -137,6 +247,10 @@ var $$AnimateCssDriverProvider = ['$$animationProvider', function($$animationPro } styles[key] = Math.floor(value) + 'px'; }); + forEach(ANIMATED_PROPS, function(prop){ + styles[prop] = computedStyle[prop]; + }); + return styles; }