2017-07-13 10:25:46 +00:00
|
|
|
import R from 'ramda'
|
|
|
|
|
2017-07-13 19:55:59 +00:00
|
|
|
export let makeJsx = (node) =>
|
|
|
|
typeof(node.jsx) == "function" ? node.jsx(node.nodeValue, node.explanation) : node.jsx
|
|
|
|
|
2017-07-13 10:25:46 +00:00
|
|
|
export let collectNodeMissing = (node) =>
|
|
|
|
node.collectMissing ? node.collectMissing(node) : []
|
|
|
|
|
|
|
|
export let evaluateNode = (situationGate, parsedRules, node) =>
|
|
|
|
node.evaluate ? node.evaluate(situationGate, parsedRules, node) : node
|
|
|
|
|
|
|
|
export let rewriteNode = (node, nodeValue, explanation, collectMissing) =>
|
|
|
|
({
|
|
|
|
...node,
|
|
|
|
nodeValue,
|
|
|
|
collectMissing,
|
2017-07-13 19:55:59 +00:00
|
|
|
explanation
|
2017-07-13 10:25:46 +00:00
|
|
|
})
|
|
|
|
|
2017-07-14 11:33:37 +00:00
|
|
|
export let evaluateArray = (reducer, start, nullable = true) => (situationGate, parsedRules, node) => {
|
2017-07-13 10:25:46 +00:00
|
|
|
let evaluateOne = child => evaluateNode(situationGate, parsedRules, child),
|
|
|
|
explanation = R.map(evaluateOne, node.explanation),
|
|
|
|
values = R.pluck("nodeValue",explanation),
|
2017-07-14 11:33:37 +00:00
|
|
|
nodeValue = (nullable && R.any(R.equals(null),values)) ? null : R.reduce(reducer, start, values)
|
2017-07-13 10:25:46 +00:00
|
|
|
|
|
|
|
let collectMissing = node => R.chain(collectNodeMissing,node.explanation)
|
2017-07-13 19:55:59 +00:00
|
|
|
return rewriteNode(node,nodeValue,explanation,collectMissing)
|
2017-07-13 10:25:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export let parseObject = (recurse, objectShape, value) => {
|
|
|
|
let recurseOne = key => defaultValue => {
|
|
|
|
if (!value[key] && ! defaultValue) throw "Il manque une valeur '"+key+"'"
|
|
|
|
return value[key] ? recurse(value[key]) : defaultValue
|
|
|
|
}
|
|
|
|
let transforms = R.fromPairs(R.map(k => [k,recurseOne(k)],R.keys(objectShape)))
|
|
|
|
return R.evolve(transforms,objectShape)
|
|
|
|
}
|
|
|
|
|
|
|
|
export let evaluateObject = (objectShape, effect) => (situationGate, parsedRules, node) => {
|
|
|
|
let evaluateOne = child => evaluateNode(situationGate, parsedRules, child),
|
|
|
|
collectMissing = node => R.chain(collectNodeMissing,R.values(node.explanation))
|
|
|
|
|
|
|
|
let transforms = R.map(k => [k,evaluateOne], R.keys(objectShape)),
|
|
|
|
explanation = R.evolve(R.fromPairs(transforms))(node.explanation),
|
|
|
|
nodeValue = effect(explanation)
|
2017-07-13 19:55:59 +00:00
|
|
|
return rewriteNode(node,nodeValue,explanation,collectMissing)
|
2017-07-13 10:25:46 +00:00
|
|
|
}
|