feat: initial refactor to use marka as backend

This commit is contained in:
Max Richter
2025-10-28 20:15:23 +01:00
parent 0beb3b1071
commit f680b5f832
39 changed files with 245 additions and 1012 deletions

View File

@@ -2,16 +2,18 @@ import { Handlers, PageProps } from "$fresh/server.ts";
import { MainLayout } from "@components/layouts/main.tsx";
import { HashTags } from "@components/HashTags.tsx";
import { removeImage, renderMarkdown } from "@lib/documents.ts";
import { getSeries, Series } from "@lib/resource/series.ts";
import { Series } from "@lib/resource/series.ts";
import { RedirectSearchHandler } from "@islands/Search.tsx";
import { KMenu } from "@islands/KMenu.tsx";
import PageHero from "@components/PageHero.tsx";
import { Star } from "@components/Stars.tsx";
import { MetaTags } from "@components/MetaTags.tsx";
import { parseRating } from "@lib/helpers.ts";
import { fetchResource } from "@lib/resources.ts";
export const handler: Handlers<{ serie: Series; session: unknown }> = {
async GET(_, ctx) {
const serie = await getSeries(ctx.params.name);
const serie = await fetchResource(`series/${ctx.params.name}`);
if (!serie) {
return ctx.renderNotFound();
@@ -25,24 +27,28 @@ export default function Greet(
) {
const { serie, session } = props.data;
const { author = "", date = "" } = serie.meta;
const { author = "", date = "" } = serie.content;
const content = renderMarkdown(
removeImage(serie.description || "", serie.meta.image),
removeImage(serie.description || "", serie.content.image),
);
return (
<MainLayout url={props.url} title={`Serie > ${serie.name}`} context={serie}>
<MainLayout
url={props.url}
title={`Serie > ${serie.content.name}`}
context={serie}
>
<RedirectSearchHandler />
<KMenu type="main" context={serie} />
<MetaTags resource={serie} />
<PageHero image={serie.meta.image} thumbnail={serie.meta.thumbnail}>
<PageHero image={serie.content.image} thumbnail={serie.content.thumbnail}>
<PageHero.Header>
<PageHero.BackLink href="/series" />
{session && (
<PageHero.EditLink
href={`https://notes.max-richter.dev/Media/series/${serie.id}`}
href={`https://notes.max-richter.dev/resources/series/${serie.name}`}
/>
)}
</PageHero.Header>
@@ -57,18 +63,22 @@ export default function Greet(
date.toString(),
]}
>
{serie.meta.rating && <Star rating={serie.meta.rating} />}
{serie.content.reviewRating && (
<Star
rating={parseRating(serie.content.reviewRating.ratingValue)}
/>
)}
</PageHero.Subline>
</PageHero.Footer>
</PageHero>
{serie.tags.length > 0 && (
{serie.content?.tags?.length > 0 && (
<>
<br />
<HashTags tags={serie.tags} />
<HashTags tags={serie.content.tags} />
</>
)}
<div class="px-8 text-white mt-10">
{serie?.description?.length > 80
{serie?.content?.reviewBody?.length > 80
? <h2 class="text-4xl font-bold mb-4">Review</h2>
: <></>}
<pre

View File

@@ -2,18 +2,19 @@ import { Handlers, PageProps } from "$fresh/server.ts";
import { MainLayout } from "@components/layouts/main.tsx";
import { Grid } from "@components/Grid.tsx";
import { IconArrowLeft } from "@components/icons.tsx";
import { getAllSeries, Series } from "@lib/resource/series.ts";
import { Series } from "@lib/resource/series.ts";
import { RedirectSearchHandler } from "@islands/Search.tsx";
import { KMenu } from "@islands/KMenu.tsx";
import { ResourceCard } from "@components/Card.tsx";
import { parseResourceUrl, searchResource } from "@lib/search.ts";
import { GenericResource } from "@lib/types.ts";
import { fetchResource } from "@lib/resources.ts";
import { parseResourceUrl, searchResource } from "@lib/search.ts";
export const handler: Handlers<
{ series: Series[] | null; searchResults?: GenericResource[] }
> = {
async GET(req, ctx) {
const series = await getAllSeries();
const { content: series } = await fetchResource("series");
const searchParams = parseResourceUrl(req.url);
const searchResults = searchParams &&
await searchResource({ ...searchParams, types: ["series"] });