mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-05-09 04:02:40 -05:00
35 lines
754 B
TypeScript
35 lines
754 B
TypeScript
import { t } from "@lingui/macro";
|
|
import { useLingui } from "@lingui/react";
|
|
import Image from "next/image";
|
|
import React from "react";
|
|
|
|
interface WeaponImageProps {
|
|
name: string;
|
|
size: 32 | 64 | 128;
|
|
noTitle?: boolean;
|
|
}
|
|
|
|
const WeaponImage: React.FC<WeaponImageProps> = ({ name, size, noTitle }) => {
|
|
const { i18n } = useLingui();
|
|
|
|
return (
|
|
<Image
|
|
src={`/weapons/${name.replace(".", "").trim()}.png`}
|
|
alt={i18n._(name)}
|
|
title={getTitle()}
|
|
width={size}
|
|
height={size}
|
|
/>
|
|
);
|
|
|
|
function getTitle() {
|
|
if (noTitle) return undefined;
|
|
if (name === "RANDOM") return t`Random`;
|
|
if (name === "RANDOM_GRIZZCO") return t`Random (Grizzco)`;
|
|
|
|
return i18n._(name);
|
|
}
|
|
};
|
|
|
|
export default WeaponImage;
|