mon-entreprise/source/components/Simu.js

135 lines
3.6 KiB
JavaScript
Raw Normal View History

2018-07-12 08:09:41 +00:00
import withColours from 'Components/utils/withColours'
import React, { Component } from 'react'
2018-07-12 08:09:41 +00:00
import { Trans } from 'react-i18next'
2018-06-06 16:17:13 +00:00
import { connect } from 'react-redux'
import { Link } from 'react-router-dom'
import { animated, Spring } from 'react-spring'
import {
blockingInputControlsSelector,
2018-07-06 16:25:59 +00:00
nextStepsSelector,
noUserInputSelector
} from 'Selectors/analyseSelectors'
2018-07-12 08:09:41 +00:00
import * as Animate from 'Ui/animate'
import Conversation from './conversation/Conversation'
2018-07-12 08:09:41 +00:00
import Distribution from './Distribution'
import PaySlip from './PaySlip'
import QuickLink from './QuickLink'
import './Simu.css'
import TargetSelection from './TargetSelection'
2018-06-06 16:17:13 +00:00
@withColours
@connect(
state => ({
noUserInput: noUserInputSelector(state),
blockingInputControls: blockingInputControlsSelector(state),
2018-07-06 16:25:59 +00:00
conversationStarted: state.conversationStarted,
nextSteps: state.conversationStarted && nextStepsSelector(state)
}),
{
startConversation: () => ({ type: 'START_CONVERSATION' })
}
)
export default class Simu extends Component {
render() {
let {
colours,
conversationStarted,
noUserInput,
2018-07-06 16:25:59 +00:00
nextSteps,
startConversation,
blockingInputControls
} = this.props
2018-07-06 16:25:59 +00:00
const firstValidInputEntered =
!conversationStarted && !blockingInputControls && !noUserInput
const displayConversation = conversationStarted && !blockingInputControls
2018-07-06 16:25:59 +00:00
const simulationCompleted =
!blockingInputControls && conversationStarted && !nextSteps.length
return (
<>
<div id="simu">
<Spring
to={{
2018-07-06 16:25:59 +00:00
height: firstValidInputEntered ? 'auto' : 0,
opacity: firstValidInputEntered ? 1 : 0
}}
native>
{styles => (
<animated.div
2018-07-12 08:09:41 +00:00
className="ui__ button-container"
style={{
...styles,
display: 'flex',
overflow: 'hidden',
flexWrap: 'wrap',
fontSize: '110%',
justifyContent: 'space-evenly'
}}>
<QuickLink />
</animated.div>
)}
</Spring>
2018-07-12 08:09:41 +00:00
{conversationStarted &&
!nextSteps.length && (
<>
<h1>No more questions left!</h1>
2018-07-12 08:09:41 +00:00
<p>
<Trans>
You have reached the most accurate estimate. You can now
turn your hiring project into reality.
2018-07-12 08:09:41 +00:00
</Trans>
</p>
<div style={{ textAlign: 'center' }}>
<Link className="ui__ button" to="/hiring-process">
See the procedures
2018-07-12 08:09:41 +00:00
</Link>
</div>
</>
)}
<div id="focusZone">
{displayConversation && (
<>
<Conversation textColourOnWhite={colours.textColourOnWhite} />
</>
)}
<TargetSelection colours={colours} />
</div>
2018-07-06 16:25:59 +00:00
{conversationStarted &&
!simulationCompleted && (
<div style={{ textAlign: 'center' }}>
<Link className="ui__ button" to="/hiring-process">
Go to the hiring process
</Link>
</div>
)}
2018-07-12 08:09:41 +00:00
{simulationCompleted && (
<Animate.fromBottom>
<h2>Detailed payslip</h2>
<PaySlip />
</Animate.fromBottom>
)}
2018-03-15 14:51:39 +00:00
</div>
2018-07-06 16:25:59 +00:00
{firstValidInputEntered && (
<Animate.fromBottom>
<h2>What&apos;s included in my contributions?</h2>
<Distribution />
<h2>Estimate my real costs</h2>
<p>
This is a <strong>rough estimate</strong> 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.
</p>
<p style={{ textAlign: 'center' }}>
<button className="ui__ button" onClick={startConversation}>
Estimate my real costs
</button>
</p>
</Animate.fromBottom>
)}
</>
)
}
}