mon-entreprise/source/engine/units.js

52 lines
1.3 KiB
JavaScript

import { remove, isEmpty } from 'ramda'
export let parseUnit = string => {
let [a, b = ''] = string.split('/')
return {
numerators: a !== '' ? [a] : [],
denominators: b !== '' ? [b] : []
}
}
export let serializeUnit = ({ numerators, denominators }) => {
let n = !isEmpty(numerators)
let d = !isEmpty(denominators)
return n && !d
? numerators
: !n && d
? `/${denominators}`
: `${numerators} / ${denominators}`
}
let noUnit = { numerators: [], denominators: [] }
export let inferUnit = (operator, unit1 = noUnit, unit2 = noUnit) =>
operator === '*'
? simplify({
numerators: [...unit1.numerators, ...unit2.numerators],
denominators: [...unit1.denominators, ...unit2.denominators]
})
: operator === '/'
? inferUnit('*', unit1, {
numerators: unit2.denominators,
denominators: unit2.numerators
})
: null
export let removeOnce = element => list => {
let index = list.indexOf(element)
if (index > -1) return remove(index, 1)(list)
else return list
}
let simplify = unit =>
[...unit.numerators, ...unit.denominators].reduce(
({ numerators, denominators }, next) =>
numerators.includes(next) && denominators.includes(next)
? {
numerators: removeOnce(next)(numerators),
denominators: removeOnce(next)(denominators)
}
: { numerators, denominators },
unit
)