2018-10-04 13:20:57 +00:00
|
|
|
|
import { startConversation } from 'Actions/actions'
|
2019-01-08 10:41:52 +00:00
|
|
|
|
import { Component, React, T } from 'Components'
|
2018-10-04 13:20:57 +00:00
|
|
|
|
import AnswerList from 'Components/AnswerList'
|
2019-01-11 10:46:02 +00:00
|
|
|
|
import Distribution from 'Components/Distribution'
|
|
|
|
|
import PaySlip from 'Components/PaySlip'
|
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'
|
2019-01-11 10:46:02 +00:00
|
|
|
|
import withSitePaths from 'Components/utils/withSitePaths'
|
2018-11-14 15:51:37 +00:00
|
|
|
|
import { compose } from 'ramda'
|
2019-01-08 10:41:52 +00:00
|
|
|
|
import emoji from 'react-easy-emoji'
|
2018-11-21 17:39:09 +00:00
|
|
|
|
import { Trans, withNamespaces } from 'react-i18next'
|
2018-06-06 16:17:13 +00:00
|
|
|
|
import { connect } from 'react-redux'
|
2018-10-04 13:20:57 +00:00
|
|
|
|
import { Redirect, withRouter } from 'react-router'
|
2018-07-06 15:03:16 +00:00
|
|
|
|
import { Link } from 'react-router-dom'
|
2019-01-08 10:41:52 +00:00
|
|
|
|
import { formValueSelector } 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,
|
2018-10-04 13:20:57 +00:00
|
|
|
|
noUserInputSelector,
|
|
|
|
|
validInputEnteredSelector
|
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-10-04 13:20:57 +00:00
|
|
|
|
import { normalizeBasePath } from '../utils'
|
2018-03-01 18:07:40 +00:00
|
|
|
|
import Conversation from './conversation/Conversation'
|
2018-10-04 13:20:57 +00:00
|
|
|
|
import PageFeedback from './Feedback/PageFeedback'
|
2018-07-23 14:26:11 +00:00
|
|
|
|
import QuickLink from './QuickLink'
|
2018-07-31 12:53:40 +00:00
|
|
|
|
import ResultView from './ResultView'
|
2019-01-08 18:19:19 +00:00
|
|
|
|
import './SalarySimulation.css'
|
2018-06-18 09:54:18 +00:00
|
|
|
|
import TargetSelection from './TargetSelection'
|
2018-06-06 16:17:13 +00:00
|
|
|
|
|
2018-11-14 15:51:37 +00:00
|
|
|
|
export default compose(
|
|
|
|
|
withRouter,
|
|
|
|
|
withColours,
|
2018-11-21 17:39:09 +00:00
|
|
|
|
withNamespaces(), // Triggers rerender when the language changes
|
2018-11-14 15:51:37 +00:00
|
|
|
|
connect(
|
|
|
|
|
state => ({
|
|
|
|
|
blockingInputControls: blockingInputControlsSelector(state),
|
|
|
|
|
conversationStarted: state.conversationStarted,
|
|
|
|
|
validInputEntered: validInputEnteredSelector(state),
|
|
|
|
|
arePreviousAnswers: state.conversationSteps.foldedSteps.length !== 0,
|
|
|
|
|
nextSteps: state.conversationStarted && nextStepsSelector(state),
|
2018-12-27 15:59:29 +00:00
|
|
|
|
noUserInput: noUserInputSelector(state),
|
2018-11-21 17:39:09 +00:00
|
|
|
|
period: formValueSelector('conversation')(state, 'période')
|
2018-11-14 15:51:37 +00:00
|
|
|
|
}),
|
|
|
|
|
{
|
|
|
|
|
startConversation
|
|
|
|
|
}
|
|
|
|
|
),
|
2019-01-11 10:46:02 +00:00
|
|
|
|
withLanguage,
|
|
|
|
|
withSitePaths
|
2018-11-14 15:51:37 +00:00
|
|
|
|
)(
|
|
|
|
|
class Simulation extends Component {
|
|
|
|
|
state = {
|
|
|
|
|
displayPreviousAnswers: false
|
|
|
|
|
}
|
|
|
|
|
render() {
|
|
|
|
|
let {
|
|
|
|
|
colours,
|
|
|
|
|
conversationStarted,
|
|
|
|
|
arePreviousAnswers,
|
|
|
|
|
nextSteps,
|
|
|
|
|
blockingInputControls,
|
2018-11-20 12:27:57 +00:00
|
|
|
|
displayHiringProcedures,
|
2018-11-14 15:51:37 +00:00
|
|
|
|
match,
|
|
|
|
|
validInputEntered,
|
2019-01-08 09:43:32 +00:00
|
|
|
|
period,
|
2019-01-11 10:46:02 +00:00
|
|
|
|
location,
|
|
|
|
|
sitePaths,
|
2019-01-08 09:43:32 +00:00
|
|
|
|
noUserInput
|
2018-11-14 15:51:37 +00:00
|
|
|
|
} = this.props
|
|
|
|
|
const displayConversation = conversationStarted && !blockingInputControls
|
|
|
|
|
const simulationCompleted =
|
|
|
|
|
!blockingInputControls && conversationStarted && !nextSteps.length
|
|
|
|
|
const displayPreviousAnswers =
|
|
|
|
|
arePreviousAnswers && this.state.displayPreviousAnswers
|
|
|
|
|
const simulationHomePath = normalizeBasePath(match.path).replace(
|
|
|
|
|
/\/simulation\/$/,
|
|
|
|
|
''
|
|
|
|
|
)
|
|
|
|
|
return (
|
|
|
|
|
<>
|
|
|
|
|
<div id="simu">
|
2019-01-08 09:43:32 +00:00
|
|
|
|
{noUserInput && (
|
|
|
|
|
<p
|
|
|
|
|
id="updateMessage"
|
|
|
|
|
style={{ fontStyle: 'italic', textAlign: 'center' }}>
|
|
|
|
|
{emoji('🌟')}{' '}
|
|
|
|
|
<T k="maj2019">
|
|
|
|
|
Le simulateur est à jour aux taux 2019 –{' '}
|
|
|
|
|
<a href="https://github.com/betagouv/syso/issues/441">
|
|
|
|
|
détails
|
|
|
|
|
</a>
|
|
|
|
|
</T>
|
|
|
|
|
</p>
|
|
|
|
|
)}
|
2018-11-14 15:51:37 +00:00
|
|
|
|
<QuickLink />
|
|
|
|
|
{location.pathname.endsWith('/simulation') && (
|
|
|
|
|
<>
|
|
|
|
|
{!conversationStarted && <Redirect to={simulationHomePath} />}
|
|
|
|
|
<Link to={simulationHomePath} style={{ position: 'absolute' }}>
|
|
|
|
|
<i
|
|
|
|
|
className="fa fa-arrow-left"
|
|
|
|
|
aria-hidden="true"
|
|
|
|
|
style={{ marginRight: '0.5rem' }}
|
|
|
|
|
/>
|
|
|
|
|
<Trans>Retour</Trans>
|
|
|
|
|
</Link>
|
2018-10-09 09:29:33 +00:00
|
|
|
|
|
2018-11-14 15:51:37 +00:00
|
|
|
|
<div
|
|
|
|
|
className="change-answer-link"
|
|
|
|
|
style={{
|
|
|
|
|
visibility: arePreviousAnswers ? 'visible' : 'hidden'
|
|
|
|
|
}}>
|
|
|
|
|
<button
|
|
|
|
|
className="ui__ link-button"
|
|
|
|
|
onClick={() =>
|
|
|
|
|
this.setState({ displayPreviousAnswers: true })
|
|
|
|
|
}>
|
|
|
|
|
<Trans>Modifier mes réponses</Trans>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
{displayPreviousAnswers && (
|
|
|
|
|
<AnswerList
|
|
|
|
|
onClose={() =>
|
|
|
|
|
this.setState({ displayPreviousAnswers: false })
|
|
|
|
|
}
|
|
|
|
|
/>
|
|
|
|
|
)}
|
|
|
|
|
{simulationCompleted && (
|
|
|
|
|
<>
|
|
|
|
|
<h1>
|
|
|
|
|
<Trans i18nKey="simulation-end.title">
|
|
|
|
|
Plus de questions !
|
|
|
|
|
</Trans>
|
|
|
|
|
</h1>
|
|
|
|
|
<p>
|
|
|
|
|
<Trans i18nKey="simulation-end.text">
|
|
|
|
|
Vous avez atteint l'estimation la plus précise. Vous
|
|
|
|
|
pouvez maintenant concrétiser votre projet d'embauche.
|
|
|
|
|
</Trans>
|
|
|
|
|
</p>
|
2018-11-20 12:27:57 +00:00
|
|
|
|
{displayHiringProcedures && (
|
2018-11-14 15:51:37 +00:00
|
|
|
|
<div style={{ textAlign: 'center' }}>
|
|
|
|
|
<Link
|
|
|
|
|
className="ui__ button"
|
2019-01-11 10:46:02 +00:00
|
|
|
|
to={sitePaths.démarcheEmbauche}>
|
2018-11-14 15:51:37 +00:00
|
|
|
|
<Trans i18nKey="simulation-end.cta">
|
|
|
|
|
Connaître les démarches
|
|
|
|
|
</Trans>
|
|
|
|
|
</Link>
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
<br />
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
{displayConversation && (
|
|
|
|
|
<>
|
|
|
|
|
<ScrollToTop />
|
|
|
|
|
<Conversation
|
|
|
|
|
textColourOnWhite={colours.textColourOnWhite}
|
|
|
|
|
/>
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
<TargetSelection colours={colours} />
|
|
|
|
|
{location.pathname.endsWith('/simulation') && (
|
|
|
|
|
<>
|
|
|
|
|
{conversationStarted && (
|
|
|
|
|
<Animate.fromBottom>
|
|
|
|
|
<ResultView />
|
|
|
|
|
<div style={{ textAlign: 'center' }} />
|
|
|
|
|
</Animate.fromBottom>
|
|
|
|
|
)}
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
{validInputEntered && (
|
|
|
|
|
<PageFeedback
|
|
|
|
|
customMessage={
|
|
|
|
|
<Trans i18nKey="feedback.simulator">
|
|
|
|
|
Ce simulateur vous a plu ?
|
|
|
|
|
</Trans>
|
|
|
|
|
}
|
|
|
|
|
customEventName="rate simulator"
|
|
|
|
|
/>
|
|
|
|
|
)}
|
|
|
|
|
</div>
|
2019-01-11 10:46:02 +00:00
|
|
|
|
{!location.pathname.endsWith('/simulation') && validInputEntered && (
|
2018-10-04 13:20:57 +00:00
|
|
|
|
<Animate.fromBottom>
|
|
|
|
|
<div style={{ textAlign: 'center' }}>
|
2018-11-14 15:51:37 +00:00
|
|
|
|
{arePreviousAnswers && conversationStarted && (
|
|
|
|
|
<button className="ui__ button" onClick={startConversation}>
|
|
|
|
|
<Trans>Continuer la simulation</Trans>
|
|
|
|
|
</button>
|
|
|
|
|
)}
|
2018-10-04 13:20:57 +00:00
|
|
|
|
</div>
|
|
|
|
|
<h2>
|
|
|
|
|
<Trans>A quoi servent mes cotisations ?</Trans>
|
|
|
|
|
</h2>
|
|
|
|
|
<Distribution />
|
2018-07-03 16:28:45 +00:00
|
|
|
|
|
2018-10-09 15:34:52 +00:00
|
|
|
|
{!(arePreviousAnswers && conversationStarted) && (
|
2018-10-04 13:20:57 +00:00
|
|
|
|
<>
|
|
|
|
|
<h2>
|
|
|
|
|
<Trans>Simulation personnalisée</Trans>
|
|
|
|
|
</h2>
|
|
|
|
|
<p>
|
|
|
|
|
<Trans i18nKey="custom-simulation">
|
|
|
|
|
Il s'agit pour l'instant d'une
|
|
|
|
|
<strong> première estimation</strong> sur la base d'un
|
|
|
|
|
contrat générique. La législation française prévoit une
|
|
|
|
|
multitude de cas particuliers et de règles spécifiques qui
|
2018-11-23 16:15:44 +00:00
|
|
|
|
modifient considérablement les montants de l'embauche.
|
2018-10-04 13:20:57 +00:00
|
|
|
|
</Trans>
|
|
|
|
|
</p>
|
|
|
|
|
<p style={{ textAlign: 'center' }}>
|
|
|
|
|
<button className="ui__ button" onClick={startConversation}>
|
|
|
|
|
<Trans>Faire une simulation personnalisée</Trans>
|
|
|
|
|
</button>
|
|
|
|
|
</p>
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
<h2>
|
2018-11-21 17:39:09 +00:00
|
|
|
|
<Trans>
|
|
|
|
|
{period === 'mois'
|
|
|
|
|
? 'Fiche de paie mensuelle'
|
|
|
|
|
: 'Détail annuel des cotisations'}
|
|
|
|
|
</Trans>
|
2018-10-04 13:20:57 +00:00
|
|
|
|
</h2>
|
|
|
|
|
<PaySlip />
|
|
|
|
|
</Animate.fromBottom>
|
2019-01-11 10:46:02 +00:00
|
|
|
|
)}
|
2018-11-14 15:51:37 +00:00
|
|
|
|
</>
|
|
|
|
|
)
|
|
|
|
|
}
|
2018-02-28 16:45:13 +00:00
|
|
|
|
}
|
2018-11-14 15:51:37 +00:00
|
|
|
|
)
|