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.
37 lines
842 B
37 lines
842 B
import React from 'react'; |
|
import PropTypes from 'prop-types'; |
|
import classNames from 'classnames'; |
|
|
|
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 = <i className={`fa fa-fw fa-${icon} column-header__icon`} />; |
|
} |
|
|
|
return ( |
|
<h1 className={classNames('column-header', { active })} id={columnHeaderId || null}> |
|
<button onClick={this.handleClick}> |
|
{iconElement} |
|
{type} |
|
</button> |
|
</h1> |
|
); |
|
} |
|
|
|
}
|
|
|