You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
889 B
38 lines
889 B
import React from 'react'; |
|
import PropTypes from 'prop-types'; |
|
import classNames from 'classnames'; |
|
import Icon from 'mastodon/components/icon'; |
|
|
|
export default class ColumnHeader extends React.PureComponent { |
|
|
|
static propTypes = { |
|
icon: PropTypes.string, |
|
type: PropTypes.string, |
|
active: PropTypes.bool, |
|
onClick: PropTypes.func, |
|
columnHeaderId: PropTypes.string, |
|
}; |
|
|
|
handleClick = () => { |
|
this.props.onClick(); |
|
} |
|
|
|
render () { |
|
const { icon, type, active, columnHeaderId } = this.props; |
|
let iconElement = ''; |
|
|
|
if (icon) { |
|
iconElement = <Icon id={icon} fixedWidth className='column-header__icon' />; |
|
} |
|
|
|
return ( |
|
<h1 className={classNames('column-header', { active })} id={columnHeaderId || null}> |
|
<button onClick={this.handleClick}> |
|
{iconElement} |
|
{type} |
|
</button> |
|
</h1> |
|
); |
|
} |
|
|
|
}
|
|
|