mon-entreprise/source/components/Rule.js

236 lines
5.2 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

import React, { Component } from 'react'
// import {findRuleByName} from '../engine/rules.js'
import {analyseSituation} from '../engine/traverse'
import './Rule.css'
import JSONTree from 'react-json-tree'
import R from 'ramda'
import PageTypeIcon from './PageTypeIcon'
import {connect} from 'react-redux'
import {formValueSelector} from 'redux-form'
// situationGate function useful for testing :
let testingSituationGate = v => R.path(v.split('.'))(
{
"Salariat ":{
" CDD ":{
" événements":"_",
" motif":"usage",
" engagement employeur complément formation":"non",
" durée contrat":"2"
},
" contrat aidé":"non",
" salaire de base": 1481,
" congés non pris": 3
}
})
@connect(state => ({
situationGate: name => formValueSelector('conversation')(state, name)
}))
export default class Rule extends Component {
render() {
let {
params: {name},
situationGate
} = this.props,
rule = analyseSituation(
testingSituationGate
).find(R.propEq('name', name))
if (!rule) {
this.props.router.push('/404')
return null
}
return (
<div id="rule">
Pourquoi cette règle me concerne ? Comment est-elle calculée ?
<PageTypeIcon type="comprendre"/>
<h1>
<span className="rule-type">{rule.type}</span>
<span className="rule-name">{name}</span>
</h1>
<section id="rule-meta" style={{display: 'none'}}>
<div id="meta-paragraph">
<p>
{rule.description}
</p>
</div>
<div>
<h2>Propriétés</h2>
<JSONView o={{
...rule.attributs,
'contexte': rule['attache']
}} />
<h2>Références</h2>
{this.renderReferences(rule)}
</div>
</section>
<section id="rule-rules">
{ do {
let cond =
R.toPairs(rule).find(([,v]) => v.rulePropType == 'cond')
cond != null && <section id="declenchement">
<h2>Conditions de déclenchement</h2>
<RuleProp {...cond[1]} />
</section>
}}
<section id="formule">
<h2>Calcul</h2>
<RuleProp {...rule['formule']}/>
</section>
</section>
{/* <pre>
<JSONView data={rule} />
</pre> */}
</div>
)
}
renderReferences(rule) {
return (
rule['référence'] && <div>{rule['référence']}</div>)
|| (
rule['références'] && <ul id="rule-references">
{R.toPairs(rule['références']).map(
([name, link]) =>
<li key={name}>
{link.indexOf('legifrance.gouv') >= 0 &&
<i className="fa fa-gavel" aria-hidden="true"></i>
}
<a href={link} target="_blank">
{name}
</a>
</li>
)}
</ul>
)
}
}
let RuleProp = ({nodeValue, explanation, name}) =>
<div className="ruleProp node" >
<div>
<span className="name">{name}</span>
<NodeValue data={nodeValue}/>
</div>
{
explanation.category == 'mecanism' && <Mecanism {...explanation}/>
}
{
explanation.category == 'expression' && <Expression {...explanation}/>
}
</div>
let Mecanism = ({nodeValue, name, explanation}) =>
<div className="mecanism node" >
<div>
<span className="name">{name}</span>
<NodeValue data={nodeValue}/>
</div>
{R.contains(name)(["l'une de ces conditions", 'toutes ces conditions']) &&
<ul>
{explanation.map(item => <li key={item.expression + item.name}>
{item.category == 'expression' ?
<Expression {...item} /> : <Mecanism {...item} />
}
</li>)}
</ul>
}
{name == 'multiplication' &&
<Multiplication {...explanation}/>
}
{name == 'le maximum de' &&
<JSONView o={{nodeValue, name, explanation}} />
}
</div>
let Multiplication = ({base, rate}) =>
<div className="multiplication node" >
<Variable {...base}/>
<span className="multiplicationSign">×</span>
{
rate.explanation ?
<JSONView o={rate} />
: <Percentage {...rate}/>
}
</div>
let Variable = ({nodeValue, variableName}) =>
<span className="variable" >
<span className="name">{variableName}</span>
<NodeValue data={nodeValue}/>
</span>
let Percentage = ({percentage}) =>
<span className="rate" >
<span className="name">{percentage}</span>
</span>
let Expression = ({nodeValue, expression}) =>
<div className="expression node" >
<div>
<span className="name">{expression}</span>
<NodeValue data={nodeValue}/>
</div>
</div>
let NodeValue = ({data}) => do {
console.log('NodeValue', data)
let valeur = data == null ?
'?'
: ( R.is(Number)(data) ?
Math.round(data)
: ( data ? 'oui' : 'non')
);
<span className={"value " + valeur}>&nbsp;
{valeur}
</span>
}
let Formula = ({explanation, nodeValue}) => do {
<div className="form node" >
<div>
<span className="name">{expression}</span>
<NodeValue data={nodeValue}/>
</div>
</div>
}
let JSONView = ({o, rootKey}) =>
<JSONTree
getItemString={() => ''}
theme={theme}
hideRoot={true}
shouldExpandNode={() => true}
data={rootKey ? {[rootKey]: o} : o} />
var theme = {
scheme: 'atelier forest',
author: 'bram de haan (http://atelierbram.github.io/syntax-highlighting/atelier-schemes/forest)',
base00: '#1b1918',
base01: '#2c2421',
base02: '#68615e',
base03: '#766e6b',
base04: '#9c9491',
base05: '#a8a19f',
base06: '#e6e2e0',
base07: '#f1efee',
base08: '#f22c40',
base09: '#df5320',
base0A: '#d5911a',
base0B: '#5ab738',
base0C: '#00ad9c',
base0D: '#407ee7',
base0E: '#6666ea',
base0F: '#c33ff3'
}