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