2017-07-02 17:12:02 +00:00
|
|
|
import marked from 'Engine/marked'
|
2018-03-29 08:55:42 +00:00
|
|
|
import { findRuleByDottedName } from 'Engine/rules'
|
2018-06-20 12:08:49 +00:00
|
|
|
import React, { Component } from 'react'
|
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import { flatRulesSelector } from 'Selectors/analyseSelectors'
|
2018-01-03 15:54:19 +00:00
|
|
|
import { EXPLAIN_VARIABLE } from '../actions'
|
2017-07-02 17:12:02 +00:00
|
|
|
import './Aide.css'
|
2018-06-20 12:08:49 +00:00
|
|
|
import References from './rule/References'
|
|
|
|
import withColours from './withColours'
|
2017-02-09 17:15:25 +00:00
|
|
|
@connect(
|
2018-01-10 16:51:35 +00:00
|
|
|
state => ({
|
|
|
|
explained: state.explainedVariable,
|
2018-06-20 12:08:49 +00:00
|
|
|
flatRules: flatRulesSelector(state)
|
2018-01-10 16:51:35 +00:00
|
|
|
}),
|
2017-02-09 17:38:51 +00:00
|
|
|
dispatch => ({
|
2018-01-03 15:54:19 +00:00
|
|
|
stopExplaining: () => dispatch({ type: EXPLAIN_VARIABLE })
|
2017-02-09 17:38:51 +00:00
|
|
|
})
|
2017-02-09 17:15:25 +00:00
|
|
|
)
|
2018-06-20 12:08:49 +00:00
|
|
|
@withColours
|
2017-02-09 17:15:25 +00:00
|
|
|
export default class Aide extends Component {
|
2017-04-28 15:47:01 +00:00
|
|
|
renderExplanationMarkdown(explanation, term) {
|
|
|
|
return marked(`### ${term} \n\n${explanation}`)
|
|
|
|
}
|
2017-02-09 17:15:25 +00:00
|
|
|
render() {
|
2018-06-20 12:08:49 +00:00
|
|
|
let { flatRules, explained, stopExplaining, colours } = this.props
|
2017-02-09 17:15:25 +00:00
|
|
|
|
2017-05-05 16:38:43 +00:00
|
|
|
if (!explained) return <section id="helpWrapper" />
|
2017-02-09 17:15:25 +00:00
|
|
|
|
2018-03-29 08:55:42 +00:00
|
|
|
let rule = findRuleByDottedName(flatRules, explained),
|
2017-04-28 15:47:01 +00:00
|
|
|
text = rule.description,
|
2017-04-13 14:43:56 +00:00
|
|
|
refs = rule.références
|
2017-02-09 17:15:25 +00:00
|
|
|
|
|
|
|
return (
|
2017-05-05 16:38:43 +00:00
|
|
|
<div id="helpWrapper" className="active">
|
|
|
|
<section id="help">
|
2018-01-10 16:51:35 +00:00
|
|
|
<i
|
|
|
|
className="fa fa-times-circle"
|
|
|
|
onClick={stopExplaining}
|
2018-06-20 12:08:49 +00:00
|
|
|
style={{ color: colours.colour }}
|
2018-01-10 16:51:35 +00:00
|
|
|
/>
|
2017-05-05 16:38:43 +00:00
|
|
|
<p
|
2018-01-03 15:54:19 +00:00
|
|
|
dangerouslySetInnerHTML={{
|
|
|
|
__html: this.renderExplanationMarkdown(text, rule.title)
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
{refs && (
|
|
|
|
<div>
|
|
|
|
<p>Pour en savoir plus: </p>
|
|
|
|
<References refs={refs} />
|
|
|
|
</div>
|
|
|
|
)}
|
2017-05-05 16:38:43 +00:00
|
|
|
</section>
|
|
|
|
</div>
|
2017-02-09 17:15:25 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|