52 lines
1.3 KiB
JavaScript
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
|
|
)
|