2019-07-29 07:13:05 +00:00
|
|
|
import { bonus, evaluateNode, mergeMissing } from 'Engine/evaluation'
|
2019-11-04 10:03:01 +00:00
|
|
|
import { map, mergeAll, pick, pipe } from 'ramda'
|
2019-06-13 16:01:49 +00:00
|
|
|
import { anyNull, undefOrTrue, val } from './traverse-common-functions'
|
|
|
|
|
2019-11-04 10:03:01 +00:00
|
|
|
export const evaluateApplicability = (cache, situationGate, parsedRules, node) => {
|
2019-06-13 16:01:49 +00:00
|
|
|
let evaluatedAttributes = pipe(
|
2019-11-04 10:03:01 +00:00
|
|
|
pick([
|
|
|
|
'parentDependency',
|
|
|
|
'non applicable si',
|
|
|
|
'applicable si',
|
|
|
|
'rendu non applicable'
|
|
|
|
]),
|
|
|
|
map(value => evaluateNode(cache, situationGate, parsedRules, value))
|
|
|
|
)(node),
|
2019-06-13 16:01:49 +00:00
|
|
|
{
|
|
|
|
parentDependency,
|
|
|
|
'non applicable si': notApplicable,
|
2019-07-29 07:13:05 +00:00
|
|
|
'applicable si': applicable,
|
2019-08-19 07:36:27 +00:00
|
|
|
'rendu non applicable': disabled
|
2019-06-13 16:01:49 +00:00
|
|
|
} = evaluatedAttributes,
|
|
|
|
isApplicable =
|
2019-07-29 07:13:05 +00:00
|
|
|
val(parentDependency) === false ||
|
2019-11-04 10:03:01 +00:00
|
|
|
val(notApplicable) === true ||
|
|
|
|
val(applicable) === false ||
|
|
|
|
val(disabled) === true
|
2019-06-13 16:01:49 +00:00
|
|
|
? false
|
|
|
|
: anyNull([notApplicable, applicable, parentDependency])
|
2019-11-04 10:03:01 +00:00
|
|
|
? null
|
|
|
|
: !val(notApplicable) && undefOrTrue(val(applicable)),
|
|
|
|
missingVariables =
|
|
|
|
isApplicable === false
|
|
|
|
? {}
|
|
|
|
: mergeAll([
|
|
|
|
parentDependency ?.missingVariables || {},
|
|
|
|
notApplicable ?.missingVariables || {},
|
|
|
|
applicable ?.missingVariables || {}
|
|
|
|
])
|
|
|
|
// On veut abaisser le score des conséquences par rapport aux conditions,
|
|
|
|
// mais seulement dans le cas où une condition est effectivement présente
|
|
|
|
return { nodeValue: isApplicable, missingVariables, ...evaluatedAttributes, inactiveParent: parentDependency && val(parentDependency) == false }
|
|
|
|
}
|
|
|
|
export default (cache, situationGate, parsedRules, node) => {
|
|
|
|
cache.parseLevel++
|
|
|
|
let
|
|
|
|
applicabilityEvaluation = evaluateApplicability(cache, situationGate, parsedRules, node),
|
|
|
|
{ missingVariables: condMissing, nodeValue: isApplicable } = applicabilityEvaluation,
|
2019-06-13 16:01:49 +00:00
|
|
|
evaluateFormula = () =>
|
|
|
|
node.formule
|
|
|
|
? evaluateNode(cache, situationGate, parsedRules, node.formule)
|
|
|
|
: {},
|
|
|
|
// evaluate the formula lazily, only if the applicability is known and true
|
|
|
|
evaluatedFormula =
|
2019-11-04 10:03:01 +00:00
|
|
|
isApplicable
|
2019-06-13 16:01:49 +00:00
|
|
|
? evaluateFormula()
|
|
|
|
: isApplicable === false
|
2019-11-04 10:03:01 +00:00
|
|
|
? {
|
2019-06-13 16:01:49 +00:00
|
|
|
...node.formule,
|
|
|
|
missingVariables: {},
|
|
|
|
nodeValue: 0
|
2019-11-04 10:03:01 +00:00
|
|
|
}
|
|
|
|
: {
|
2019-06-13 16:01:49 +00:00
|
|
|
...node.formule,
|
|
|
|
missingVariables: {},
|
|
|
|
nodeValue: null
|
2019-11-04 10:03:01 +00:00
|
|
|
},
|
|
|
|
{ missingVariables: formulaMissingVariables, nodeValue } = evaluatedFormula,
|
2019-06-13 16:01:49 +00:00
|
|
|
|
|
|
|
missingVariables = mergeMissing(
|
2019-11-04 10:03:01 +00:00
|
|
|
bonus(condMissing, !!Object.keys(condMissing).length),
|
2019-06-13 16:01:49 +00:00
|
|
|
formulaMissingVariables
|
|
|
|
)
|
|
|
|
cache.parseLevel--
|
2019-11-04 10:03:01 +00:00
|
|
|
|
2019-06-13 16:01:49 +00:00
|
|
|
return {
|
|
|
|
...node,
|
2019-11-04 10:03:01 +00:00
|
|
|
...applicabilityEvaluation,
|
2019-06-13 16:01:49 +00:00
|
|
|
...{ formule: evaluatedFormula },
|
|
|
|
nodeValue,
|
|
|
|
isApplicable,
|
|
|
|
missingVariables,
|
2019-11-04 10:03:01 +00:00
|
|
|
|
2019-06-13 16:01:49 +00:00
|
|
|
}
|
|
|
|
}
|