80 lines
2.2 KiB
TypeScript
80 lines
2.2 KiB
TypeScript
|
import { T } from 'Components'
|
||
|
import Controls from 'Components/Controls'
|
||
|
import Conversation, {
|
||
|
ConversationProps
|
||
|
} 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 { useSelector } from 'react-redux'
|
||
|
import { firstStepCompletedSelector } from 'Selectors/analyseSelectors'
|
||
|
import { simulationProgressSelector } from 'Selectors/progressSelectors'
|
||
|
import * as Animate from 'Ui/animate'
|
||
|
import Progress from 'Ui/Progress'
|
||
|
|
||
|
type SimulationProps = {
|
||
|
explanations: React.ReactNode
|
||
|
customEndMessages?: ConversationProps['customEndMessages']
|
||
|
}
|
||
|
|
||
|
export default function Simulation({
|
||
|
explanations,
|
||
|
customEndMessages
|
||
|
}: SimulationProps) {
|
||
|
const firstStepCompleted = useSelector(firstStepCompletedSelector)
|
||
|
const progress = useSelector(simulationProgressSelector)
|
||
|
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>
|
||
|
<section className="ui__ full-width lighter-bg">
|
||
|
<div className="ui__ container">
|
||
|
<Controls />
|
||
|
<Conversation customEndMessages={customEndMessages} />
|
||
|
</div>
|
||
|
</section>
|
||
|
{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>
|
||
|
</>
|
||
|
)}
|
||
|
</>
|
||
|
)
|
||
|
}
|