mon-entreprise/source/components/Controls.tsx

86 lines
2.5 KiB
TypeScript
Raw Normal View History

import { goToQuestion, hideControl } from 'Actions/actions'
import { useControls, useInversionFail } from 'Components/utils/EngineContext'
import { makeJsx } from 'Engine/evaluation'
import React from 'react'
import emoji from 'react-easy-emoji'
import { useTranslation } from 'react-i18next'
import { useDispatch, useSelector } from 'react-redux'
import { RootState } from 'Reducers/rootReducer'
2019-04-03 09:16:09 +00:00
import animate from 'Ui/animate'
import './Controls.css'
import { Markdown } from './utils/markdown'
import { ScrollToElement } from './utils/Scroll'
import { answeredQuestionsSelector } from 'Selectors/simulationSelectors'
export default function Controls() {
const { t } = useTranslation()
const answeredQuestions = useSelector(answeredQuestionsSelector)
const controls = useControls()
const inversionFail = useInversionFail()
const hiddenControls = useSelector(
(state: RootState) => state.simulation?.hiddenControls
)
const dispatch = useDispatch()
if (!controls) {
return null
}
const messages = inversionFail
? [
{
message: t([
'simulateurs.inversionFail',
'Le montant saisi ne permet pas de calculer un résultat, nous vous invitons à essayer une autre valeur.'
]),
level: 'avertissement'
}
]
: controls
if (!messages?.length) return null
return (
2018-09-11 15:33:11 +00:00
<div id="controlsBlock">
2019-04-03 09:16:09 +00:00
<ul style={{ margin: 0, padding: 0 }}>
{messages.map(({ level, test, message, solution, evaluated }) =>
hiddenControls?.includes(test) ? null : (
<animate.fromTop key={message}>
<li key={test}>
<div className="control">
{emoji(level == 'avertissement' ? '⚠️' : '')}
<div className="controlText ui__ card">
{message ? (
<Markdown source={message} />
) : (
<span id="controlExplanation">{makeJsx(evaluated)}</span>
)}
{solution && !answeredQuestions?.includes(solution.cible) && (
<div>
<button
key={solution.cible}
className="ui__ link-button"
onClick={() => dispatch(goToQuestion(solution.cible))}
>
{solution.texte}
</button>
</div>
)}
<button
className="hide"
aria-label="close"
onClick={() => dispatch(hideControl(test))}
>
×
</button>
</div>
2019-04-03 09:16:09 +00:00
</div>
</li>
<ScrollToElement />
</animate.fromTop>
)
)}
</ul>
</div>
)
}