import clsx from 'clsx' import Link from 'next/link' import Image from 'next/image' import { useUser } from '../hooks/use-user' import { formatMoney } from '../lib/util/format' import { Row } from './layout/row' import { firebaseLogin, firebaseLogout, User } from '../lib/firebase/users' import { MenuButton } from './menu' const hoverClasses = 'hover:underline hover:decoration-indigo-400 hover:decoration-2' function getNavigationOptions(user: User, options: { mobile: boolean }) { const { mobile } = options return [ { name: 'Home', href: '/', }, ...(mobile ? [ { name: 'About', href: '/about' }, { name: 'Create a market', href: '/create', }, ] : []), { name: 'Your bets', href: '/bets', }, { name: 'Your markets', href: `/${user.username}`, }, { name: 'Sign out', href: '#', onClick: () => firebaseLogout(), }, ] } function ProfileSummary(props: { user: User }) { const { user } = props return (
{user.name}
{formatMoney(user.balance)}
) } function SignedInHeaders(props: { user: User; themeClasses?: string }) { const { user, themeClasses } = props return ( <> } /> } /> ) } function SignedOutHeaders(props: { themeClasses?: string }) { const { themeClasses } = props return ( <>
Sign in
) } export function Header(props: { darkBackground?: boolean className?: string children?: any }) { const { darkBackground, className, children } = props const user = useUser() const themeClasses = clsx(darkBackground && 'text-white', hoverClasses) return ( ) }