fix: some stuff
Some checks failed
Deploy to SFTP Server / build (push) Has been cancelled

This commit is contained in:
Max Richter
2025-10-22 12:58:18 +02:00
parent 5ba54fee6e
commit a27e9046c0
6 changed files with 39 additions and 47 deletions

View File

@@ -1,19 +1,11 @@
import { rgbaToThumbHash } from "thumbhash";
import ExifReader from 'exifreader';
import ExifReader from "exifreader";
import type { ImageMetadata } from "astro";
import sharp from "sharp";
let s: typeof import("sharp") | undefined;
async function getSharp(): Promise<typeof import("sharp") | undefined> {
if (s) return s;
s = (await import("sharp")).default;
return s;
}
export async function generateThumbHash(image: ImageMetadata & { fsPath?: string }) {
const sharp = await getSharp();
if (!sharp) return;
export async function generateThumbHash(
image: ImageMetadata & { fsPath?: string },
) {
const scaleFactor = 100 / Math.max(image.width, image.height);
const smallWidth = Math.floor(image.width * scaleFactor);
@@ -30,10 +22,9 @@ export async function generateThumbHash(image: ImageMetadata & { fsPath?: string
const buffer = rgbaToThumbHash(smallWidth, smallHeight, smallImg);
return Buffer.from(buffer).toString("base64");
} catch (error) {
console.log(`Could not generate thumbhash for ${image.fsPath}`, error)
return ""
console.log(`Could not generate thumbhash for ${image.fsPath}`, error);
return "";
}
}
const allowedExif = [
@@ -54,11 +45,8 @@ const allowedExif = [
export async function getExifData(image: ImageMetadata) {
if (image.format === "svg") return undefined; // SVGs don't have EXIF data")
const sharp = await getSharp();
if (!sharp) return;
const imagePath = (image as ImageMetadata & { fsPath: string }).fsPath;
try {
const buffer = await sharp(imagePath).toBuffer();
const tags = await ExifReader.load(buffer, { async: true });
@@ -74,9 +62,7 @@ export async function getExifData(image: ImageMetadata) {
return hasExif ? out : undefined;
} catch (error) {
console.log(`Error reading EXIF data from ${imagePath}`, error);
return undefined
return undefined;
}
}

View File

@@ -1,25 +1,26 @@
import MarkdownIt from 'markdown-it';
import MarkdownIt from "markdown-it";
const parser = new MarkdownIt();
export default function markdownToText(markdown: string): string {
export default function markdownToText(markdown: string = "<empty>"): string {
return parser
.render(markdown)
.split('\n')
.split("\n")
.map((str) => str.trim())
.map((str) => {
return str.replace(/<\/?[^>]+(>|$)/g, '').split('\n');
return str.replace(/<\/?[^>]+(>|$)/g, "").split("\n");
})
.flat()
.filter((str) => !str.startsWith("import")
&& !str.startsWith("export")
&& !str.startsWith("#")
&& !str.startsWith("const")
&& !str.startsWith("function")
&& !str.startsWith("export")
&& !str.startsWith("import")
&& !str.startsWith("&lt;")
&& !str.startsWith("let")
&& str.length > 0
.filter((str) =>
!str.startsWith("import") &&
!str.startsWith("export") &&
!str.startsWith("#") &&
!str.startsWith("const") &&
!str.startsWith("function") &&
!str.startsWith("export") &&
!str.startsWith("import") &&
!str.startsWith("&lt;") &&
!str.startsWith("let") &&
str.length > 0
)
.join(' ');
.join(" ");
}

View File

@@ -41,7 +41,6 @@ export async function listResource(
}
} catch (_e) {
console.log("Failed to get: ", url);
console.log(_e);
return;
}
}

View File

@@ -27,12 +27,12 @@ export async function getStaticPaths() {
return paths.flat().filter(Boolean);
} catch (err) {
return []
return [];
}
}
const resource = await memorium.listResource(
`/${resourceType}/${resourceName}.md`,
`${resourceType}/${resourceName}.md`,
);
---
@@ -59,7 +59,7 @@ const resource = await memorium.listResource(
<h2>Ingredients</h2>
<ul>
{
resource.content.recipeIngredient.map((ingredient) => (
resource?.content.recipeIngredient.map((ingredient) => (
<li>{markdownToText(ingredient)}</li>
))
}
@@ -68,7 +68,7 @@ const resource = await memorium.listResource(
<h2>Steps</h2>
<ol>
{
resource.content.recipeInstructions.map((ingredient) => (
resource?.content.recipeInstructions.map((ingredient) => (
<li>{markdownToText(ingredient)}</li>
))
}

View File

@@ -6,7 +6,15 @@ import { resources as resourceTypes } from "../resources.ts";
const { resourceType } = Astro.params;
const resources = await memorium.listResource(resourceType);
async function safeGetResource(resType) {
try {
return await memorium.listResource(resourceType);
} catch (error) {
return {content:[]};
}
}
const resources = await safeGetResource(resourceType);
export async function getStaticPaths() {
return resourceTypes.map((type: any) => {

View File

@@ -3,7 +3,6 @@ const collection = "resources";
type Resource = {
id: string;
collection: string;
body: string;
data: {
title: string;
icon: string;
@@ -31,9 +30,8 @@ type Resource = {
// };
const recipes = {
id: "Recipes",
id: "recipes",
collection,
body: "Recipes",
data: {
title: "Recipes",
icon: "🍲",