1
mirror of https://github.com/jakejarvis/jarv.is.git synced 2025-04-26 17:48:30 -04:00
jarv.is/pages/notes/index.tsx

49 lines
1.1 KiB
TypeScript

import { NextSeo } from "next-seo";
import Content from "../../components/Content";
import NotesList from "../../components/NotesList";
import { getAllNotes } from "../../lib/helpers/parse-notes";
import { authorName } from "../../lib/config";
import type { GetStaticProps } from "next";
import type { NotesByYear } from "../../types";
type StaticProps = {
notesByYear: NotesByYear;
};
const Notes = ({ notesByYear }: StaticProps) => {
return (
<>
<NextSeo
title="Notes"
description={`Recent posts by ${authorName}.`}
openGraph={{
title: "Notes",
}}
/>
<Content>
<NotesList notesByYear={notesByYear} />
</Content>
</>
);
};
export const getStaticProps: GetStaticProps<StaticProps> = async () => {
// parse the year of each note and group them together
const notes = await getAllNotes();
const notesByYear: NotesByYear = {};
notes.forEach((note) => {
const year = new Date(note.date).getUTCFullYear();
(notesByYear[year] || (notesByYear[year] = [])).push(note);
});
return {
props: {
notesByYear,
},
};
};
export default Notes;