Refactored computation into folders

This commit is contained in:
Stefan Zermatten
2021-02-04 13:33:20 +02:00
parent 87fa941f63
commit 326d1bd165
41 changed files with 115 additions and 67 deletions

View File

@@ -0,0 +1,50 @@
import { forOwn, has } from 'lodash';
export default function computeLevels(memo){
computeClassLevels(memo);
computeTotalLevel(memo);
}
function computeClassLevels(memo){
forOwn(memo.classLevelsById, classLevel => {
// class levels are mutually dependent
classLevel.dependencies.push(Object.keys(memo.classLevelsById));
let name = classLevel.variableName;
let stat = memo.statsByVariableName[name];
if (!stat){
memo.statsByVariableName[name] = classLevel;
memo.classes[name] = classLevel;
} else if (!has(stat, 'level')){
// Stat is overriden by an attribute
return;
} else if (stat.level < classLevel.level) {
memo.statsByVariableName[name] = classLevel;
memo.classes[name] = classLevel;
}
});
}
function computeTotalLevel(memo){
let currentLevel = memo.statsByVariableName['level'];
if (!currentLevel){
currentLevel = {
value: 0,
dependencies: [],
computationDetails: {
builtIn: true,
computed: true,
}
};
memo.statsByVariableName['level'] = currentLevel;
}
// bail out if overriden by an attribute
if (!currentLevel.computationDetails.builtIn) return;
let level = 0;
for (let name in memo.classes){
let cls = memo.classes[name];
level += cls.level || 0;
if (cls._id) currentLevel.dependencies.push(cls._id);
if (cls.dependencies) currentLevel.dependencies.push(...cls.dependencies);
}
currentLevel.value = level;
}