2023-07-05 11:23:16 +00:00
|
|
|
// Set darkmode
|
|
|
|
document.getElementById('mode').addEventListener('click', () => {
|
2023-09-04 13:53:20 +00:00
|
|
|
let isDarkTheme = document.body.classList.contains('dark');
|
|
|
|
setColorTheme(!isDarkTheme ? "dark" : "light");
|
2023-07-05 11:23:16 +00:00
|
|
|
});
|
2023-09-04 13:53:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
let preferDarkTheme = prefersDarkMode();
|
|
|
|
let theme = localStorage.getItem('theme');
|
|
|
|
if (theme !== null) {
|
|
|
|
setColorTheme(theme);
|
|
|
|
} else {
|
|
|
|
setColorTheme(preferDarkTheme ? "dark" : "light");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the media query list object for the prefers-color-scheme media feature
|
|
|
|
const colorSchemeQueryList = window.matchMedia("(prefers-color-scheme: dark)");
|
|
|
|
// Add an event listener for the change event
|
|
|
|
colorSchemeQueryList.addEventListener("change", handleColorSchemeChange);
|
|
|
|
|
|
|
|
|
|
|
|
function setColorTheme(theme) {
|
|
|
|
if (theme === "dark") {
|
|
|
|
document.body.classList.add('dark');
|
|
|
|
switchClanLogo("white");
|
|
|
|
localStorage.setItem('theme', 'dark');
|
|
|
|
} else {
|
|
|
|
document.body.classList.remove('dark');
|
|
|
|
switchClanLogo("dark");
|
|
|
|
localStorage.setItem('theme', 'light');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// A function that returns true if the user prefers dark mode, false otherwise
|
|
|
|
function prefersDarkMode() {
|
|
|
|
// Check if the browser supports the prefers-color-scheme media query
|
|
|
|
if (window.matchMedia) {
|
|
|
|
// Get the current value of the media query
|
|
|
|
let colorScheme = window.matchMedia("(prefers-color-scheme: dark)");
|
|
|
|
// Return true if the media query matches, false otherwise
|
|
|
|
return colorScheme.matches;
|
|
|
|
} else {
|
|
|
|
// If the browser does not support the media query, return false by default
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function switchClanLogo(theme) {
|
|
|
|
let favs = document.getElementsByClassName("favicon");
|
|
|
|
for (item of favs) {
|
|
|
|
if (theme === "white")
|
|
|
|
{
|
|
|
|
item.href = item.href.replace("dark-favicon", "white-favicon")
|
|
|
|
} else {
|
|
|
|
item.href = item.href.replace("white-favicon", "dark-favicon")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let clogos = document.getElementsByClassName("clogo");
|
|
|
|
for (item of clogos) {
|
|
|
|
if (theme === "white")
|
|
|
|
{
|
|
|
|
item.src = item.src.replace("dark", "white")
|
|
|
|
} else {
|
|
|
|
item.src = item.src.replace("white", "dark")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// A function that executes some logic based on the color scheme preference
|
|
|
|
function handleColorSchemeChange(e) {
|
|
|
|
if (e.matches) {
|
|
|
|
// The user prefers dark mode
|
|
|
|
setColorTheme("dark");
|
|
|
|
} else {
|
|
|
|
// The user prefers light mode
|
|
|
|
setColorTheme("light");
|
|
|
|
}
|
2023-07-05 11:23:16 +00:00
|
|
|
}
|
2024-03-19 05:13:33 +00:00
|
|
|
|
|
|
|
// Function to resize all video elements to match their parent article's width
|
|
|
|
function resizeVideosToMatchArticleWidth() {
|
|
|
|
// Function to adjust video sizes
|
|
|
|
function adjustVideoSizes() {
|
|
|
|
// Find all video elements
|
|
|
|
const videos = document.querySelectorAll('video');
|
|
|
|
|
|
|
|
videos.forEach(video => {
|
|
|
|
// Find the closest parent article element
|
|
|
|
const article = video.closest('article');
|
|
|
|
if (!article) return; // Skip if no parent article found
|
|
|
|
|
|
|
|
// Calculate new video height to maintain aspect ratio
|
|
|
|
const aspectRatio = video.videoHeight / video.videoWidth;
|
|
|
|
const newWidth = article.clientWidth; // Width of the parent article
|
|
|
|
const newHeight = newWidth * aspectRatio;
|
|
|
|
|
|
|
|
// Set new width and height on the video
|
|
|
|
video.style.width = `${newWidth}px`;
|
|
|
|
video.style.height = `${newHeight}px`;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Adjust video sizes on load
|
|
|
|
document.addEventListener('DOMContentLoaded', adjustVideoSizes);
|
|
|
|
|
|
|
|
// Adjust video sizes on window resize
|
|
|
|
window.onresize = adjustVideoSizes;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Call the function to initialize the resizing
|
|
|
|
resizeVideosToMatchArticleWidth();
|