2019-02-15 15:01:09 +00:00
|
|
|
/* @flow */
|
|
|
|
|
2019-02-15 10:33:07 +00:00
|
|
|
import { resetSimulation } from 'Actions/actions'
|
|
|
|
import { React, T } from 'Components'
|
|
|
|
import Answers from 'Components/AnswerList'
|
|
|
|
import Conversation from 'Components/conversation/Conversation'
|
2019-02-15 15:01:09 +00:00
|
|
|
import PageFeedback from 'Components/Feedback/PageFeedback'
|
2019-02-15 10:33:07 +00:00
|
|
|
import withColours from 'Components/utils/withColours'
|
|
|
|
import { compose } from 'ramda'
|
2019-03-25 15:51:56 +00:00
|
|
|
import emoji from 'react-easy-emoji'
|
2019-02-15 10:33:07 +00:00
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import {
|
|
|
|
nextStepsSelector,
|
2019-02-12 14:59:01 +00:00
|
|
|
noUserInputSelector
|
2019-02-15 10:33:07 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2019-01-17 14:34:44 +00:00
|
|
|
|
|
|
|
export default compose(
|
|
|
|
withColours,
|
2019-01-23 19:36:19 +00:00
|
|
|
connect(
|
|
|
|
state => ({
|
|
|
|
conversationStarted: state.conversationStarted,
|
|
|
|
previousAnswers: state.conversationSteps.foldedSteps,
|
|
|
|
noNextSteps:
|
2019-02-12 14:59:01 +00:00
|
|
|
state.conversationStarted && nextStepsSelector(state).length == 0,
|
|
|
|
noUserInput: noUserInputSelector(state)
|
2019-01-23 19:36:19 +00:00
|
|
|
}),
|
|
|
|
{ resetSimulation }
|
|
|
|
)
|
2019-01-17 14:34:44 +00:00
|
|
|
)(
|
|
|
|
class Simulation extends React.Component {
|
|
|
|
state = {
|
|
|
|
displayAnswers: false
|
|
|
|
}
|
|
|
|
render() {
|
|
|
|
let {
|
|
|
|
noNextSteps,
|
|
|
|
previousAnswers,
|
|
|
|
noUserInput,
|
|
|
|
conversationStarted,
|
2019-01-23 19:36:19 +00:00
|
|
|
resetSimulation,
|
2019-02-15 15:01:09 +00:00
|
|
|
noFeedback,
|
2019-01-21 21:38:18 +00:00
|
|
|
showTargetsAnyway,
|
2019-01-17 14:34:44 +00:00
|
|
|
targetsTriggerConversation
|
|
|
|
} = this.props
|
|
|
|
let arePreviousAnswers = previousAnswers.length > 0,
|
|
|
|
displayConversation =
|
2019-02-12 14:59:01 +00:00
|
|
|
!targetsTriggerConversation || conversationStarted,
|
2019-01-21 21:38:18 +00:00
|
|
|
showTargets =
|
|
|
|
targetsTriggerConversation || !noUserInput || showTargetsAnyway
|
2019-01-17 14:34:44 +00:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{this.state.displayAnswers && (
|
|
|
|
<Answers onClose={() => this.setState({ displayAnswers: false })} />
|
|
|
|
)}
|
2019-03-19 17:50:16 +00:00
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: 'flex',
|
|
|
|
justifyContent: 'center',
|
|
|
|
alignItems: 'baseline'
|
|
|
|
}}>
|
2019-01-24 10:10:55 +00:00
|
|
|
{arePreviousAnswers ? (
|
2019-01-23 19:36:19 +00:00
|
|
|
<button
|
2019-03-01 16:00:19 +00:00
|
|
|
style={{ marginRight: '1em' }}
|
2019-03-19 17:50:16 +00:00
|
|
|
className="ui__ small button "
|
2019-01-23 19:36:19 +00:00
|
|
|
onClick={() => this.setState({ displayAnswers: true })}>
|
2019-01-31 18:30:39 +00:00
|
|
|
<T>Voir mes réponses</T>
|
2019-01-23 19:36:19 +00:00
|
|
|
</button>
|
2019-01-24 10:10:55 +00:00
|
|
|
) : (
|
|
|
|
<span />
|
2019-01-23 19:36:19 +00:00
|
|
|
)}
|
2019-02-27 10:26:37 +00:00
|
|
|
{displayConversation && !noUserInput && (
|
2019-01-23 19:36:19 +00:00
|
|
|
<button
|
|
|
|
className="ui__ small simple skip button left"
|
|
|
|
onClick={() => resetSimulation()}>
|
|
|
|
⟲ <T>Recommencer</T>
|
|
|
|
</button>
|
|
|
|
)}
|
|
|
|
</div>
|
2019-01-17 14:34:44 +00:00
|
|
|
|
|
|
|
{displayConversation && (
|
|
|
|
<>
|
|
|
|
<Conversation
|
|
|
|
textColourOnWhite={this.props.colours.textColourOnWhite}
|
|
|
|
/>
|
|
|
|
{noNextSteps && (
|
|
|
|
<>
|
2019-03-25 15:51:56 +00:00
|
|
|
<h2>
|
|
|
|
{emoji('🌟')}{' '}
|
|
|
|
<T k="simulation-end.title">Situation complétée à 100%</T>{' '}
|
|
|
|
</h2>
|
|
|
|
<p>
|
|
|
|
<T k="simulation-end.text">
|
|
|
|
Nous n'avons plus de questions à poser, vous avez atteint
|
|
|
|
l'estimation la plus précise.
|
|
|
|
</T>
|
|
|
|
{this.props.customEndMessages}
|
|
|
|
</p>
|
2019-01-17 14:34:44 +00:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)}
|
2019-04-02 16:56:44 +00:00
|
|
|
|
2019-04-10 15:23:18 +00:00
|
|
|
{showTargets && this.props.targets}
|
2019-04-19 13:23:40 +00:00
|
|
|
{!noFeedback && (
|
2019-04-03 09:16:09 +00:00
|
|
|
<div style={{ margin: '-0.6rem' }}>
|
2019-02-15 15:01:09 +00:00
|
|
|
<PageFeedback
|
|
|
|
customMessage={
|
|
|
|
<T k="feedback.simulator">
|
|
|
|
Êtes-vous satisfait de ce simulateur ?
|
|
|
|
</T>
|
|
|
|
}
|
|
|
|
customEventName="rate simulator"
|
|
|
|
/>
|
2019-04-03 09:16:09 +00:00
|
|
|
</div>
|
2019-02-15 15:01:09 +00:00
|
|
|
)}
|
2019-04-19 13:23:40 +00:00
|
|
|
{!noUserInput && this.props.explanation}
|
2019-01-17 14:34:44 +00:00
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|