diff options
| author | Dawid Rycerz <dawid@rycerz.xyz> | 2025-07-03 10:56:21 +0300 |
|---|---|---|
| committer | Dawid Rycerz <dawid@rycerz.xyz> | 2025-07-03 10:56:21 +0300 |
| commit | 456cf011b36de91c9936994b1fa45703adcd309b (patch) | |
| tree | 8e60daf998f731ac50d100fa490eaecae1168042 /src/components/blog/webmentions/Likes.astro | |
Initial fork of chrismwilliams/astro-theme-cactus theme
Diffstat (limited to 'src/components/blog/webmentions/Likes.astro')
| -rw-r--r-- | src/components/blog/webmentions/Likes.astro | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/components/blog/webmentions/Likes.astro b/src/components/blog/webmentions/Likes.astro new file mode 100644 index 0000000..7862c43 --- /dev/null +++ b/src/components/blog/webmentions/Likes.astro @@ -0,0 +1,52 @@ +--- +import { Image } from "astro:assets"; +import type { WebmentionsChildren } from "@/types"; + +interface Props { + mentions: WebmentionsChildren[]; +} + +const { mentions } = Astro.props; +const MAX_LIKES = 10; + +const likes = mentions.filter((mention) => mention["wm-property"] === "like-of"); +const likesToShow = likes + .filter((like) => like.author?.photo && like.author.photo !== "") + .slice(0, MAX_LIKES); +--- + +{ + !!likes.length && ( + <div> + <p class="text-accent-2 mb-0"> + <strong>{likes.length}</strong> + {likes.length > 1 ? " People" : " Person"} liked this + </p> + {!!likesToShow.length && ( + <ul class="flex list-none flex-wrap overflow-hidden ps-2" role="list"> + {likesToShow.map((like) => ( + <li class="p-like h-cite -ms-2"> + <a + class="u-url not-prose ring-global-text hover:ring-link focus-visible:ring-link relative inline-block overflow-hidden rounded-full ring-2 hover:z-10 hover:ring-4 focus-visible:z-10 focus-visible:ring-4" + href={like.author?.url} + rel="noreferrer" + target="_blank" + title={like.author?.name} + > + <span class="p-author h-card"> + <Image + alt={like.author!.name} + class="u-photo my-0 inline-block h-12 w-12" + height={48} + src={like.author!.photo} + width={48} + /> + </span> + </a> + </li> + ))} + </ul> + )} + </div> + ) +} |
