mirror of
https://github.com/immich-app/immich
synced 2025-11-07 17:27:20 +00:00
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:
parent
e5d083fe79
commit
696900228b
5 changed files with 26 additions and 48 deletions
|
|
@ -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}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue