2022-04-28 12:37:12 -04:00
|
|
|
import Link from 'next/link';
|
2024-02-13 18:01:07 -05:00
|
|
|
|
2022-04-28 12:37:12 -04:00
|
|
|
import Layout from '../../components/layout';
|
2024-02-13 18:01:07 -05:00
|
|
|
import { toRelativeDate } from '../../lib/date';
|
2023-10-30 00:18:38 -04:00
|
|
|
|
|
|
|
import NotesInfo from '../../public/notes.json';
|
2022-04-28 12:37:12 -04:00
|
|
|
|
2024-02-13 18:01:07 -05:00
|
|
|
function NoteEntry({ note }: { note: { title: string, mtime: string, slug: string } }) {
|
2022-04-28 12:37:12 -04:00
|
|
|
return (
|
2023-10-30 00:18:38 -04:00
|
|
|
<tr>
|
|
|
|
<td style={{ flex: '1 0 50%' }}>
|
2024-02-13 18:01:07 -05:00
|
|
|
<Link href={`/notes/${note.slug}`}>
|
|
|
|
{note.title}
|
2023-10-30 00:18:38 -04:00
|
|
|
</Link>
|
|
|
|
</td>
|
|
|
|
<td style={{ fontStyle: 'italic' }}>
|
2024-02-13 18:01:07 -05:00
|
|
|
{note.mtime && toRelativeDate(note.mtime)}
|
2023-10-30 00:18:38 -04:00
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
function NotesPage() {
|
2024-02-13 18:01:07 -05:00
|
|
|
const notes = Object.entries(NotesInfo)
|
|
|
|
.map(([slug, note]) => {
|
|
|
|
return {
|
|
|
|
slug,
|
|
|
|
title: note.title,
|
|
|
|
mtime: new Date(note.mtime)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.sort(
|
|
|
|
(a, b) => {
|
|
|
|
return b.mtime.getTime() - a.mtime.getTime();
|
|
|
|
}
|
|
|
|
);
|
2023-10-30 00:18:38 -04:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Layout>
|
2024-02-13 18:01:07 -05:00
|
|
|
{
|
|
|
|
!notes || notes.length === 0
|
|
|
|
&& <>No notes found</>
|
|
|
|
|| <table>
|
|
|
|
<tbody>
|
|
|
|
{notes.map(
|
|
|
|
(note: any, i: number) => {
|
|
|
|
return (<NoteEntry note={note} key={i} />);
|
|
|
|
}
|
|
|
|
)}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
}
|
2022-04-28 12:37:12 -04:00
|
|
|
</Layout>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-10-30 00:18:38 -04:00
|
|
|
export default NotesPage;
|