75 lines
2.1 KiB
JavaScript
75 lines
2.1 KiB
JavaScript
import { T } from 'Components'
|
|
import Controls from 'Components/Controls'
|
|
import Conversation from 'Components/conversation/Conversation'
|
|
import SeeAnswersButton from 'Components/conversation/SeeAnswersButton'
|
|
import PageFeedback from 'Components/Feedback/PageFeedback'
|
|
import SearchButton from 'Components/SearchButton'
|
|
import TargetSelection from 'Components/TargetSelection'
|
|
import React from 'react'
|
|
import { connect } from 'react-redux'
|
|
import { firstStepCompletedSelector } from 'Selectors/analyseSelectors'
|
|
import { simulationProgressSelector } from 'Selectors/progressSelectors'
|
|
import * as Animate from 'Ui/animate'
|
|
import Progress from 'Ui/Progress'
|
|
|
|
export default connect(state => ({
|
|
firstStepCompleted: firstStepCompletedSelector(state),
|
|
progress: simulationProgressSelector(state)
|
|
}))(function Simulation({
|
|
firstStepCompleted,
|
|
explanations,
|
|
customEndMessages,
|
|
progress
|
|
}) {
|
|
return (
|
|
<>
|
|
<TargetSelection />
|
|
<SearchButton invisibleButton />
|
|
{firstStepCompleted && (
|
|
<>
|
|
<Animate.fromTop>
|
|
<div
|
|
style={{
|
|
display: 'flex',
|
|
justifyContent: 'space-between',
|
|
marginTop: '1.2rem',
|
|
marginBottom: '0.6rem',
|
|
alignItems: 'baseline'
|
|
}}>
|
|
{progress < 1 ? (
|
|
<small css="padding: 0.4rem 0">
|
|
<T k="simulateurs.précision.défaut">
|
|
Affinez la simulation en répondant aux questions :
|
|
</T>
|
|
</small>
|
|
) : (
|
|
<span />
|
|
)}
|
|
<SeeAnswersButton />
|
|
</div>
|
|
<div className="ui__ full-width choice-group">
|
|
<div className="ui__ container">
|
|
<Controls />
|
|
<Conversation customEndMessages={customEndMessages} />
|
|
</div>
|
|
</div>
|
|
{progress < 1 && (
|
|
<Progress progress={progress} className="ui__ full-width" />
|
|
)}
|
|
<br />
|
|
<PageFeedback
|
|
customMessage={
|
|
<T k="feedback.simulator">
|
|
Êtes-vous satisfait de ce simulateur ?
|
|
</T>
|
|
}
|
|
customEventName="rate simulator"
|
|
/>{' '}
|
|
{explanations}
|
|
</Animate.fromTop>
|
|
</>
|
|
)}
|
|
</>
|
|
)
|
|
})
|