Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added public/default-post-thumbnail.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
20 changes: 18 additions & 2 deletions src/components/SEOMeta.astro
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
interface Props {
title: string
description?: string
image?: string | undefined
favicon?: string
faviconMimeType?: string
canonicalURL?: string | undefined
Expand All @@ -13,6 +14,7 @@ interface Props {
const {
title,
description,
image = 'default-post-thumbnail.png',
favicon,
faviconMimeType,
canonicalURL,
Expand All @@ -21,14 +23,14 @@ const {
robots,
} = Astro.props

const _canonicalURL = canonicalURL || Astro.url.href
const url = canonicalURL || Astro.url.href
---

<!-- Global Metadata -->
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="icon" type={faviconMimeType} href={favicon} />
{_canonicalURL && <link rel="canonical" href={_canonicalURL} />}
{url && <link rel="canonical" href={url} />}

<!-- Primary Meta Tags -->
<title>{title}</title>
Expand All @@ -40,3 +42,17 @@ const _canonicalURL = canonicalURL || Astro.url.href
<meta name="author" content={author} />
{robots && <meta name="robots" content={robots} />}
<meta name="generator" content={Astro.generator} />

<!-- Open Graph / Facebook -->
<meta property="og:type" content="website" />
<meta property="og:url" content={url} />
<meta property="og:title" content={title} />
<meta property="og:description" content={description} />
<meta property="og:image" content={new URL(image, Astro.site)} />

<!-- Twitter -->
<meta property="twitter:card" content="summary_large_image" />
<meta property="twitter:url" content={url} />
<meta property="twitter:title" content={title} />
<meta property="twitter:description" content={description} />
<meta property="twitter:image" content={new URL(image, Astro.site)} />
4 changes: 3 additions & 1 deletion src/layouts/AppLayout.astro
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,14 @@ import siteConfig from '@/configs/site'
export interface Props {
title: string
description: string
image?: string | undefined
canonicalURL?: string | undefined
author: string
headerCssClasses?: string
keywords?: string[]
}

const { title, description = '', canonicalURL, author, headerCssClasses = '' } = Astro.props
const { title, description = '', image, canonicalURL, author, headerCssClasses = '' } = Astro.props
const { favicon, faviconMimeType } = siteConfig
const pageDescription =
description.length > 0 ? description : `${title} - ${siteConfig.description}`
Expand All @@ -27,6 +28,7 @@ const pageDescription =
<SEOMeta
title={title}
description={pageDescription}
image={image}
canonicalURL={canonicalURL}
favicon={favicon}
faviconMimeType={faviconMimeType}
Expand Down