mon-entreprise/source/components/Simulation.tsx

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>
</>
)}
</>
)
}