mon-entreprise/source/components/Simulateur.js

167 lines
4.2 KiB
JavaScript
Raw Normal View History

import { reject, isNil, equals, pluck, path, map, omit } from 'ramda'
import React, { Component } from 'react'
import Helmet from 'react-helmet'
import { reset, change, formValueSelector } from 'redux-form'
import { connect } from 'react-redux'
import { withRouter, Redirect } from 'react-router-dom'
import classNames from 'classnames'
import { START_CONVERSATION } from '../actions'
import {
findRuleByName,
findRule,
findRuleByDottedName,
decodeRuleName
} from 'Engine/rules'
import './conversation/conversation.css'
import './Simulateur.css'
import Conversation from './conversation/Conversation'
2018-02-06 16:02:13 +00:00
import { getInputComponent } from 'Engine/generateQuestions'
2017-10-18 09:24:50 +00:00
import ReactPiwik from './Tracker'
import Results from 'Components/Results'
import Explanation from 'Components/Explanation'
@withRouter
@connect(
state => ({
currentQuestion: state.currentQuestion,
foldedSteps: state.foldedSteps,
themeColours: state.themeColours,
situationGate: state.situationGate,
targetNames: state.targetNames,
done: state.done,
nextSteps: state.nextSteps,
inputInversions: formValueSelector('conversation')(state, 'inversions'),
analysis: state.analysis,
parsedRules: state.parsedRules
}),
dispatch => ({
startConversation: (targetNames, fromScratch = false) =>
dispatch({ type: START_CONVERSATION, targetNames, fromScratch }),
resetForm: () => dispatch(reset('conversation')),
resetFormField: name => dispatch(change('conversation', name, ''))
})
)
2017-10-18 09:24:50 +00:00
export default class extends Component {
state = {
started: false
}
componentWillMount() {
let {
match: {
params: { targets: encodedTargets }
},
targetNames: pastTargetNames,
resetFormField,
parsedRules
} = this.props,
targetNames = encodedTargets.split('+').map(decodeRuleName)
this.targetNames = targetNames
2018-01-08 15:07:26 +00:00
this.targetRules = reject(isNil)(
targetNames.map(name => findRule(parsedRules, name))
)
this.targetRules.map(({ dottedName }) => resetFormField(dottedName))
if (
this.targetRules.length > 0 &&
(this.props.foldedSteps.length === 0 ||
2018-01-08 15:07:26 +00:00
!equals(targetNames, pastTargetNames))
)
2017-11-17 12:06:24 +00:00
this.props.startConversation(targetNames)
}
render() {
if (this.targetRules.length == 0) return <Redirect to="/404" />
let {
flatRules,
foldedSteps,
currentQuestion,
themeColours,
inputInversions,
2018-02-06 16:02:13 +00:00
done,
parsedRules
} = this.props,
reinitalise = () => {
2017-10-18 09:24:50 +00:00
ReactPiwik.push(['trackEvent', 'restart', ''])
this.props.resetForm()
this.props.startConversation(this.targetNames, true)
},
noQuestionsLeft = currentQuestion == null
return (
<div id="sim" className={classNames({ noQuestionsLeft })}>
<Helmet>
<title>
{"Simulateur d'embauche : "}
2018-01-08 15:07:26 +00:00
{pluck('title', this.targetRules).join(', ')}
</title>
<meta
name="description"
2018-01-08 15:07:26 +00:00
content={pluck('description', this.targetRules).join(' - ')}
/>
</Helmet>
<Conversation
{...{
reinitalise,
currentQuestion:
currentQuestion &&
2018-02-06 16:02:13 +00:00
getInputComponent({ unfolded: true })(
flatRules,
this.targetNames,
inputInversions
)(currentQuestion),
2018-01-08 15:07:26 +00:00
foldedSteps: map(
2018-02-06 16:02:13 +00:00
getInputComponent({ unfolded: false })(
flatRules,
this.targetNames,
inputInversions
),
foldedSteps
),
done: this.props.done,
nextSteps: this.props.nextSteps,
textColourOnWhite: themeColours.textColourOnWhite
}}
/>
<Results />
{done && (
<Explanation
2018-01-08 15:07:26 +00:00
targetRules={path(['analysis', 'targets'], this.props)}
/>
)}
</div>
)
}
buildStep = ({ unfolded, flatRules }) => (
situationGate,
targetNames,
inputInversions
) => question => {
let step = makeQuestion(flatRules, targetNames)(question)
let fieldName =
(inputInversions &&
2018-01-08 15:07:26 +00:00
path(step.dottedName.split('.'), inputInversions)) ||
step.dottedName,
fieldTitle = findRuleByDottedName(flatRules, fieldName).title
return (
<step.component
key={step.dottedName}
{...omit('component', step)}
unfolded={unfolded}
step={omit('component', step)}
situationGate={situationGate}
fieldName={fieldName}
fieldTitle={fieldTitle}
inverted={step.dottedName !== fieldName}
/>
)
}
}