display blog article

This commit is contained in:
Michal Vanko 2019-12-26 07:50:57 +01:00
parent b67fb2e6a5
commit 1dd89aef87
4 changed files with 65 additions and 38 deletions

View File

@ -71,3 +71,24 @@ adspexit Circe est iuvencae ut favilla inque vir. Fas gelidas depressitque, et
ipse, occidit **afflatibus** est caesosque Liber? Animam [gramine quam ipse, occidit **afflatibus** est caesosque Liber? Animam [gramine quam
melior](http://nequesolum.net/in.html); arbor parte gestit moras trementia melior](http://nequesolum.net/in.html); arbor parte gestit moras trementia
aquilone se membris prima; Atlantis. aquilone se membris prima; Atlantis.
- Iunget quem color baculumque insistere perque nequiquam
- Temptabat Macareus hoc urbem inmanem alasque averserisque
- Tibia vita ita
- Mihi caput audito Hippolytus debita finita
- Ignis murmura summa nimis fragmina
- Aeneadae omnibus
## Tractus aderat
Datque **in sidera** timorem in fuerant partem, sit hi lapidis robora et
Phrygii! Dixisse dato posse et balatus tu tractare adit, merito quid tamen se.
[Huic](http://quibus-corpus.net/dissimulare-condit.html) nivea in modo iam enixa
sinistrum, haud collabitur misit, bello.
1. Stimuletur orbem vestigia regina
2. Pedibusque Latona in sub ponderis sustinuit maiora
3. Paverunt metiris malorum genetrice de illis
4. Sedebant ora
5. Deae bicolor submisso
6. Suis astra ut illas frontes

View File

@ -23,7 +23,11 @@ export async function get(req, res, next) {
} }
const parsedPost = fm(postSource) const parsedPost = fm(postSource)
const response = parseField('body')(parsedPost)
const response = parseField('body')({
...parsedPost.attributes,
body: parsedPost.body,
})
res.setHeader('Content-Type', 'application/json') res.setHeader('Content-Type', 'application/json')
res.end(JSON.stringify(response)) res.end(JSON.stringify(response))

View File

@ -1,24 +1,24 @@
<script context="module"> <script context="module">
export async function preload({ params, query }) { export async function preload({ params, query }) {
// the `slug` parameter is available because // the `slug` parameter is available because
// this file is called [slug].svelte // this file is called [slug].svelte
const res = await this.fetch(`blog/${params.slug}.json`); const res = await this.fetch(`blog/${params.slug}.json`)
const data = await res.json(); const data = await res.json()
if (res.status === 200) { if (res.status === 200) {
return { post: data }; return { post: data }
} else { } else {
this.error(res.status, data.message); this.error(res.status, data.message)
} }
} }
</script> </script>
<script> <script>
export let post; export let post
</script> </script>
<style> <style>
/* /*
By default, CSS is locally scoped to the component, By default, CSS is locally scoped to the component,
and any unused styles are dead-code-eliminated. and any unused styles are dead-code-eliminated.
In this page, Svelte can't know which elements are In this page, Svelte can't know which elements are
@ -26,39 +26,39 @@
so we have to use the :global(...) modifier to target so we have to use the :global(...) modifier to target
all elements inside .content all elements inside .content
*/ */
.content :global(h2) { .content :global(h2) {
font-size: 1.4em; font-size: 1.4em;
font-weight: 500; font-weight: 500;
} }
.content :global(pre) { .content :global(pre) {
background-color: #f9f9f9; background-color: #f9f9f9;
box-shadow: inset 1px 1px 5px rgba(0,0,0,0.05); box-shadow: inset 1px 1px 5px rgba(0, 0, 0, 0.05);
padding: 0.5em; padding: 0.5em;
border-radius: 2px; border-radius: 2px;
overflow-x: auto; overflow-x: auto;
} }
.content :global(pre) :global(code) { .content :global(pre) :global(code) {
background-color: transparent; background-color: transparent;
padding: 0; padding: 0;
} }
.content :global(ul) { .content :global(ul) {
line-height: 1.5; line-height: 1.5;
} }
.content :global(li) { .content :global(li) {
margin: 0 0 0.5em 0; margin: 0 0 0.5em 0;
} }
</style> </style>
<svelte:head> <svelte:head>
<title>{post.title}</title> <title>{post.title}</title>
</svelte:head> </svelte:head>
<h1>{post.title}</h1> <h1>{post.title}</h1>
<div class='content'> <div class="content">
{@html post.html} {@html post.body}
</div> </div>

View File

@ -1,5 +1,6 @@
import { readdir, readFile } from 'fs' import { readdir, readFile } from 'fs'
import { promisify } from 'util' import { promisify } from 'util'
import { basename } from 'path'
import fm from 'front-matter' import fm from 'front-matter'
import marked from 'marked' import marked from 'marked'
@ -24,6 +25,7 @@ export async function get(req, res) {
return { return {
...parsedAttributes.attributes, ...parsedAttributes.attributes,
preview, preview,
slug: basename(file, '.md'),
} }
}) })
) )