Files
recipe-app/backend/dist/common/utils/units.js
T
Nils-Johan Gynther 969dafdbc6
Test Suite / test (24.15.0) (push) Has been cancelled
Refactor code structure for improved readability and maintainability
2026-05-06 07:37:59 +02:00

78 lines
3.8 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.UNIT_DEFINITIONS = void 0;
exports.normalizeUnit = normalizeUnit;
exports.getUnitDefinition = getUnitDefinition;
exports.getUnitType = getUnitType;
exports.canConvert = canConvert;
exports.convertUnit = convertUnit;
exports.UNIT_DEFINITIONS = [
{ value: 'g', labelSv: 'g (gram)', type: 'weight', toBaseFactor: 1, aliases: ['gram'] },
{ value: 'hg', labelSv: 'hg (hektogram)', type: 'weight', toBaseFactor: 100, aliases: ['hektogram'] },
{ value: 'kg', labelSv: 'kg (kilogram)', type: 'weight', toBaseFactor: 1000, aliases: ['kilo', 'kilogram'] },
{ value: 'mg', labelSv: 'mg (milligram)', type: 'weight', toBaseFactor: 0.001, aliases: ['milligram'] },
{ value: 'ml', labelSv: 'ml (milliliter)', type: 'volume', toBaseFactor: 1, aliases: ['milliliter'] },
{ value: 'cl', labelSv: 'cl (centiliter)', type: 'volume', toBaseFactor: 10, aliases: ['centiliter'] },
{ value: 'dl', labelSv: 'dl (deciliter)', type: 'volume', toBaseFactor: 100, aliases: ['deciliter'] },
{ value: 'l', labelSv: 'l (liter)', type: 'volume', toBaseFactor: 1000, aliases: ['liter'] },
{ value: 'krm', labelSv: 'krm (kryddmått)', type: 'cooking', toBaseFactor: 1, aliases: ['kryddmatt', 'kryddmått'] },
{ value: 'tsk', labelSv: 'tsk (tesked)', type: 'cooking', toBaseFactor: 5, aliases: ['tesked', 'test'] },
{ value: 'msk', labelSv: 'msk (matsked)', type: 'cooking', toBaseFactor: 15, aliases: ['matsked', 'matsled'] },
{ value: 'st', labelSv: 'st (styck)', type: 'piece', toBaseFactor: 1, aliases: ['stycke', 'styck', 'stk'] },
{ value: 'port', labelSv: 'port (portioner)', type: 'piece', toBaseFactor: 1, aliases: ['portion', 'portioner'] },
{ value: 'förp', labelSv: 'förp (förpackning)', type: 'piece', toBaseFactor: 1, aliases: ['forp', 'förpackning', 'forpackning'] },
{ value: 'klyfta', labelSv: 'klyfta', type: 'piece', toBaseFactor: 1, aliases: [] },
{ value: 'efter smak', labelSv: 'efter smak', type: 'other', toBaseFactor: 1, aliases: ['eftr smak', 'efter smak'] },
];
const _unitLookup = new Map();
for (const def of exports.UNIT_DEFINITIONS) {
_unitLookup.set(def.value.toLowerCase(), def);
for (const alias of def.aliases) {
_unitLookup.set(alias.toLowerCase(), def);
}
}
function normalizeUnit(unit) {
const key = unit.trim().toLowerCase();
return _unitLookup.get(key)?.value ?? key;
}
function getUnitDefinition(unit) {
const key = unit.trim().toLowerCase();
return _unitLookup.get(key);
}
function getUnitType(unit) {
return getUnitDefinition(unit)?.type ?? null;
}
function canConvert(fromUnit, toUnit) {
const from = getUnitDefinition(fromUnit);
const to = getUnitDefinition(toUnit);
if (!from || !to)
return false;
if (from.type !== to.type)
return false;
if (from.type === 'piece' || from.type === 'other')
return false;
return true;
}
function convertUnit(quantity, fromUnit, toUnit) {
if (quantity <= 0) {
throw new Error(`Invalid quantity: ${quantity}. Quantity must be positive.`);
}
const normalizedFrom = normalizeUnit(fromUnit);
const normalizedTo = normalizeUnit(toUnit);
if (normalizedFrom === normalizedTo)
return quantity;
const fromDef = getUnitDefinition(normalizedFrom);
const toDef = getUnitDefinition(normalizedTo);
if (!fromDef)
throw new Error(`Unknown unit: "${fromUnit}"`);
if (!toDef)
throw new Error(`Unknown unit: "${toUnit}"`);
if (fromDef.type !== toDef.type) {
throw new Error(`Cannot convert between incompatible unit types: "${fromUnit}" (${fromDef.type}) and "${toUnit}" (${toDef.type})`);
}
if (fromDef.type === 'piece' || fromDef.type === 'other') {
return quantity;
}
return (quantity * fromDef.toBaseFactor) / toDef.toBaseFactor;
}
//# sourceMappingURL=units.js.map