99 lines
2.6 KiB
JavaScript
99 lines
2.6 KiB
JavaScript
|
import React, {Component} from 'react'
|
||
|
import './CDD.css'
|
||
|
import Results from './Results'
|
||
|
import {reduxForm, formValueSelector} from 'redux-form'
|
||
|
import {connect} from 'react-redux'
|
||
|
import './conversation/conversation.css'
|
||
|
import {START_CONVERSATION} from '../actions'
|
||
|
import Aide from './Aide'
|
||
|
import PageTypeIcon from './PageTypeIcon'
|
||
|
|
||
|
//TODO fusionner SimulationCDD & SimulationNet
|
||
|
|
||
|
let situationSelector = formValueSelector('conversation')
|
||
|
|
||
|
@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}),
|
||
|
}),
|
||
|
)
|
||
|
export default class CDD extends Component {
|
||
|
componentDidMount() {
|
||
|
// C'est ici que la génération du formulaire, et donc la traversée des variables commence
|
||
|
this.props.startConversation('surcoût CDD')
|
||
|
}
|
||
|
render() {
|
||
|
let {foldedSteps, unfoldedSteps, situation} = this.props
|
||
|
|
||
|
return (
|
||
|
<div id="sim">
|
||
|
<PageTypeIcon type="simulation" />
|
||
|
<h1>Simulateur CDD</h1>
|
||
|
<div id="conversation">
|
||
|
<div id="questions-answers">
|
||
|
<div id="foldedSteps">
|
||
|
{foldedSteps
|
||
|
.map(step => (
|
||
|
<step.component
|
||
|
key={step.name}
|
||
|
{...step}
|
||
|
step={step}
|
||
|
answer={situation(step.name)}
|
||
|
/>
|
||
|
))}
|
||
|
</div>
|
||
|
<div id="unfoldedSteps">
|
||
|
{unfoldedSteps.map(step => (
|
||
|
<step.component
|
||
|
key={step.name}
|
||
|
{...step}
|
||
|
step={step}
|
||
|
unfolded={true}
|
||
|
answer={situation(step.name)}
|
||
|
/>
|
||
|
))}
|
||
|
</div>
|
||
|
{unfoldedSteps.length == 0 &&
|
||
|
<div id="fin">
|
||
|
<img src={require('../images/fin.png')} />
|
||
|
<p>
|
||
|
Nous n'avons plus de questions : votre simulation est terminée.
|
||
|
</p><p>
|
||
|
Une remarque ?
|
||
|
<a href="mailto:contact@embauche.beta.gouv.fr">
|
||
|
Écrivez-nous
|
||
|
</a>
|
||
|
{' '}
|
||
|
<i
|
||
|
style={{cursor: 'pointer'}}
|
||
|
className="fa fa-envelope-o"
|
||
|
/>
|
||
|
{' '}
|
||
|
!
|
||
|
</p>
|
||
|
</div>}
|
||
|
</div>
|
||
|
<Aide />
|
||
|
</div>
|
||
|
<Results {...this.props} />
|
||
|
</div>
|
||
|
)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* 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)
|
||
|
|
||
|
*/
|