fix: commit avatar loading improvement (#4335)

This commit is contained in:
Nico Domino 2024-07-11 17:46:04 +02:00 committed by GitHub
parent d0a257e745
commit db28854983
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 70 additions and 21 deletions

View File

@ -95,7 +95,7 @@ export function ghResponseToInstance(
name: pr.user.login || undefined,
email: pr.user.email || undefined,
isBot: pr.user.type.toLowerCase() === 'bot',
gravatarUrl: new URL(pr.user.avatar_url)
gravatarUrl: pr.user.avatar_url
}
: null,
labels: labels,

View File

@ -1,3 +1,3 @@
export function gravatarUrl(id: string | undefined | null): URL | undefined {
if (id) return new URL(`https://www.gravatar.com/avatar/${id}?s=100&r=g&d=retro`);
export function gravatarUrl(id: string | undefined | null): string | undefined {
if (id) return `https://www.gravatar.com/avatar/${id}?s=100&r=g&d=retro`;
}

View File

@ -317,7 +317,7 @@ export class RemoteFile {
export interface Author {
email?: string;
name?: string;
gravatarUrl?: URL;
gravatarUrl?: string;
isBot?: boolean;
}

View File

@ -0,0 +1,59 @@
<script lang="ts">
import { tooltip } from '$lib/utils/tooltip';
interface Props {
srcUrl: string;
tooltipText: string;
altText: string;
}
let isLoaded = $state(false);
const { srcUrl, tooltipText, altText }: Props = $props();
</script>
<div class="image-wrapper">
<img
class="avatar"
alt={altText}
src={srcUrl}
loading="lazy"
onload={() => (isLoaded = true)}
width="100"
height="100"
class:hidden={!isLoaded}
use:tooltip={tooltipText}
/>
<img
class="avatar"
class:hidden={isLoaded}
alt={altText}
src=""
width="100"
height="100"
use:tooltip={tooltipText}
/>
</div>
<style lang="postcss">
.image-wrapper {
display: grid;
place-content: center;
overflow: hidden;
}
.image-wrapper > * {
grid-area: 1 / 1;
}
.hidden {
opacity: 0;
}
.avatar {
position: relative;
width: 12px;
height: 12px;
border-radius: 6px;
}
</style>

View File

@ -1,4 +1,5 @@
<script lang="ts">
import AvatarImage from './AvatarImage.svelte';
import { tooltip } from '$lib/utils/tooltip';
import { isDefined } from '$lib/utils/typeguards';
import type { CommitNodeData, Color } from '$lib/CommitLines/types';
@ -32,13 +33,10 @@
>
{#if commitNode.type === 'large' && commitNode.commit}
<div class="large-node">
<img
class="avatar"
alt="Gravatar for {commitNode.commit.author.email}"
srcset="{commitNode.commit.author.gravatarUrl} 2x"
width="100"
height="100"
use:tooltip={hoverText}
<AvatarImage
srcUrl={commitNode.commit?.author.gravatarUrl ?? ''}
tooltipText={hoverText}
altText={`Gravatar for ${commitNode.commit.author.email}`}
/>
</div>
{:else}
@ -102,12 +100,4 @@
justify-content: center;
}
}
.avatar {
position: relative;
width: 12px;
height: 12px;
border-radius: 6px;
}
</style>

View File

@ -29,7 +29,7 @@ export interface LineGroupData {
export interface Author {
name?: string;
email?: string;
gravatarUrl?: URL;
gravatarUrl?: string;
}
/**

View File

@ -11,7 +11,7 @@ type Story = StoryObj<typeof meta>;
const caleb: Author = {
email: 'hello@calebowens.com',
gravatarUrl: new URL('https://gravatar.com/avatar/f43ef760d895a84ca7bb35ff6f4c6b7c')
gravatarUrl: 'https://gravatar.com/avatar/f43ef760d895a84ca7bb35ff6f4c6b7c'
};
function author() {