import { startConversation } from 'Actions/actions' import ScrollToTop from 'Components/utils/ScrollToTop' import withColours from 'Components/utils/withColours' import React, { Component } from 'react' import { Trans } from 'react-i18next' import { connect } from 'react-redux' import { Link } from 'react-router-dom' import { animated, Spring } from 'react-spring' import { blockingInputControlsSelector, nextStepsSelector, noUserInputSelector } from 'Selectors/analyseSelectors' import * as Animate from 'Ui/animate' import AnswerList from './AnswerList' import Conversation from './conversation/Conversation' import Distribution from './Distribution' import PaySlip from './PaySlip' import QuickLink from './QuickLink' import './Simu.css' import TargetSelection from './TargetSelection' @withColours @connect( state => ({ noUserInput: noUserInputSelector(state), blockingInputControls: blockingInputControlsSelector(state), conversationStarted: state.conversationStarted, arePreviousAnswers: state.conversationSteps.foldedSteps.length !== 0, nextSteps: state.conversationStarted && nextStepsSelector(state) }), { startConversation } ) export default class Simu extends Component { state = { displayPreviousAnswers: false } render() { let { colours, conversationStarted, noUserInput, arePreviousAnswers, nextSteps, startConversation, blockingInputControls } = this.props const firstValidInputEntered = !conversationStarted && !blockingInputControls && !noUserInput const displayConversation = conversationStarted && !blockingInputControls const simulationCompleted = !blockingInputControls && conversationStarted && !nextSteps.length const displayPreviousAnswers = arePreviousAnswers && this.state.displayPreviousAnswers return ( <>
{arePreviousAnswers && (
)} {styles => ( )} {simulationCompleted && ( <>

No more questions left!

You have reached the most accurate estimate. You can now turn your hiring project into reality.

See the procedures
)}
{displayConversation && ( <> )}
{conversationStarted && (

Payslip

)} {displayPreviousAnswers && ( this.setState({ displayPreviousAnswers: false })} /> )}
{firstValidInputEntered && (

What's included in my contributions?

Estimate my real costs

This is a rough estimate based on a pre-made generic contract. French legislation provides for a multitude of special cases, and specific rules that can considerably change hiring costs.

)} ) } }