mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-04-22 06:59:05 -05:00
39 lines
781 B
TypeScript
39 lines
781 B
TypeScript
import { badgeUrl } from "~/utils/urls";
|
|
import { Image } from "./Image";
|
|
|
|
export interface BadgeProps {
|
|
badge: { displayName: string; hue?: number | null; code: string };
|
|
onClick?: () => void;
|
|
isAnimated: boolean;
|
|
size: number;
|
|
}
|
|
|
|
export function Badge({ badge, onClick, isAnimated, size }: BadgeProps) {
|
|
const commonProps = {
|
|
title: badge.displayName,
|
|
onClick,
|
|
width: size,
|
|
height: size,
|
|
style: badge.hue ? { filter: `hue-rotate(${badge.hue}deg)` } : undefined,
|
|
};
|
|
|
|
if (isAnimated) {
|
|
return (
|
|
<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}
|
|
/>
|
|
);
|
|
}
|