2017-01-10 18:22:44 +00:00
|
|
|
import React, { Component } from 'react'
|
2017-02-09 12:58:12 +00:00
|
|
|
import classNames from 'classnames'
|
2017-02-13 12:28:49 +00:00
|
|
|
import {Link} from 'react-router'
|
2017-03-15 15:26:00 +00:00
|
|
|
import {connect} from 'react-redux'
|
2017-01-10 18:22:44 +00:00
|
|
|
|
2017-03-13 12:35:38 +00:00
|
|
|
let fmt = new Intl.NumberFormat('fr-FR').format
|
|
|
|
let humanFigure = decimalDigits => value => fmt(value.toFixed(decimalDigits))
|
|
|
|
|
2017-03-15 15:26:00 +00:00
|
|
|
@connect(
|
|
|
|
state => ({
|
|
|
|
pointedOutObjectives: state.pointedOutObjectives
|
|
|
|
})
|
|
|
|
)
|
2017-01-10 18:22:44 +00:00
|
|
|
export default class Results extends Component {
|
|
|
|
render() {
|
2017-03-15 15:26:00 +00:00
|
|
|
let {analysedSituation, pointedOutObjectives} = this.props
|
2017-03-01 19:27:35 +00:00
|
|
|
// missingVariables = collectMissingVariables(analysedSituation, 'groupByResult')
|
2017-01-10 18:22:44 +00:00
|
|
|
return (
|
|
|
|
<section id="results">
|
2017-03-13 14:38:47 +00:00
|
|
|
<div id="results-titles">
|
|
|
|
<h2>Vos obligations</h2>
|
|
|
|
<div>Cliquez pour comprendre chaque calcul <i className="fa fa-hand-o-right" aria-hidden="true"></i></div>
|
|
|
|
</div>
|
2017-01-10 18:22:44 +00:00
|
|
|
<ul>
|
2017-02-10 14:12:00 +00:00
|
|
|
{analysedSituation.map(
|
2017-03-01 19:27:35 +00:00
|
|
|
({name, type, 'non applicable si': {nodeValue: nonApplicable}, formule: {nodeValue: computedValue}}) =>
|
2017-02-09 12:58:12 +00:00
|
|
|
do {
|
|
|
|
let
|
2017-03-01 19:27:35 +00:00
|
|
|
unsatisfied = nonApplicable == null || computedValue == null,
|
2017-03-15 15:26:00 +00:00
|
|
|
irrelevant = nonApplicable === true,
|
|
|
|
pointedOut = pointedOutObjectives.find(objective => objective == name),
|
|
|
|
number = nonApplicable == false && computedValue != null
|
2017-03-01 19:27:35 +00:00
|
|
|
|
2017-03-15 15:26:00 +00:00
|
|
|
;<li key={name} className={classNames({unsatisfied, irrelevant, number, pointedOut})}>
|
2017-02-13 14:18:44 +00:00
|
|
|
<Link to={"/regle/" + name} className="understand">
|
2017-03-13 14:38:47 +00:00
|
|
|
<div className="rule-box">
|
|
|
|
<div className="rule-type">
|
|
|
|
{type}
|
|
|
|
</div>
|
|
|
|
<div className="rule-name">
|
|
|
|
{name}
|
|
|
|
</div>
|
|
|
|
<p>
|
|
|
|
{irrelevant ?
|
2017-03-15 15:26:00 +00:00
|
|
|
"Vous n'êtes pas concerné"
|
2017-03-13 14:38:47 +00:00
|
|
|
: unsatisfied ?
|
|
|
|
'En attente de vos réponses...'
|
|
|
|
: <span className="figure">{humanFigure(2)(computedValue) + '€'}</span>
|
|
|
|
}
|
|
|
|
</p>
|
|
|
|
</div>
|
2017-02-13 12:28:49 +00:00
|
|
|
</Link>
|
2017-03-15 15:26:00 +00:00
|
|
|
<div className="pointer">•</div>
|
2017-02-09 12:58:12 +00:00
|
|
|
</li>
|
|
|
|
}
|
2017-01-10 18:22:44 +00:00
|
|
|
)}
|
|
|
|
</ul>
|
|
|
|
</section>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|