1
0
Fork 0
mirror of https://github.com/betagouv/mon-entreprise synced 2025-02-09 23:55:01 +00:00
mon-entreprise/source/engine/react.tsx
Maxime Quandalle 57bb595884
😷 Page Coronavirus et intégration du chômage partiel (#926)
Suite à la crise du coronavirus le gouvernement a élargi le dispositif
d'activité partielle et encouragé son recours massif.

Ce commit contient les modifications suivantes :

* Intégration de l'activité partielle sur le simulateur salarié ;
* Création d'une page /coronavirus incluant un simulateur spécifique pour le
  chômage partiel ainsi que des informations générale sur les dispositifs
  gouvernementaux. Référencement de cette page sur la page d'accueil et sur
  le simulateur salarié ;
* Grosse refacto du calcul de la CSG/CRDS pour y inclure le calcul des revenus
  de remplacement. Corrige aussi des erreurs pour la CSG des salariés
  bénéficiant de la DFS, et intègre l'exonération de CSG à Mayotte ;
* Légères modifications de la fenêtre « prochaines question » ;
* Affichage d'un placeholder sur les inputs des questions.

Co-authored-by: Johan Girod <johangirod@gmail.com>
2020-03-22 23:14:51 +01:00

54 lines
1.3 KiB
TypeScript

import Value from 'Components/Value'
import React, { createContext, useContext, useMemo } from 'react'
import Engine from '.'
export const EngineContext = createContext<{
engine: Engine | null
error: string | null
}>({ engine: new Engine(), error: null })
type InputProps = {
rules?: any
extra?: any
situation?: any
children: React.ReactNode
}
export function Provider({ rules, extra, situation, children }: InputProps) {
const [engine, error] = useMemo(() => {
try {
return [new Engine({ rules, extra }), null]
} catch (err) {
return [null, (err?.message ?? err.toString()) as string]
}
}, [rules, extra])
if (engine !== null && !Object.is(situation, engine.situation)) {
engine.setSituation(situation)
}
return (
<EngineContext.Provider value={{ engine, error }}>
{children}
</EngineContext.Provider>
)
}
export function useEvaluation(expression: string) {
const { engine } = useContext(EngineContext)
return engine === null ? null : engine.evaluate(expression)
}
export function useError() {
return useContext(EngineContext).error
}
export function Evaluation({ expression }) {
const value = useEvaluation(expression)
return value === null ? null : <Value {...value} />
}
export default {
Provider,
useEvaluation,
useError,
Evaluation
}