Some checks failed
CI / Unit & Component Tests (push) Has been cancelled
CI / Backend Unit Tests (push) Has been cancelled
CI / E2E Tests (push) Has been cancelled
CI / Unit & Component Tests (pull_request) Failing after 1m23s
CI / Backend Unit Tests (pull_request) Failing after 2m38s
CI / E2E Tests (pull_request) Failing after 1h14m58s
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
34 lines
964 B
Svelte
34 lines
964 B
Svelte
<script lang="ts">
|
|
import { abbreviateName, personAvatarColor } from '$lib/utils/personFormat';
|
|
|
|
type Person = { id: string; firstName: string; lastName: string };
|
|
|
|
type Props = {
|
|
person: Person;
|
|
abbreviated: boolean;
|
|
};
|
|
|
|
let { person, abbreviated }: Props = $props();
|
|
|
|
const displayName = $derived(
|
|
abbreviated ? abbreviateName(person) : `${person.firstName} ${person.lastName}`
|
|
);
|
|
const avatarColor = $derived(personAvatarColor(person.id));
|
|
const initials = $derived(
|
|
`${person.firstName.charAt(0)}${person.lastName.charAt(0)}`.toUpperCase()
|
|
);
|
|
</script>
|
|
|
|
<span
|
|
class="inline-flex shrink-0 items-center gap-1.5 rounded-full border border-line bg-muted px-2 py-0.5"
|
|
>
|
|
<span
|
|
class="flex h-[25px] w-[25px] shrink-0 items-center justify-center rounded-full text-[13px] font-bold text-white"
|
|
style="background-color: {avatarColor}"
|
|
aria-hidden="true"
|
|
>
|
|
{initials}
|
|
</span>
|
|
<span class="text-[14px] font-semibold text-ink">{displayName}</span>
|
|
</span>
|