From 0d041c6b61fddb96fe3c65764bf54298cdadbeba Mon Sep 17 00:00:00 2001 From: Fuwn Date: Fri, 15 May 2026 10:27:00 +0000 Subject: perf(images): lazy-load and async-decode off-screen imagery Add loading=lazy and decoding=async to the 16 elements that weren't already deferring across Tools/Wrapped, Events, EasterEvent, Hololive, and the rate-limited fallback. Also drop the backdrop-filter: blur(160px) the dropdown items were paying on every hover; the background-color change already gives sufficient feedback, and the parent card's own blur stays. --- .../Events/AniListBadges/EasterEvent2025/ClickableAreaPage.svelte | 2 ++ src/lib/Events/AniListBadges/EasterEvent2025/EasterEgg.svelte | 8 ++++++++ src/lib/Events/Event.svelte | 4 ++-- src/lib/Events/Group.svelte | 4 ++-- 4 files changed, 14 insertions(+), 4 deletions(-) (limited to 'src/lib/Events') diff --git a/src/lib/Events/AniListBadges/EasterEvent2025/ClickableAreaPage.svelte b/src/lib/Events/AniListBadges/EasterEvent2025/ClickableAreaPage.svelte index 8faf0ba3..f606f366 100644 --- a/src/lib/Events/AniListBadges/EasterEvent2025/ClickableAreaPage.svelte +++ b/src/lib/Events/AniListBadges/EasterEvent2025/ClickableAreaPage.svelte @@ -21,6 +21,8 @@ const handleClick = (index: number) => { Option {i + 1} { id="egg-visual-{targetID}-{id}" src="https://images.vexels.com/media/users/3/162149/isolated/preview/7f9f0546b21308e4851956e9c15313c9-egg-easter-painted-easter-egg-easter-egg-spot-pattern-stripe-flat.png" alt="Easter Egg" + loading="lazy" + decoding="async" class="egg" /> @@ -133,6 +135,8 @@ const onLeavePopup = () => { Banner @@ -156,6 +160,8 @@ const onLeavePopup = () => { Badge 1 @@ -169,6 +175,8 @@ const onLeavePopup = () => { Badge 2 diff --git a/src/lib/Events/Event.svelte b/src/lib/Events/Event.svelte index f8d0efbc..a1d6cf42 100644 --- a/src/lib/Events/Event.svelte +++ b/src/lib/Events/Event.svelte @@ -12,14 +12,14 @@ let { event, avatar = false }: { event: Event; avatar?: boolean } = $props(); style={`background-image: ${event.banner ? `url(${event.banner})` : 'none'}; padding: 0;`} > {#if event} - + {/if}
{#if avatar} {/if} diff --git a/src/lib/Events/Group.svelte b/src/lib/Events/Group.svelte index 02cd53ac..9b0ddba5 100644 --- a/src/lib/Events/Group.svelte +++ b/src/lib/Events/Group.svelte @@ -11,13 +11,13 @@ let { group }: { group: Group } = $props(); style={`background-image: ${group.banner ? `url(${group.banner})` : 'none'}; padding: 0;`} > {#if group} - + {/if}
-- cgit v1.2.3