import { Handlers, PageProps } from "$fresh/server.ts"; import { MainLayout } from "@components/layouts/main.tsx"; import { KMenu } from "@islands/KMenu.tsx"; import { YoutubePlayer } from "@components/Youtube.tsx"; import { HashTags } from "@components/HashTags.tsx"; import { isYoutubeLink } from "@lib/string.ts"; import { removeImage, renderMarkdown } from "@lib/markdown.ts"; import { RedirectSearchHandler } from "@islands/Search.tsx"; import PageHero from "@components/PageHero.tsx"; import { Star } from "@components/Stars.tsx"; import { MetaTags } from "@components/MetaTags.tsx"; import { fetchResource } from "@lib/marka/index.ts"; import { ArticleResource } from "@lib/marka/schema.ts"; import { parseRating } from "@lib/helpers.ts"; export const handler: Handlers<{ article: ArticleResource; session: unknown }> = { async GET(_, ctx) { const article = await fetchResource( `articles/${ctx.params.name}.md`, ); if (!article) { return ctx.renderNotFound(); } return ctx.render({ article, session: ctx.state.session }); }, }; export default function Greet( props: PageProps< { article: ArticleResource; session: Record } >, ) { const { article, session } = props.data; const { author, datePublished, reviewRating, articleBody = "" } = article?.content || {}; const content = renderMarkdown( removeImage(articleBody, article.image?.url), ); const rating = reviewRating?.ratingValue && parseRating(reviewRating.ratingValue); return ( ${article.content.headline}`} context={article} > {session && ( )} {article.content.headline} {rating && } {article.content?.keywords?.length && ( <>
)}
{(article.content.url && isYoutubeLink(article.content.url)) && ( )}
      
); }