-
Notifications
You must be signed in to change notification settings - Fork 13k
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
rustdoc: clarify theme settings #84539
Comments
That would be problematic when browsing documentation from the filesystem and not with a server because then, it'd not be possible to change the theme because the local storage is stored at a folder level. |
One way we could address that issue would be to make the settings page rendered by JS instead of a standalone HTML page. That would also allow all the other settings to be applied in the file:/// context. Another way would be to decide that certain features (like theme switching) only work locally if you use, e.g. `python -m http.server' so you can access the files at an HTTP URL. |
That could work I guess... I'm not super happy about adding more JS. Also, currently it's very easy to change the current theme, putting it into the setting page would make this more confusing I think. |
I left a related comment about this here. |
Doesn't this just mean that changing the theme is already broken when browsing via |
It depends on the browser. On Firefox the storage appears to be isolated per-file (in other words, yes, theme selection is broken on navigation between local files). On Chrome it seems to persist across various files. That would mean putting theme settings on the settings page would work fine on Chrome, but on Firefox it would further break the already-broken behavior. If you're in Firefox viewing a single page repeatedly, right now you can set the theme for that single page even though it won't take effect for neighboring pages. I don't think there's anything we can do to get Firefox to persist settings between different file:/// URLs. |
To be more precise, on firefox it's per-folder and not per-file.
I can confirm that there isn't anything which can be done... If only we could tell firefox "this is the root path so apply for all children"... So any JS-based solution won't work on firefox, and on chrome it's not much better iirc. |
In my local tests (Firefox 93.0, Linux), it's per-file. Steps to reproduce:
So is it okay by you moving the theme setting onto the settings page? Things would continue to work as they do today on Chrome. On Firefox, you would stop being able to set the theme page-at-a-time, but I think the current page-at-a-time functionality on Firefox is not very useful. |
I'm pretty sure that if we do that, people will simply complain because they can't change the theme anymore. And that would also prevent to have theme change which I quite enjoy locally. As for your scenario, I tried it locally but it worked fine. Weird... I don't seem to have any specific customization though... |
From MDN:
Undefined, great. |
@GuillaumeGomez and I discussed via PM on Zulip, and came to a compromise solution: We'll show the theme picker icon only when visiting a file:/// URL. That way we get a nice uncluttered UI on doc.rust-lang.org and docs.rs, but we don't lose the theme-picking functionality on local files. |
Right now, you can set theme options in two places, the paintbrush icon, and the settings page:
It's not clear how these are related. Does one override the other? Also, what is the "system theme"?
I propose that we move the paintbrush icon's functionality into the settings page, and overhaul the settings available there.
GitHub has put a lot of attention into their "dark mode" implementation and might make a good example for verbiage:
Following that example, the settings page should have a choice between "single theme" and "sync with system", with a single dropdown visible if you pick "single theme," and two dropdowns (for light/dark) visible if you pick "sync with system."
Prior work:
#77213
#79642
#77809
#77213
The text was updated successfully, but these errors were encountered: