mon-entreprise/ui-react/source/RuleLink.tsx

90 lines
2.4 KiB
TypeScript
Raw Normal View History

import Engine, { utils } from 'publicodes'
import React, { useContext } from 'react'
import { Link, useLocation } from 'react-router-dom'
import {
BasepathContext,
EngineContext,
SituationMetaContext,
} from './contexts'
const { encodeRuleName } = utils
type RuleLinkProps<Name extends string> = Omit<
React.ComponentProps<Link>,
'to'
> & {
dottedName: Name
engine: Engine<Name>
documentationPath: string
displayIcon?: boolean
situationName?: string
children?: React.ReactNode
}
export function RuleLink<Name extends string>({
dottedName,
engine,
documentationPath,
situationName,
displayIcon = false,
children,
...props
}: RuleLinkProps<Name>) {
const rule = engine.getRule(dottedName)
const newPath = documentationPath + '/' + encodeRuleName(dottedName)
// There is a problem with this line of code : we loose the information
// about the applicability of the formula. Besides, when we are not in the context of the
// rules which defines the reference, we want to print a link to the parent rule and not
// the value directly.
// Besides, sometimes nodes don't have formula (which makes the doc page crash)
// Furthermore, nothing prevent from using a type notification as a reference
// For all these reason, I'm advocating for a change of perspective inside this notion of ruleWithDedicatedDocumentationPage
// if (!ruleWithDedicatedDocumentationPage(rule)) {
// return <Explanation node={engine.evaluate(rule.dottedName).formule} />
// }
if (!rule) {
throw new Error(`Unknown rule: ${dottedName}`)
}
return (
<Link
to={{
pathname: newPath,
state: {
situation: engine.parsedSituation,
situationName,
},
}}
{...props}
>
{children || rule.title}{' '}
Squashed 'publicodes/' changes from 10a30d32..a680ad31 a680ad31 :bug: Corrige un bug sur l'affichage des remplacements dans la doc publicodes 1e45d98d 🔥 Supprime la transformation d'emoji dans la doc publicodes 77973a9b :bug: Répare l'affichage des règles remplacées 341b2e39 :art::bug: corrige le style du remplacement dans les sommes 24dce683 :art: Améliore l'explication des règles avec remplacement 6d086823 :green_heart: fix lint 2d64d908 🏗Add export as Pdf button on simulators 163b766a ✅ Prettier linting in publicodes subtree e1507975 ✨ Reformat files 80161f95 🐛 Fix VAT example 79bde0be 🔥 Remove "classnames" dependency from publicodes-react 3e65e320 🔥 Remove ramda from publicodes-react 71b68707 📦 Publicodes v1.0.0-beta.16 bdc92216 Merge the tests and publish workflows 1c032ebc ✅ Add test for a value with a percentage in its unit d2865e8c Disable sum optimization inside comparisons f4faa35d Ajout d'un test qui casse l'implé actuelle des missing parentes f6105283 🖋 Document packages publication on NPM a79eeb86 Better Github workflows d0db4d09 Import publish action c268cff5 Type checking in CI a35403d7 Correction formattage 3022fd78 Add a separate cache for applicability 35095da9 Optimize the evaluation of applicability 7525446e Add a github action to run tests on push 39a12a13 Ajout d'un prettierrc / reformattage de quelques fichiers récents c296a25e Ajout d'un deuxièmes test non fonctionnel sur le sujet #33 9f5afb4e Désactivation d'un nouveau test pas encore résolu 76d00085 Récupération de la complexité initiale du test missing variations 93210235 :bug: Meilleures missingVariables des variations 369abeae Simplification du test missingVariables qui ne marche pas 64217d3d Nouveau test missing variables éval paresseuse variations d9c3e1f6 Conversion d'un gros test JS object en YAML 615ae5e5 Ajout d'un test râté pour #33 d290b46d Passage à mochapack pour webpack 5 5d7a5b31 Paquets NPM et conf babel manquants 1df9a8d4 Ajout d'un .gitignore et yarn.lock 6c2d0203 Uniformise l'unité des arrondis 2cbffe8a ⬆ MAJ Typescript vers 4.3 678403e4 Corrige le calcul des cotisations forfaitaires de début d'activité 8cdaac05 Simpler condition component (#1578) b7459617 🔥 Supprime les variables temporelles db62b57d 🔥 Supprime l'utilisation des temporals dans les mécanismes git-subtree-dir: publicodes git-subtree-split: a680ad31c33b93e4f35171488cec1b6f9e08179a
2021-11-05 14:52:37 +00:00
{displayIcon && rule.rawNode.icônes && <span>{rule.rawNode.icônes}</span>}
</Link>
)
}
export function RuleLinkWithContext(
props: Omit<RuleLinkProps<string>, 'engine' | 'documentationPath'>
) {
const engine = useContext(EngineContext)
if (!engine) {
throw new Error('an engine should be provided in context')
}
const documentationPath = useContext(BasepathContext)
const { state } = useLocation<{ situationName?: string } | undefined>()
const situationName =
useContext(SituationMetaContext)?.name ?? state?.situationName
return (
<RuleLink
engine={engine}
documentationPath={documentationPath}
situationName={situationName}
{...props}
/>
)
}