diff --git a/public/ads.txt b/src/pages/ads.txt similarity index 100% rename from public/ads.txt rename to src/pages/ads.txt diff --git a/src/pages/blog/[...page].astro b/src/pages/blog/[...page].astro new file mode 100644 index 0000000..bae6a05 --- /dev/null +++ b/src/pages/blog/[...page].astro @@ -0,0 +1,31 @@ +--- +import type { CollectionEntry } from "astro:content"; +import { getAllPosts, getUniqueCategories, getUniqueTags } from "@/data/post"; +import { collectionDateSort } from "@/utils/date"; +import type { GetStaticPaths, Page } from "astro"; + +export const getStaticPaths = (async ({ paginate }) => { + const MAX_POSTS_PER_PAGE = 20; + const MAX_TAGS = 7; + const MAX_CATEGORIES = 7; + const allPosts = await getAllPosts(); + const uniqueTags = getUniqueTags(allPosts).slice(0, MAX_TAGS); + const uniqueCategories = getUniqueCategories(allPosts).slice(0, MAX_CATEGORIES); + const postsCount = allPosts.length; + return paginate(allPosts.sort(collectionDateSort), { + pageSize: MAX_POSTS_PER_PAGE, + props: { uniqueTags, uniqueCategories, postsCount }, + }); +}) satisfies GetStaticPaths; + +interface Props { + page: Page>; + uniqueTags: string[]; + uniqueCategories: string[]; + postsCount: number; +} + +const currentPath = Astro.url.pathname; +const newPath = currentPath.replace("/blog/", "/posts/"); +return Astro.redirect(newPath); +--- diff --git a/src/pages/blog/[...slug].astro b/src/pages/blog/[...slug].astro index d46c51e..543116f 100644 --- a/src/pages/blog/[...slug].astro +++ b/src/pages/blog/[...slug].astro @@ -1,4 +1,16 @@ --- +import { getAllPosts } from "@/data/post"; +import type { GetStaticPaths } from "astro"; + +// if you're using an adaptor in SSR mode, getStaticPaths wont work -> https://docs.astro.build/en/guides/routing/#modifying-the-slug-example-for-ssr +export const getStaticPaths = (async () => { + const blogEntries = await getAllPosts(); + return blogEntries.map((post) => ({ + params: { slug: post.id }, + props: { post }, + })); +}) satisfies GetStaticPaths; + const currentPath = Astro.url.pathname; const newPath = currentPath.replace("/blog/", "/posts/"); return Astro.redirect(newPath); diff --git a/src/pages/category/[category]/[...page].astro b/src/pages/category/[category]/[...page].astro new file mode 100644 index 0000000..0fa2b0d --- /dev/null +++ b/src/pages/category/[category]/[...page].astro @@ -0,0 +1,23 @@ +--- +import { getAllPosts, getUniqueCategories } from "@/data/post"; +import { collectionDateSort } from "@/utils/date"; +import type { GetStaticPaths } from "astro"; + +export const getStaticPaths: GetStaticPaths = async ({ paginate }) => { + const allPosts = await getAllPosts(); + const sortedPosts = allPosts.sort(collectionDateSort); + const uniqueCategories = getUniqueCategories(sortedPosts); + + return uniqueCategories.flatMap((category) => { + const filterPosts = sortedPosts.filter((post) => post.data.category === category); + return paginate(filterPosts, { + pageSize: 20, + params: { category }, + }); + }); +}; + +const currentPath = Astro.url.pathname; +const newPath = currentPath.replace("/category/", "/categories/"); +return Astro.redirect(newPath); +--- diff --git a/src/pages/category/index.astro b/src/pages/category/index.astro new file mode 100644 index 0000000..ec0cff5 --- /dev/null +++ b/src/pages/category/index.astro @@ -0,0 +1,3 @@ +--- +return Astro.redirect("/categories"); +--- diff --git a/src/pages/diary/[...page].astro b/src/pages/diary/[...page].astro new file mode 100644 index 0000000..bc32ebe --- /dev/null +++ b/src/pages/diary/[...page].astro @@ -0,0 +1,25 @@ +--- +import { type CollectionEntry, getCollection } from "astro:content"; +import { collectionModifiedDateSort } from "@/utils/date"; +import type { GetStaticPaths, Page } from "astro"; + +export const getStaticPaths = (async ({ paginate }) => { + const MAX_NOTES_PER_PAGE = 10; + const allNotes = await getCollection("note"); + const notesCount = allNotes.length; + return paginate(allNotes.sort(collectionModifiedDateSort), { + pageSize: MAX_NOTES_PER_PAGE, + props: { notesCount }, + }); +}) satisfies GetStaticPaths; + +interface Props { + page: Page>; + uniqueTags: string[]; + notesCount: number; +} + +const currentPath = Astro.url.pathname; +const newPath = currentPath.replace("/diary/", "/notes/"); +return Astro.redirect(newPath); +--- diff --git a/src/pages/diary/[...slug].astro b/src/pages/diary/[...slug].astro index a8eaa99..ca929d7 100644 --- a/src/pages/diary/[...slug].astro +++ b/src/pages/diary/[...slug].astro @@ -1,4 +1,17 @@ --- +import { getCollection } from "astro:content"; + +import type { GetStaticPaths } from "astro"; + +// if you're using an adaptor in SSR mode, getStaticPaths wont work -> https://docs.astro.build/en/guides/routing/#modifying-the-slug-example-for-ssr +export const getStaticPaths = (async () => { + const allNotes = await getCollection("note"); + return allNotes.map((note) => ({ + params: { slug: note.id }, + props: { note }, + })); +}) satisfies GetStaticPaths; + const currentPath = Astro.url.pathname; const newPath = currentPath.replace("/diary/", "/notes/"); return Astro.redirect(newPath); diff --git a/src/pages/tag/[...slug].astro b/src/pages/tag/[...slug].astro deleted file mode 100644 index ccadc0b..0000000 --- a/src/pages/tag/[...slug].astro +++ /dev/null @@ -1,5 +0,0 @@ ---- -const currentPath = Astro.url.pathname; -const newPath = currentPath.replace("/tag/", "/tags/"); -return Astro.redirect(newPath); ---- diff --git a/src/pages/tag/[tag]/[...page].astro b/src/pages/tag/[tag]/[...page].astro new file mode 100644 index 0000000..6f3cafc --- /dev/null +++ b/src/pages/tag/[tag]/[...page].astro @@ -0,0 +1,23 @@ +--- +import { getAllPosts, getUniqueTags } from "@/data/post"; +import { collectionDateSort } from "@/utils/date"; +import type { GetStaticPaths } from "astro"; + +export const getStaticPaths: GetStaticPaths = async ({ paginate }) => { + const allPosts = await getAllPosts(); + const sortedPosts = allPosts.sort(collectionDateSort); + const uniqueTags = getUniqueTags(sortedPosts); + + return uniqueTags.flatMap((tag) => { + const filterPosts = sortedPosts.filter((post) => post.data.tags.includes(tag)); + return paginate(filterPosts, { + pageSize: 20, + params: { tag }, + }); + }); +}; + +const currentPath = Astro.url.pathname; +const newPath = currentPath.replace("/tag/", "/tags/"); +return Astro.redirect(newPath); +--- diff --git a/src/pages/tag/index.astro b/src/pages/tag/index.astro new file mode 100644 index 0000000..e4518d1 --- /dev/null +++ b/src/pages/tag/index.astro @@ -0,0 +1,3 @@ +--- +return Astro.redirect("/tags"); +---