aboutsummaryrefslogtreecommitdiff
path: root/src/components/Head.astro
diff options
context:
space:
mode:
authorValentin Popov <valentin@popov.link>2026-04-22 20:53:21 +0300
committerValentin Popov <valentin@popov.link>2026-04-22 20:53:21 +0300
commit933d6874b1fe1dbb113e9de39425f2d713a72408 (patch)
tree44278a4088a2144ac08fb72fd4abe86ab60a55e8 /src/components/Head.astro
parent5e818d804d5d38beff0f3754a006333752fd5082 (diff)
downloadpopov.link-933d6874b1fe1dbb113e9de39425f2d713a72408.tar.xz
popov.link-933d6874b1fe1dbb113e9de39425f2d713a72408.zip
feat: enhance blog and SEO features with new plugins and metadata
- Introduced rehypeLazyImages plugin for lazy loading images in blog posts. - Updated sitemap integration to include last modified dates for blog posts. - Enhanced Head and BaseLayout components to support additional Open Graph metadata. - Improved RSS feed generation with sanitized content and author information. - Updated manifest.json for a darker theme and standalone display mode. - Added support for language-specific attributes in various components. - Refactored blog post handling to include modified and published timestamps.
Diffstat (limited to 'src/components/Head.astro')
-rw-r--r--src/components/Head.astro37
1 files changed, 30 insertions, 7 deletions
diff --git a/src/components/Head.astro b/src/components/Head.astro
index 258162d..fbfba1c 100644
--- a/src/components/Head.astro
+++ b/src/components/Head.astro
@@ -1,33 +1,44 @@
---
import type { Thing } from "schema-dts";
+import { config } from "../config";
import JsonLd from "./JsonLd.astro";
type Props = {
readonly description: string;
+ readonly lang: string;
+ readonly modifiedTime?: string;
+ readonly ogType?: "website" | "article";
readonly preview: string;
+ readonly publishedTime?: string;
readonly robots?: string;
readonly schema: Thing[];
readonly title: string;
};
-const { description, preview, robots = "index, follow", schema, title } = Astro.props;
+const { description, lang, modifiedTime, ogType = "website", preview, publishedTime, robots = "index, follow", schema, title } = Astro.props;
const canonicalUrl = new URL(Astro.url.pathname, Astro.site);
const previewUrl = new URL(preview, Astro.site);
+const ogLocale = lang === "ru" ? "ru_RU" : "en_US";
---
<head>
<!-- Meta Tags -->
- <meta http-equiv="X-UA-Compatible" content="IE=edge" />
- <meta http-equiv="content-type" content="text/html; charset=utf-8" />
+ <meta charset="utf-8" />
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
<meta name="description" content={description} />
<meta name="robots" content={robots} />
- <meta name="viewport" content="width=device-width, initial-scale=1" />
+ <meta name="author" content={config.author.name} />
<link href="/feed.xml" rel="alternate" title="RSS" type="application/atom+xml" />
<link href="/sitemap-index.xml" rel="sitemap" />
<link href={canonicalUrl} rel="canonical" />
+ <link href={config.author.url} rel="author" />
+
+ <!-- hreflang -->
+ <link rel="alternate" hreflang={lang} href={canonicalUrl} />
+ <link rel="alternate" hreflang="x-default" href={canonicalUrl} />
<title>{title}</title>
@@ -36,20 +47,32 @@ const previewUrl = new URL(preview, Astro.site);
<link rel="icon" type="image/png" href="/favicon.png" />
<link rel="apple-touch-icon" href="/apple-touch-icon.png" />
<link rel="manifest" href="/manifest.json" />
- <meta name="theme-color" content="#ffffff" />
+ <meta name="theme-color" content="#181818" />
<!-- Open Graph -->
- <meta property="og:type" content="website" />
+ <meta property="og:type" content={ogType} />
+ <meta property="og:site_name" content={config.og.website} />
+ <meta property="og:locale" content={ogLocale} />
<meta property="og:title" content={title} />
<meta property="og:description" content={description} />
- <meta property="og:image" content={previewUrl} />
<meta property="og:url" content={canonicalUrl} />
+ <meta property="og:image" content={previewUrl} />
+ <meta property="og:image:width" content={String(config.og.dimensions.width)} />
+ <meta property="og:image:height" content={String(config.og.dimensions.height)} />
+ <meta property="og:image:alt" content={title} />
+
+ {ogType === "article" && publishedTime && <meta property="article:published_time" content={publishedTime} />}
+ {ogType === "article" && modifiedTime && <meta property="article:modified_time" content={modifiedTime} />}
+ {ogType === "article" && <meta property="article:author" content={config.author.url} />}
<!-- Twitter Cards -->
<meta name="twitter:card" content="summary_large_image" />
+ <meta name="twitter:site" content="@valyaha" />
+ <meta name="twitter:creator" content="@valyaha" />
<meta name="twitter:title" content={title} />
<meta name="twitter:description" content={description} />
<meta name="twitter:image" content={previewUrl} />
+ <meta name="twitter:image:alt" content={title} />
<JsonLd schema={schema} />
</head>