mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-04-24 23:19:39 -05:00
* Initial * CSS lint * Test CI * Add 1v1, 2v2, and 3v3 Tags (#1771) * Initial * CSS lint * Test CI * Rename step --------- Co-authored-by: xi <104683822+ximk@users.noreply.github.com>
43 lines
805 B
TypeScript
43 lines
805 B
TypeScript
import { badgeUrl } from "~/utils/urls";
|
|
import { Image } from "./Image";
|
|
|
|
export function Badge({
|
|
badge,
|
|
onClick,
|
|
isAnimated,
|
|
size,
|
|
}: {
|
|
badge: { displayName: string; hue?: number | null; code: string };
|
|
onClick?: () => void;
|
|
isAnimated: boolean;
|
|
size: number;
|
|
}) {
|
|
const commonProps = {
|
|
title: badge.displayName,
|
|
onClick,
|
|
width: size,
|
|
height: size,
|
|
style: badge.hue ? { filter: `hue-rotate(${badge.hue}deg)` } : undefined,
|
|
};
|
|
|
|
if (isAnimated) {
|
|
return (
|
|
// biome-ignore lint/a11y/useAltText: false positive..?
|
|
<img
|
|
src={badgeUrl({ code: badge.code, extension: "gif" })}
|
|
alt={badge.displayName}
|
|
{...commonProps}
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Image
|
|
path={badgeUrl({ code: badge.code })}
|
|
alt={badge.displayName}
|
|
loading="lazy"
|
|
{...commonProps}
|
|
/>
|
|
);
|
|
}
|