Skip to content
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

Docs for disabling Dark Mode are incomplete #923

Open
3 tasks done
woodseowl opened this issue Dec 23, 2024 · 9 comments
Open
3 tasks done

Docs for disabling Dark Mode are incomplete #923

woodseowl opened this issue Dec 23, 2024 · 9 comments
Assignees

Comments

@woodseowl
Copy link

Flux version

v1.1.2

Livewire version

v3.5.12

What is the problem?

The docs for disabling dark mode explain you should update tailwind.config.js to use darkMode: null, however, a class="dark" is still added to the root <html> element.

Code snippets

I see this code added by Flux in the generated HTML for a page containing @fluxStyles:

<script>
    let appearance = window.localStorage.getItem('flux.appearance') || 'system'

    if (appearance === 'system') {
        appearance = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
    }

    appearance === 'dark' ? document.documentElement.classList.add('dark') : document.documentElement.classList.remove('dark')
</script>

How do you expect it to work?

I'd like to have the documentation also describe how to prevent the class from being added.

The way that I came up to do it is add the following before @fluxStyles:

    <script>
        window.localStorage.setItem('flux.appearance', 'none');
    </script>

Ideally, this would not be needed because the code would be able to detect that darkMode: null is set and then not inject the script. For the mean time, just getting better documentation would help.

Please confirm (incomplete submissions will not be addressed)

  • I have provided easy and step-by-step instructions to reproduce the bug.
  • I have provided code samples as text and NOT images.
  • I understand my bug report will be closed if I haven't met the criteria above.
@calebporzio
Copy link
Contributor

Ahhhh you're right - if someone enables dark mode, then tries to disable it, the key is left in localStorage and that bit of JS will bring ".dark" back when it shouldn't be. hmmm. @joshhanley ?

@woodseowl
Copy link
Author

if someone enables dark mode, then tries to disable it, the key is left in localStorage and that bit of JS will bring ".dark" back when it shouldn't be

Well, not quite that. I'm working with an app that specifically should never have dark mode enabled and needs to not have a "dark" class applied universally because we already have that class name in use for other purposes. The code injected by Flux adds "dark" as a class if someone has their system settings set to dark mode, regardless of whether darkMode is intended to be on within the app overall.

(As a side note to this, if there are namespace conflicts with "dark" as a class name in the site design, there's not really a way to use Flux dark mode selection. I did look at how Tailwind handles dark mode naming and saw that the dark mode selector could be customized with a different classname. I realize that's a lot of work to apply in Flux and not a solution for what I've reported in this issue, but maybe it's a long term idea.)

@igmltd
Copy link

igmltd commented Dec 24, 2024

@calebporzio, I do the following, could this be a solution?

#913

@joshhanley
Copy link
Member

@calebporzio yeah I think we should update the dark mode detector to account for that, and get it to clear local storage and remove any dark classes if it detects that Tailwind dark mode has been disabled.

@dicktornfeldt
Copy link

Having similar issue here. My system is set to dark mode, but Im building an app where I dont want the users to be able to switch between dark/light mode.

Setting tailwind.config.js to darkMode: null still adds a dark class to the html element which leads to my variant="primary" buttons to look like this instead of having a black background (among other unwanted stuff, nothing is saved in localstorage)
Image

@woodseowl
Copy link
Author

woodseowl commented Jan 2, 2025

@calebporzio, I do the following, could this be a solution?

#913

FYI, I had used the darkMode selector setting discussed in #913 as a solution. That used to work, but the most recent Flux (at the time I reported this issue) says to set darkMode: null in order to prevent Flux from managing it, but it still injects the script that adds class="dark" to the root html element (introduced with PR #899). The setting of the class is where the issue I've reported arises.

@joshhanley
Copy link
Member

Yeah the dark class should not be applied if the tailwind.config.js is set to darkMode: null. I've submitted a PR with a fix which will remove the class and also remove it from local storage if darkMode is not set to selector.

@alantrotter
Copy link

I think this might be another example of what @dicktornfeldt is mentioning above, styling not working correctly when darkMode is turned off:

with darkMode set to null, the 'current' flux:navlist.item ends up with white text and a white icon on a white background. Inspecting the page and removing 'dark' from the html element fixes the issue and the item displays correctly.

This is what a current home link looks like:

Image

@dicktornfeldt
Copy link

Personally I have temporarly fixed this by adding the following to end of resources/js/app.js

window.addEventListener("load", function () {
    document.documentElement.classList.remove("dark");
});

Maybe something for you @alantrotter ?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants