81 lines
2.9 KiB
JavaScript
81 lines
2.9 KiB
JavaScript
import React, { Component } from 'react'
|
|
import classNames from 'classnames'
|
|
import {Link} from 'react-router-dom'
|
|
import {connect} from 'react-redux'
|
|
import R from 'ramda'
|
|
import './Results.css'
|
|
import {capitalise0} from '../utils'
|
|
import {computeRuleValue} from '../engine/traverse'
|
|
import {encodeRuleName} from '../engine/rules'
|
|
|
|
let fmt = new Intl.NumberFormat('fr-FR').format
|
|
let humanFigure = decimalDigits => value => fmt(value.toFixed(decimalDigits))
|
|
@connect(
|
|
state => ({
|
|
pointedOutObjectives: state.pointedOutObjectives,
|
|
analysedSituation: state.analysedSituation,
|
|
conversationStarted: !R.isEmpty(state.form)
|
|
})
|
|
)
|
|
export default class Results extends Component {
|
|
render() {
|
|
let {analysedSituation, pointedOutObjectives, conversationStarted} = this.props,
|
|
// On travaille pour l'instant sur un objectif qui est une somme de plusieurs variables, et c'est ces variables que nous affichons comme résultats. D'où ce chemin :
|
|
formuleType = R.path(['formule', 'explanation', 'name'])(analysedSituation),
|
|
explanation =
|
|
formuleType == 'somme' ? R.pluck('explanation', R.path(['formule', 'explanation', 'explanation'])(analysedSituation))
|
|
: formuleType ? [analysedSituation]
|
|
: null
|
|
|
|
if (!explanation) return null
|
|
|
|
return (
|
|
<section id="results" className={classNames({started: conversationStarted})}>
|
|
<div id="results-titles">
|
|
<h2>Vos obligations</h2>
|
|
{conversationStarted &&
|
|
<div>Cliquez pour comprendre chaque calcul <i className="fa fa-hand-o-right" aria-hidden="true"></i></div>}
|
|
</div>
|
|
<ul>
|
|
{explanation.map(
|
|
({name, dottedName, type, 'non applicable si': nonApplicable, formule: {nodeValue: formuleValue}}) =>
|
|
do {
|
|
//TODO quel bordel, à revoir
|
|
let
|
|
ruleValue = computeRuleValue(formuleValue, nonApplicable && nonApplicable.nodeValue),
|
|
unsatisfied = ruleValue == null,
|
|
nonApplicableValue = nonApplicable ? nonApplicable.nodeValue : false,
|
|
irrelevant = nonApplicableValue === true || formuleValue == 0,
|
|
number = nonApplicableValue == false && formuleValue != null,
|
|
pointedOut = pointedOutObjectives.find(objective => objective == dottedName)
|
|
|
|
;<li key={name} className={classNames({unsatisfied, irrelevant, number, pointedOut})}>
|
|
<Link to={"/regle/" + encodeRuleName(name)} className="understand">
|
|
<div className="rule-box">
|
|
<div className="rule-type">
|
|
{type}
|
|
</div>
|
|
<div className="rule-name">
|
|
{capitalise0(name)}
|
|
</div>
|
|
<p>
|
|
{conversationStarted && (
|
|
irrelevant ?
|
|
"Vous n'êtes pas concerné"
|
|
: unsatisfied ?
|
|
'En attente de vos réponses...'
|
|
: <span className="figure">{humanFigure(2)(formuleValue) + '€'}</span>
|
|
)}
|
|
</p>
|
|
</div>
|
|
</Link>
|
|
<div className="pointer">•</div>
|
|
</li>
|
|
}
|
|
)}
|
|
</ul>
|
|
</section>
|
|
)
|
|
}
|
|
}
|