import React, {Component} from 'react' import {reduxForm, formValueSelector, reset} from 'redux-form' import {connect} from 'react-redux' import {START_CONVERSATION} from '../actions' import R from 'ramda' import {Redirect, Link, withRouter} from 'react-router-dom' import Aide from './Aide' import {createMarkdownDiv} from 'Engine/marked' import {findRuleByName, decodeRuleName} from 'Engine/rules' import 'Components/conversation/conversation.css' import 'Components/Simulateur.css' import classNames from 'classnames' import {capitalise0} from '../utils' import Satisfaction from 'Components/Satisfaction' import Helmet from 'react-helmet' let situationSelector = formValueSelector('conversation') @withRouter @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}), resetForm: () => dispatch(reset('conversation')) }) ) export default class extends React.Component { componentWillMount() { let { match: { params: { name: encodedName } } } = this.props, name = decodeRuleName(encodedName) this.encodedName = encodedName this.name = name this.rule = findRuleByName(name) // C'est ici que la génération du formulaire, et donc la traversée des variables commence if (this.rule.formule) this.props.startConversation(name) } render(){ if (!this.rule.formule) return let started = !this.props.match.params.intro, {foldedSteps, unfoldedSteps, situation} = this.props, sim = path => R.path(R.unless(R.is(Array), R.of)(path))(this.rule.simulateur || {}), reinitalise = () => { this.props.resetForm(this.name) this.props.startConversation(this.name) }, title = sim('titre') || capitalise0(this.rule['titre'] || this.rule['nom']) return (
{title} {sim('sous-titre') && }

{title}

{sim('sous-titre') &&
{sim('sous-titre')}
} {sim(['introduction', 'notes']) &&
{sim(['introduction', 'notes']).map( ({icône, texte, titre}) =>
{texte}
)}
} { // Tant que le bouton 'C'est parti' n'est pas cliqué, on affiche l'intro !started ?
{createMarkdownDiv(sim(['introduction', 'motivation'])) ||

Simulez cette règle en quelques clics

}

Pour simplifier, les résultats sont calculés par mois de contrat, et pour un temps complet.

N'hésitez pas à nous écrire ! La loi française est très ciblée, et donc complexe. Nous pouvons la rendre plus transparente.

: (
{ !R.isEmpty(foldedSteps) &&

Vos réponses

{foldedSteps .map(step => ( ))}
}
{ !R.isEmpty(unfoldedSteps) && do { let step = R.head(unfoldedSteps) ; }}
{unfoldedSteps.length == 0 && }
)}
) } } class Conclusion extends Component { render() { return (

Votre simulation est terminée !

N'hésitez pas à modifier vos réponses, ou cliquez sur vos résultats pour comprendre le calcul.

) } }