mon-entreprise/model.js

69 lines
2.1 KiB
JavaScript
Raw Normal View History

2016-06-30 10:16:47 +00:00
import parameters from './load-parameters'
import deepAssign from 'deep-assign'
import R from 'ramda'
2016-06-30 10:16:47 +00:00
let groupedItemsByVariable = R.groupBy(R.prop('variable'))(parameters),
higherOrderVariables = R.pipe(
R.keys,
R.map(R.pipe(
R.propEq('variable'),
R.flip(R.find)(parameters)
))
)(groupedItemsByVariable),
hasHistoryProp = R.pipe(JSON.stringify, R.contains('"historique":')),
itemHasHistoricProp = (item, prop) => R.has(prop)(item) && hasHistoryProp(item[prop]),
itemIsCalculable = item =>
itemHasHistoricProp(item, 'linear') || itemHasHistoricProp(item, 'marginalRateTaxScale'),
tagsConflict = (tags1, tags2) =>
R.compose(
R.any(R.identity),
R.values,
R.mapObjIndexed((tagValue, tag) => tags2[tag] != undefined && tags2[tag] !== tagValue)
)(tags1),
mergedItemsByVariable =
R.mapObjIndexed((variableItems, name) => {
/* Les items sont des fragments de variables.
Les premiers fragments vont être fusionnés dans les suivants,
sauf s'ils provoquent l'écrasement d'un tag */
let mergedVariableItems = R.tail(variableItems) // Le premier ne peut être étendu
.reduce((mergedItems, item) =>
[ ...mergedItems,
mergedItems.reduce((final, higherLevelItem) => {
let oups = tagsConflict(higherLevelItem.tags, item.tags)
return oups ? item : deepAssign({}, item, higherLevelItem)
}, item)
], R.of(R.head(variableItems)))
return {
name,
// La variable de haut niveau, contenant la plupart du temps une description, etc.
first: R.head(variableItems),
// Tous les tags qui peuvent être trouvés dans les items de cette variable
tags: R.pipe(
R.pluck('tags'),
R.map(R.map(R.of)),
R.reduce(R.mergeWith(R.union), {})
)(variableItems),
// Gardons seulement les variables ayant une implémentation : capable de faire un calcul
calculable: R.filter(itemIsCalculable)(mergedVariableItems)
}}
)(groupedItemsByVariable)
let calculableItems =
R.pipe(
R.values,
R.pluck('calculable'),
R.unnest
)(mergedItemsByVariable),
mergedItems = R.values(mergedItemsByVariable)
export {
groupedItemsByVariable,
calculableItems,
mergedItems
}