mon-entreprise/source/components/GenericSimulation.js

77 lines
2.0 KiB
JavaScript
Raw Normal View History

import React from 'react'
import { connect } from 'react-redux'
2018-12-06 17:22:38 +00:00
import { isEmpty, compose } from 'ramda'
import Answers from 'Components/AnswerList'
import Conversation from 'Components/conversation/Conversation'
import withColours from 'Components/utils/withColours'
import Targets from 'Components/Targets'
import './GenericSimulation.css'
import {
nextStepsSelector,
analysisWithDefaultsSelector
} from 'Selectors/analyseSelectors'
import { reduxForm } from 'redux-form'
import PeriodSwitch from 'Components/PeriodSwitch'
import Controls from './Controls'
2018-12-06 17:22:38 +00:00
export default compose(
withColours,
connect(state => ({
previousAnswers: state.conversationSteps.foldedSteps,
noNextSteps: nextStepsSelector(state).length == 0,
analysis: analysisWithDefaultsSelector(state)
2018-12-06 17:22:38 +00:00
}))
)(
class extends React.Component {
2018-12-06 17:22:38 +00:00
state = {
displayAnswers: false
}
render() {
let {
colours,
noNextSteps,
previousAnswers,
analysis: { controls }
} = this.props
2018-12-06 17:22:38 +00:00
return (
<div id="GenericSimulation">
<header>
<img src="https://images.unsplash.com/photo-1488722796624-0aa6f1bb6399?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=crop&w=1350&q=80" />
<h1>Quel revenu au régime des indépendants ?</h1>
<PeriodSwitch />
2018-12-06 17:22:38 +00:00
</header>
<div className="ui__ container" id="simulationContent">
{!isEmpty(previousAnswers) && (
<button
style={{
background: colours.colour,
color: colours.textColour
}}
onClick={() => this.setState({ displayAnswers: true })}>
Mes réponses
</button>
)}
2018-12-06 17:22:38 +00:00
{this.state.displayAnswers && (
<Answers
onClose={() => this.setState({ displayAnswers: false })}
/>
)}
<Conversation
textColourOnWhite={this.props.colours.textColourOnWhite}
/>
<Controls {...{ controls }} />
2018-12-06 17:22:38 +00:00
{noNextSteps && (
<>
<h2>Plus de questions ! </h2>
<p>Vous avez atteint l'estimation la plus précise.</p>
</>
)}
<Targets />
</div>
2018-11-20 20:02:59 +00:00
</div>
2018-12-06 17:22:38 +00:00
)
}
}
2018-12-06 17:22:38 +00:00
)