|
|
<button id="theme-toggle" aria-label="Toggle color theme"> |
|
|
<svg |
|
|
class="icon light" |
|
|
width="20" |
|
|
height="20" |
|
|
viewBox="0 0 24 24" |
|
|
aria-hidden="true" |
|
|
focusable="false" |
|
|
fill="none" |
|
|
stroke="currentColor" |
|
|
stroke-width="2" |
|
|
stroke-linecap="round" |
|
|
stroke-linejoin="round" |
|
|
> |
|
|
<circle cx="12" cy="12" r="5"></circle> |
|
|
<line x1="12" y1="1" x2="12" y2="4"></line> |
|
|
<line x1="12" y1="20" x2="12" y2="23"></line> |
|
|
<line x1="1" y1="12" x2="4" y2="12"></line> |
|
|
<line x1="20" y1="12" x2="23" y2="12"></line> |
|
|
<line x1="4.22" y1="4.22" x2="6.34" y2="6.34"></line> |
|
|
<line x1="17.66" y1="17.66" x2="19.78" y2="19.78"></line> |
|
|
<line x1="4.22" y1="19.78" x2="6.34" y2="17.66"></line> |
|
|
<line x1="17.66" y1="6.34" x2="19.78" y2="4.22"></line> |
|
|
</svg> |
|
|
<svg |
|
|
class="icon dark" |
|
|
width="20" |
|
|
height="20" |
|
|
viewBox="0 0 24 24" |
|
|
aria-hidden="true" |
|
|
focusable="false" |
|
|
fill="none" |
|
|
stroke="currentColor" |
|
|
stroke-width="2" |
|
|
stroke-linecap="round" |
|
|
stroke-linejoin="round" |
|
|
> |
|
|
<path d="M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"></path> |
|
|
</svg> |
|
|
<script> |
|
|
const btn = document.getElementById("theme-toggle"); |
|
|
const media = |
|
|
window.matchMedia && window.matchMedia("(prefers-color-scheme: dark)"); |
|
|
const prefersDark = media && media.matches; |
|
|
const saved = localStorage.getItem("theme"); |
|
|
|
|
|
const apply = (mode) => { |
|
|
document.documentElement.dataset.theme = mode; |
|
|
}; |
|
|
|
|
|
|
|
|
apply(saved || (prefersDark ? "dark" : "light")); |
|
|
|
|
|
|
|
|
if (!saved && media) { |
|
|
const syncWithSystem = (e) => apply(e.matches ? "dark" : "light"); |
|
|
if (media.addEventListener) |
|
|
media.addEventListener("change", syncWithSystem); |
|
|
else if (media.addListener) media.addListener(syncWithSystem); |
|
|
} |
|
|
|
|
|
const toggleTheme = () => { |
|
|
const next = |
|
|
document.documentElement.dataset.theme === "dark" ? "light" : "dark"; |
|
|
localStorage.setItem("theme", next); |
|
|
apply(next); |
|
|
}; |
|
|
|
|
|
if (btn) { |
|
|
btn.addEventListener("click", toggleTheme); |
|
|
} |
|
|
</script> |
|
|
</button> |
|
|
|
|
|
<style> |
|
|
#theme-toggle { |
|
|
display: inline-flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
border: none; |
|
|
background: transparent; |
|
|
padding: 6px 10px; |
|
|
border-radius: 8px; |
|
|
cursor: pointer; |
|
|
color: var(--text-color) !important; |
|
|
} |
|
|
#theme-toggle .icon.dark { |
|
|
display: none; |
|
|
} |
|
|
[data-theme="dark"] #theme-toggle .icon.light { |
|
|
display: none; |
|
|
} |
|
|
[data-theme="dark"] #theme-toggle .icon.dark { |
|
|
display: inline; |
|
|
} |
|
|
#theme-toggle .icon { |
|
|
filter: none !important; |
|
|
} |
|
|
</style> |
|
|
|