Added notification count in footer bar

• Added:
- notification count in footer bar
This commit is contained in:
mgabdev 2020-05-15 18:27:06 -04:00
parent 5f50ea137f
commit 239d0d6a5e
2 changed files with 23 additions and 1 deletions

View File

@ -3,15 +3,25 @@ import { me } from '../initial_state'
import { CX } from '../constants' import { CX } from '../constants'
import Button from './button' import Button from './button'
const mapStateToProps = (state) => ({
notificationCount: state.getIn(['notifications', 'unread']),
})
export default export default
@withRouter @withRouter
@connect(mapStateToProps)
class FooterBar extends PureComponent { class FooterBar extends PureComponent {
static contextTypes = { static contextTypes = {
router: PropTypes.object, router: PropTypes.object,
} }
static propTypes = {
notificationCount: PropTypes.number.isRequired,
}
render() { render() {
const { notificationCount } = this.props
if (!me) return false if (!me) return false
const noRouter = !this.context.router const noRouter = !this.context.router
@ -68,6 +78,13 @@ class FooterBar extends PureComponent {
}) })
const color = props.active ? 'brand' : 'secondary' const color = props.active ? 'brand' : 'secondary'
const childIcon = props.to === '/notifications' && notificationCount > 0 ? (
<div className={[_s.posAbs, _s.ml5, _s.top0, _s.pt5, _s.pl20].join(' ')}>
<span className={[_s.bgRed, _s.colorWhite, _s.circle, _s.py2, _s.px2, _s.minWidth14PX, _s.displayBlock].join(' ')} style={{fontSize: '12px'}}>
{notificationCount}
</span>
</div>
) : null
return ( return (
<Button <Button
@ -80,7 +97,9 @@ class FooterBar extends PureComponent {
href={props.href} href={props.href}
title={props.title} title={props.title}
className={classes} className={classes}
/> >
{childIcon}
</Button>
) )
}) })
} }

View File

@ -380,6 +380,7 @@ body {
.bgBrandDark { background-color: var(--color_brand-dark); } .bgBrandDark { background-color: var(--color_brand-dark); }
.bgBrandDark_onHover:hover { background-color: var(--color_brand-dark); } .bgBrandDark_onHover:hover { background-color: var(--color_brand-dark); }
.bgRed { background-color: red; }
.bgDanger { background-color: var(--color_red); } .bgDanger { background-color: var(--color_red); }
.bgDangerDark_onHover:hover { background-color: var(--color_red-dark); } .bgDangerDark_onHover:hover { background-color: var(--color_red-dark); }
@ -493,6 +494,7 @@ body {
.maxWidth100PC42PX { max-width: calc(100% - 42px); } .maxWidth100PC42PX { max-width: calc(100% - 42px); }
.minWidth330PX { min-width: 330px; } .minWidth330PX { min-width: 330px; }
.minWidth14PX { min-width: 14px; }
.width100PC { width: 100%; } .width100PC { width: 100%; }
.width50PC { width: 50%; } .width50PC { width: 50%; }
@ -737,6 +739,7 @@ body {
.pl35 { padding-left: 35px; } .pl35 { padding-left: 35px; }
.pl25 { padding-left: 25px; } .pl25 { padding-left: 25px; }
.pl20 { padding-left: 20px; }
.pl15 { padding-left: 15px; } .pl15 { padding-left: 15px; }
.pl10 { padding-left: 10px; } .pl10 { padding-left: 10px; }
.pl5 { padding-left: 5px; } .pl5 { padding-left: 5px; }