feat: App component

This commit is contained in:
원더 2021-01-04 20:12:01 +09:00
parent 340bed616f
commit 9ec40a4bd2

View File

@ -1,16 +1,49 @@
import Head from 'next/head' import Head from 'next/head'
import type { AppProps /*, AppContext */ } from 'next/app' import type { AppProps } from 'next/app'
import { ThemeProvider } from 'next-themes'
const App = ({ Component, pageProps }: AppProps): JSX.Element => { import Navbar from '../components/Navbar'
import './app.css'
import '@fortawesome/fontawesome-free/css/all.css'
import { useEffect } from 'react'
let systemColor
export default function App({ Component, pageProps }: AppProps): JSX.Element {
console.log(
'%c' + 'KOREANBOTS',
'color: #3366FF; -webkit-text-stroke: 2px black; font-size: 72px; font-weight: bold;'
)
console.log(
'%c' + '이곳에 코드를 붙여넣으면 공격자에게 엑세스 토큰을 넘겨줄 수 있습니다!!',
'color: #ff0000; font-size: 20px; font-weight: bold;'
)
useEffect(() => {
try {
systemColor = window.matchMedia('(prefers-color-scheme: dark)')?.matches ? 'dark' : 'light'
} catch (e) {
systemColor = 'dark'
}
if (!localStorage.theme || !['dark', 'light'].includes(localStorage.theme))
localStorage.setItem('theme', systemColor)
}, [])
return ( return (
<> <ThemeProvider defaultTheme={systemColor} attribute="class" storageKey="theme">
<Head> <Head>
<meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Next.js TypeScript Quickstart</title> <title> </title>
<meta
name="description"
content="국내 디스코드봇들을 확인하고, 초대해보세요!"
data-react-helmet="true"
/>
<meta charSet="utf-8" />
<link rel="shortcut icon" href="/logo.png" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<meta name="theme-color" content="#3366FF" />
</Head> </Head>
<Navbar />
<Component {...pageProps} /> <Component {...pageProps} />
</> </ThemeProvider>
) )
} }
export default App