import type { Project, Diary } from "./types"; import asciidoctor from "asciidoctor"; export const projectEmpty = "
Kein Projekt ausgewählt.
"; const projectNotFoundHtml = `
Sorry! There is no data for this project. Please check back later to see if that changed!
`; const projectServerErrorHtml = `
Sorry! A server error happend when the project data was fetched!
`; const ad = asciidoctor(); export async function generateContent(content: Project|Diary, selectedPage?: number): Promise { if(!content) return projectEmpty; switch (content.type) { case "project": return await generateProjectHTML(content); case "diary": return await generateDiaryHTML(content, selectedPage); default: return projectNotFoundHtml; } } async function generateProjectHTML(project: Project): Promise { const resp = await fetch(`/content/projects/${project.name}.adoc`); if (resp.status !== 200) return projectServerErrorHtml; const rawAd = await resp.text(); const pathsCorrected = rawAd.replace(/(image[:]+)(.*\.[a-zA-Z]+)\[/g, "$1/content/projects/$2["); const adDoc = ad.load(pathsCorrected, { attributes: { showtitle: true } }); return `${adDoc.convert(adDoc).toString()}
`; } async function generateDiaryHTML(diary: Diary, selectedPage?: number): Promise { const page: number = Number.parseInt(selectedPage?.toString() || "0") - 1; const resp = page === -1 ? await fetch(`/content/diaries/${diary.name}.adoc`) : await fetch(`/content/diaries/${diary.name}/${diary.entries[page].filename}.adoc`); if (resp.status !== 200) return projectServerErrorHtml; const rawAd = await resp.text(); const pathsCorrected = rawAd.replace(/(image[:]{1,2})(.*\.[a-zA-Z]+)\[/g, "$1/content/diaries/$2["); const adDoc = ad.load(pathsCorrected, { attributes: { showtitle: true } }); const gitfile = page === -1 ? `${diary.name}.adoc` : `${diary.name}/${diary.entries[page].filename}.adoc`; return `${adDoc.convert(adDoc).toString()}
`; }