mirror of
https://github.com/nextcloud/all-in-one.git
synced 2025-12-19 22:16:49 +00:00
Merge pull request #5434 from nextcloud/ernolf/darkmode-fix
aio-interface: fix dark-mode
This commit is contained in:
commit
327c91d0b7
5 changed files with 32 additions and 24 deletions
|
|
@ -14,6 +14,7 @@
|
||||||
--color-info: #0071ad;
|
--color-info: #0071ad;
|
||||||
--color-info-hover: #00aaef;
|
--color-info-hover: #00aaef;
|
||||||
--color-border-maxcontrast: #7d7d7d;
|
--color-border-maxcontrast: #7d7d7d;
|
||||||
|
--color-loader: #f3f3f3;
|
||||||
--border: .5px;
|
--border: .5px;
|
||||||
--border-hover: 2px;
|
--border-hover: 2px;
|
||||||
--border-radius: 7px;
|
--border-radius: 7px;
|
||||||
|
|
@ -35,6 +36,7 @@
|
||||||
--color-error-text: #ff8080;
|
--color-error-text: #ff8080;
|
||||||
--color-info: #00aeff;
|
--color-info: #00aeff;
|
||||||
--color-info-hover: #33beff;
|
--color-info-hover: #33beff;
|
||||||
|
--color-loader: var(--color-border-maxcontrast);
|
||||||
--border-hover: var(--border);
|
--border-hover: var(--border);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -235,6 +237,7 @@ select:hover {
|
||||||
textarea {
|
textarea {
|
||||||
border-radius: var(--border-radius);
|
border-radius: var(--border-radius);
|
||||||
border: .5px solid var(--color-main-border);
|
border: .5px solid var(--color-main-border);
|
||||||
|
max-width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type="text"]:focus,
|
input[type="text"]:focus,
|
||||||
|
|
@ -279,7 +282,7 @@ html[data-theme="dark"] ::-webkit-scrollbar-track {
|
||||||
background-color: var(--color-main-background);
|
background-color: var(--color-main-background);
|
||||||
border-radius: var(--border-radius-large);
|
border-radius: var(--border-radius-large);
|
||||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||||
max-height: calc(100dvh - 40px);
|
max-height: calc(100dvh - 50px);
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -385,7 +388,7 @@ label {
|
||||||
}
|
}
|
||||||
|
|
||||||
.loader {
|
.loader {
|
||||||
border: 16px solid #f3f3f3;
|
border: 16px solid var(--color-loader);
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
border-top: 16px solid var(--color-nextcloud-blue);
|
border-top: 16px solid var(--color-nextcloud-blue);
|
||||||
width: 120px;
|
width: 120px;
|
||||||
|
|
@ -418,6 +421,7 @@ label {
|
||||||
font-size: 36px; /* Adjust font size */
|
font-size: 36px; /* Adjust font size */
|
||||||
cursor: pointer; /* Change cursor to pointer */
|
cursor: pointer; /* Change cursor to pointer */
|
||||||
outline: none;
|
outline: none;
|
||||||
|
z-index: 9999; /* Ensures the icon is on top of every layer */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Icon styling: default state */
|
/* Icon styling: default state */
|
||||||
|
|
@ -449,7 +453,6 @@ label {
|
||||||
position: relative; /* Ensures stacking order */
|
position: relative; /* Ensures stacking order */
|
||||||
filter: grayscale(0%); /* Restore full color */
|
filter: grayscale(0%); /* Restore full color */
|
||||||
opacity: 1; /* Fully visible on hover */
|
opacity: 1; /* Fully visible on hover */
|
||||||
z-index: 1; /* Ensures the icon is on top of the shadow */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Inner glow when hovered */
|
/* Inner glow when hovered */
|
||||||
|
|
@ -461,4 +464,10 @@ label {
|
||||||
/* Remove hover effects when not hovering */
|
/* Remove hover effects when not hovering */
|
||||||
#theme-toggle:not(:hover) #theme-icon {
|
#theme-toggle:not(:hover) #theme-icon {
|
||||||
opacity: 0.6; /* Slightly transparent */
|
opacity: 0.6; /* Slightly transparent */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 800px) {
|
||||||
|
.container {
|
||||||
|
margin: 50px auto 0px auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
// Function to toggle theme
|
// Function to toggle theme
|
||||||
function toggleTheme() {
|
function toggleTheme() {
|
||||||
const currentTheme = document.documentElement.getAttribute('data-theme');
|
const currentTheme = document.documentElement.getAttribute('data-theme');
|
||||||
const newTheme = (currentTheme === 'dark') ? 'light' : 'dark';
|
const newTheme = (currentTheme === 'dark') ? '' : 'dark'; // Toggle between no theme and dark theme
|
||||||
document.documentElement.setAttribute('data-theme', newTheme);
|
document.documentElement.setAttribute('data-theme', newTheme);
|
||||||
localStorage.setItem('theme', newTheme);
|
localStorage.setItem('theme', newTheme);
|
||||||
|
|
||||||
|
|
@ -13,14 +13,14 @@ function toggleTheme() {
|
||||||
// Function to apply saved theme from localStorage
|
// Function to apply saved theme from localStorage
|
||||||
function applySavedTheme() {
|
function applySavedTheme() {
|
||||||
const savedTheme = localStorage.getItem('theme');
|
const savedTheme = localStorage.getItem('theme');
|
||||||
if (savedTheme) {
|
if (savedTheme === 'dark') {
|
||||||
document.documentElement.setAttribute('data-theme', savedTheme);
|
document.documentElement.setAttribute('data-theme', 'dark');
|
||||||
|
document.getElementById('theme-icon').textContent = '☀️'; // Sun icon for dark mode
|
||||||
// Ensure the icon is set correctly based on the saved theme
|
} else {
|
||||||
const themeIcon = document.getElementById('theme-icon');
|
document.documentElement.removeAttribute('data-theme'); // Default to light theme (no data-theme)
|
||||||
themeIcon.textContent = savedTheme === 'dark' ? '☀️' : '🌙';
|
document.getElementById('theme-icon').textContent = '🌙'; // Moon icon for light mode
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Apply theme when the page loads
|
// Immediately apply the saved theme
|
||||||
document.addEventListener('DOMContentLoaded', applySavedTheme);
|
applySavedTheme();
|
||||||
|
|
|
||||||
|
|
@ -683,7 +683,4 @@
|
||||||
|
|
||||||
</main>
|
</main>
|
||||||
</div>
|
</div>
|
||||||
<div id="overlay">
|
{% endblock %}
|
||||||
<div class="loader"></div>
|
|
||||||
</div>
|
|
||||||
{% endblock %}
|
|
||||||
|
|
|
||||||
|
|
@ -4,13 +4,18 @@
|
||||||
<link rel="stylesheet" href="/style.css?v3" media="all" />
|
<link rel="stylesheet" href="/style.css?v3" media="all" />
|
||||||
<link rel="icon" href="/img/favicon.png">
|
<link rel="icon" href="/img/favicon.png">
|
||||||
<script type="text/javascript" src="forms.js"></script>
|
<script type="text/javascript" src="forms.js"></script>
|
||||||
|
<script type="text/javascript" src="toggle-dark-mode.js"></script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div class="wrapper">
|
<div class="wrapper">
|
||||||
{% block body %}{% endblock %}
|
{% block body %}{% endblock %}
|
||||||
</div>
|
</div>
|
||||||
<button id="theme-toggle" onclick="toggleTheme()"><span id="theme-icon"/></button>
|
<div id="overlay">
|
||||||
<script type="text/javascript" src="toggle-dark-mode.js"></script>
|
<div class="loader"></div>
|
||||||
|
</div>
|
||||||
|
<button id="theme-toggle" onclick="toggleTheme()">
|
||||||
|
<span id="theme-icon">🌙</span>
|
||||||
|
</button>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,4 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
<script type="text/javascript" src="before-unload.js"></script>
|
<script type="text/javascript" src="before-unload.js"></script>
|
||||||
<div id="overlay">
|
{% endblock %}
|
||||||
<div class="loader"></div>
|
|
||||||
</div>
|
|
||||||
{% endblock %}
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue