Paul W.
e3c70632e2
Remove custom html from markdown, clean-up UI (again) Signed-off-by: Paul W. <lambdapaul@protonmail.com>
106 lines
3.3 KiB
TypeScript
106 lines
3.3 KiB
TypeScript
import Layout from '../../components/layout';
|
|
import ReactMarkdown from 'react-markdown';
|
|
import style from '../../styles/post.module.css';
|
|
import PostsInfo from '../../public/posts.json';
|
|
import readMarkdown from '../../lib/read-markdown';
|
|
import DateTool from '../../lib/date';
|
|
|
|
interface Post {
|
|
title: string;
|
|
mtime: string;
|
|
otime?: string;
|
|
}
|
|
|
|
interface Posts {
|
|
[slug: string]: Post
|
|
}
|
|
|
|
|
|
function TimeBlock({ mtime, otime }: { mtime: string, otime: string }) {
|
|
const ampm = (h: number) => { if (h >= 12) return 'p.m.'; return 'a.m.'; };
|
|
|
|
const mdate = new Date(mtime);
|
|
const odate = new Date(otime);
|
|
|
|
const format = (date: Date) => {
|
|
const day = date.getDay();
|
|
const ord = <sup>{DateTool.getOrdinalDaySuffix(date.getDay())}</sup>;
|
|
const month = DateTool.getFullMonth(date.getMonth());
|
|
const year = date.getFullYear();
|
|
const hours = date.getHours() > 12 ? date.getHours() - 12 : date.getHours();
|
|
const minPrefix = date.getMinutes() < 10 ? '0' : '';
|
|
const minutes = date.getMinutes();
|
|
const twelveSfx = ampm(date.getHours());
|
|
return <>{day}{ord} {month} {year} at {hours}:{minPrefix}{minutes} {twelveSfx}</>
|
|
};
|
|
|
|
return (
|
|
<div style={{ textAlign: 'right', fontSize: '16px', fontFamily: 'Cantarell', fontStyle: 'italic' }}>
|
|
{
|
|
mtime ?
|
|
<div className='mtime' data-text={mdate.toISOString()}>
|
|
Last updated: {format(mdate)}
|
|
</div>
|
|
:
|
|
<></>
|
|
}
|
|
<div className='otime'>
|
|
{format(odate)}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
function Post({ post }: { post: Post & { content: string, cover?: string, otime: string, mtime?: string } }) {
|
|
return (<>
|
|
<Layout removeContainer={true} >
|
|
{<div className={style.imageBlock}
|
|
style={{
|
|
backgroundImage:
|
|
post.cover ?
|
|
`url(/assets/images/${post.cover})` :
|
|
'linear-gradient(to bottom right, rgb(5, 51, 11), rgb(5, 45, 13) 15%, rgb(5, 39,15) 40%, rgb(0, 30, 16) 80%)'
|
|
}}></div>}
|
|
<div className={`${style.spacer} ${post.cover ? style.background : ''}`}></div>
|
|
<section className={`${style.block} block`}>
|
|
<div className='container'>
|
|
<TimeBlock mtime={post.mtime} otime={post.otime} />
|
|
<ReactMarkdown>{post.content}</ReactMarkdown>
|
|
</div>
|
|
</section>
|
|
<div className={style.spacer}></div>
|
|
</Layout>
|
|
|
|
</>
|
|
);
|
|
}
|
|
|
|
export async function getStaticProps({ params }: any) {
|
|
const postsInfo: Posts = PostsInfo;
|
|
const post: Post = postsInfo[params.post];
|
|
return {
|
|
props: {
|
|
post: {
|
|
...post,
|
|
content: await readMarkdown('posts', params.post, true)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export async function getStaticPaths() {
|
|
return {
|
|
paths: Object.keys(PostsInfo).map((post: string) => {
|
|
return {
|
|
params: {
|
|
post
|
|
}
|
|
}
|
|
}),
|
|
fallback: false
|
|
};
|
|
}
|
|
|
|
|
|
export default Post;
|