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

Add dark mode support to the HTML versions of the OpenAPI specs #4268

Open
wants to merge 14 commits into
base: main
Choose a base branch
from

Conversation

Bellangelo
Copy link
Member

Closes #3866

Except from adding the necessary CSS rules I have also moved it into its own file here: b3949bd

This declutters a little bit the md2html.js. Plus, we can also use the IDE for styling and formatting.

The CSS is heavily inspired by the work of @pavelkornev, see #3866 (comment)

End results: https://jsfiddle.net/gu23x9kb/

Copy link
Contributor

@ralfhandl ralfhandl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As @pavelkornev points out in #3866 (comment) this only works on my Mac if the system appearance is set to Dark. If it is set to Light, or set to Auto and is currently Light, then the switch doesn't work.

@Bellangelo
Copy link
Member Author

As @pavelkornev points out in #3866 (comment) this only works on my Mac if the system appearance is set to Dark. If it is set to Light, or set to Auto and is currently Light, then the switch doesn't work.

@ralfhandl Oh yes... I had encapsulated the code under the prefers-color-scheme which was running only on dark mode. Fixed in 973999a

@Bellangelo Bellangelo requested a review from ralfhandl December 19, 2024 11:32
@ralfhandl
Copy link
Contributor

Still doesn't work if system is in Light mode:
image

and
image

Background stays white, only text colors change.

Copy link
Contributor

@ralfhandl ralfhandl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On MacOS only works if system is in dark mode.

@Bellangelo
Copy link
Member Author

Bellangelo commented Dec 19, 2024

On MacOS only works if system is in dark mode.

@ralfhandl That's weird.. I am not getting the same results as you. I am testing it on a MacOS and it perfectly works with both Chrome and Safari. Could it be a browser setting? I will further look into it.

@Bellangelo
Copy link
Member Author

@ralfhandl I have managed to reproduce it with Firefox. The problem is that respec adds this link

<link rel="stylesheet" media="(prefers-color-scheme: dark)" href="https://www.w3.org/StyleSheets/TR/2021/dark.css">

Once again, due to the (prefers-color-scheme: dark) it doesn't work correctly. For this reason, i have copied/pasted the changes from the file into our main.css here: e25d753

Although, this seems to be fixing the issue it still loads unnecessarily the dark.css. Would it be ok if I changed the build.shto parse the output and remove it? Or are we ok with the extra request?

Note: I will fix the tests after we agree on the solution.

@ralfhandl
Copy link
Contributor

i have copied/pasted the changes from the file into our main.css

Is that necessary? I'd prefer to keep our CSS as slim as possible.

@ralfhandl
Copy link
Contributor

Would it be ok if I changed the build.shto parse the output and remove it?

Why not, if that works better?

@lornajane
Copy link
Contributor

@swaldron58 can you check if our theme fits this?

@Bellangelo
Copy link
Member Author

Bellangelo commented Dec 20, 2024

Is that necessary? I'd prefer to keep our CSS as slim as possible.

@ralfhandl I think so. The implementation depends on how Respec handles dark mode, which is by adding the darkmode class in the body tag. Since we apply the styling based on this class and not by checking the preferred mode the media="(prefers-color-scheme: dark)" becomes an obstacle.

Why not, if that works better?

@ralfhandl I have changed the build.sh in this commit and its tests here.

UPDATE:
It seems that we cannot stop the loading of the dark.css without changing quite a few things. The problem arises from the fixup.js which handles the dark mode toggle:

  /* Dark mode toggle */
  const darkCss = document.querySelector('link[rel~="stylesheet"][href^="https://www.w3.org/StyleSheets/TR/2021/dark"]');
  if (darkCss) {
    const colorScheme = localStorage.getItem("tr-theme") || "auto";
    const browserDarkMode = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
    const theme = colorScheme === "auto" ? (browserDarkMode ? "dark" : "light") : colorScheme;

    darkCss.disabled = theme === "light";
    darkCss.media = theme === "dark" ? "(prefers-color-scheme: dark)" : "";

Since the code runs only when the stylesheet exist, the dark mode toggle does not appear. To bypass this we would need to add our own javascript to replicate this behavior.

@Bellangelo Bellangelo requested a review from ralfhandl December 20, 2024 23:04
@ralfhandl
Copy link
Contributor

@Bellangelo Thanks for the detailed analysis!

It seems that we cannot stop the loading of the dark.css without changing quite a few things.

I'd prefer not to go that path, given how fiddly it was to get back from a modified ReSpec v21 to an unmodified ReSpec v35.

How far can we get with just additional CSS?

@Bellangelo
Copy link
Member Author

Bellangelo commented Jan 3, 2025

How far can we get with just additional CSS?

@ralfhandl What exactly do you mean? The dark mode should be working right now. Did you encounter perhaps any problems?

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

Successfully merging this pull request may close these issues.

Add dark mode support to the HTML versions of the OpenAPI specs
3 participants