2016-12-07 18:08:10 +00:00
|
|
|
import React, { Component } from 'react'
|
2017-03-27 16:37:11 +00:00
|
|
|
import ReactDOM from 'react-dom'
|
2017-05-09 14:33:35 +00:00
|
|
|
import {decodeRuleName} from '../engine/rules.js'
|
2016-12-07 18:08:10 +00:00
|
|
|
import './Rule.css'
|
2016-12-16 16:09:21 +00:00
|
|
|
import JSONTree from 'react-json-tree'
|
2017-02-13 12:28:49 +00:00
|
|
|
import R from 'ramda'
|
2017-02-22 16:55:36 +00:00
|
|
|
import PageTypeIcon from './PageTypeIcon'
|
2017-03-01 19:27:35 +00:00
|
|
|
import {connect} from 'react-redux'
|
2017-03-14 10:42:44 +00:00
|
|
|
import mockSituation from '../engine/mockSituation.yaml'
|
2017-03-17 11:37:55 +00:00
|
|
|
import {START_CONVERSATION} from '../actions'
|
|
|
|
import classNames from 'classnames'
|
2017-04-24 18:03:38 +00:00
|
|
|
import possiblesDestinataires from '../../règles/ressources/destinataires/destinataires.yaml'
|
2017-03-27 16:37:11 +00:00
|
|
|
import {capitalise0} from '../utils'
|
|
|
|
import knownMecanisms from '../engine/known-mecanisms.yaml'
|
2017-03-28 16:52:01 +00:00
|
|
|
import marked from '../engine/marked'
|
2017-04-13 14:43:56 +00:00
|
|
|
import References from './References'
|
2017-04-28 15:47:01 +00:00
|
|
|
import {AttachDictionary} from './AttachDictionary'
|
2017-05-07 17:45:44 +00:00
|
|
|
import {analyseSituation} from '../engine/traverse'
|
|
|
|
import {formValueSelector} from 'redux-form'
|
|
|
|
|
2016-12-07 18:08:10 +00:00
|
|
|
|
2017-03-02 15:31:24 +00:00
|
|
|
// situationGate function useful for testing :
|
2017-03-14 10:42:44 +00:00
|
|
|
let testingSituationGate = v => // eslint-disable-line no-unused-vars
|
|
|
|
R.path(v.split('.'))(mockSituation)
|
2017-03-01 19:27:35 +00:00
|
|
|
|
2017-03-17 11:37:55 +00:00
|
|
|
@connect(
|
|
|
|
state => ({
|
2017-05-07 17:45:44 +00:00
|
|
|
situationGate: name => formValueSelector('conversation')(state, name),
|
2017-03-17 11:37:55 +00:00
|
|
|
form: state.form
|
|
|
|
}),
|
|
|
|
dispatch => ({
|
2017-04-11 15:44:53 +00:00
|
|
|
startConversation: rootVariable => dispatch({type: START_CONVERSATION, rootVariable}),
|
2017-03-17 11:37:55 +00:00
|
|
|
})
|
|
|
|
)
|
2016-12-07 18:08:10 +00:00
|
|
|
export default class Rule extends Component {
|
|
|
|
render() {
|
2016-12-16 16:28:42 +00:00
|
|
|
let {
|
2017-05-09 14:33:35 +00:00
|
|
|
match: {params: {name: encodedName}},
|
2017-05-07 17:45:44 +00:00
|
|
|
situationGate,
|
2017-03-17 11:37:55 +00:00
|
|
|
form
|
2017-05-09 14:33:35 +00:00
|
|
|
} = this.props,
|
|
|
|
name = decodeRuleName(encodedName)
|
2016-12-16 16:09:21 +00:00
|
|
|
|
2017-05-07 17:45:44 +00:00
|
|
|
let rule = analyseSituation(name)(situationGate)
|
|
|
|
console.log('rule', rule)
|
|
|
|
// if (!rule) {
|
|
|
|
// this.props.router.push('/404')
|
|
|
|
// return null
|
|
|
|
// }
|
2017-03-02 15:31:24 +00:00
|
|
|
|
2017-03-17 11:37:55 +00:00
|
|
|
let
|
2017-03-27 16:37:11 +00:00
|
|
|
situationExists = !R.isEmpty(form)
|
2017-03-17 11:37:55 +00:00
|
|
|
|
2017-05-05 17:47:54 +00:00
|
|
|
let destinataire = R.path([rule.type, 'destinataire'])(rule),
|
2017-04-06 16:34:00 +00:00
|
|
|
destinataireData = possiblesDestinataires[destinataire]
|
2017-03-17 15:49:09 +00:00
|
|
|
|
|
|
|
|
2016-12-07 18:08:10 +00:00
|
|
|
return (
|
2017-02-13 12:28:49 +00:00
|
|
|
<div id="rule">
|
2017-02-22 16:55:36 +00:00
|
|
|
<PageTypeIcon type="comprendre"/>
|
2017-02-13 12:28:49 +00:00
|
|
|
<h1>
|
|
|
|
<span className="rule-type">{rule.type}</span>
|
2017-03-27 16:37:11 +00:00
|
|
|
<span className="rule-name">{capitalise0(name)}</span>
|
2017-02-13 12:28:49 +00:00
|
|
|
</h1>
|
2017-03-17 15:49:09 +00:00
|
|
|
<section id="rule-meta">
|
2017-02-13 12:28:49 +00:00
|
|
|
<div id="meta-paragraph">
|
|
|
|
<p>
|
|
|
|
{rule.description}
|
|
|
|
</p>
|
|
|
|
</div>
|
2017-03-17 15:49:09 +00:00
|
|
|
<div id="destinataire">
|
|
|
|
<h2>Destinataire</h2>
|
2017-04-06 16:34:00 +00:00
|
|
|
{!destinataireData ?
|
|
|
|
<p>Non renseigné</p>
|
|
|
|
: <div>
|
|
|
|
<a href={destinataireData.lien} target="_blank">
|
|
|
|
{destinataireData.image &&
|
2017-04-24 18:03:38 +00:00
|
|
|
<img src={require('../../règles/ressources/destinataires/' + destinataireData.image)} /> }
|
2017-04-06 16:34:00 +00:00
|
|
|
{!destinataireData.image &&
|
|
|
|
<div id="calligraphy">{destinataire}</div>
|
|
|
|
}
|
|
|
|
</a>
|
|
|
|
{destinataireData.nom && <div id="destinataireName">{destinataireData.nom}</div>}
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
|
2017-03-17 15:49:09 +00:00
|
|
|
</div>
|
2017-02-13 12:28:49 +00:00
|
|
|
<div>
|
|
|
|
<h2>Références</h2>
|
|
|
|
{this.renderReferences(rule)}
|
|
|
|
</div>
|
|
|
|
</section>
|
2017-03-27 16:37:11 +00:00
|
|
|
<Algorithm {...{rule, situationExists}}/>
|
2016-12-07 18:08:10 +00:00
|
|
|
</div>
|
2017-02-13 12:28:49 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-03-17 15:49:09 +00:00
|
|
|
renderReferences({'références': refs}) {
|
|
|
|
if (!refs) return <p>Cette règle manque de références.</p>
|
|
|
|
|
2017-04-13 14:43:56 +00:00
|
|
|
return <References refs={refs}/>
|
2016-12-07 18:08:10 +00:00
|
|
|
}
|
|
|
|
}
|
2016-12-16 16:22:47 +00:00
|
|
|
|
2017-03-27 16:37:11 +00:00
|
|
|
@AttachDictionary(knownMecanisms)
|
|
|
|
class Algorithm extends React.Component {
|
|
|
|
state = {
|
|
|
|
showValues: false
|
|
|
|
}
|
|
|
|
render(){
|
|
|
|
let {rule, situationExists, explain} = this.props,
|
|
|
|
showValues = situationExists && this.state.showValues
|
|
|
|
return (
|
|
|
|
<div id="algorithm">
|
|
|
|
<section id="rule-rules" className={classNames({showValues})}>
|
|
|
|
{ do {
|
2017-04-06 16:34:00 +00:00
|
|
|
// TODO ce let est incompréhensible !
|
2017-03-27 16:37:11 +00:00
|
|
|
let [,cond] =
|
2017-04-06 16:34:00 +00:00
|
|
|
R.toPairs(rule).find(([,v]) => v && v.rulePropType == 'cond') || []
|
2017-03-27 16:37:11 +00:00
|
|
|
cond != null &&
|
|
|
|
<section id="declenchement">
|
|
|
|
<h2>Conditions de déclenchement</h2>
|
|
|
|
{cond.jsx}
|
|
|
|
</section>
|
|
|
|
}}
|
|
|
|
<section id="formule">
|
|
|
|
<h2>Calcul</h2>
|
|
|
|
{rule['formule'].jsx}
|
|
|
|
</section>
|
|
|
|
</section>
|
|
|
|
{situationExists && <div>
|
|
|
|
<button id="showValues" onClick={() => this.setState({showValues: !this.state.showValues})}>
|
|
|
|
<i className="fa fa-rocket" aria-hidden="true"></i> {!showValues ? 'Injecter votre situation' : 'Cacher votre situation'}
|
|
|
|
</button>
|
|
|
|
</div>}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|