2024-04-01 18:59:28 +02:00
|
|
|
/*!
|
|
|
|
* Color mode toggler for Bootstrap's docs (https://getbootstrap.com/)
|
|
|
|
* Copyright 2011-2024 The Bootstrap Authors
|
|
|
|
* Licensed under the Creative Commons Attribution 3.0 Unported License.
|
2024-04-19 14:00:49 +02:00
|
|
|
* Modified to work with a simpler checkbox toggle & support prettify CSS themes
|
2024-04-01 18:59:28 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
(() => {
|
|
|
|
'use strict'
|
|
|
|
|
|
|
|
const getStoredTheme = () => localStorage.getItem('theme')
|
|
|
|
const setStoredTheme = theme => localStorage.setItem('theme', theme)
|
|
|
|
const getPreferredTheme = () => window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
|
|
|
|
|
|
|
|
const getStoredPreferredTheme = () => {
|
|
|
|
const storedTheme = getStoredTheme()
|
|
|
|
if (storedTheme) {
|
|
|
|
return storedTheme
|
|
|
|
}
|
|
|
|
return getPreferredTheme()
|
|
|
|
}
|
|
|
|
|
2024-04-19 14:00:49 +02:00
|
|
|
const delStoredPrettifyTheme = () => localStorage.removeItem('themePrettify')
|
|
|
|
const getStoredPrettifyTheme = () => localStorage.getItem('themePrettify')
|
|
|
|
const setStoredPrettifyTheme = theme => localStorage.setItem('themePrettify', theme)
|
|
|
|
|
|
|
|
const getPrettifyThemeLink = () => {
|
|
|
|
for (const sheet of document.getElementsByTagName('link')) {
|
|
|
|
if (sheet.rel === 'stylesheet' && sheet.href.includes('css/prettify/') && !sheet.href.includes('css/prettify/prettify.css')) {
|
|
|
|
return sheet
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
|
2024-04-01 18:59:28 +02:00
|
|
|
const setTheme = theme => {
|
2024-04-19 14:00:49 +02:00
|
|
|
const preferredTheme = theme === 'auto' ? getPreferredTheme() : theme
|
|
|
|
document.documentElement.setAttribute('data-bs-theme', preferredTheme)
|
|
|
|
const sheetPrettify = getPrettifyThemeLink()
|
|
|
|
if (sheetPrettify) {
|
|
|
|
sheetPrettify.remove()
|
|
|
|
}
|
|
|
|
const link = document.createElement('link')
|
|
|
|
link.rel = 'stylesheet'
|
|
|
|
if (preferredTheme === 'dark') {
|
|
|
|
link.href = 'css/prettify/sons-of-obsidian.css'
|
|
|
|
document.head.appendChild(link)
|
2024-04-01 18:59:28 +02:00
|
|
|
} else {
|
2024-04-19 14:00:49 +02:00
|
|
|
const themePrettify = getStoredPrettifyTheme()
|
|
|
|
if (themePrettify) {
|
|
|
|
link.href = themePrettify
|
|
|
|
document.head.appendChild(link)
|
|
|
|
}
|
2024-04-01 18:59:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', () => {
|
|
|
|
const storedTheme = getStoredTheme()
|
|
|
|
if (storedTheme !== 'light' && storedTheme !== 'dark') {
|
|
|
|
setTheme(getStoredPreferredTheme())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
window.addEventListener('DOMContentLoaded', () => {
|
2024-04-19 14:00:49 +02:00
|
|
|
const sheetPrettify = getPrettifyThemeLink()
|
|
|
|
if (sheetPrettify) {
|
|
|
|
setStoredPrettifyTheme(sheetPrettify.href)
|
|
|
|
} else {
|
|
|
|
delStoredPrettifyTheme()
|
|
|
|
}
|
2024-04-01 18:59:28 +02:00
|
|
|
const toggle = document.querySelector('#bd-theme')
|
2024-06-13 20:00:26 +02:00
|
|
|
const theme = getStoredPreferredTheme()
|
|
|
|
setTheme(theme)
|
|
|
|
toggle.checked = (theme === 'dark')
|
2024-04-01 18:59:28 +02:00
|
|
|
toggle.addEventListener('change', (event) => {
|
|
|
|
const theme = event.currentTarget.checked ? 'dark' : 'light'
|
|
|
|
setStoredTheme(theme)
|
|
|
|
setTheme(theme)
|
|
|
|
event.currentTarget.focus()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})()
|