2024-04-16 19:03:11 +01:00
|
|
|
"use client";
|
|
|
|
|
2024-04-17 18:26:53 +01:00
|
|
|
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();
|
2024-04-17 18:26:53 +01:00
|
|
|
const { toast } = useToast();
|
|
|
|
const [id, setId] = useState("");
|
2024-04-16 19:03:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Lookup a player
|
|
|
|
*/
|
2024-04-17 18:26:53 +01:00
|
|
|
const lookupPlayer = async () => {
|
|
|
|
if (!id || id.length === 0) {
|
2024-04-16 19:03:11 +01:00
|
|
|
return;
|
|
|
|
}
|
2024-04-17 18:26:53 +01:00
|
|
|
|
|
|
|
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 (
|
2024-04-17 18:26:53 +01:00
|
|
|
<form className="flex gap-2 justify-center mt-2" action="" onSubmit={(event) => event.preventDefault()}>
|
|
|
|
<Input
|
|
|
|
className="w-fit"
|
2024-04-17 23:29:11 +01:00
|
|
|
type="search"
|
|
|
|
name="query"
|
2024-04-17 18:26:53 +01:00
|
|
|
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
|
|
|
);
|
|
|
|
}
|