2017-01-03 17:23:04 +00:00
|
|
|
import React, { Component } from 'react'
|
2017-01-10 14:39:40 +00:00
|
|
|
import './CDD.css'
|
2017-01-10 18:22:44 +00:00
|
|
|
import IntroCDD from './IntroCDD'
|
|
|
|
import Results from './Results'
|
|
|
|
import {reduxForm, formValueSelector} from 'redux-form'
|
|
|
|
import {connect} from 'react-redux'
|
|
|
|
import './conversation/conversation.css'
|
|
|
|
import {START_CONVERSATION} from '../actions'
|
2017-02-08 16:50:22 +00:00
|
|
|
import {findRuleByName} from '../engine/rules'
|
2017-01-03 17:23:04 +00:00
|
|
|
|
2017-02-08 16:50:22 +00:00
|
|
|
@connect(({form: {conversation}, steps, explainTerm}) => ({conversationState: conversation && conversation.values, steps, explainTerm}))
|
2017-01-10 18:22:44 +00:00
|
|
|
class Aide extends Component {
|
|
|
|
render() {
|
2017-02-08 16:50:22 +00:00
|
|
|
let {steps, conversationState, explainTerm} = this.props
|
2017-01-18 08:48:46 +00:00
|
|
|
if (!steps.length) return null
|
|
|
|
let [{dependencyOfVariables, helpText}] = steps
|
2017-02-08 16:50:22 +00:00
|
|
|
|
|
|
|
if (!explainTerm) return <section id="help" />
|
|
|
|
|
|
|
|
let rule = findRuleByName(explainTerm),
|
|
|
|
text = rule.description || rule.titre
|
|
|
|
|
|
|
|
let possibilities = rule['choix exclusifs']
|
|
|
|
|
|
|
|
return (
|
|
|
|
<section id="help" className="active">
|
|
|
|
<p>
|
|
|
|
{text}
|
|
|
|
</p>
|
|
|
|
{ possibilities &&
|
|
|
|
<p>
|
|
|
|
{possibilities.length} possibilités :
|
|
|
|
<ul>
|
|
|
|
{possibilities.map(p =>
|
|
|
|
<li key={p}>{p}</li>
|
|
|
|
)}
|
|
|
|
</ul>
|
|
|
|
</p>
|
|
|
|
}
|
|
|
|
</section>
|
|
|
|
)
|
2017-01-10 18:22:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
let situationSelector = formValueSelector('conversation')
|
|
|
|
|
|
|
|
@reduxForm(
|
|
|
|
{form: 'conversation'}
|
|
|
|
)
|
|
|
|
@connect(state => ({
|
|
|
|
situation: variableName => situationSelector(state, variableName),
|
|
|
|
steps: state.steps,
|
|
|
|
themeColours: state.themeColours,
|
|
|
|
analysedSituation: state.analysedSituation
|
|
|
|
}), dispatch => ({
|
|
|
|
startConversation: () => dispatch({type: START_CONVERSATION})
|
|
|
|
}))
|
2017-01-03 17:23:04 +00:00
|
|
|
export default class CDD extends Component {
|
2017-01-10 18:22:44 +00:00
|
|
|
componentDidMount() {
|
|
|
|
this.props.startConversation()
|
2017-01-10 14:39:40 +00:00
|
|
|
}
|
2017-01-03 17:23:04 +00:00
|
|
|
render() {
|
2017-01-10 14:39:40 +00:00
|
|
|
|
2017-01-10 18:22:44 +00:00
|
|
|
let {steps} = this.props
|
|
|
|
|
|
|
|
let conversation = steps.map(step =>
|
|
|
|
<step.component key={step.name} {...step}/>
|
|
|
|
)
|
2017-01-10 14:39:40 +00:00
|
|
|
|
2017-01-03 17:23:04 +00:00
|
|
|
return (
|
2017-01-10 14:39:40 +00:00
|
|
|
<div id="sim">
|
2017-01-10 18:22:44 +00:00
|
|
|
<IntroCDD />
|
2017-01-10 14:39:40 +00:00
|
|
|
<div id="conversation">
|
|
|
|
<section id="questions-answers">
|
2017-01-10 18:22:44 +00:00
|
|
|
{conversation}
|
2017-01-10 14:39:40 +00:00
|
|
|
</section>
|
2017-01-10 18:22:44 +00:00
|
|
|
<Aide />
|
2017-01-10 14:39:40 +00:00
|
|
|
</div>
|
2017-01-10 18:22:44 +00:00
|
|
|
<Results {...this.props}/>
|
2017-01-10 11:17:02 +00:00
|
|
|
</div>
|
2017-01-03 17:23:04 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2017-01-10 11:17:02 +00:00
|
|
|
|
|
|
|
/* TODO Problèmes à résoudre :
|
|
|
|
|
|
|
|
- exprimer la justification du CDD d'usage au delà des secteurs.
|
|
|
|
" l'usage exclut le recours au CDI en raison de la nature de l'activité et du caractère temporaire de ces emplois."
|
|
|
|
+ interdictions explicites (grève et travaux dangereux)
|
|
|
|
|
|
|
|
*/
|