pleroma/app/soapbox/components/button.js

82 lines
1.7 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import classNames from 'classnames';
import PropTypes from 'prop-types';
import React from 'react';
2020-04-21 17:44:55 -07:00
import { Link } from 'react-router-dom';
2020-04-21 17:44:55 -07:00
import Icon from './icon';
2020-03-27 13:59:38 -07:00
export default class Button extends React.PureComponent {
static propTypes = {
2022-01-12 10:03:24 -08:00
type: PropTypes.string,
2020-03-27 13:59:38 -07:00
text: PropTypes.node,
onClick: PropTypes.func,
2020-04-21 17:44:55 -07:00
to: PropTypes.string,
2020-03-27 13:59:38 -07:00
disabled: PropTypes.bool,
block: PropTypes.bool,
secondary: PropTypes.bool,
size: PropTypes.number,
className: PropTypes.string,
style: PropTypes.object,
2020-04-21 17:44:55 -07:00
icon: PropTypes.string,
2020-03-27 13:59:38 -07:00
children: PropTypes.node,
};
static defaultProps = {
size: 36,
2020-04-23 07:19:50 -07:00
}
2020-03-27 13:59:38 -07:00
handleClick = (e) => {
2020-04-23 07:19:50 -07:00
if (!this.props.disabled && this.props.onClick) {
2020-03-27 13:59:38 -07:00
this.props.onClick(e);
}
}
setRef = (c) => {
this.node = c;
}
focus() {
this.node.focus();
}
render() {
2020-03-27 13:59:38 -07:00
const style = {
padding: `0 ${this.props.size / 2.25}px`,
height: `${this.props.size}px`,
lineHeight: `${this.props.size}px`,
...this.props.style,
};
const className = classNames('button', this.props.className, {
'button-secondary': this.props.secondary,
'button--block': this.props.block,
});
2020-04-21 17:44:55 -07:00
const btn = (
2020-03-27 13:59:38 -07:00
<button
2022-01-12 10:03:24 -08:00
type={this.props.type}
2020-03-27 13:59:38 -07:00
className={className}
disabled={this.props.disabled}
onClick={this.handleClick}
ref={this.setRef}
style={style}
>
2020-04-21 17:44:55 -07:00
{this.props.icon && <Icon id={this.props.icon} />}
2020-03-27 13:59:38 -07:00
{this.props.text || this.props.children}
</button>
);
2020-04-21 17:44:55 -07:00
if (this.props.to) {
return (
<Link to={this.props.to} tabIndex={-1} className='button__link'>
2020-04-21 17:44:55 -07:00
{btn}
</Link>
);
} else {
return btn;
}
2020-03-27 13:59:38 -07:00
}
}