chinwagsocial/app/javascript/mastodon/components/button.jsx

58 lines
1.2 KiB
React
Raw Normal View History

2023-05-23 18:52:27 +10:00
import { PureComponent } from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
2023-05-23 18:52:27 +10:00
export default class Button extends PureComponent {
static propTypes = {
text: PropTypes.node,
type: PropTypes.string,
onClick: PropTypes.func,
disabled: PropTypes.bool,
block: PropTypes.bool,
secondary: PropTypes.bool,
className: PropTypes.string,
title: PropTypes.string,
children: PropTypes.node,
};
static defaultProps = {
type: 'button',
};
handleClick = (e) => {
if (!this.props.disabled && this.props.onClick) {
this.props.onClick(e);
}
2023-01-30 11:45:35 +11:00
};
setRef = (c) => {
this.node = c;
2023-01-30 11:45:35 +11:00
};
focus() {
this.node.focus();
}
render () {
const className = classNames('button', this.props.className, {
'button-secondary': this.props.secondary,
'button--block': this.props.block,
});
return (
<button
className={className}
disabled={this.props.disabled}
onClick={this.handleClick}
ref={this.setRef}
title={this.props.title}
type={this.props.type}
>
{this.props.text || this.props.children}
2016-09-01 06:58:10 +10:00
</button>
);
}
}