mirror of
https://github.com/woodchen-ink/nezha-dash-v1.git
synced 2025-07-18 01:21:56 +08:00
127 lines
3.3 KiB
HTML
127 lines
3.3 KiB
HTML
<!doctype html>
|
|
<html>
|
|
<head>
|
|
<script>
|
|
// 在页面渲染前就执行主题初始化
|
|
try {
|
|
const storageKey = "vite-ui-theme"
|
|
let theme = localStorage.getItem(storageKey)
|
|
if (theme === "system" || !theme) {
|
|
theme = window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light"
|
|
}
|
|
document.documentElement.classList.add(theme)
|
|
} catch (e) {
|
|
document.documentElement.classList.add("light")
|
|
}
|
|
</script>
|
|
<style>
|
|
/* Prevent FOUC in Safari */
|
|
html:not(.dark):not(.light) * {
|
|
visibility: hidden;
|
|
}
|
|
|
|
:root {
|
|
color-scheme: light;
|
|
--bg: #ffffff;
|
|
}
|
|
|
|
html.dark {
|
|
color-scheme: dark;
|
|
--bg: #242424;
|
|
}
|
|
|
|
html.light {
|
|
color-scheme: light;
|
|
--bg: #ffffff;
|
|
}
|
|
|
|
html {
|
|
background-color: var(--bg) !important;
|
|
}
|
|
|
|
body {
|
|
background-color: var(--bg) !important;
|
|
}
|
|
|
|
#root {
|
|
background-color: var(--bg) !important;
|
|
visibility: hidden;
|
|
}
|
|
|
|
#root.loaded {
|
|
visibility: visible;
|
|
animation: fadein 0.2s;
|
|
}
|
|
|
|
@keyframes fadein {
|
|
from {
|
|
opacity: 0;
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
</style>
|
|
<script>
|
|
;(function () {
|
|
const storageKey = "vite-ui-theme"
|
|
const theme = localStorage.getItem(storageKey) || "system"
|
|
const root = document.documentElement
|
|
|
|
function updateThemeColor(isDark) {
|
|
const themeColor = isDark ? "#242424" : "#fafafa"
|
|
document.querySelector('meta[name="theme-color"]')?.setAttribute("content", themeColor)
|
|
}
|
|
|
|
function setTheme(newTheme) {
|
|
root.classList.remove("light", "dark")
|
|
root.classList.add(newTheme)
|
|
updateThemeColor(newTheme === "dark")
|
|
}
|
|
|
|
if (theme === "system") {
|
|
const systemTheme = window.matchMedia("(prefers-color-scheme: dark)").matches
|
|
? "dark"
|
|
: "light"
|
|
setTheme(systemTheme)
|
|
|
|
window.matchMedia("(prefers-color-scheme: dark)").addEventListener("change", (e) => {
|
|
setTheme(e.matches ? "dark" : "light")
|
|
})
|
|
} else {
|
|
setTheme(theme)
|
|
}
|
|
|
|
// Add loaded class after React has mounted
|
|
window.addEventListener("load", () => {
|
|
const root = document.getElementById("root")
|
|
if (root) {
|
|
// 使用 RAF 确保在下一帧渲染
|
|
requestAnimationFrame(() => {
|
|
requestAnimationFrame(() => {
|
|
root.classList.add("loaded")
|
|
})
|
|
})
|
|
}
|
|
})
|
|
})()
|
|
</script>
|
|
<meta charset="UTF-8" />
|
|
<link rel="icon" type="image/png" href="/apple-touch-icon.png" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
<title>NEZHA</title>
|
|
<link
|
|
rel="stylesheet"
|
|
href="https://fastly.jsdelivr.net/gh/lipis/flag-icons@7.0.0/css/flag-icons.min.css"
|
|
/>
|
|
<link
|
|
rel="stylesheet"
|
|
href="https://fastly.jsdelivr.net/npm/font-logos@1/assets/font-logos.css"
|
|
/>
|
|
</head>
|
|
<body>
|
|
<div id="root"></div>
|
|
<script type="module" src="/src/main.tsx"></script>
|
|
</body>
|
|
</html>
|