Files
Frontend/src/app/components/player/lookup-player.tsx

65 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-04-16 19:03:11 +01:00
"use client";
import { useToast } from "@/common/use-toast";
import { getPlayer } from "mcutils-library";
2024-04-16 19:03:11 +01:00
import { useRouter } from "next/navigation";
import { useState } from "react";
2024-04-16 19:12:26 +01:00
import { Button } from "../ui/button";
import { Input } from "../ui/input";
2024-04-17 18:08:13 +01:00
import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
2024-04-16 19:03:11 +01:00
2024-04-16 21:18:08 +01:00
export function LookupPlayer(): JSX.Element {
2024-04-16 19:03:11 +01:00
const router = useRouter();
const { toast } = useToast();
const [id, setId] = useState("");
2024-04-16 19:03:11 +01:00
/**
* Lookup a player
*/
const lookupPlayer = async () => {
if (!id || id.length === 0) {
2024-04-16 19:03:11 +01:00
return;
}
try {
await getPlayer(id);
} catch (err) {
toast({
title: "Error",
variant: "destructive",
description: (err as Error).message,
duration: 5000,
});
return;
}
router.push(`/player/${id}`);
2024-04-16 19:03:11 +01:00
};
return (
<form className="flex gap-2 justify-center mt-2" action="" onSubmit={(event) => event.preventDefault()}>
<Input
className="w-fit"
type="search"
name="query"
placeholder="Name / UUID"
value={id}
onChange={(event) => {
setId(event.target.value);
}}
maxLength={36}
/>
2024-04-17 18:08:13 +01:00
<Tooltip>
<TooltipTrigger asChild>
<Button type="submit" onClick={() => lookupPlayer()}>
Lookup
</Button>
</TooltipTrigger>
<TooltipContent>
<p>Click to lookup the player</p>
</TooltipContent>
</Tooltip>
2024-04-16 19:35:07 +01:00
</form>
2024-04-16 19:03:11 +01:00
);
}