mastodon/app/assets/javascripts/components/components/avatar.jsx

65 lines
1.2 KiB
React
Raw Normal View History

import PureRenderMixin from 'react-addons-pure-render-mixin';
2016-08-24 21:08:00 +02:00
const Avatar = React.createClass({
propTypes: {
2016-08-31 22:58:10 +02:00
src: React.PropTypes.string.isRequired,
staticSrc: React.PropTypes.string,
size: React.PropTypes.number.isRequired,
2017-01-31 19:16:35 +01:00
style: React.PropTypes.object,
animate: React.PropTypes.bool
2017-01-31 19:16:35 +01:00
},
getDefaultProps () {
return {
animate: false
2017-01-31 19:16:35 +01:00
};
2016-08-24 21:08:00 +02:00
},
getInitialState () {
return {
hovering: false
};
},
mixins: [PureRenderMixin],
handleMouseEnter () {
this.setState({ hovering: true });
},
handleMouseLeave () {
this.setState({ hovering: false });
},
2016-08-24 21:08:00 +02:00
render () {
const { src, size, staticSrc, animate } = this.props;
const { hovering } = this.state;
const style = {
...this.props.style,
width: `${size}px`,
height: `${size}px`,
backgroundSize: `${size}px ${size}px`
};
if (hovering || animate) {
style.backgroundImage = `url(${src})`;
} else {
style.backgroundImage = `url(${staticSrc})`;
2017-01-31 19:16:35 +01:00
}
2016-08-24 21:08:00 +02:00
return (
<div
className='avatar'
onMouseEnter={this.handleMouseEnter}
onMouseLeave={this.handleMouseLeave}
style={style}
/>
2016-08-24 21:08:00 +02:00
);
}
});
export default Avatar;