@ -15,6 +15,13 @@ import {MenuContext} from 'components/useMenu';
import { Logo } from '../../Logo' ;
import { Logo } from '../../Logo' ;
import NavLink from './NavLink' ;
import NavLink from './NavLink' ;
declare global {
interface Window {
__theme : string ;
__setPreferredTheme : ( theme : string ) = > void ;
}
}
const feedbackIcon = (
const feedbackIcon = (
< svg
< svg
xmlns = "http://www.w3.org/2000/svg"
xmlns = "http://www.w3.org/2000/svg"
@ -92,14 +99,6 @@ function inferSection(pathname: string): 'learn' | 'reference' | 'home' {
export default function Nav() {
export default function Nav() {
const { pathname } = useRouter ( ) ;
const { pathname } = useRouter ( ) ;
const { isOpen , toggleOpen } = React . useContext ( MenuContext ) ;
const { isOpen , toggleOpen } = React . useContext ( MenuContext ) ;
// TODO: persist
// TODO: respect system pref
const [ isDark , setIsDark ] = React . useState ( ( ) = > {
if ( typeof document === 'undefined' ) {
return false ;
}
return document . documentElement . classList . contains ( 'dark' ) ;
} ) ;
const section = inferSection ( pathname ) ;
const section = inferSection ( pathname ) ;
function handleFeedback() {
function handleFeedback() {
@ -137,22 +136,29 @@ export default function Nav() {
Beta
Beta
< / div >
< / div >
< / div >
< / div >
< div className = "block dark:hidden" >
< button
< button
type = "button"
type = "button"
aria - label = { isDark ? 'Use Light Mode' : 'Use Dark Mode' }
aria - label = "Use Dark Mode"
onClick = { ( ) = > {
onClick = { ( ) = > {
if ( isDark ) {
window . __setPreferredTheme ( 'dark' ) ;
document . documentElement . classList . remove ( 'dark' ) ;
} }
setIsDark ( false ) ;
className = "hidden lg:flex items-center h-full pr-2" >
} else {
{ darkIcon }
document . documentElement . classList . add ( 'dark' ) ;
< / button >
setIsDark ( true ) ;
< / div >
}
< div className = "hidden dark:block" >
< button
type = "button"
aria - label = "Use Light Mode"
onClick = { ( ) = > {
window . __setPreferredTheme ( 'light' ) ;
} }
} }
className = "hidden lg:flex items-center h-full pr-2" >
className = "hidden lg:flex items-center h-full pr-2" >
{ isDark ? lightIcon : darkIcon }
{ lightIcon }
< / button >
< / button >
< / div >
< / div >
< / div >
< div className = "px-0 pt-2 w-full 2xl:max-w-xs hidden lg:flex items-center self-center border-b-0 lg:border-b border-border dark:border-border-dark" >
< div className = "px-0 pt-2 w-full 2xl:max-w-xs hidden lg:flex items-center self-center border-b-0 lg:border-b border-border dark:border-border-dark" >
< NavLink href = "/" isActive = { section === 'home' } >
< NavLink href = "/" isActive = { section === 'home' } >
Home
Home
@ -172,22 +178,29 @@ export default function Nav() {
onClick = { handleFeedback } >
onClick = { handleFeedback } >
{ feedbackIcon }
{ feedbackIcon }
< / button >
< / button >
< div className = "block dark:hidden" >
< button
< button
type = "button"
type = "button"
aria - label = { isDark ? 'Use Light Mode' : 'Use Dark Mode' }
aria - label = "Use Dark Mode"
onClick = { ( ) = > {
onClick = { ( ) = > {
if ( isDark ) {
window . __setPreferredTheme ( 'dark' ) ;
document . documentElement . classList . remove ( 'dark' ) ;
} }
setIsDark ( false ) ;
className = "flex lg:hidden items-center p-1 h-full ml-4 lg:ml-6" >
} else {
{ darkIcon }
document . documentElement . classList . add ( 'dark' ) ;
< / button >
setIsDark ( true ) ;
< / div >
}
< div className = "hidden dark:block" >
< button
type = "button"
aria - label = "Use Light Mode"
onClick = { ( ) = > {
window . __setPreferredTheme ( 'light' ) ;
} }
} }
className = "flex lg:hidden items-center p-1 h-full ml-4 lg:ml-6" >
className = "flex lg:hidden items-center p-1 h-full ml-4 lg:ml-6" >
{ isDark ? lightIcon : darkIcon }
{ lightIcon }
< / button >
< / button >
< / div >
< / div >
< / div >
< / nav >
< / nav >
) ;
) ;
}
}