/ mission-control / src / components / Header.tsx
Header.tsx
 1  import { Link } from '@tanstack/react-router'
 2  import ThemeToggle from './ThemeToggle'
 3  
 4  export default function Header() {
 5    return (
 6      <header className="sticky top-0 z-50 border-b border-[var(--line)] bg-[var(--header-bg)] px-4 backdrop-blur-lg">
 7        <nav className="page-wrap flex flex-wrap items-center gap-x-3 gap-y-2 py-3 sm:py-4">
 8          <h2 className="m-0 flex-shrink-0 text-base font-semibold tracking-tight">
 9            <Link
10              to="/"
11              className="inline-flex items-center gap-2 rounded-full border border-[var(--chip-line)] bg-[var(--chip-bg)] px-3 py-1.5 text-sm text-[var(--sea-ink)] no-underline shadow-[0_8px_24px_rgba(30,90,72,0.08)] sm:px-4 sm:py-2"
12            >
13              <span className="h-2 w-2 rounded-full bg-[linear-gradient(90deg,#56c6be,#7ed3bf)]" />
14              TanStack Start
15            </Link>
16          </h2>
17  
18          <div className="ml-auto flex items-center gap-1.5 sm:ml-0 sm:gap-2">
19            <a
20              href="https://x.com/tan_stack"
21              target="_blank"
22              rel="noreferrer"
23              className="hidden rounded-xl p-2 text-[var(--sea-ink-soft)] transition hover:bg-[var(--link-bg-hover)] hover:text-[var(--sea-ink)] sm:block"
24            >
25              <span className="sr-only">Follow TanStack on X</span>
26              <svg viewBox="0 0 16 16" aria-hidden="true" width="24" height="24">
27                <path
28                  fill="currentColor"
29                  d="M12.6 1h2.2L10 6.48 15.64 15h-4.41L7.78 9.82 3.23 15H1l5.14-5.84L.72 1h4.52l3.12 4.73L12.6 1zm-.77 12.67h1.22L4.57 2.26H3.26l8.57 11.41z"
30                />
31              </svg>
32            </a>
33            <a
34              href="https://github.com/TanStack"
35              target="_blank"
36              rel="noreferrer"
37              className="hidden rounded-xl p-2 text-[var(--sea-ink-soft)] transition hover:bg-[var(--link-bg-hover)] hover:text-[var(--sea-ink)] sm:block"
38            >
39              <span className="sr-only">Go to TanStack GitHub</span>
40              <svg viewBox="0 0 16 16" aria-hidden="true" width="24" height="24">
41                <path
42                  fill="currentColor"
43                  d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.012 8.012 0 0 0 16 8c0-4.42-3.58-8-8-8z"
44                />
45              </svg>
46            </a>
47  
48            <ThemeToggle />
49          </div>
50  
51          <div className="order-3 flex w-full flex-wrap items-center gap-x-4 gap-y-1 pb-1 text-sm font-semibold sm:order-2 sm:w-auto sm:flex-nowrap sm:pb-0">
52            <Link
53              to="/"
54              className="nav-link"
55              activeProps={{ className: 'nav-link is-active' }}
56            >
57              Home
58            </Link>
59            <Link
60              to="/about"
61              className="nav-link"
62              activeProps={{ className: 'nav-link is-active' }}
63            >
64              About
65            </Link>
66            <a
67              href="https://tanstack.com/start/latest/docs/framework/react/overview"
68              className="nav-link"
69              target="_blank"
70              rel="noreferrer"
71            >
72              Docs
73            </a>
74          </div>
75        </nav>
76      </header>
77    )
78  }