mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-24 15:49:42 +02:00
* filter unallowed fields #1140 * fix type and layout * propery validate none type quantites * fix rendering error #1237
41 lines
1.3 KiB
TypeScript
41 lines
1.3 KiB
TypeScript
import DOMPurify from "isomorphic-dompurify";
|
|
import { useFraction } from "./use-fraction";
|
|
import { RecipeIngredient } from "~/types/api-types/recipe";
|
|
const { frac } = useFraction();
|
|
|
|
function sanitizeIngredientHTML(rawHtml: string) {
|
|
return DOMPurify.sanitize(rawHtml, {
|
|
USE_PROFILES: { html: true },
|
|
ALLOWED_TAGS: ["b", "q", "i", "strong", "sup"],
|
|
});
|
|
}
|
|
|
|
export function parseIngredientText(ingredient: RecipeIngredient, disableAmount: boolean, scale = 1): string {
|
|
if (disableAmount) {
|
|
return ingredient.note || "";
|
|
}
|
|
|
|
const { quantity, food, unit, note } = ingredient;
|
|
|
|
let returnQty = "";
|
|
|
|
// casting to number is required as sometimes quantity is a string
|
|
if (quantity && Number(quantity) !== 0) {
|
|
console.log("Using Quantity", quantity, typeof quantity);
|
|
if (unit?.fraction) {
|
|
const fraction = frac(quantity * scale, 10, true);
|
|
if (fraction[0] !== undefined && fraction[0] > 0) {
|
|
returnQty += fraction[0];
|
|
}
|
|
|
|
if (fraction[1] > 0) {
|
|
returnQty += ` <sup>${fraction[1]}</sup>⁄<sub>${fraction[2]}</sub>`;
|
|
}
|
|
} else {
|
|
returnQty = (quantity * scale).toString();
|
|
}
|
|
}
|
|
|
|
const text = `${returnQty} ${unit?.name || " "} ${food?.name || " "} ${note || " "}`.replace(/ {2,}/g, " ");
|
|
return sanitizeIngredientHTML(text);
|
|
}
|