1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-11 18:24:43 +02:00
joplin/packages/app-desktop/gui/IconButton.jsx

46 lines
967 B
React
Raw Normal View History

2017-11-11 00:18:00 +02:00
const React = require('react');
const { themeStyle } = require('@joplin/lib/theme');
2017-11-11 00:18:00 +02:00
class IconButton extends React.Component {
render() {
const style = this.props.style;
2020-09-15 15:01:07 +02:00
const theme = themeStyle(this.props.themeId);
2017-11-11 00:18:00 +02:00
const iconStyle = {
color: theme.color,
fontSize: theme.fontSize * 1.4,
};
const icon = <i style={iconStyle} className={`fas ${this.props.iconName}`}></i>;
2017-11-11 00:18:00 +02:00
const rootStyle = Object.assign(
{
display: 'flex',
textDecoration: 'none',
padding: 10,
width: theme.buttonMinHeight,
height: theme.buttonMinHeight,
boxSizing: 'border-box',
alignItems: 'center',
justifyContent: 'center',
backgroundColor: theme.backgroundColor,
cursor: 'default',
},
style
);
2017-11-11 00:18:00 +02:00
return (
<a
href="#"
style={rootStyle}
className="icon-button"
onClick={() => {
if (this.props.onClick) this.props.onClick();
}}
>
{icon}
2017-11-11 00:18:00 +02:00
</a>
);
}
}
module.exports = { IconButton };