mon-entreprise/source/components/Explanation.js

41 lines
1.3 KiB
JavaScript

import React, { Component } from 'react'
import ResultsGrid from 'Components/ResultsGrid'
import { salaries } from 'Components/TargetSelection'
import { isEmpty, intersection, head } from 'ramda'
import Rule from 'Components/rule/Rule'
import './Explanation.css'
import { pluck } from 'ramda'
export default class Explanation extends Component {
render() {
let { targetRules } = this.props
if (!targetRules) return null
return (
<section id="explanation">
{this.renderExplanation(targetRules)}
<div id="warning">
<p>
<i className="fa fa-info-circle" aria-hidden="true" />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.
</p>
</div>
</section>
)
}
renderExplanation(targetRules) {
if (!isEmpty(intersection(pluck('name', targetRules), salaries)))
return <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>Cliquez sur les lignes de résultat ci-dessus pour les comprendre</p>
)
return <Rule rule={head(targetRules)} />
}
}