82 lines
2.5 KiB
JavaScript
82 lines
2.5 KiB
JavaScript
|
import Input from 'Components/conversation/Input'
|
||
|
import Question from 'Components/conversation/Question'
|
||
|
import SelectGéo from 'Components/conversation/select/SelectGéo'
|
||
|
import SelectAtmp from 'Components/conversation/select/SelectTauxRisque'
|
||
|
import { is, pick, prop, unless } from 'ramda'
|
||
|
import React from 'react'
|
||
|
import DateInput from '../components/conversation/DateInput'
|
||
|
import { findRuleByDottedName, queryRule } from './rules'
|
||
|
|
||
|
export const binaryOptionChoices = [
|
||
|
{ value: 'non', label: 'Non' },
|
||
|
{ value: 'oui', label: 'Oui' }
|
||
|
]
|
||
|
// 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.
|
||
|
|
||
|
// eslint-disable-next-line react/display-name
|
||
|
export default ({ rules, dottedName, onChange, value }) => {
|
||
|
let rule = findRuleByDottedName(rules, dottedName)
|
||
|
|
||
|
let commonProps = {
|
||
|
key: dottedName,
|
||
|
fieldName: dottedName,
|
||
|
value,
|
||
|
onChange,
|
||
|
...pick(
|
||
|
['dottedName', 'title', 'question', 'defaultValue', 'suggestions'],
|
||
|
rule
|
||
|
)
|
||
|
}
|
||
|
|
||
|
if (getVariant(rule)) {
|
||
|
return (
|
||
|
<Question
|
||
|
{...commonProps}
|
||
|
choices={buildVariantTree(rules, dottedName)}
|
||
|
/>
|
||
|
)
|
||
|
}
|
||
|
if (rule.API && rule.API === 'géo')
|
||
|
return <SelectGéo {...{ ...commonProps }} />
|
||
|
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 <SelectAtmp {...commonProps} />
|
||
|
|
||
|
if (rule.type === 'date') {
|
||
|
return <DateInput {...commonProps} />
|
||
|
}
|
||
|
|
||
|
if (rule.unit == null && rule.defaultUnit == null)
|
||
|
return <Question {...commonProps} choices={binaryOptionChoices} />
|
||
|
|
||
|
// Now the numeric input case
|
||
|
|
||
|
return <Input {...commonProps} unit={rule.unit || rule.defaultUnit} />
|
||
|
}
|
||
|
|
||
|
let getVariant = rule => queryRule(rule)('formule . une possibilité')
|
||
|
|
||
|
export let buildVariantTree = (allRules, path) => {
|
||
|
let rec = path => {
|
||
|
let node = findRuleByDottedName(allRules, path)
|
||
|
if (!node) throw new Error(`La règle ${path} est introuvable`)
|
||
|
let variant = getVariant(node),
|
||
|
variants = variant && unless(is(Array), prop('possibilités'))(variant),
|
||
|
shouldBeExpanded = variant && true, //variants.find( v => relevantPaths.find(rp => contains(path + ' . ' + v)(rp) )),
|
||
|
canGiveUp = variant && !variant['choix obligatoire']
|
||
|
|
||
|
return Object.assign(
|
||
|
node,
|
||
|
shouldBeExpanded
|
||
|
? {
|
||
|
canGiveUp,
|
||
|
children: variants.map(v => rec(path + ' . ' + v))
|
||
|
}
|
||
|
: null
|
||
|
)
|
||
|
}
|
||
|
return rec(path)
|
||
|
}
|