import { injectIntl, defineMessages } from 'react-intl' import Icon from './icon' import Button from './button' import Heading from './heading' const messages = defineMessages({ show: { id: 'column_header.show_settings', defaultMessage: 'Show settings' }, hide: { id: 'column_header.hide_settings', defaultMessage: 'Hide settings' }, }) export default @injectIntl class ColumnHeader extends PureComponent { static contextTypes = { router: PropTypes.object, } static propTypes = { intl: PropTypes.object.isRequired, title: PropTypes.node, icon: PropTypes.string, active: PropTypes.bool, children: PropTypes.node, showBackBtn: PropTypes.bool, actions: PropTypes.array, } state = { collapsed: true, } historyBack = () => { if (window.history && window.history.length === 1) { this.context.router.history.push('/home') // homehack } else { this.context.router.history.goBack() } } handleToggleClick = (e) => { e.stopPropagation() this.setState({ collapsed: !this.state.collapsed, }) } handleBackClick = () => { this.historyBack() } render() { const { title, showBackBtn, icon, active, children, actions, intl: { formatMessage } } = this.props const { collapsed } = this.state return (
{ showBackBtn && }
{title}
{ !!actions &&
{ actions.map((action, i) => ( )) }
}
) } }