Update default title and description

This commit is contained in:
Valentin Popov 2024-09-11 22:03:55 +00:00
parent 97aa90a605
commit c89ed0f7f9
Signed by: Valentin Popov
GPG Key ID: AE3CE523DAAA8401
8 changed files with 29 additions and 14 deletions

2
.env Normal file
View File

@ -0,0 +1,2 @@
DEFAULT_TITLE=Valentin Popovs Technology Blog
DEFAULT_DESCRIPTION=Tech insights and coding best practices from an OpenSource enthusiast and ethical hacker.

View File

@ -14,7 +14,6 @@ const theme = "transparent_dark";
--- ---
<script <script
defer
src="https://giscus.app/client.js" src="https://giscus.app/client.js"
data-category-id={categoryId} data-category-id={categoryId}
data-category={category} data-category={category}
@ -28,5 +27,4 @@ const theme = "transparent_dark";
data-strict={strict} data-strict={strict}
data-theme={theme} data-theme={theme}
crossorigin={crossorigin} crossorigin={crossorigin}
> ></script>
</script>

View File

@ -1,17 +1,20 @@
--- ---
const canonicalURL = new URL(Astro.url.pathname, Astro.site); const canonicalURL = new URL(Astro.url.pathname, Astro.site);
const { title, description } = Astro.props;
--- ---
<head> <head>
<meta content="IE=edge" http-equiv="X-UA-Compatible" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta content="text/html; charset=utf-8" http-equiv="content-type" /> <meta http-equiv="content-type" content="text/html; charset=utf-8" />
<meta content="width=device-width, initial-scale=1" name="viewport" />
<meta content="index, follow" name="robots" /> <meta name="description" content={description ?? import.meta.env.DEFAULT_DESCRIPTION} />
<meta content="Description" name="description" /> <meta name="robots" content="index, follow" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link href="/feed.xml" rel="alternate" title="RSS" type="application/atom+xml" /> <link href="/feed.xml" rel="alternate" title="RSS" type="application/atom+xml" />
<link href="/sitemap-index.xml" rel="sitemap" /> <link href="/sitemap-index.xml" rel="sitemap" />
<link href={canonicalURL} rel="canonical" /> <link href={canonicalURL} rel="canonical" />
<title>Title</title> <title>{title ?? import.meta.env.DEFAULT_TITLE}</title>
</head> </head>

8
src/env.d.ts vendored
View File

@ -1 +1,9 @@
/// <reference path="../.astro/types.d.ts" /> /// <reference path="../.astro/types.d.ts" />
interface ImportMetaEnv {
readonly DEFAULT_TITLE: string;
readonly DEFAULT_DESCRIPTION: string;
}
interface ImportMeta {
readonly env: ImportMetaEnv;
}

View File

@ -1,10 +1,12 @@
--- ---
import Head from "../components/Head.astro"; import Head from "../components/Head.astro";
import Header from "../components/Header.astro"; import Header from "../components/Header.astro";
const { title, description } = Astro.props;
--- ---
<html> <html>
<Head /> <Head title={title} description={description} />
<body> <body>
<Header /> <Header />

View File

@ -1,7 +1,9 @@
--- ---
import BaseLayout from "./BaseLayout.astro"; import BaseLayout from "./BaseLayout.astro";
const { title, description } = Astro.props;
--- ---
<BaseLayout> <BaseLayout title={title} description={description}>
<slot /> <slot />
</BaseLayout> </BaseLayout>

View File

@ -22,7 +22,7 @@ const { Content, remarkPluginFrontmatter } = await post.render();
} }
</style> </style>
<Layout> <Layout title={post.data.title} description={post.data.description}>
<div class="header"> <div class="header">
<h1>{post.data.title}</h1> <h1>{post.data.title}</h1>
<p> <p>

View File

@ -6,7 +6,7 @@ export async function GET(context) {
return rss({ return rss({
customData: `<language>ru-ru</language>`, customData: `<language>ru-ru</language>`,
description: "Tech insights and coding best practices from an OpenSource enthusiast and ethical hacker.", description: import.meta.env.DEFAULT_DESCRIPTION,
items: posts.map((post) => ({ items: posts.map((post) => ({
customData: post.data.customData, customData: post.data.customData,
description: post.data.description, description: post.data.description,
@ -15,6 +15,6 @@ export async function GET(context) {
title: post.data.title, title: post.data.title,
})), })),
site: context.site, site: context.site,
title: "Valentin Popovs Technology Blog", title: import.meta.env.DEFAULT_TITLE,
}); });
} }