2024-09-05 22:29:12 +02:00
|
|
|
import { Link, useFetcher } from "@remix-run/react";
|
|
|
|
import Meta from "~/lib/api/meta";
|
2024-09-25 15:14:48 +02:00
|
|
|
import { User } from "~/lib/api/user";
|
2024-09-05 22:29:12 +02:00
|
|
|
|
2024-09-15 16:48:22 +02:00
|
|
|
import { Nav, NavDropdown } from "react-bootstrap";
|
2024-09-10 20:33:22 +02:00
|
|
|
import { useTranslation } from "react-i18next";
|
2024-09-15 16:48:22 +02:00
|
|
|
import BaseNavbar from "~/components/nav/BaseNavbar";
|
2024-09-05 22:29:12 +02:00
|
|
|
|
|
|
|
export default function MainNavbar({
|
|
|
|
user,
|
|
|
|
}: {
|
|
|
|
meta: Meta;
|
|
|
|
user?: User;
|
|
|
|
}) {
|
|
|
|
const fetcher = useFetcher();
|
2024-09-10 20:33:22 +02:00
|
|
|
const { t } = useTranslation();
|
2024-09-05 22:29:12 +02:00
|
|
|
|
|
|
|
const userMenu = user ? (
|
|
|
|
<NavDropdown title={<>@{user.username}</>} align="end">
|
|
|
|
<NavDropdown.Item as={Link} to={`/@${user.username}`}>
|
2024-09-10 20:33:22 +02:00
|
|
|
{t("navbar.view-profile")}
|
2024-09-05 22:29:12 +02:00
|
|
|
</NavDropdown.Item>
|
|
|
|
<NavDropdown.Item as={Link} to="/settings">
|
2024-09-10 20:33:22 +02:00
|
|
|
{t("navbar.settings")}
|
2024-09-05 22:29:12 +02:00
|
|
|
</NavDropdown.Item>
|
|
|
|
<NavDropdown.Divider />
|
2024-09-10 20:33:22 +02:00
|
|
|
<fetcher.Form method="POST" action="/auth/log-out">
|
|
|
|
<NavDropdown.Item as="button" type="submit">
|
|
|
|
{t("navbar.log-out")}
|
|
|
|
</NavDropdown.Item>
|
|
|
|
</fetcher.Form>
|
2024-09-05 22:29:12 +02:00
|
|
|
</NavDropdown>
|
|
|
|
) : (
|
2024-09-10 21:24:40 +02:00
|
|
|
<Nav.Link to="/auth/log-in" as={Link}>
|
2024-09-10 20:33:22 +02:00
|
|
|
{t("navbar.log-in")}
|
2024-09-05 22:29:12 +02:00
|
|
|
</Nav.Link>
|
|
|
|
);
|
2024-09-25 15:14:48 +02:00
|
|
|
|
2024-09-05 22:29:12 +02:00
|
|
|
return (
|
2024-09-25 15:14:48 +02:00
|
|
|
<BaseNavbar>
|
2024-09-15 16:48:22 +02:00
|
|
|
{userMenu}
|
|
|
|
</BaseNavbar>
|
2024-09-05 22:29:12 +02:00
|
|
|
);
|
|
|
|
}
|