2018-09-13 13:19:56 +00:00
|
|
|
import { resetSimulation, startConversation } from 'Actions/actions'
|
2018-09-05 08:52:53 +00:00
|
|
|
import { ScrollToTop } from 'Components/utils/Scroll'
|
2018-07-12 08:09:41 +00:00
|
|
|
import withColours from 'Components/utils/withColours'
|
2018-08-06 11:50:39 +00:00
|
|
|
import withLanguage from 'Components/utils/withLanguage'
|
2018-02-28 16:45:13 +00:00
|
|
|
import React, { Component } from 'react'
|
2018-07-31 13:32:41 +00:00
|
|
|
import { Trans, translate } from 'react-i18next'
|
2018-06-06 16:17:13 +00:00
|
|
|
import { connect } from 'react-redux'
|
2018-07-06 15:03:16 +00:00
|
|
|
import { Link } from 'react-router-dom'
|
2018-07-03 16:28:45 +00:00
|
|
|
import { animated, Spring } from 'react-spring'
|
2018-09-13 13:19:56 +00:00
|
|
|
import { reset } from 'redux-form'
|
2018-06-29 16:14:00 +00:00
|
|
|
import {
|
2018-07-03 16:28:45 +00:00
|
|
|
blockingInputControlsSelector,
|
2018-09-04 14:23:05 +00:00
|
|
|
nextStepsSelector,
|
|
|
|
noUserInputSelector
|
2018-06-29 16:14:00 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2018-07-12 08:09:41 +00:00
|
|
|
import * as Animate from 'Ui/animate'
|
2018-07-25 14:07:53 +00:00
|
|
|
import AnswerList from './AnswerList'
|
2018-03-01 18:07:40 +00:00
|
|
|
import Conversation from './conversation/Conversation'
|
2018-07-12 08:09:41 +00:00
|
|
|
import Distribution from './Distribution'
|
|
|
|
import PaySlip from './PaySlip'
|
2018-07-23 14:26:11 +00:00
|
|
|
import QuickLink from './QuickLink'
|
2018-07-31 12:53:40 +00:00
|
|
|
import ResultView from './ResultView'
|
2018-06-18 09:54:18 +00:00
|
|
|
import './Simu.css'
|
|
|
|
import TargetSelection from './TargetSelection'
|
2018-06-06 16:17:13 +00:00
|
|
|
|
2018-02-28 16:45:13 +00:00
|
|
|
@withColours
|
2018-07-31 13:32:41 +00:00
|
|
|
@translate() // Triggers rerender when the language changes
|
2018-07-03 16:28:45 +00:00
|
|
|
@connect(
|
|
|
|
state => ({
|
|
|
|
noUserInput: noUserInputSelector(state),
|
|
|
|
blockingInputControls: blockingInputControlsSelector(state),
|
2018-07-06 16:25:59 +00:00
|
|
|
conversationStarted: state.conversationStarted,
|
2018-07-25 14:07:53 +00:00
|
|
|
arePreviousAnswers: state.conversationSteps.foldedSteps.length !== 0,
|
2018-07-06 16:25:59 +00:00
|
|
|
nextSteps: state.conversationStarted && nextStepsSelector(state)
|
2018-07-03 16:28:45 +00:00
|
|
|
}),
|
2018-09-13 13:19:56 +00:00
|
|
|
dispatch => ({
|
|
|
|
startConversation: () => dispatch(startConversation()),
|
|
|
|
resetSimulation: () => {
|
|
|
|
dispatch(resetSimulation())
|
|
|
|
dispatch(reset('conversation'))
|
|
|
|
}
|
|
|
|
})
|
2018-07-03 16:28:45 +00:00
|
|
|
)
|
2018-08-06 11:50:39 +00:00
|
|
|
@withLanguage
|
2018-09-21 15:28:28 +00:00
|
|
|
class Simu extends Component {
|
2018-07-25 14:07:53 +00:00
|
|
|
state = {
|
|
|
|
displayPreviousAnswers: false
|
|
|
|
}
|
2018-02-28 16:45:13 +00:00
|
|
|
render() {
|
2018-06-29 16:14:00 +00:00
|
|
|
let {
|
|
|
|
colours,
|
|
|
|
conversationStarted,
|
|
|
|
noUserInput,
|
2018-07-25 14:07:53 +00:00
|
|
|
arePreviousAnswers,
|
2018-07-06 16:25:59 +00:00
|
|
|
nextSteps,
|
2018-07-23 14:26:11 +00:00
|
|
|
startConversation,
|
2018-09-13 13:19:56 +00:00
|
|
|
resetSimulation,
|
2018-07-03 10:19:19 +00:00
|
|
|
blockingInputControls
|
2018-06-29 16:14:00 +00:00
|
|
|
} = this.props
|
2018-07-06 16:25:59 +00:00
|
|
|
const firstValidInputEntered =
|
|
|
|
!conversationStarted && !blockingInputControls && !noUserInput
|
2018-07-03 16:28:45 +00:00
|
|
|
const displayConversation = conversationStarted && !blockingInputControls
|
2018-07-06 16:25:59 +00:00
|
|
|
const simulationCompleted =
|
|
|
|
!blockingInputControls && conversationStarted && !nextSteps.length
|
2018-07-25 14:07:53 +00:00
|
|
|
const displayPreviousAnswers =
|
|
|
|
arePreviousAnswers && this.state.displayPreviousAnswers
|
2018-02-28 16:45:13 +00:00
|
|
|
return (
|
2018-07-03 16:28:45 +00:00
|
|
|
<>
|
|
|
|
<div id="simu">
|
2018-09-13 13:19:56 +00:00
|
|
|
{displayConversation && (
|
|
|
|
<button className="ui__ button small" onClick={resetSimulation}>
|
|
|
|
←
|
|
|
|
</button>
|
|
|
|
)}
|
2018-07-25 14:07:53 +00:00
|
|
|
{arePreviousAnswers && (
|
|
|
|
<div className="change-answer-link">
|
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={() => this.setState({ displayPreviousAnswers: true })}>
|
2018-08-24 15:43:27 +00:00
|
|
|
<Trans>Modifier mes réponses</Trans>
|
2018-07-25 14:07:53 +00:00
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
)}
|
2018-07-03 16:28:45 +00:00
|
|
|
<Spring
|
|
|
|
to={{
|
2018-07-06 16:25:59 +00:00
|
|
|
height: firstValidInputEntered ? 'auto' : 0,
|
|
|
|
opacity: firstValidInputEntered ? 1 : 0
|
2018-07-03 16:28:45 +00:00
|
|
|
}}
|
|
|
|
native>
|
|
|
|
{styles => (
|
|
|
|
<animated.div
|
2018-07-12 08:09:41 +00:00
|
|
|
className="ui__ button-container"
|
2018-07-03 16:28:45 +00:00
|
|
|
style={{
|
|
|
|
...styles,
|
|
|
|
display: 'flex',
|
|
|
|
overflow: 'hidden',
|
2018-09-10 13:47:51 +00:00
|
|
|
flexWrap: 'wrap-reverse',
|
2018-07-03 16:28:45 +00:00
|
|
|
fontSize: '110%',
|
2018-08-30 16:09:15 +00:00
|
|
|
justifyContent: 'space-evenly',
|
|
|
|
marginBottom: '0.6rem'
|
2018-07-03 16:28:45 +00:00
|
|
|
}}>
|
2018-07-23 14:26:11 +00:00
|
|
|
<QuickLink />
|
2018-07-03 16:28:45 +00:00
|
|
|
</animated.div>
|
|
|
|
)}
|
|
|
|
</Spring>
|
2018-07-25 14:07:53 +00:00
|
|
|
{simulationCompleted && (
|
|
|
|
<>
|
2018-07-27 17:34:46 +00:00
|
|
|
<h1>
|
|
|
|
<Trans i18nKey="simulation-end.title">
|
|
|
|
Plus de questions !
|
|
|
|
</Trans>
|
|
|
|
</h1>
|
2018-07-25 14:07:53 +00:00
|
|
|
<p>
|
2018-07-27 17:34:46 +00:00
|
|
|
<Trans i18nKey="simulation-end.text">
|
|
|
|
Vous avez atteint l'estimation la plus précise. Vous pouvez
|
|
|
|
maintenant concrétiser votre projet d'embauche.
|
2018-07-25 14:07:53 +00:00
|
|
|
</Trans>
|
|
|
|
</p>
|
2018-08-10 09:07:40 +00:00
|
|
|
{this.props.displayHiringProcedures && (
|
|
|
|
<div style={{ textAlign: 'center' }}>
|
|
|
|
<Link className="ui__ button" to="/hiring-process">
|
|
|
|
<Trans i18nKey="simulation-end.cta">
|
|
|
|
Connaître les démarches
|
|
|
|
</Trans>
|
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
<br />
|
2018-07-25 14:07:53 +00:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
<div id="focusZone">
|
|
|
|
{displayConversation && (
|
2018-09-05 08:52:53 +00:00
|
|
|
<>
|
|
|
|
<ScrollToTop />
|
|
|
|
<Conversation textColourOnWhite={colours.textColourOnWhite} />
|
|
|
|
</>
|
2018-07-06 16:25:59 +00:00
|
|
|
)}
|
2018-07-25 14:07:53 +00:00
|
|
|
<TargetSelection colours={colours} />
|
|
|
|
</div>
|
|
|
|
{conversationStarted && (
|
2018-07-12 08:09:41 +00:00
|
|
|
<Animate.fromBottom>
|
2018-07-31 12:53:40 +00:00
|
|
|
<ResultView />
|
2018-09-21 15:28:28 +00:00
|
|
|
<div style={{ textAlign: 'center' }} />
|
2018-07-12 08:09:41 +00:00
|
|
|
</Animate.fromBottom>
|
|
|
|
)}
|
2018-07-25 14:07:53 +00:00
|
|
|
{displayPreviousAnswers && (
|
|
|
|
<AnswerList
|
|
|
|
onClose={() => this.setState({ displayPreviousAnswers: false })}
|
|
|
|
/>
|
|
|
|
)}
|
2018-03-15 14:51:39 +00:00
|
|
|
</div>
|
2018-07-03 16:28:45 +00:00
|
|
|
|
2018-07-06 16:25:59 +00:00
|
|
|
{firstValidInputEntered && (
|
2018-07-03 16:28:45 +00:00
|
|
|
<Animate.fromBottom>
|
2018-07-27 17:13:26 +00:00
|
|
|
<h2>
|
|
|
|
<Trans>A quoi servent mes cotisations ?</Trans>
|
|
|
|
</h2>
|
2018-07-03 16:28:45 +00:00
|
|
|
<Distribution />
|
2018-07-31 12:53:40 +00:00
|
|
|
|
2018-07-27 17:13:26 +00:00
|
|
|
<h2>
|
2018-07-31 16:07:38 +00:00
|
|
|
<Trans>Simulation personnalisée</Trans>
|
2018-07-27 17:13:26 +00:00
|
|
|
</h2>
|
2018-07-03 16:28:45 +00:00
|
|
|
<p>
|
2018-08-01 17:43:24 +00:00
|
|
|
<Trans i18nKey="custom-simulation">
|
|
|
|
Il s'agit pour l'instant d'une
|
|
|
|
<strong> première estimation</strong> sur la base d'un contrat
|
2018-07-31 16:07:38 +00:00
|
|
|
générique. La législation française prévoit une multitude de cas
|
|
|
|
particuliers et de règles spécifiques qui modifient
|
|
|
|
considérablement les montant de l'embauche.
|
2018-07-27 17:13:26 +00:00
|
|
|
</Trans>
|
2018-07-03 16:28:45 +00:00
|
|
|
</p>
|
|
|
|
<p style={{ textAlign: 'center' }}>
|
2018-08-06 12:26:53 +00:00
|
|
|
<button
|
|
|
|
className="ui__ button"
|
|
|
|
onClick={() => startConversation()}>
|
2018-07-31 16:07:38 +00:00
|
|
|
<Trans>Faire une simulation personnalisée</Trans>
|
2018-07-03 16:28:45 +00:00
|
|
|
</button>
|
|
|
|
</p>
|
2018-07-31 12:53:40 +00:00
|
|
|
<h2>
|
|
|
|
<Trans>Fiche de paie</Trans>
|
|
|
|
</h2>
|
|
|
|
<PaySlip />
|
2018-07-03 16:28:45 +00:00
|
|
|
</Animate.fromBottom>
|
|
|
|
)}
|
|
|
|
</>
|
2018-02-28 16:45:13 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2018-09-21 15:28:28 +00:00
|
|
|
|
|
|
|
export default Simu
|