55 lines
1.3 KiB
JavaScript
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>
|
|
)
|
|
)
|
|
}
|
|
}
|