2017-04-18 17:37:38 +00:00
|
|
|
import React, {Component} from 'react'
|
|
|
|
import './CDD.css'
|
2017-05-02 15:24:28 +00:00
|
|
|
import {reduxForm, formValueSelector, reset} from 'redux-form'
|
2017-04-18 17:37:38 +00:00
|
|
|
import {connect} from 'react-redux'
|
|
|
|
import './conversation/conversation.css'
|
|
|
|
import {START_CONVERSATION} from '../actions'
|
|
|
|
import Aide from './Aide'
|
|
|
|
import PageTypeIcon from './PageTypeIcon'
|
|
|
|
import simulateurs from '../../règles/simulateurs.yaml'
|
|
|
|
import R from 'ramda'
|
2017-04-24 18:03:38 +00:00
|
|
|
import {Redirect, Link, withRouter} from 'react-router-dom'
|
2017-04-18 17:37:38 +00:00
|
|
|
import {createMarkdownDiv} from '../engine/marked'
|
|
|
|
import './Simulateur.css'
|
|
|
|
import classNames from 'classnames'
|
|
|
|
let situationSelector = formValueSelector('conversation')
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
@withRouter
|
2017-04-18 17:37:38 +00:00
|
|
|
@reduxForm({form: 'conversation', destroyOnUnmount: false})
|
|
|
|
@connect(
|
|
|
|
state => ({
|
|
|
|
situation: variableName => situationSelector(state, variableName),
|
|
|
|
foldedSteps: state.foldedSteps,
|
|
|
|
unfoldedSteps: state.unfoldedSteps,
|
|
|
|
themeColours: state.themeColours,
|
|
|
|
analysedSituation: state.analysedSituation,
|
|
|
|
}),
|
|
|
|
dispatch => ({
|
|
|
|
startConversation: rootVariable => dispatch({type: START_CONVERSATION, rootVariable}),
|
2017-05-02 15:24:28 +00:00
|
|
|
resetForm: rootVariable => dispatch(reset('conversation'))
|
2017-04-18 17:37:38 +00:00
|
|
|
})
|
|
|
|
)
|
|
|
|
export default class extends React.Component {
|
|
|
|
componentWillMount() {
|
|
|
|
let {
|
|
|
|
match: {
|
|
|
|
params: {
|
|
|
|
simulateurId
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} = this.props
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
this.simulateurId = simulateurId
|
2017-04-18 17:37:38 +00:00
|
|
|
this.simulateur = R.find(R.propEq('id', simulateurId))(simulateurs)
|
|
|
|
|
|
|
|
// C'est ici que la génération du formulaire, et donc la traversée des variables commence
|
|
|
|
if (this.simulateur)
|
|
|
|
this.props.startConversation(this.simulateur.objectif)
|
|
|
|
}
|
|
|
|
render(){
|
|
|
|
if (!this.simulateur) return <Redirect to="/404"/>
|
|
|
|
|
|
|
|
let
|
2017-04-24 18:03:38 +00:00
|
|
|
started = !this.props.match.params.intro,
|
2017-04-18 17:37:38 +00:00
|
|
|
{foldedSteps, unfoldedSteps, situation} = this.props,
|
|
|
|
sim = path =>
|
2017-05-02 15:24:28 +00:00
|
|
|
R.path(R.unless(R.is(Array), R.of)(path))(this.simulateur),
|
|
|
|
objectif = this.simulateur.objectif,
|
|
|
|
reinitalise = () => {
|
|
|
|
this.props.resetForm(objectif);
|
|
|
|
this.props.startConversation(objectif);
|
|
|
|
}
|
|
|
|
|
2017-04-18 17:37:38 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div id="sim" className={classNames({started})}>
|
|
|
|
<PageTypeIcon type="simulation" />
|
|
|
|
<h1>{sim('titre')}</h1>
|
|
|
|
<div id="simSubtitle">{sim('sous-titre')}</div>
|
|
|
|
<div className="intro centered">
|
|
|
|
{sim('introduction').map( ({icône, texte, titre}) =>
|
|
|
|
<div key={titre}>
|
|
|
|
<i title={titre} className={"fa "+icône} aria-hidden="true"></i>
|
|
|
|
<span>
|
|
|
|
{texte}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
{
|
|
|
|
// Tant que le bouton 'C'est parti' n'est pas cliqué, on affiche l'intro
|
2017-04-24 18:03:38 +00:00
|
|
|
!started ?
|
2017-04-18 17:37:38 +00:00
|
|
|
<div>
|
|
|
|
<div className="action centered">
|
|
|
|
<p>{sim(['action', 'texte'])}</p>
|
2017-04-24 18:03:38 +00:00
|
|
|
<button onClick={() => this.props.history.push(`/simulateurs/${this.simulateurId}`) }>
|
2017-04-18 17:37:38 +00:00
|
|
|
{sim(['action', 'bouton'])}
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div className="remarks centered">
|
|
|
|
<p>
|
|
|
|
Pour simplifier, les résultats sont calculés par mois de contrat.
|
|
|
|
</p>
|
|
|
|
<p>
|
2017-04-28 15:47:01 +00:00
|
|
|
N'hésitez pas à <Link to="/contact">nous écrire</Link> ! La loi française est très ciblée, et donc complexe. Nous pouvons la rendre plus transparente.
|
2017-04-18 17:37:38 +00:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
: (
|
|
|
|
<div>
|
|
|
|
<div id="conversation">
|
|
|
|
<div id="questions-answers">
|
|
|
|
{ !R.isEmpty(foldedSteps) &&
|
|
|
|
<div id="foldedSteps">
|
2017-05-02 15:24:28 +00:00
|
|
|
<div id="reinitialise" >
|
|
|
|
<button onClick={reinitalise}>
|
|
|
|
<i className="fa fa-trash" aria-hidden="true"></i>
|
|
|
|
Tout effacer
|
|
|
|
</button>
|
|
|
|
</div>
|
2017-04-18 17:37:38 +00:00
|
|
|
{foldedSteps
|
|
|
|
.map(step => (
|
|
|
|
<step.component
|
|
|
|
key={step.name}
|
|
|
|
{...step}
|
|
|
|
step={step}
|
|
|
|
answer={situation(step.name)}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
<div id="unfoldedSteps">
|
|
|
|
{ !R.isEmpty(unfoldedSteps) && do {
|
2017-04-28 15:03:34 +00:00
|
|
|
let step = R.head(unfoldedSteps)
|
2017-04-18 17:37:38 +00:00
|
|
|
;<step.component
|
|
|
|
key={step.name}
|
2017-04-28 15:03:34 +00:00
|
|
|
step={R.dissoc('component', step)}
|
2017-04-18 17:37:38 +00:00
|
|
|
unfolded={true}
|
|
|
|
answer={situation(step.name)}
|
|
|
|
/>
|
|
|
|
}}
|
|
|
|
</div>
|
|
|
|
{unfoldedSteps.length == 0 &&
|
|
|
|
<div id="fin">
|
|
|
|
<img src={require('../images/fin.png')} />
|
|
|
|
{createMarkdownDiv(sim('conclusion'))}
|
|
|
|
</div>}
|
|
|
|
</div>
|
|
|
|
<Aide />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|