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.

86 lines
2.0 KiB

import React from 'react'
import PropTypes from 'prop-types'
import { FormattedMessage, FormattedRelative } from 'react-intl'
import { Text } from 'components/UI'
import messages from './messages'
class Countdown extends React.Component {
state = {
isExpired: null,
timer: null
}
static propTypes = {
colorActive: PropTypes.string,
colorExpired: PropTypes.string,
date: PropTypes.oneOfType([PropTypes.number, PropTypes.instanceOf(Date)]).isRequired,
countdownStyle: PropTypes.string,
countUpAfterExpire: PropTypes.bool,
updateInterval: PropTypes.number
}
static defaultProps = {
colorActive: 'superGreen',
colorExpired: 'superRed',
countdownStyle: 'best fit',
countUpAfterExpire: true,
updateInterval: 1000
}
componentDidMount() {
let { date } = this.props
if (date instanceof Date) {
date = new Date(date)
}
const expiresIn = date - Date.now()
if (expiresIn >= 0) {
this.setState({ isExpired: false })
const timer = setInterval(() => this.setState({ isExpired: true }), expiresIn)
this.setState({ timer })
} else {
this.setState({ isExpired: true })
}
}
componentWillUnmount() {
const { timer } = this.state
clearInterval(timer)
}
render() {
const {
colorActive,
colorExpired,
countdownStyle,
countUpAfterExpire,
date,
updateInterval,
...rest
} = this.props
const { isExpired } = this.state
return (
<Text color={isExpired ? colorExpired : colorActive} {...rest}>
{isExpired ? (
<FormattedMessage {...messages.expired} />
) : (
<FormattedMessage {...messages.expires} />
)}
{(!isExpired || (isExpired && countUpAfterExpire)) && (
<React.Fragment>
{` `}
<FormattedRelative
value={new Date(date)}
updateInterval={updateInterval}
style={countdownStyle}
/>
</React.Fragment>
)}
</Text>
)
}
}
export default Countdown