mon-entreprise/source/components/Aide.js

59 lines
1.4 KiB
JavaScript
Raw Normal View History

import React, {Component} from 'react'
import {connect} from 'react-redux'
import {findRuleByDottedName} from '../engine/rules'
2017-02-09 17:38:51 +00:00
import './Aide.css'
import {EXPLAIN_VARIABLE} from '../actions'
import References from './References'
import marked from '../engine/marked'
@connect(
state =>
2017-02-09 17:38:51 +00:00
({explained: state.explainedVariable}),
dispatch => ({
stopExplaining: () => dispatch(
{type: EXPLAIN_VARIABLE})
})
)
export default class Aide extends Component {
renderExplanationMarkdown(explanation, term) {
return marked(`### ${term} \n\n${explanation}`)
}
render() {
2017-02-09 17:38:51 +00:00
let {explained, stopExplaining} = this.props
if (!explained) return <section id="help" />
let rule = findRuleByDottedName(explained),
text = rule.description,
refs = rule.références
let possibilities = rule['choix exclusifs']
return (
<section id="help" className="active">
2017-02-09 17:38:51 +00:00
<i className="fa fa-info-circle"></i>
<i
className="fa fa-times-circle"
onClick={stopExplaining} ></i>
<p
dangerouslySetInnerHTML={{__html: this.renderExplanationMarkdown(text, rule.titre)}}>
</p>
{/* { possibilities &&
<p>
{possibilities.length} possibilités :
<ul>
{possibilities.map(p =>
<li key={p}>{p}</li>
)}
</ul>
</p>
} */}
{refs && <div>
<p>Pour en savoir plus: </p>
<References refs={refs} />
</div>}
</section>
)
}
}