diff --git a/src/components/PostElement.astro b/src/components/PostElement.astro
index 2263e92..85320ee 100644
--- a/src/components/PostElement.astro
+++ b/src/components/PostElement.astro
@@ -25,12 +25,14 @@ const formattedDate = dayjs(post.data.pubDate.toString()).format("MMMM DD, YYYY"
- {post.data.title}
-
-
-
- •
- {remarkPluginFrontmatter.minutesRead}
-
-
+
+ {post.data.title}
+
+
+
+ •
+ {remarkPluginFrontmatter.minutesRead}
+
+
+
diff --git a/src/pages/blog/index.astro b/src/pages/blog/index.astro
index 611d0fc..fd8b376 100644
--- a/src/pages/blog/index.astro
+++ b/src/pages/blog/index.astro
@@ -30,6 +30,7 @@ const lang = "en";
const schema = blogSchema({
siteUrl: new URL("/", Astro.site).toString(),
title,
+ posts,
});
---
diff --git a/src/utils/schemas/blogSchema.ts b/src/utils/schemas/blogSchema.ts
index 7ff84d8..54e2fca 100644
--- a/src/utils/schemas/blogSchema.ts
+++ b/src/utils/schemas/blogSchema.ts
@@ -1,13 +1,24 @@
-import type { WithContext, Blog } from "schema-dts";
+import type { WithContext, CollectionPage } from "schema-dts";
+import type { CollectionEntry } from "astro:content";
export type BlogSchemaParams = {
readonly siteUrl: string;
readonly title: string;
+ readonly posts: CollectionEntry<"blog">[];
};
-export default ({ siteUrl, title }: BlogSchemaParams): WithContext => ({
+export default ({ siteUrl, title, posts }: BlogSchemaParams): WithContext => ({
"@context": "https://schema.org",
- "@type": "Blog",
+ "@type": "CollectionPage",
"url": new URL("/blog/", siteUrl).toString(),
"name": title,
+ "mainEntity": {
+ "@type": "ItemList",
+ "itemListElement": posts.map((post, index) => ({
+ "@type": "ListItem",
+ "position": index + 1,
+ "url": new URL(`/blog/${post.slug}`, siteUrl).toString(),
+ "name": post.data.title,
+ })),
+ },
});