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-04-18 17:37:38 +00:00
import { Link } from 'react-router-dom'
2017-03-15 15:26:00 +00:00
import { connect } from 'react-redux'
2017-03-16 18:30:30 +00:00
import R from 'ramda'
2017-03-27 13:32:03 +00:00
import './Results.css'
2017-05-07 17:45:44 +00:00
import { capitalise0 } from '../utils'
import { computeRuleValue } from '../engine/traverse'
2017-05-09 14:33:35 +00:00
import { encodeRuleName } from '../engine/rules'
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 => ( {
2017-04-18 17:37:38 +00:00
pointedOutObjectives : state . pointedOutObjectives ,
analysedSituation : state . analysedSituation ,
conversationStarted : ! R . isEmpty ( state . form )
2017-03-15 15:26:00 +00:00
} )
)
2017-01-10 18:22:44 +00:00
export default class Results extends Component {
render ( ) {
2017-05-07 17:45:44 +00:00
let { analysedSituation , pointedOutObjectives , conversationStarted } = this . props ,
2017-04-06 16:34:00 +00:00
// 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 :
2017-05-07 17:45:44 +00:00
formuleType = R . path ( [ 'formule' , 'explanation' , 'name' ] ) ( analysedSituation ) ,
explanation =
formuleType == 'somme' ? R . pluck ( 'explanation' , R . path ( [ 'formule' , 'explanation' , 'explanation' ] ) ( analysedSituation ) )
: formuleType ? [ analysedSituation ]
: null
2017-03-16 18:30:30 +00:00
if ( ! explanation ) return null
2017-01-10 18:22:44 +00:00
return (
2017-04-18 17:37:38 +00:00
< section id = "results" className = { classNames ( { started : conversationStarted } ) } >
2017-03-13 14:38:47 +00:00
< div id = "results-titles" >
< h2 > Vos obligations < / h 2 >
2017-04-18 17:37:38 +00:00
{ conversationStarted &&
< div > Cliquez pour comprendre chaque calcul & nbsp ; < i className = "fa fa-hand-o-right" aria - hidden = "true" > < / i > < / d i v > }
2017-03-13 14:38:47 +00:00
< / d i v >
2017-01-10 18:22:44 +00:00
< ul >
2017-03-16 18:30:30 +00:00
{ explanation . map (
2017-05-07 17:45:44 +00:00
( { name , dottedName , type , 'non applicable si' : nonApplicable , formule : { nodeValue : formuleValue } } ) =>
2017-02-09 12:58:12 +00:00
do {
2017-05-07 17:45:44 +00:00
//TODO quel bordel, à revoir
2017-02-09 12:58:12 +00:00
let
2017-05-07 17:45:44 +00:00
ruleValue = computeRuleValue ( formuleValue , nonApplicable && nonApplicable . nodeValue ) ,
unsatisfied = ruleValue == null ,
2017-04-06 16:34:00 +00:00
nonApplicableValue = nonApplicable ? nonApplicable . nodeValue : false ,
2017-05-07 17:45:44 +00:00
irrelevant = nonApplicableValue === true || formuleValue == 0 ,
number = nonApplicableValue == false && formuleValue != null ,
pointedOut = pointedOutObjectives . find ( objective => objective == dottedName )
2017-03-01 19:27:35 +00:00
2017-03-16 18:30:30 +00:00
; < li key = { name } className = { classNames ( { unsatisfied , irrelevant , number , pointedOut } ) } >
2017-05-09 14:33:35 +00:00
< Link to = { "/regle/" + encodeRuleName ( name ) } className = "understand" >
2017-03-13 14:38:47 +00:00
< div className = "rule-box" >
< div className = "rule-type" >
{ type }
< / d i v >
< div className = "rule-name" >
2017-05-07 17:45:44 +00:00
{ capitalise0 ( name ) }
2017-03-13 14:38:47 +00:00
< / d i v >
< p >
2017-04-18 17:37:38 +00:00
{ conversationStarted && (
irrelevant ?
"Vous n'êtes pas concerné"
: unsatisfied ?
'En attente de vos réponses...'
2017-05-07 17:45:44 +00:00
: < span className = "figure" > { humanFigure ( 2 ) ( formuleValue ) + '€' } < / s p a n >
2017-04-18 17:37:38 +00:00
) }
2017-03-13 14:38:47 +00:00
< / p >
< / d i v >
2017-02-13 12:28:49 +00:00
< / L i n k >
2017-03-15 15:26:00 +00:00
< div className = "pointer" > • < / d i v >
2017-02-09 12:58:12 +00:00
< / l i >
}
2017-01-10 18:22:44 +00:00
) }
< / u l >
< / s e c t i o n >
)
}
}