119 lines
2.7 KiB
JavaScript
Raw Normal View History

import React from 'react'
import PropTypes from 'prop-types'
2020-03-25 23:11:32 -04:00
import { withRouter } from 'react-router-dom'
2020-05-01 01:50:27 -04:00
import { CX } from '../constants'
2020-03-25 23:11:32 -04:00
import Button from './button'
2020-02-22 18:26:23 -05:00
import Text from './text'
2020-04-23 02:13:29 -04:00
/**
* Renders a tab bar item component
* @param {bool} [props.isLarge] - to style the tab bar larger
* @param {bool} [props.isActive] - if item is active
* @param {func} [props.onClick] - function to call on click
* @param {string} [props.title] - title to use
* @param {string} [props.to] - location to direct to on click
*/
class TabBarItem extends React.PureComponent {
2020-04-23 02:13:29 -04:00
2020-02-22 18:26:23 -05:00
state = {
2020-05-01 01:50:27 -04:00
isCurrent: false,
2020-02-22 18:26:23 -05:00
}
componentDidMount() {
this.checkIfCurrent()
}
2020-02-22 18:26:23 -05:00
componentDidUpdate(prevProps) {
if (prevProps.location !== this.props.location) {
this.checkIfCurrent()
}
}
checkIfCurrent() {
2020-04-23 02:13:29 -04:00
// If user navigates to different page, ensure tab bar item
// with this.props.to that is on location is set to active.
const isCurrent = this.props.to === this.props.location.pathname && !this.props.location.search
2020-02-22 18:26:23 -05:00
if (this.state.isCurrent !== isCurrent) {
this.setState({ isCurrent })
2020-02-22 18:26:23 -05:00
}
}
render() {
2020-03-25 23:11:32 -04:00
const {
title,
to,
onClick,
location,
2020-04-23 02:13:29 -04:00
isLarge,
isActive,
2020-03-25 23:11:32 -04:00
} = this.props
2020-04-06 21:53:23 -04:00
const { isCurrent } = this.state
2020-02-22 18:26:23 -05:00
2020-04-23 02:13:29 -04:00
// Combine state, props, location to make absolutely
// sure of active status.
const active = isActive || (to === location.pathname && !location.search) || isCurrent
2020-02-22 18:26:23 -05:00
2020-05-01 01:50:27 -04:00
const containerClasses = CX({
d: 1,
h100PC: 1,
2020-02-22 18:26:23 -05:00
noUnderline: 1,
text: 1,
displayFlex: 1,
aiCenter: 1,
jcCenter: 1,
2020-02-22 18:26:23 -05:00
borderBottom2PX: 1,
2020-03-11 19:56:18 -04:00
py5: 1,
2020-04-09 15:18:14 -04:00
outlineNone: 1,
2020-04-02 21:05:49 -04:00
cursorPointer: 1,
2020-04-29 18:32:49 -04:00
bgTransparent: 1,
2020-04-23 02:13:29 -04:00
borderColorTransparent: !active,
borderColorBrand: active,
mr5: isLarge,
mr2: !isLarge,
2020-02-28 10:20:47 -05:00
})
2020-05-01 01:50:27 -04:00
const textParentClasses = CX({
d: 1,
h100PC: 1,
aiCenter: 1,
jcCenter: 1,
2020-02-28 10:20:47 -05:00
radiusSmall: 1,
2020-04-23 02:13:29 -04:00
px10: !isLarge,
px15: isLarge,
2020-04-29 18:32:49 -04:00
bgSecondaryDark_onHover: !active,
2020-02-22 18:26:23 -05:00
})
const textOptions = {
2020-04-23 02:13:29 -04:00
size: !!isLarge ? 'normal' : 'small',
color: active ? 'brand' : isLarge ? 'secondary' : 'primary',
weight: active ? 'bold' : isLarge ? 'medium' : 'normal',
2020-02-22 18:26:23 -05:00
}
return (
2020-03-25 23:11:32 -04:00
<Button
onClick={onClick}
className={containerClasses}
2020-04-06 21:53:23 -04:00
to={to || undefined}
2020-03-25 23:11:32 -04:00
noClasses
>
2020-02-28 10:20:47 -05:00
<span className={textParentClasses}>
2020-04-29 18:32:49 -04:00
<Text {...textOptions}>
{title}
</Text>
2020-02-28 10:20:47 -05:00
</span>
2020-03-25 23:11:32 -04:00
</Button>
2020-02-22 18:26:23 -05:00
)
}
2020-04-23 02:13:29 -04:00
}
TabBarItem.propTypes = {
isLarge: PropTypes.bool,
isActive: PropTypes.bool,
onClick: PropTypes.func,
title: PropTypes.string,
to: PropTypes.string,
}
export default withRouter(TabBarItem)