2019-05-21 08:58:55 +00:00
|
|
|
import Controls from 'Components/Controls'
|
2020-03-22 22:14:51 +00:00
|
|
|
import Conversation, {
|
|
|
|
ConversationProps
|
|
|
|
} from 'Components/conversation/Conversation'
|
2019-06-06 14:33:06 +00:00
|
|
|
import SeeAnswersButton from 'Components/conversation/SeeAnswersButton'
|
2019-06-06 16:38:48 +00:00
|
|
|
import PageFeedback from 'Components/Feedback/PageFeedback'
|
2019-09-05 16:06:03 +00:00
|
|
|
import SearchButton from 'Components/SearchButton'
|
2019-05-20 15:01:47 +00:00
|
|
|
import TargetSelection from 'Components/TargetSelection'
|
2020-04-28 09:10:51 +00:00
|
|
|
import React, { useEffect } from 'react'
|
2020-01-21 18:15:23 +00:00
|
|
|
import { Trans } from 'react-i18next'
|
2020-04-28 09:10:51 +00:00
|
|
|
import { useSelector, useDispatch } from 'react-redux'
|
2020-04-23 07:30:03 +00:00
|
|
|
import { firstStepCompletedSelector } from 'Selectors/simulationSelectors'
|
|
|
|
import { useSimulationProgress } from 'Components/utils/useNextQuestion'
|
2019-06-06 14:33:06 +00:00
|
|
|
import * as Animate from 'Ui/animate'
|
|
|
|
import Progress from 'Ui/Progress'
|
2020-04-28 09:10:51 +00:00
|
|
|
import { setSimulationConfig } from 'Actions/actions'
|
|
|
|
import { useLocation } from 'react-router'
|
|
|
|
import { SimulationConfig } from 'Reducers/rootReducer'
|
2019-01-17 14:34:44 +00:00
|
|
|
|
2019-11-10 15:57:44 +00:00
|
|
|
type SimulationProps = {
|
2020-04-28 09:10:51 +00:00
|
|
|
config: SimulationConfig
|
2020-03-22 22:14:51 +00:00
|
|
|
explanations?: React.ReactNode
|
|
|
|
results?: React.ReactNode
|
2019-11-10 15:57:44 +00:00
|
|
|
customEndMessages?: ConversationProps['customEndMessages']
|
2020-03-22 22:14:51 +00:00
|
|
|
showPeriodSwitch?: boolean
|
2019-11-10 15:57:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export default function Simulation({
|
2020-04-28 09:10:51 +00:00
|
|
|
config,
|
2019-11-10 15:57:44 +00:00
|
|
|
explanations,
|
2020-03-22 22:14:51 +00:00
|
|
|
results,
|
|
|
|
customEndMessages,
|
|
|
|
showPeriodSwitch
|
2019-11-10 15:57:44 +00:00
|
|
|
}: SimulationProps) {
|
2020-04-28 09:10:51 +00:00
|
|
|
const dispatch = useDispatch()
|
|
|
|
const location = useLocation<{ fromGérer?: boolean }>()
|
|
|
|
useEffect(() => {
|
|
|
|
dispatch(setSimulationConfig(config, location.state?.fromGérer))
|
|
|
|
}, [config])
|
2019-10-08 13:16:12 +00:00
|
|
|
const firstStepCompleted = useSelector(firstStepCompletedSelector)
|
2020-04-23 07:30:03 +00:00
|
|
|
const progress = useSimulationProgress()
|
2019-05-20 15:01:47 +00:00
|
|
|
return (
|
|
|
|
<>
|
2020-03-22 22:14:51 +00:00
|
|
|
<TargetSelection showPeriodSwitch={showPeriodSwitch} />
|
2019-07-09 14:44:38 +00:00
|
|
|
<SearchButton invisibleButton />
|
2019-05-20 15:01:47 +00:00
|
|
|
{firstStepCompleted && (
|
2019-01-17 14:34:44 +00:00
|
|
|
<>
|
2019-06-06 14:33:06 +00:00
|
|
|
<Animate.fromTop>
|
2020-03-22 22:14:51 +00:00
|
|
|
{results}
|
2019-06-06 14:33:06 +00:00
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: 'flex',
|
|
|
|
justifyContent: 'space-between',
|
|
|
|
marginTop: '1.2rem',
|
|
|
|
marginBottom: '0.6rem',
|
2019-09-05 16:06:03 +00:00
|
|
|
alignItems: 'baseline'
|
2019-11-10 15:57:44 +00:00
|
|
|
}}
|
|
|
|
>
|
2019-09-05 16:06:03 +00:00
|
|
|
{progress < 1 ? (
|
|
|
|
<small css="padding: 0.4rem 0">
|
2020-01-21 18:29:43 +00:00
|
|
|
<Trans i18nKey="simulateurs.précision.défaut">
|
2019-09-05 16:06:03 +00:00
|
|
|
Affinez la simulation en répondant aux questions :
|
2020-01-21 18:15:23 +00:00
|
|
|
</Trans>
|
2019-09-05 16:06:03 +00:00
|
|
|
</small>
|
|
|
|
) : (
|
2019-11-10 15:57:44 +00:00
|
|
|
<span />
|
|
|
|
)}
|
2019-06-06 14:33:06 +00:00
|
|
|
<SeeAnswersButton />
|
|
|
|
</div>
|
2019-10-14 14:29:04 +00:00
|
|
|
<section className="ui__ full-width lighter-bg">
|
2019-06-06 14:33:06 +00:00
|
|
|
<div className="ui__ container">
|
|
|
|
<Controls />
|
|
|
|
<Conversation customEndMessages={customEndMessages} />
|
|
|
|
</div>
|
2019-10-02 16:46:05 +00:00
|
|
|
</section>
|
2019-06-06 14:33:06 +00:00
|
|
|
{progress < 1 && (
|
|
|
|
<Progress progress={progress} className="ui__ full-width" />
|
|
|
|
)}
|
2019-06-06 16:38:48 +00:00
|
|
|
<br />
|
|
|
|
<PageFeedback
|
|
|
|
customMessage={
|
2020-01-21 18:29:43 +00:00
|
|
|
<Trans i18nKey="feedback.simulator">
|
2019-06-06 16:38:48 +00:00
|
|
|
Êtes-vous satisfait de ce simulateur ?
|
2020-01-21 18:15:23 +00:00
|
|
|
</Trans>
|
2019-06-06 16:38:48 +00:00
|
|
|
}
|
|
|
|
customEventName="rate simulator"
|
|
|
|
/>{' '}
|
2019-05-21 08:58:55 +00:00
|
|
|
{explanations}
|
2019-06-06 14:33:06 +00:00
|
|
|
</Animate.fromTop>
|
2019-01-17 14:34:44 +00:00
|
|
|
</>
|
2019-05-20 15:01:47 +00:00
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)
|
2019-10-08 13:16:12 +00:00
|
|
|
}
|