82 lines
2.4 KiB
JavaScript
82 lines
2.4 KiB
JavaScript
import React, { Component } from 'react'
|
|
import { Trans, translate } from 'react-i18next'
|
|
import ResultsGrid from 'Components/ResultsGrid'
|
|
import { salaries } from 'Components/TargetSelection'
|
|
import { isEmpty, intersection, head, path } from 'ramda'
|
|
import Rule from 'Components/rule/Rule'
|
|
import './Explanation.css'
|
|
import { pluck } from 'ramda'
|
|
import { connect } from 'react-redux'
|
|
import { scroller, Element } from 'react-scroll'
|
|
import SearchButton from './SearchButton'
|
|
import withColours from './withColours'
|
|
|
|
@translate()
|
|
@withColours
|
|
@connect(state => ({
|
|
analysis: state.analysis
|
|
}))
|
|
export default class Explanation extends Component {
|
|
handleScrollToResults = () => {
|
|
scroller.scrollTo('resultsScrollElement', {
|
|
smooth: true,
|
|
duration: 200,
|
|
delay: 0
|
|
})
|
|
}
|
|
render() {
|
|
let targetRules = path(['analysis', 'targets'], this.props)
|
|
if (!targetRules) return null
|
|
|
|
return (
|
|
<Element name="resultsScrollElement" id="resultsScrollElement">
|
|
<section id="explanation">
|
|
<h3
|
|
className="scrollIndication down"
|
|
style={{
|
|
color: this.props.colours.textColourOnWhite
|
|
}}>
|
|
<button
|
|
className="unstyledButton"
|
|
onClick={this.handleScrollToResults}>
|
|
<i className="fa fa-long-arrow-down" aria-hidden="true" />
|
|
<Trans i18nKey="details">Comprendre mes résultats</Trans>
|
|
</button>
|
|
</h3>
|
|
{this.renderExplanation(targetRules)}
|
|
<div id="warning">
|
|
<p>
|
|
<i className="fa fa-info-circle" aria-hidden="true" />
|
|
<Trans i18nKey="disclaimer">
|
|
Le calcul ne prend pas en compte les conventions et accords
|
|
collectifs, et n'est pas opposable à un bulletin de paie. En cas
|
|
d'écart, vous pouvez en discuter avec votre responsable.
|
|
</Trans>
|
|
</p>
|
|
</div>
|
|
</section>
|
|
</Element>
|
|
)
|
|
}
|
|
renderExplanation(targetRules) {
|
|
if (!isEmpty(intersection(pluck('name', targetRules), salaries)))
|
|
return (
|
|
<>
|
|
<SearchButton />
|
|
<ResultsGrid />
|
|
</>
|
|
) // Problem if targetRules is [salaire net, aides] the Explanation will not explain 'aides'. The user will have to click on Aides to understand it. Should we display a list of <Rule /> sections ?
|
|
|
|
if (targetRules.length > 1)
|
|
return (
|
|
<p>
|
|
<Trans i18nKey="clickForMore">
|
|
Cliquez sur les lignes de résultat ci-dessus pour les comprendre
|
|
</Trans>
|
|
</p>
|
|
)
|
|
|
|
return <Rule rule={head(targetRules)} />
|
|
}
|
|
}
|