Merge pull request #372 from matrix-org/rav/velociraptor_warnings

Fix warnings emanating from Velociraptor elements
pull/21833/head
David Baker 2016-08-01 17:22:29 +01:00 committed by GitHub
commit 0ad23fa9ed
2 changed files with 56 additions and 28 deletions

View File

@ -18,6 +18,19 @@ module.exports = React.createClass({
// optional transition information for changing existing children // optional transition information for changing existing children
transition: React.PropTypes.object, transition: React.PropTypes.object,
// a list of state objects to apply to each child node in turn
startStyles: React.PropTypes.array,
// a list of transition options from the corresponding startStyle
enterTransitionOpts: React.PropTypes.array,
},
getDefaultProps: function() {
return {
startStyles: [],
enterTransitionOpts: [],
};
}, },
componentWillMount: function() { componentWillMount: function() {
@ -56,56 +69,71 @@ module.exports = React.createClass({
} }
self.children[c.key] = old; self.children[c.key] = old;
} else { } else {
// new element. If it has a startStyle, use that as the style and go through // new element. If we have a startStyle, use that as the style and go through
// the enter animations // the enter animations
var newProps = { var newProps = {};
ref: self.collectNode.bind(self, c.key) var restingStyle = c.props.style;
};
if (c.props.startStyle && Object.keys(c.props.startStyle).length) { var startStyles = self.props.startStyles;
var startStyle = c.props.startStyle; if (startStyles.length > 0) {
if (Array.isArray(startStyle)) { var startStyle = startStyles[0]
startStyle = startStyle[0];
}
newProps._restingStyle = c.props.style;
newProps.style = startStyle; newProps.style = startStyle;
//console.log("mounted@startstyle0: "+JSON.stringify(startStyle)); // console.log("mounted@startstyle0: "+JSON.stringify(startStyle));
// apply the enter animations once it's mounted
} }
newProps.ref = (n => self._collectNode(
c.key, n, restingStyle
));
self.children[c.key] = React.cloneElement(c, newProps); self.children[c.key] = React.cloneElement(c, newProps);
} }
}); });
}, },
collectNode: function(k, node) { /**
* called when a child element is mounted/unmounted
*
* @param {string} k key of the child
* @param {null|Object} node On mount: React node. On unmount: null
* @param {Object} restingStyle final style
*/
_collectNode: function(k, node, restingStyle) {
if ( if (
node && node &&
this.nodes[k] === undefined && this.nodes[k] === undefined &&
node.props.startStyle && this.props.startStyles.length > 0
Object.keys(node.props.startStyle).length
) { ) {
var startStyles = this.props.startStyles;
var transitionOpts = this.props.enterTransitionOpts;
var domNode = ReactDom.findDOMNode(node); var domNode = ReactDom.findDOMNode(node);
var startStyles = node.props.startStyle;
var transitionOpts = node.props.enterTransitionOpts;
if (!Array.isArray(startStyles)) {
startStyles = [ startStyles ];
transitionOpts = [ transitionOpts ];
}
// start from startStyle 1: 0 is the one we gave it // start from startStyle 1: 0 is the one we gave it
// to start with, so now we animate 1 etc. // to start with, so now we animate 1 etc.
for (var i = 1; i < startStyles.length; ++i) { for (var i = 1; i < startStyles.length; ++i) {
Velocity(domNode, startStyles[i], transitionOpts[i-1]); Velocity(domNode, startStyles[i], transitionOpts[i-1]);
//console.log("start: "+JSON.stringify(startStyles[i])); /*
console.log("start:",
JSON.stringify(transitionOpts[i-1]),
"->",
JSON.stringify(startStyles[i]),
);
*/
} }
// and then we animate to the resting state // and then we animate to the resting state
Velocity(domNode, node.props._restingStyle, Velocity(domNode, restingStyle,
transitionOpts[i-1]) transitionOpts[i-1])
.then(() => { .then(() => {
// once we've reached the resting state, hide the element if // once we've reached the resting state, hide the element if
// appropriate // appropriate
domNode.style.visibility = node.props._restingStyle.visibility; domNode.style.visibility = restingStyle.visibility;
}); });
//console.log("enter: "+JSON.stringify(node.props._restingStyle)); /*
console.log("enter:",
JSON.stringify(transitionOpts[i-1]),
"->",
JSON.stringify(restingStyle));
*/
} else if (node === null) { } else if (node === null) {
// Velocity stores data on elements using the jQuery .data() // Velocity stores data on elements using the jQuery .data()
// method, and assumes you'll be using jQuery's .remove() to // method, and assumes you'll be using jQuery's .remove() to

View File

@ -163,13 +163,13 @@ module.exports = React.createClass({
}; };
return ( return (
<Velociraptor> <Velociraptor
startStyles={this.state.startStyles}
enterTransitionOpts={this.state.enterTransitionOpts} >
<MemberAvatar <MemberAvatar
member={this.props.member} member={this.props.member}
width={14} height={14} resizeMethod="crop" width={14} height={14} resizeMethod="crop"
style={style} style={style}
startStyle={this.state.startStyles}
enterTransitionOpts={this.state.enterTransitionOpts}
onClick={this.props.onClick} onClick={this.props.onClick}
/> />
</Velociraptor> </Velociraptor>