"use client"; import { CheckIcon } from "@heroicons/react/24/solid"; import { useLiveQuery } from "dexie-react-hooks"; import useDatabase from "../../hooks/use-database"; import { useToast } from "@/hooks/use-toast"; import Tooltip from "../tooltip"; import { Button } from "../ui/button"; import { revalidatePath } from "next/cache"; import { setCookieValue } from "@ssr/common/utils/cookie-utils"; type Props = { /** * The ID of the players profile to claim. */ playerId: string; }; export default function ClaimProfile({ playerId }: Props) { const database = useDatabase(); const { toast } = useToast(); const settings = useLiveQuery(() => database.getSettings()); /** * Claims the profile. */ async function claimProfile() { const settings = await database.getSettings(); settings?.setPlayerId(playerId); await setCookieValue("playerId", playerId); toast({ title: "Profile Claimed", description: "You have claimed this profile.", }); revalidatePath("/player/[...slug]"); } // Database is not ready if (settings == undefined || database == undefined) { return null; } if (settings?.playerId == playerId) { return null; // Don't show the claim button if it's the same user. } return (

Set as your profile!

Claiming a profile will also initialize it for data tracking.

This will overwrite your currently set profile (if any)

} side={"bottom"} >
); }