mon-entreprise/source/components/ComparativeSimulation.js

74 lines
2.1 KiB
JavaScript

import React from 'react'
import { connect } from 'react-redux'
import { isEmpty, compose, chain, uniqBy } from 'ramda'
import Answers from 'Components/AnswerList'
import Conversation from 'Components/conversation/Conversation'
import withColours from 'Components/utils/withColours'
import ComparativeTargets from 'Components/ComparativeTargets'
import './ComparativeSimulation.css'
import {
nextStepsSelector,
analysisWithDefaultsSelector
} from 'Selectors/analyseSelectors'
import Controls from './Controls'
import simulationConfig from './simulateur-rémunération-dirigeant.yaml'
import { createMarkdownDiv } from 'Engine/marked'
export default compose(
withColours,
connect(state => ({
previousAnswers: state.conversationSteps.foldedSteps,
noNextSteps: nextStepsSelector(state, simulationConfig).length == 0,
analyses: analysisWithDefaultsSelector(state, simulationConfig)
}))
)(
class extends React.Component {
state = {
displayAnswers: false
}
render() {
let { colours, noNextSteps, previousAnswers, analyses } = this.props
let controls = uniqBy(
({ test, dottedName }) => test + dottedName,
chain(({ controls }) => controls, analyses)
)
return (
<div id="ComparativeSimulation" className="ui__ container">
<header>{createMarkdownDiv(simulationConfig.titre)}</header>
<div id="simulationContent">
{!isEmpty(previousAnswers) && (
<button
style={{
background: colours.colour,
color: colours.textColour
}}
onClick={() => this.setState({ displayAnswers: true })}>
Mes réponses
</button>
)}
{this.state.displayAnswers && (
<Answers
onClose={() => this.setState({ displayAnswers: false })}
/>
)}
<Conversation
simulationConfig={simulationConfig}
textColourOnWhite={this.props.colours.textColourOnWhite}
/>
<Controls {...{ controls }} />
{noNextSteps && (
<>
<h2>Plus de questions ! </h2>
<p>Vous avez atteint l'estimation la plus précise.</p>
</>
)}
<ComparativeTargets />
</div>
</div>
)
}
}
)