2018-01-08 15:07:26 +00:00
|
|
|
import { isEmpty, dropLast, last } from 'ramda'
|
2018-01-03 15:54:19 +00:00
|
|
|
import { splitName, joinName } from './rules'
|
2017-03-16 18:30:30 +00:00
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
let evaluateBottomUp = situationGate => startingFragments => {
|
2018-01-03 15:54:19 +00:00
|
|
|
let rec = (parentFragments, childFragments = []) =>
|
|
|
|
parentFragments.length == 0
|
|
|
|
? null
|
|
|
|
: do {
|
|
|
|
let query = joinName(parentFragments),
|
2018-01-08 15:07:26 +00:00
|
|
|
expectedResult = isEmpty(childFragments)
|
2018-01-03 15:54:19 +00:00
|
|
|
? 'oui'
|
|
|
|
: joinName(childFragments)
|
2017-04-24 18:03:38 +00:00
|
|
|
|
2018-01-03 15:54:19 +00:00
|
|
|
situationGate(query) == null
|
2018-01-08 15:07:26 +00:00
|
|
|
? rec(dropLast(1)(parentFragments), [
|
|
|
|
last(parentFragments),
|
2018-01-03 15:54:19 +00:00
|
|
|
...childFragments
|
2018-05-22 17:12:13 +00:00
|
|
|
])
|
2018-01-03 15:54:19 +00:00
|
|
|
: situationGate(query) == expectedResult
|
2018-05-22 17:12:13 +00:00
|
|
|
}
|
2017-04-24 18:03:38 +00:00
|
|
|
return rec(startingFragments)
|
|
|
|
}
|
|
|
|
|
2017-05-10 14:09:36 +00:00
|
|
|
/* Evalue la valeur d'une variable
|
|
|
|
en utilisant la fonction situationGate qui donne accès à la situation courante*/
|
|
|
|
export let evaluateVariable = (situationGate, variableName, rule) => {
|
2017-04-24 18:03:38 +00:00
|
|
|
// test rec
|
2017-03-16 18:30:30 +00:00
|
|
|
let value = situationGate(variableName)
|
2017-05-10 14:09:36 +00:00
|
|
|
|
2018-01-03 15:54:19 +00:00
|
|
|
return rule.format != null
|
|
|
|
? value
|
|
|
|
: !rule.formule
|
|
|
|
? // c'est une variante, eg. motifs . classique . accroissement d'activité
|
2018-05-22 17:12:13 +00:00
|
|
|
evaluateBottomUp(situationGate)(splitName(variableName))
|
2018-01-03 15:54:19 +00:00
|
|
|
: rule.formule['une possibilité']
|
|
|
|
? evaluateBottomUp(situationGate)(splitName(variableName))
|
2017-05-10 14:09:36 +00:00
|
|
|
: value
|
2017-03-16 18:30:30 +00:00
|
|
|
}
|