2018-02-28 16:45:13 +00:00
|
|
|
import React, { Component } from 'react'
|
2018-06-06 16:17:13 +00:00
|
|
|
import { connect } from 'react-redux'
|
2018-07-03 16:28:45 +00:00
|
|
|
import { animated, Spring } from 'react-spring'
|
2018-06-29 16:14:00 +00:00
|
|
|
import {
|
2018-07-03 16:28:45 +00:00
|
|
|
blockingInputControlsSelector,
|
|
|
|
noUserInputSelector
|
2018-06-29 16:14:00 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2018-03-01 18:07:40 +00:00
|
|
|
import Conversation from './conversation/Conversation'
|
2018-07-03 16:28:45 +00:00
|
|
|
import * as Animate from './inFranceApp/animate'
|
|
|
|
import Distribution from './ResultView/Distribution'
|
2018-06-18 09:54:18 +00:00
|
|
|
import './Simu.css'
|
|
|
|
import TargetSelection from './TargetSelection'
|
|
|
|
import withColours from './withColours'
|
2018-06-06 16:17:13 +00:00
|
|
|
|
2018-02-28 16:45:13 +00:00
|
|
|
@withColours
|
2018-07-03 16:28:45 +00:00
|
|
|
@connect(
|
|
|
|
state => ({
|
|
|
|
noUserInput: noUserInputSelector(state),
|
|
|
|
blockingInputControls: blockingInputControlsSelector(state),
|
|
|
|
conversationStarted: state.conversationStarted
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
onSimulationContinued: () => ({ type: 'START_CONVERSATION' })
|
|
|
|
}
|
|
|
|
)
|
2018-06-12 10:21:36 +00:00
|
|
|
export default class Simu extends Component {
|
2018-02-28 16:45:13 +00:00
|
|
|
render() {
|
2018-06-29 16:14:00 +00:00
|
|
|
let {
|
|
|
|
colours,
|
|
|
|
conversationStarted,
|
|
|
|
noUserInput,
|
2018-07-03 16:28:45 +00:00
|
|
|
onSimulationContinued,
|
2018-07-03 10:19:19 +00:00
|
|
|
blockingInputControls
|
2018-06-29 16:14:00 +00:00
|
|
|
} = this.props
|
2018-07-03 16:28:45 +00:00
|
|
|
const displayConversation = conversationStarted && !blockingInputControls
|
|
|
|
const displayResults =
|
|
|
|
!noUserInput && !blockingInputControls && !conversationStarted
|
2018-02-28 16:45:13 +00:00
|
|
|
return (
|
2018-07-03 16:28:45 +00:00
|
|
|
<>
|
|
|
|
<div id="simu">
|
|
|
|
<Spring
|
|
|
|
to={{
|
|
|
|
height: displayResults ? 'auto' : 0,
|
|
|
|
opacity: displayResults ? 1 : 0
|
|
|
|
}}
|
|
|
|
delay={2000}
|
|
|
|
native>
|
|
|
|
{styles => (
|
|
|
|
<animated.div
|
|
|
|
style={{
|
|
|
|
...styles,
|
|
|
|
display: 'flex',
|
|
|
|
overflow: 'hidden',
|
|
|
|
flexWrap: 'wrap',
|
|
|
|
fontSize: '110%',
|
|
|
|
justifyContent: 'space-between'
|
|
|
|
}}>
|
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={onSimulationContinued}>
|
|
|
|
Permanent/Fixed term contract
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={onSimulationContinued}>
|
|
|
|
Part-time
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={onSimulationContinued}>
|
|
|
|
Cadre status
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
className="ui__ link-button"
|
|
|
|
onClick={onSimulationContinued}>
|
|
|
|
Other
|
|
|
|
</button>
|
|
|
|
</animated.div>
|
|
|
|
)}
|
|
|
|
</Spring>
|
|
|
|
<div id="focusZone">
|
|
|
|
{displayConversation && (
|
2018-07-03 13:11:25 +00:00
|
|
|
<>
|
|
|
|
<Conversation textColourOnWhite={colours.textColourOnWhite} />
|
|
|
|
</>
|
|
|
|
)}
|
2018-07-03 16:28:45 +00:00
|
|
|
<TargetSelection colours={colours} />
|
|
|
|
</div>
|
2018-03-15 14:51:39 +00:00
|
|
|
</div>
|
2018-07-03 16:28:45 +00:00
|
|
|
|
|
|
|
{displayResults && (
|
|
|
|
<Animate.fromBottom>
|
|
|
|
<h2>What'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={onSimulationContinued}>
|
|
|
|
Estimate my real costs
|
|
|
|
</button>
|
|
|
|
</p>
|
|
|
|
</Animate.fromBottom>
|
|
|
|
)}
|
|
|
|
</>
|
2018-02-28 16:45:13 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|