2018-04-11 00:28:52 +02:00
|
|
|
import React, { Component } from 'react'
|
|
|
|
import PropTypes from 'prop-types'
|
2018-07-19 02:47:01 +02:00
|
|
|
import classnames from 'classnames'
|
2018-04-11 00:28:52 +02:00
|
|
|
|
|
|
|
export default class PageContainerHeader extends Component {
|
|
|
|
static propTypes = {
|
2018-06-23 08:52:45 +02:00
|
|
|
title: PropTypes.string,
|
2018-04-11 00:28:52 +02:00
|
|
|
subtitle: PropTypes.string,
|
|
|
|
onClose: PropTypes.func,
|
|
|
|
showBackButton: PropTypes.bool,
|
|
|
|
onBackButtonClick: PropTypes.func,
|
|
|
|
backButtonStyles: PropTypes.object,
|
|
|
|
backButtonString: PropTypes.string,
|
2018-07-19 02:47:01 +02:00
|
|
|
tabs: PropTypes.node,
|
2018-09-20 18:06:23 +02:00
|
|
|
headerCloseText: PropTypes.string,
|
2018-07-19 02:47:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
renderTabs () {
|
|
|
|
const { tabs } = this.props
|
|
|
|
|
|
|
|
return tabs && (
|
|
|
|
<ul className="page-container__tabs">
|
|
|
|
{ tabs }
|
|
|
|
</ul>
|
|
|
|
)
|
|
|
|
}
|
2018-04-11 00:28:52 +02:00
|
|
|
|
|
|
|
renderHeaderRow () {
|
|
|
|
const { showBackButton, onBackButtonClick, backButtonStyles, backButtonString } = this.props
|
|
|
|
|
|
|
|
return showBackButton && (
|
|
|
|
<div className="page-container__header-row">
|
|
|
|
<span
|
|
|
|
className="page-container__back-button"
|
|
|
|
onClick={onBackButtonClick}
|
|
|
|
style={backButtonStyles}
|
|
|
|
>
|
|
|
|
{ backButtonString || 'Back' }
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
render () {
|
2018-09-20 18:06:23 +02:00
|
|
|
const { title, subtitle, onClose, tabs, headerCloseText } = this.props
|
2018-04-11 00:28:52 +02:00
|
|
|
|
|
|
|
return (
|
2018-07-19 02:47:01 +02:00
|
|
|
<div className={
|
|
|
|
classnames(
|
|
|
|
'page-container__header',
|
2018-07-21 00:42:28 +02:00
|
|
|
{ 'page-container__header--no-padding-bottom': Boolean(tabs) }
|
2018-07-19 02:47:01 +02:00
|
|
|
)
|
|
|
|
}>
|
2018-04-11 00:28:52 +02:00
|
|
|
|
|
|
|
{ this.renderHeaderRow() }
|
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
{
|
|
|
|
title && <div className="page-container__title">
|
|
|
|
{ title }
|
|
|
|
</div>
|
|
|
|
}
|
2018-04-11 00:28:52 +02:00
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
{
|
|
|
|
subtitle && <div className="page-container__subtitle">
|
|
|
|
{ subtitle }
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2018-09-20 18:06:23 +02:00
|
|
|
onClose && headerCloseText
|
|
|
|
? <div className="page-container__header-close-text" onClick={() => onClose()}>{ headerCloseText }</div>
|
|
|
|
: onClose && <div
|
|
|
|
className="page-container__header-close"
|
|
|
|
onClick={() => onClose()}
|
|
|
|
/>
|
2018-06-23 08:52:45 +02:00
|
|
|
}
|
2018-04-11 00:28:52 +02:00
|
|
|
|
2018-07-19 02:47:01 +02:00
|
|
|
{ this.renderTabs() }
|
2018-04-11 00:28:52 +02:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|