import classNames from 'classnames'; import PropTypes from 'prop-types'; import React from 'react'; import spring from 'react-motion/lib/spring'; import Icon from 'soapbox/components/icon'; import emojify from 'soapbox/features/emoji/emoji'; import Motion from '../features/ui/util/optional_motion'; export default class IconButton extends React.PureComponent { static propTypes = { className: PropTypes.string, iconClassName: PropTypes.string, title: PropTypes.string.isRequired, icon: PropTypes.string, src: PropTypes.string, onClick: PropTypes.func, onMouseDown: PropTypes.func, onKeyUp: PropTypes.func, onKeyDown: PropTypes.func, onKeyPress: PropTypes.func, onMouseEnter: PropTypes.func, onMouseLeave: PropTypes.func, size: PropTypes.number, active: PropTypes.bool, pressed: PropTypes.bool, expanded: PropTypes.bool, style: PropTypes.object, activeStyle: PropTypes.object, disabled: PropTypes.bool, inverted: PropTypes.bool, animate: PropTypes.bool, overlay: PropTypes.bool, tabIndex: PropTypes.string, text: PropTypes.string, emoji: PropTypes.string, type: PropTypes.string, }; static defaultProps = { size: 18, active: false, disabled: false, animate: false, overlay: false, tabIndex: '0', onKeyUp: () => {}, onKeyDown: () => {}, onClick: () => {}, onMouseEnter: () => {}, onMouseLeave: () => {}, type: 'button', }; handleClick = (e) => { e.preventDefault(); if (!this.props.disabled) { this.props.onClick(e); } } handleMouseDown = (e) => { if (!this.props.disabled && this.props.onMouseDown) { this.props.onMouseDown(e); } } handleKeyDown = (e) => { if (!this.props.disabled && this.props.onKeyDown) { this.props.onKeyDown(e); } } handleKeyUp = (e) => { if (!this.props.disabled && this.props.onKeyUp) { this.props.onKeyUp(e); } } handleKeyPress = (e) => { if (this.props.onKeyPress && !this.props.disabled) { this.props.onKeyPress(e); } } render() { const style = { fontSize: `${this.props.size}px`, width: `${this.props.size * 1.28571429}px`, height: `${this.props.size * 1.28571429}px`, lineHeight: `${this.props.size}px`, ...this.props.style, ...(this.props.active ? this.props.activeStyle : {}), }; const { active, animate, className, iconClassName, disabled, expanded, icon, src, inverted, overlay, pressed, tabIndex, title, text, emoji, type, } = this.props; const classes = classNames(className, 'icon-button', { active, disabled, inverted, overlayed: overlay, }); if (!animate) { // Perf optimization: avoid unnecessary components unless // we actually need to animate. return ( ); } return ( {({ rotate }) => ( )} ); } }