From bda3b8b7f6d89bc9950afafc2104a0dfadb0d8b0 Mon Sep 17 00:00:00 2001 From: LynithDev <61880709+LynithDev@users.noreply.github.com> Date: Sat, 30 Nov 2024 12:39:27 +0100 Subject: [PATCH] fix(ui): Fix PlayerHead component on account switch --- .../src/ui/components/game/PlayerHead.tsx | 43 ++++++++----------- 1 file changed, 18 insertions(+), 25 deletions(-) diff --git a/apps/frontend/src/ui/components/game/PlayerHead.tsx b/apps/frontend/src/ui/components/game/PlayerHead.tsx index fbf7ee7..fae70ed 100644 --- a/apps/frontend/src/ui/components/game/PlayerHead.tsx +++ b/apps/frontend/src/ui/components/game/PlayerHead.tsx @@ -1,5 +1,5 @@ import type { JSX } from 'solid-js'; -import { createEffect, createSignal, on, Show, splitProps } from 'solid-js'; +import { createEffect, createSignal, splitProps } from 'solid-js'; import steveSrc from '../../../assets/images/steve.png'; type PlayerHeadProps = JSX.IntrinsicElements['img'] & { @@ -7,38 +7,31 @@ type PlayerHeadProps = JSX.IntrinsicElements['img'] & { onError?: () => void; }; -function headSrc(uuid: string) { +function crafatar(uuid: string) { return `https://crafatar.com/avatars/${uuid}?size=48`; } function PlayerHead(props: PlayerHeadProps) { const [split, rest] = splitProps(props, ['uuid', 'class']); - const [isLoaded, setLoaded] = createSignal(false); + const [src, setSrc] = createSignal(steveSrc); - createEffect(on(() => props.uuid, () => setLoaded(false))); + createEffect(() => { + if (split.uuid) + setSrc(crafatar(split.uuid)); + }); + + const onError = () => { + setSrc(steveSrc); + props.onError && props.onError(); + }; return ( - <> - props.onError && props.onError()} - onLoad={() => setLoaded(true)} - src={headSrc(split.uuid!)} - {...rest} - /> - )} - fallback={( - - )} - when={props.uuid !== null && props.uuid !== undefined} - /> - + ); }