Files
Trilium/apps/website/src/components/Header.tsx

82 lines
3.0 KiB
TypeScript
Raw Normal View History

2025-09-26 23:32:09 +03:00
import "./Header.css";
import { Link } from "./Button.js";
import { SocialButtons, SocialButton } from "./Footer.js";
import { useContext, useEffect, useMemo, useState } from "preact/hooks";
import { useLocation } from 'preact-iso';
2025-09-27 22:36:26 +03:00
import DownloadButton from './DownloadButton.js';
import githubIcon from "../assets/boxicons/bx-github.svg?raw";
2025-09-27 22:36:26 +03:00
import Icon from "./Icon.js";
import logoPath from "../assets/icon-color.svg";
2025-09-27 17:22:34 +03:00
import menuIcon from "../assets/boxicons/bx-menu.svg?raw";
import { LocaleContext } from "..";
import { useTranslation } from "react-i18next";
interface HeaderLink {
url: string;
text: string;
external?: boolean;
}
export function Header(props: {repoStargazersCount: number}) {
const { url } = useLocation();
const { t } = useTranslation();
const locale = useContext(LocaleContext);
2025-09-27 17:22:34 +03:00
const [ mobileMenuShown, setMobileMenuShown ] = useState(false);
const HEADER_LINKS = useMemo<HeaderLink[]>(() => [
{ url: "/get-started/", text: t("header.get-started") },
{ url: "https://docs.triliumnotes.org/", text: t("header.documentation"), external: true },
{ url: "/support-us/", text: t("header.support-us") }
], [ locale ]);
return (
<header>
<div class="content-wrapper">
2025-09-27 17:22:34 +03:00
<div class="first-row">
<a class="banner" href={`/${locale}/`}>
2025-09-27 22:26:41 +03:00
<img src={logoPath} width="300" height="300" alt="Trilium Notes logo" />&nbsp;<span>Trilium Notes</span>
2025-09-27 17:22:34 +03:00
</a>
2025-09-27 17:22:34 +03:00
<Link
href="#"
className="mobile-only menu-toggle"
onClick={(e) => {
e.preventDefault();
setMobileMenuShown(!mobileMenuShown)
}}
>
<Icon svg={menuIcon} />
</Link>
</div>
<nav className={`${mobileMenuShown ? "mobile-shown" : ""}`}>
{HEADER_LINKS.map(link => (
<Link
href={link.external ? link.url : `/${locale}${link.url}`}
className={url === link.url ? "active" : ""}
openExternally={link.external}
onClick={() => {
setMobileMenuShown(false);
}}
>{link.text}</Link>
))}
<SocialButtons className="mobile-only" withText />
</nav>
<div class="desktop-only repository-button">
<SocialButton
name="GitHub"
iconSvg={githubIcon}
counter={(props.repoStargazersCount / 1000).toFixed(1) + "K+"}
url="https://github.com/TriliumNext/Trilium"
/>
</div>
<DownloadButton />
</div>
</header>
);
}