mirror of
https://github.com/nextcloud/all-in-one.git
synced 2026-05-21 10:50:10 +00:00
Agent-Logs-Url: https://github.com/nextcloud/all-in-one/sessions/d51a2637-5128-4c8a-a18c-a86085d2cb88 aio-interface: do not cache the containers, logs and setup screen as it shows credentials Signed-off-by: Simon L. <szaimen@e.mail.de> fix: address PR review comments - remove inline script (CSP), use default font string Agent-Logs-Url: https://github.com/nextcloud/all-in-one/sessions/62e290a3-94de-4988-aeb8-b577fec135a7 Co-Authored-By: szaimen <42591237+szaimen@users.noreply.github.com>
41 lines
1.6 KiB
JavaScript
41 lines
1.6 KiB
JavaScript
// Function to toggle theme
|
|
function toggleTheme() {
|
|
const currentTheme = document.documentElement.getAttribute('data-theme');
|
|
const newTheme = (currentTheme === 'dark') ? '' : 'dark'; // Toggle between no theme and dark theme
|
|
setThemeToDOM(newTheme);
|
|
localStorage.setItem('theme', newTheme);
|
|
|
|
// Change the icon based on the current theme
|
|
setThemeIcon(newTheme);
|
|
}
|
|
|
|
function setThemeToDOM(value) {
|
|
// Set the theme to the root document and all possible iframe documents (so they can adapt their styling, too).
|
|
const documents = [document, Array.from(document.querySelectorAll('iframe')).map((iframe) => iframe.contentDocument)].flat()
|
|
documents.forEach((doc) => doc.documentElement.setAttribute('data-theme', value));
|
|
}
|
|
|
|
function getSavedTheme() {
|
|
return localStorage.getItem('theme') ?? '';
|
|
}
|
|
|
|
// Function to apply theme-icon update
|
|
function setThemeIcon(theme) {
|
|
if (theme === 'dark') {
|
|
document.getElementById('theme-icon').textContent = '☀️'; // Sun icon for dark mode
|
|
} else {
|
|
document.getElementById('theme-icon').textContent = '🌙'; // Moon icon for light mode
|
|
}
|
|
}
|
|
|
|
// Immediately apply the saved theme to avoid flickering
|
|
setThemeToDOM(getSavedTheme());
|
|
|
|
// Apply theme when the page loads
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
setThemeIcon(getSavedTheme())
|
|
document.querySelector('button#theme-toggle')?.addEventListener('click', () => toggleTheme());
|
|
// Re-apply theme when the overlay-log iframe navigates (e.g. after a form submission).
|
|
document.querySelector('iframe#overlay-log')?.addEventListener('load', () => setThemeToDOM(getSavedTheme()));
|
|
});
|