/* @flow */ import { resetSimulation } from 'Actions/actions' import { React, T } from 'Components' import Answers from 'Components/AnswerList' import Conversation from 'Components/conversation/Conversation' import PageFeedback from 'Components/Feedback/PageFeedback' import PeriodSwitch from 'Components/PeriodSwitch' import withColours from 'Components/utils/withColours' import { compose } from 'ramda' import { connect } from 'react-redux' import { blockingInputControlsSelector, nextStepsSelector, noUserInputSelector, validInputEnteredSelector } from 'Selectors/analyseSelectors' import Animate from 'Ui/animate' export default compose( withColours, connect( state => ({ conversationStarted: state.conversationStarted, previousAnswers: state.conversationSteps.foldedSteps, noNextSteps: state.conversationStarted && !blockingInputControlsSelector(state) && nextStepsSelector(state).length == 0, noUserInput: noUserInputSelector(state), blockingInputControls: blockingInputControlsSelector(state), validInputEntered: validInputEnteredSelector(state) }), { resetSimulation } ) )( class Simulation extends React.Component { state = { displayAnswers: false } render() { let { noNextSteps, previousAnswers, noUserInput, conversationStarted, resetSimulation, noFeedback, blockingInputControls, showTargetsAnyway, targetsTriggerConversation } = this.props let arePreviousAnswers = previousAnswers.length > 0, displayConversation = (!targetsTriggerConversation || conversationStarted) && !blockingInputControls, showTargets = targetsTriggerConversation || !noUserInput || showTargetsAnyway return ( <> {this.state.displayAnswers && ( this.setState({ displayAnswers: false })} /> )}
{arePreviousAnswers ? ( ) : ( )} {displayConversation && ( )}
{displayConversation && ( <> {noNextSteps && ( <>

Plus de questions !

Vous avez atteint l'estimation la plus précise. {this.props.customEndMessages} )} )} {showTargets && ( {this.props.targets} )} {!noUserInput && !noFeedback && ( Êtes-vous satisfait de ce simulateur ? } customEventName="rate simulator" /> )} {!noUserInput && this.props.explanation} ) } } )