feat: show recipe image on page
Some checks failed
Deploy to SFTP Server / build (push) Failing after 1m31s

This commit is contained in:
Max Richter
2025-10-22 16:24:04 +02:00
parent 24a66940e9
commit d9a2f63865
5 changed files with 27 additions and 16 deletions

View File

@@ -16,6 +16,7 @@ interface Props {
} }
async function checkImage(image: ImageMetadata) { async function checkImage(image: ImageMetadata) {
console.log("Checking image: ", image);
const src = image.src; const src = image.src;
try { try {
if (src.startsWith("/@fs") || src.startsWith("/_astro")) return true; if (src.startsWith("/@fs") || src.startsWith("/_astro")) return true;

View File

@@ -15,6 +15,8 @@ export async function generateThumbHash(
const imagePath = (image as ImageMetadata & { fsPath: string }).fsPath ?? const imagePath = (image as ImageMetadata & { fsPath: string }).fsPath ??
image.src; image.src;
if (!imagePath) return;
let sp; let sp;
if (imagePath.startsWith("https://") || imagePath.startsWith("http://")) { if (imagePath.startsWith("https://") || imagePath.startsWith("http://")) {
const res = await fetch(imagePath); const res = await fetch(imagePath);
@@ -72,6 +74,8 @@ export async function getExifData(image: ImageMetadata) {
const imagePath = (image as ImageMetadata & { fsPath: string }).fsPath ?? const imagePath = (image as ImageMetadata & { fsPath: string }).fsPath ??
image.src; image.src;
if (!imagePath) return undefined;
try { try {
let buffer: ArrayBuffer; let buffer: ArrayBuffer;
if (imagePath.startsWith("https://") || imagePath.startsWith("http://")) { if (imagePath.startsWith("https://") || imagePath.startsWith("http://")) {

View File

@@ -44,3 +44,16 @@ export async function listResource(
return; return;
} }
} }
export function getImageUrl(input: string): string {
if (!input) {
return;
}
if (input.startsWith("https://") || input.startsWith("http://")) {
return input;
}
if (input.startsWith("/")) {
return `https://marka.max-richter.dev${input}`;
}
return `https://marka.max-richter.dev/${input}`;
}

View File

@@ -4,6 +4,7 @@ import { useTranslatedPath } from "@i18n/utils";
import * as memorium from "@helpers/memorium"; import * as memorium from "@helpers/memorium";
import { resources as resourceTypes } from "../resources.ts"; import { resources as resourceTypes } from "../resources.ts";
import markdownToText from "@helpers/markdownToText"; import markdownToText from "@helpers/markdownToText";
import Image from "@components/Image.astro";
const { resourceType, resourceName } = Astro?.params; const { resourceType, resourceName } = Astro?.params;
@@ -57,9 +58,13 @@ const instructions = resource?.content?.recipeInstructions || [];
</div> </div>
</div> </div>
<h1>{resource?.content?.name}</h1> <!-- <pre>{JSON.stringify(resource, null, 2)}</pre> -->
<h1 class="text-4xl">{resource?.content?.name}</h1>
<div>
{resource?.content?.image && <Image hash src={{src: memorium.getImageUrl(resource.content.image)}} alt="Cover for {resource?.content?.name}" class="rounded-2xl overflow-hidden" pictureClass="rounded-2xl" />}
</div>
<p>{resource?.content?.description}</p> <p>{resource?.content?.description}</p>
<h2>Ingredients</h2> <h2 class="text-2xl">Ingredients</h2>
<ul> <ul>
{ {
ingredients.map((ingredient) => ( ingredients.map((ingredient) => (
@@ -68,7 +73,7 @@ const instructions = resource?.content?.recipeInstructions || [];
} }
</ul> </ul>
<h2>Steps</h2> <h2 class="text-2xl">Steps</h2>
<ol> <ol>
{ {
instructions.map((ingredient) => ( instructions.map((ingredient) => (

View File

@@ -28,18 +28,6 @@ export async function getStaticPaths() {
}); });
} }
function getImageUrl(input: string): string {
if (!input) {
return;
}
if (input.startsWith("https://") || input.startsWith("http://")) {
return input;
}
if (input.startsWith("/")) {
return `https://marka.max-richter.dev${input}`;
}
return `https://marka.max-richter.dev/${input}`;
}
--- ---
<Layout title="Max Richter"> <Layout title="Max Richter">
@@ -54,7 +42,7 @@ function getImageUrl(input: string): string {
data: { data: {
title: resource.content.name, title: resource.content.name,
cover: { cover: {
src: getImageUrl(resource.content.image), src: memorium.getImageUrl(resource.content.image),
}, },
}, },
}} }}