summaryrefslogtreecommitdiff
path: root/src/components/blog/Masthead.astro
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/blog/Masthead.astro')
-rw-r--r--src/components/blog/Masthead.astro84
1 files changed, 84 insertions, 0 deletions
diff --git a/src/components/blog/Masthead.astro b/src/components/blog/Masthead.astro
new file mode 100644
index 0000000..1f52383
--- /dev/null
+++ b/src/components/blog/Masthead.astro
@@ -0,0 +1,84 @@
+---
+import { Image } from "astro:assets";
+import type { CollectionEntry } from "astro:content";
+import FormattedDate from "@/components/FormattedDate.astro";
+
+interface Props {
+ content: CollectionEntry<"post">;
+ readingTime: string;
+}
+
+const {
+ content: { data },
+ readingTime,
+} = Astro.props;
+
+const dateTimeOptions: Intl.DateTimeFormatOptions = {
+ month: "long",
+};
+---
+
+{
+ data.coverImage && (
+ <div class="mb-6 aspect-video">
+ <Image
+ alt={data.coverImage.alt}
+ layout="constrained"
+ width={748}
+ height={420}
+ priority
+ src={data.coverImage.src}
+ />
+ </div>
+ )
+}
+{data.draft ? <span class="text-base text-red-500">(Draft)</span> : null}
+<h1 class="title">
+ {data.title}
+</h1>
+<div class="flex flex-wrap items-center gap-x-3 gap-y-2">
+ <p class="font-semibold">
+ <FormattedDate date={data.publishDate} dateTimeOptions={dateTimeOptions} /> /{" "}
+ {readingTime}
+ </p>
+ {
+ data.updatedDate && (
+ <span class="bg-quote/5 text-quote rounded-lg px-2 py-1">
+ Updated:
+ <FormattedDate class="ms-1" date={data.updatedDate} dateTimeOptions={dateTimeOptions} />
+ </span>
+ )
+ }
+</div>
+{
+ !!data.tags?.length && (
+ <div class="mt-2">
+ <svg
+ aria-hidden="true"
+ class="inline-block h-6 w-6"
+ fill="none"
+ focusable="false"
+ stroke="currentColor"
+ stroke-linecap="round"
+ stroke-linejoin="round"
+ stroke-width="1.5"
+ viewBox="0 0 24 24"
+ xmlns="http://www.w3.org/2000/svg"
+ >
+ <path d="M0 0h24v24H0z" fill="none" stroke="none" />
+ <path d="M7.859 6h-2.834a2.025 2.025 0 0 0 -2.025 2.025v2.834c0 .537 .213 1.052 .593 1.432l6.116 6.116a2.025 2.025 0 0 0 2.864 0l2.834 -2.834a2.025 2.025 0 0 0 0 -2.864l-6.117 -6.116a2.025 2.025 0 0 0 -1.431 -.593z" />
+ <path d="M17.573 18.407l2.834 -2.834a2.025 2.025 0 0 0 0 -2.864l-7.117 -7.116" />
+ <path d="M6 9h-.01" />
+ </svg>
+ {data.tags.map((tag, i) => (
+ <>
+ {/* prettier-ignore */}
+ <span class="contents">
+ <a class="cactus-link inline-block before:content-['#']" data-pagefind-filter={`tag:${tag}`} href={`/tags/${tag}/`}><span class="sr-only">View more blogs with the tag&nbsp;</span>{tag}
+ </a>{i < data.tags.length - 1 && ", "}
+ </span>
+ </>
+ ))}
+ </div>
+ )
+}