import Input from 'Components/conversation/Input'
import Question from 'Components/conversation/Question'
import SelectGéo from 'Components/conversation/select/SelectGeo'
import SelectAtmp from 'Components/conversation/select/SelectTauxRisque'
import SendButton from 'Components/conversation/SendButton'
import CurrencyInput from 'Components/CurrencyInput/CurrencyInput'
import PercentageField from 'Components/PercentageField'
import ToggleSwitch from 'Components/ui/ToggleSwitch'
import { EngineContext } from 'Components/utils/EngineContext'
import { ParsedRules, ParsedRule } from 'Engine/types'
import React, { useContext } from 'react'
import { useTranslation } from 'react-i18next'
import { DottedName } from 'Rules'
import DateInput from '../components/conversation/DateInput'
export const binaryOptionChoices = [
{ value: 'non', label: 'Non' },
{ value: 'oui', label: 'Oui' }
]
type Value = string | number | object | boolean | null
export type RuleInputProps = {
rules: ParsedRules
dottedName: DottedName
onChange: (value: Value | null) => void
useSwitch?: boolean
isTarget?: boolean
autoFocus?: boolean
value?: Value
className?: string
onSubmit?: (value: Value) => void
}
// This function takes the unknown rule and finds which React component should
// be displayed to get a user input through successive if statements
// That's not great, but we won't invest more time until we have more diverse
// input components and a better type system.
export default function RuleInput({
rules,
dottedName,
onChange,
value,
useSwitch = false,
isTarget = false,
autoFocus = false,
className,
onSubmit
}: RuleInputProps) {
const rule = rules[dottedName]
const unit = rule.unit
const language = useTranslation().i18n.language
const engine = useContext(EngineContext)
const commonProps = {
key: dottedName,
dottedName,
value,
onChange,
onSubmit,
autoFocus,
className,
title: rule.title,
question: rule.question,
defaultValue: rule.defaultValue,
suggestions: rule.suggestions
}
if (getVariant(rule)) {
return (
)
}
if (rule.API && rule.API === 'géo')
return
if (rule.API) throw new Error("Le seul API implémenté est l'API géo")
if (rule.dottedName == 'contrat salarié . ATMP . taux collectif ATMP')
return
if (rule.type === 'date') {
return (
)
}
if (unit == null) {
return useSwitch ? (
) =>
onChange(evt.target.checked ? 'oui' : 'non')
}
/>
) : (
)
}
commonProps.value =
typeof commonProps.value === 'string'
? engine.evaluate(commonProps.value as DottedName).nodeValue
: commonProps.value
if (unit?.numerators.includes('€') && isTarget) {
return (
<>
onChange(evt.target.value)}
/>
{onSubmit && }
>
)
}
if (unit?.numerators.includes('%') && isTarget) {
return
}
return
}
const getVariant = (rule: ParsedRule) =>
rule?.formule?.explanation['possibilités']
export const buildVariantTree = (
allRules: ParsedRules,
path: Name
) => {
const rec = (path: Name) => {
const node = allRules[path]
if (!node) throw new Error(`La règle ${path} est introuvable`)
const variant = getVariant(node)
const variants = variant && node.formule.explanation['possibilités']
const canGiveUp = variant && !node.formule.explanation['choix obligatoire']
return Object.assign(
node,
variant
? {
canGiveUp,
children: variants.map((v: string) => rec(`${path} . ${v}` as Name))
}
: null
)
}
return rec(path)
}