-
-
Notifications
You must be signed in to change notification settings - Fork 577
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Navigation bar color flickers on page change #138
Comments
Not the most elegant solution, but I ended up doing the following:
function setPreference(isThemeBtnClicked) {
localStorage.setItem("theme", themeValue);
reflectPreference();
changeThemeColorContent(isThemeBtnClicked);
toggleGiscusTheme();
}
function changeThemeColorContent(isThemeBtnClicked) {
const themeColorElement = document.querySelector("meta[name='theme-color']")
if (themeValue === "dark") {
themeColorElement?.setAttribute("content", "rgb(16, 23, 42)");
} else if (isThemeBtnClicked && themeValue === "light") {
themeColorElement?.setAttribute("content", "rgb(246, 238, 225)");
}
}
window.onload = () => {
function setThemeFeature() {
// set on load so screen readers can get the latest value on the button
reflectPreference();
changeThemeColorContent();
// now this script can find and listen for clicks on the control
document.querySelector("#theme-btn")?.addEventListener("click", () => {
themeValue = themeValue === "light" ? "dark" : "light";
setPreference(isThemeBtnClicked = true);
});
}
setThemeFeature();
// Runs on view transitions navigation
document.addEventListener("astro:after-swap", setThemeFeature);
}; It's true that the navigation bar still flickers when loading a new page in dark mode on mobile, but at least now it won't flicker when the light theme is set. Another solution would be to use
I won't make a pull request with these changes, as I don't think they are the most optimal solution. I wish it would be valid to set the value of the content attribute to |
Unfortunately, I cannot reproduce this issue on my browsers. function reflectPreference() {
document.firstElementChild.setAttribute("data-theme", themeValue);
document.querySelector("#theme-btn")?.setAttribute("aria-label", themeValue);
const metaThemeColor =
themeValue === "light" ? `rgb(251, 254, 251)` : `rgb(33, 39, 55)`; // here, you can get these colors from base.css in your project
document
.querySelector("meta[name='theme-color']")
?.setAttribute("content", metaThemeColor);
} In the above function, you can hard-code /* file: base.css */
html[data-theme="light"] {
--color-fill: 251, 254, 251; /* 👈🏻 get this value for light theme */
--color-text-base: 40, 39, 40;
--color-accent: 0, 108, 172;
--color-card: 230, 230, 230;
--color-card-muted: 205, 205, 205;
--color-border: 236, 233, 233;
}
html[data-theme="dark"] {
--color-fill: 33, 39, 55; /* 👈🏻 get this value for dark theme */
--color-text-base: 234, 237, 243;
--color-accent: 255, 107, 1;
--color-card: 52, 63, 96;
--color-card-muted: 138, 51, 2;
--color-border: 171, 75, 8;
} In AstroPaper, I didn't hard-code those values intentionally. This is because AstroPaper, as a template for various users, has no ability to know which color schemes the user would configure and customize. So, it is better to get the If
|
You can reproduce the issue using Chrome with the light theme on Android. EDIT: video_2023-10-06_10-01-58.mp4 |
It's a bit hard to reproduce since I don't find anything like that on iOS. |
The flickering is still present with the code you provided. Let me know if I can help with anything else. |
I can confirm the issue. I tested this on my Samsung A52s 5G phone, and the navigation bar color flickers when pages change. |
When changing pages on a mobile device, the color of the navigation bar changes from white to the background color of the body, which is annoying and detrimental to the UX. I've tried to fix this with no luck yet, but if I manage to solve it, I'll make a pull request.
The problem might be in this code of the
toggle-theme.js
file, because the value of thetheme-color
is only changed if the body exists. That is, when the page is loaded.The text was updated successfully, but these errors were encountered: