fix(web): use native image decoder (#3074)

Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
This commit is contained in:
Thomas 2023-11-29 15:09:22 +00:00 committed by GitHub
parent e5d083fe79
commit 696900228b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 26 additions and 48 deletions

View file

@ -3,7 +3,7 @@
</script>
<script lang="ts">
import { imageLoad } from '$lib/utils/image-load';
import { onMount, tick } from 'svelte';
import { UserAvatarColor, api } from '@api';
interface User {
@ -22,8 +22,19 @@
export let showTitle = true;
export let showProfileImage = true;
let img: HTMLImageElement;
let showFallback = true;
onMount(async () => {
if (!user.profileImagePath) {
return;
}
await img.decode();
await tick();
showFallback = false;
});
const colorClasses: Record<UserAvatarColor, string> = {
primary: 'bg-immich-primary dark:bg-immich-dark-primary text-immich-dark-fg dark:text-immich-fg',
pink: 'bg-pink-400 text-immich-bg',
@ -62,13 +73,12 @@
>
{#if showProfileImage && user.profileImagePath}
<img
bind:this={img}
src={api.getProfileImageUrl(user.id)}
alt="Profile image of {title}"
class="h-full w-full object-cover"
class:hidden={showFallback}
draggable="false"
use:imageLoad
on:image-load={() => (showFallback = false)}
/>
{/if}
{#if showFallback}