mirror of
https://github.com/NoFxAiOS/nofx.git
synced 2026-07-04 11:30:58 +08:00
98 lines
3.6 KiB
TypeScript
98 lines
3.6 KiB
TypeScript
import { ReactNode } from 'react'
|
|
import { Outlet, useLocation } from 'react-router-dom'
|
|
import HeaderBar from '../components/HeaderBar'
|
|
import { Container } from '../components/Container'
|
|
import { useLanguage } from '../contexts/LanguageContext'
|
|
import { useAuth } from '../contexts/AuthContext'
|
|
import { t } from '../i18n/translations'
|
|
|
|
interface MainLayoutProps {
|
|
children?: ReactNode
|
|
}
|
|
|
|
export default function MainLayout({ children }: MainLayoutProps) {
|
|
const { language, setLanguage } = useLanguage()
|
|
const { user, logout } = useAuth()
|
|
const location = useLocation()
|
|
|
|
// 根据路径自动判断当前页面
|
|
const getCurrentPage = (): 'competition' | 'traders' | 'trader' | 'faq' => {
|
|
if (location.pathname === '/faq') return 'faq'
|
|
if (location.pathname === '/traders') return 'traders'
|
|
if (location.pathname === '/dashboard') return 'trader'
|
|
if (location.pathname === '/competition') return 'competition'
|
|
return 'competition' // 默认
|
|
}
|
|
|
|
return (
|
|
<div
|
|
className="min-h-screen"
|
|
style={{ background: '#0B0E11', color: '#EAECEF' }}
|
|
>
|
|
<HeaderBar
|
|
isLoggedIn={!!user}
|
|
currentPage={getCurrentPage()}
|
|
language={language}
|
|
onLanguageChange={setLanguage}
|
|
user={user}
|
|
onLogout={logout}
|
|
onPageChange={() => {
|
|
// React Router handles navigation now
|
|
}}
|
|
/>
|
|
|
|
{/* Main Content */}
|
|
<Container as="main" className="py-6 pt-24">
|
|
{children || <Outlet />}
|
|
</Container>
|
|
|
|
{/* Footer */}
|
|
<footer
|
|
className="mt-16"
|
|
style={{ borderTop: '1px solid #2B3139', background: '#181A20' }}
|
|
>
|
|
<Container
|
|
className="py-6 text-center text-sm"
|
|
style={{ color: '#5E6673' }}
|
|
>
|
|
<p>{t('footerTitle', language)}</p>
|
|
<p className="mt-1">{t('footerWarning', language)}</p>
|
|
<div className="mt-4">
|
|
<a
|
|
href="https://github.com/tinkle-community/nofx"
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
className="inline-flex items-center gap-2 px-3 py-2 rounded text-sm font-semibold transition-all hover:scale-105"
|
|
style={{
|
|
background: '#1E2329',
|
|
color: '#848E9C',
|
|
border: '1px solid #2B3139',
|
|
}}
|
|
onMouseEnter={(e) => {
|
|
e.currentTarget.style.background = '#2B3139'
|
|
e.currentTarget.style.color = '#EAECEF'
|
|
e.currentTarget.style.borderColor = '#F0B90B'
|
|
}}
|
|
onMouseLeave={(e) => {
|
|
e.currentTarget.style.background = '#1E2329'
|
|
e.currentTarget.style.color = '#848E9C'
|
|
e.currentTarget.style.borderColor = '#2B3139'
|
|
}}
|
|
>
|
|
<svg
|
|
width="18"
|
|
height="18"
|
|
viewBox="0 0 16 16"
|
|
fill="currentColor"
|
|
>
|
|
<path 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.013 8.013 0 0016 8c0-4.42-3.58-8-8-8z" />
|
|
</svg>
|
|
GitHub
|
|
</a>
|
|
</div>
|
|
</Container>
|
|
</footer>
|
|
</div>
|
|
)
|
|
}
|