Files
pages/src/lib/lists/blog-gallery.svelte

137 lines
3.7 KiB
Svelte
Raw Normal View History

<script lang="ts">
import { BlogPostTag, type BlogPostLink } from "../../routes/blog/posts";
let {
posts,
}: {
posts: BlogPostLink[];
} = $props();
</script>
<div class="entry-container">
{#each posts as post}
<a class="entry blurred-background-hover" href="{post.key}">
2026-03-31 13:34:09 +02:00
<div class="entry-banner-container">
<img class="entry-banner" src="{post.key}/{post.post.banner}" alt="{post.post.bannerAlt}">
</div>
<div class="entry-text-container">
<p class="entry-title">{post.post.title}</p>
<p class="entry-date">
::&nbsp;{post.post.date}
{#if post.post.dateUpdated}
// {post.post.dateUpdated}
{/if}
</p>
2026-03-31 13:34:09 +02:00
<p class="entry-description">{post.post.description}</p>
<div class="entry-tag-container">
{#each post.post.tags as tag}
2026-03-31 14:48:38 +02:00
<span class="post-tag">{tag}</span>
2026-03-31 13:34:09 +02:00
{/each}
</div>
</div>
</a>
{/each}
2026-03-31 13:34:09 +02:00
</div>
<style>
.entry-container {
display: grid;
/* gap: 8px; */
grid-template-columns: 1fr 1fr 1fr;
2026-03-31 13:34:09 +02:00
}
.entry {
margin: 0;
padding: 8px;
transition: background-color var(--duration-animation) var(--anim-curve),
border-color var(--duration-animation) var(--anim-curve),
backdrop-filter var(--duration-blur) var(--anim-curve),
border-radius var(--duration-animation) var(--anim-curve);
2026-03-31 13:34:09 +02:00
border: var(--border-dash-size) var(--border-style) transparent;
text-decoration: none;
border-radius: var(--border-radius);
2026-03-31 13:34:09 +02:00
}
.entry:hover {
background-color: var(--color-background-highlight-alt);
border-color: var(--color-highlight-alt);
}
.entry:hover .entry-banner {
scale: 1.2;
}
.entry:hover .entry-banner-container {
/* border-radius: 24px 24px 0 0; */
border-top-left-radius: calc(var(--border-radius) - 8px);
border-top-right-radius: calc(var(--border-radius) - 8px);
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
}
2026-03-31 13:34:09 +02:00
.entry-banner-container {
width: 100%;
height: 160px;
overflow: hidden;
display: flex;
justify-content: center;
transition: border-radius var(--duration-animation) var(--anim-curve);
2026-03-31 13:34:09 +02:00
}
.entry-banner {
width: 100%;
object-fit: cover;
transition: scale var(--duration-animation) var(--anim-curve);
}
.entry-text-container {
display: flex;
flex-direction: column;
margin: 16px 2px 2px;
/* gap: 8px; */
2026-03-31 13:34:09 +02:00
}
.entry-title {
font-family: var(--font-mono);
font-weight: 700;
font-size: 1.2rem;
line-height: 1.4rem;
margin: 0;
}
.entry-date {
font-size: 0.8rem;
line-height: 0.8rem;
font-weight: 600;
margin: 4px 0 0 0;
font-family: var(--font-mono);
color: var(--color-text-highlight-alt);
2026-03-31 13:34:09 +02:00
}
.entry-description {
font-size: 1.0rem;
line-height: 1.3rem;
margin: 4px 0 8px;
2026-03-31 13:34:09 +02:00
}
.entry-tag-container {
display: flex;
gap: 4px;
flex-direction: row;
flex-wrap: wrap;
--color-tag-filters-bg: var(--color-background-highlight-alt);
}
@media screen and (max-width: 900px) {
.entry-container {
grid-template-columns: 1fr 1fr;
}
}
@media screen and (max-width: 600px) {
.entry-container {
grid-template-columns: 1fr;
}
2026-03-31 13:34:09 +02:00
}
</style>