File size: 2,269 Bytes
018dc4e |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
import { useEffect, useState } from "react";
import { Link, useNavigate } from "react-router-dom";
import { useAuth } from "@/contexts/AuthContext";
import { Button } from "@/components/ui/button";
import { useToast } from "@/hooks/use-toast";
import { LogIn, LogOut, User } from "lucide-react";
import { useTranslation } from "@/hooks/useTranslation";
export const UserMenu = () => {
const { user, signOut } = useAuth();
const navigate = useNavigate();
const { toast } = useToast();
const t = useTranslation();
const [mounted, setMounted] = useState(false);
useEffect(() => {
setMounted(true);
}, []);
if (!mounted) return null;
const handleSignOut = async () => {
await signOut();
toast({
title: t.auth.logoutSuccess.title,
description: t.auth.logoutSuccess.description,
});
navigate("/");
};
return (
<div className="flex items-center gap-4">
{user ? (
<div className="flex items-center gap-2">
<span className="text-sm hidden md:inline-block">
{user.email}
</span>
<Button
variant="outline"
size="sm"
onClick={handleSignOut}
className="flex items-center gap-2"
>
<LogOut className="h-4 w-4" />
<span className="hidden md:inline-block">
{t.auth.form.logout || "Logout"}
</span>
</Button>
</div>
) : (
<div className="flex items-center gap-2">
<Button
variant="outline"
size="sm"
asChild
className="flex items-center gap-2"
>
<Link to="/auth/login">
<LogIn className="h-4 w-4" />
<span className="hidden md:inline-block">{t.auth.login.linkText}</span>
</Link>
</Button>
<Button
variant="default"
size="sm"
asChild
className="flex items-center gap-2"
>
<Link to="/auth/register">
<User className="h-4 w-4" />
<span className="hidden md:inline-block">{t.auth.register.linkText}</span>
</Link>
</Button>
</div>
)}
</div>
);
};
|