mon-entreprise/source/components/ProgressTip.js

55 lines
1.3 KiB
JavaScript

import React, { Component } from 'react'
import { Trans, translate } from 'react-i18next'
import { connect } from 'react-redux'
import { withRouter } from 'react-router'
import './ProgressTip.css'
import { Line } from 'rc-progress'
import { pick } from 'ramda'
@withRouter
@translate()
@connect(
pick(['foldedSteps', 'nextSteps', 'themeColours', 'conversationStarted'])
)
export default class ProgressTip extends Component {
render() {
let {
nextSteps,
foldedSteps,
themeColours: { colour, textColourOnWhite },
conversationStarted
} = this.props,
nbQuestions = nextSteps.length
if (!conversationStarted) return null
return (
nbQuestions != 0 && (
<div className="progressTip">
<Line
style={{
visibility: foldedSteps.length > 0 ? 'visible' : 'hidden'
}}
percent={
100 * foldedSteps.length / (foldedSteps.length + nbQuestions)
}
trailWidth="1"
strokeWidth="2"
strokeColor={colour}
/>
<p style={{ color: textColourOnWhite }}>
{nbQuestions === 1
?
<Trans i18nKey="lastQ">dernière question !</Trans>
:
<Trans i18nKey="questionsLeft" count={nbQuestions}>
moins de {{nbQuestions}} questions
</Trans>
}
</p>
</div>
)
)
}
}