mirror of
				https://github.com/valentineus/popov.link.git
				synced 2025-11-04 06:49:45 +03:00 
			
		
		
		
	refactor: enhance PostElement structure and update blog schema
- Wrapped the post link in an <article> tag for improved semantic structure. - Updated blogSchema to include posts for better structured data representation. - Adjusted the blog index to utilize the new posts parameter for enhanced SEO.
This commit is contained in:
		@@ -25,12 +25,14 @@ const formattedDate = dayjs(post.data.pubDate.toString()).format("MMMM DD, YYYY"
 | 
			
		||||
</style>
 | 
			
		||||
 | 
			
		||||
<li>
 | 
			
		||||
	<a href={`/blog/${post.slug}`} lang={post.data.lang}>{post.data.title}</a>
 | 
			
		||||
	<div>
 | 
			
		||||
		<small>
 | 
			
		||||
			<time datetime={post.data.pubDate.toISOString()} lang="en">{formattedDate}</time>
 | 
			
		||||
			<span>•</span>
 | 
			
		||||
			<span>{remarkPluginFrontmatter.minutesRead}</span>
 | 
			
		||||
		</small>
 | 
			
		||||
	</div>
 | 
			
		||||
	<article>
 | 
			
		||||
		<a href={`/blog/${post.slug}`} lang={post.data.lang}>{post.data.title}</a>
 | 
			
		||||
		<div>
 | 
			
		||||
			<small>
 | 
			
		||||
				<time datetime={post.data.pubDate.toISOString()} lang="en">{formattedDate}</time>
 | 
			
		||||
				<span>•</span>
 | 
			
		||||
				<span>{remarkPluginFrontmatter.minutesRead}</span>
 | 
			
		||||
			</small>
 | 
			
		||||
		</div>
 | 
			
		||||
	</article>
 | 
			
		||||
</li>
 | 
			
		||||
 
 | 
			
		||||
@@ -30,6 +30,7 @@ const lang = "en";
 | 
			
		||||
const schema = blogSchema({
 | 
			
		||||
	siteUrl: new URL("/", Astro.site).toString(),
 | 
			
		||||
	title,
 | 
			
		||||
	posts,
 | 
			
		||||
});
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -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<Blog> => ({
 | 
			
		||||
export default ({ siteUrl, title, posts }: BlogSchemaParams): WithContext<CollectionPage> => ({
 | 
			
		||||
	"@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,
 | 
			
		||||
		})),
 | 
			
		||||
	},
 | 
			
		||||
});
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user