2017-05-09 14:33:35 +00:00
|
|
|
|
2017-01-26 10:27:24 +00:00
|
|
|
// Séparation artificielle, temporaire, entre ces deux types de règles
|
|
|
|
import rawRules from './load-rules'
|
|
|
|
import R from 'ramda'
|
2017-01-23 18:06:46 +00:00
|
|
|
import possibleVariableTypes from './possibleVariableTypes.yaml'
|
2017-03-28 16:52:01 +00:00
|
|
|
import marked from './marked'
|
2017-01-26 10:27:24 +00:00
|
|
|
|
2017-09-18 07:29:26 +00:00
|
|
|
// TODO - should be in UI, not engine
|
2017-09-19 09:22:54 +00:00
|
|
|
import taux_versement_transport from '../../règles/rémunération-travail/cotisations/ok/taux.json'
|
2017-09-18 07:29:26 +00:00
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
// console.log('rawRules', rawRules.map(({espace, nom}) => espace + nom))
|
2017-01-26 10:27:24 +00:00
|
|
|
/***********************************
|
|
|
|
Méthodes agissant sur une règle */
|
|
|
|
|
2017-02-10 14:12:00 +00:00
|
|
|
// Enrichissement de la règle avec des informations évidentes pour un lecteur humain
|
2017-09-18 07:29:26 +00:00
|
|
|
export let enrichRule = (rule, sharedData = {}) => {
|
2017-01-26 10:27:24 +00:00
|
|
|
let
|
2017-05-05 17:47:54 +00:00
|
|
|
type = possibleVariableTypes.find(t => R.has(t, rule)),
|
2017-04-24 18:03:38 +00:00
|
|
|
name = rule['nom'],
|
|
|
|
ns = rule['espace'],
|
2017-09-18 07:29:26 +00:00
|
|
|
data = rule['données'] ? sharedData[rule['données']] : null,
|
2017-04-24 18:03:38 +00:00
|
|
|
dottedName = ns ? [
|
|
|
|
ns,
|
2017-03-16 18:30:30 +00:00
|
|
|
name
|
2017-04-24 18:03:38 +00:00
|
|
|
].join(' . ') : name,
|
2017-02-16 14:08:50 +00:00
|
|
|
subquestionMarkdown = rule['sous-question'],
|
|
|
|
subquestion = subquestionMarkdown && marked(subquestionMarkdown)
|
2017-01-26 10:27:24 +00:00
|
|
|
|
2017-09-18 07:29:26 +00:00
|
|
|
return {...rule, type, name, ns, data, dottedName, subquestion}
|
2017-01-26 10:27:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export let hasKnownRuleType = rule => rule && enrichRule(rule).type
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
export let
|
2017-02-10 14:12:00 +00:00
|
|
|
splitName = R.split(' . '),
|
|
|
|
joinName = R.join(' . ')
|
2017-01-26 10:27:24 +00:00
|
|
|
|
2017-01-26 12:19:04 +00:00
|
|
|
export let parentName = R.pipe(
|
|
|
|
splitName,
|
|
|
|
R.dropLast(1),
|
2017-02-10 14:12:00 +00:00
|
|
|
joinName
|
2017-01-26 12:19:04 +00:00
|
|
|
)
|
|
|
|
export let nameLeaf = R.pipe(
|
|
|
|
splitName,
|
|
|
|
R.last
|
|
|
|
)
|
2017-01-26 10:27:24 +00:00
|
|
|
|
2017-05-09 14:33:35 +00:00
|
|
|
export let encodeRuleName = name => name.replace(/\s/g, '-')
|
|
|
|
export let decodeRuleName = name => name.replace(/\-/g, ' ')
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
/* Les variables peuvent être exprimées dans la formule d'une règle relativement à son propre espace de nom, pour une plus grande lisibilité. Cette fonction résoud cette ambiguité.
|
2017-03-16 18:30:30 +00:00
|
|
|
*/
|
2017-06-27 17:53:37 +00:00
|
|
|
|
|
|
|
export let disambiguateRuleReference = (allRules, {ns, name}, partialName) => {
|
2017-03-16 18:30:30 +00:00
|
|
|
let
|
2017-06-29 10:03:01 +00:00
|
|
|
fragments = ns ? ns.split(' . ') : [], // ex. [CDD . événements . rupture]
|
2017-04-24 18:03:38 +00:00
|
|
|
pathPossibilities = // -> [ [CDD . événements . rupture], [CDD . événements], [CDD] ]
|
|
|
|
R.range(0, fragments.length + 1)
|
2017-05-18 14:04:23 +00:00
|
|
|
.map(nbEl => R.take(nbEl)(fragments))
|
2017-04-24 18:03:38 +00:00
|
|
|
.reverse(),
|
2017-03-16 18:30:30 +00:00
|
|
|
found = R.reduce((res, path) =>
|
|
|
|
R.when(
|
|
|
|
R.is(Object), R.reduced
|
2017-06-27 17:53:37 +00:00
|
|
|
)(findRuleByDottedName(allRules, [...path, partialName].join(' . ')))
|
2017-03-16 18:30:30 +00:00
|
|
|
, null, pathPossibilities)
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
return found && found.dottedName || do {throw `OUUUUPS la référence '${partialName}' dans la règle '${name}' est introuvable dans la base`}
|
2017-03-16 18:30:30 +00:00
|
|
|
}
|
|
|
|
|
2017-01-26 10:27:24 +00:00
|
|
|
// On enrichit la base de règles avec des propriétés dérivées de celles du YAML
|
2017-09-18 22:17:02 +00:00
|
|
|
export let rules = rawRules.map(rule => enrichRule(rule, {taux_versement_transport}))
|
2017-01-26 10:27:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
/****************************************
|
|
|
|
Méthodes de recherche d'une règle */
|
2016-12-07 18:08:10 +00:00
|
|
|
|
2017-06-27 17:53:37 +00:00
|
|
|
export let findRuleByName = (allRules, search) =>
|
|
|
|
allRules
|
2017-02-09 17:15:25 +00:00
|
|
|
.find( ({name}) =>
|
2017-05-05 15:28:49 +00:00
|
|
|
name.toLowerCase() === search.toLowerCase()
|
2016-12-07 18:08:10 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
export let searchRules = searchInput =>
|
|
|
|
rules
|
|
|
|
.filter( rule =>
|
|
|
|
rule && hasKnownRuleType(rule) &&
|
2017-01-26 16:30:15 +00:00
|
|
|
JSON.stringify(rule).toLowerCase().indexOf(searchInput) > -1)
|
2017-01-24 15:22:40 +00:00
|
|
|
.map(enrichRule)
|
2016-12-07 18:08:10 +00:00
|
|
|
|
2017-07-17 12:01:48 +00:00
|
|
|
export let findRuleByDottedName = (allRules, dottedName) =>
|
|
|
|
dottedName && allRules.find(rule => rule.dottedName.toLowerCase() == dottedName.toLowerCase())
|
2017-03-01 19:27:35 +00:00
|
|
|
|
|
|
|
/*********************************
|
|
|
|
Autres */
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
let isVariant = R.path(['formule', 'une possibilité'])
|