From 261ab84b8466d06d342edff10dc4b80a4b785229 Mon Sep 17 00:00:00 2001 From: arctic_hen7 Date: Sun, 23 Jan 2022 07:48:01 +1100 Subject: [PATCH] docs(book): clarified dark mode with global state --- docs/next/en-US/reference/state/global.md | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/docs/next/en-US/reference/state/global.md b/docs/next/en-US/reference/state/global.md index 03a131a680..c73e91dbd3 100644 --- a/docs/next/en-US/reference/state/global.md +++ b/docs/next/en-US/reference/state/global.md @@ -4,6 +4,15 @@ As you've seen, Perseus has full support for reactive state in templates, but wh The essence of global state is that you can generate it at build-time (though with something like setting dark mode, you'll probably want to ignore whatever was set at build time until you know the browser's preferences) and access it seamlessly from any template. Just like usual [reactive state](:reference/state/rx), you can make it reactive with `#[make_rx(...)]`, and you essentially get app-wide MVC with just a few lines of code (and no extra dependencies, all this is completely built into Perseus). +
+How would I actually implement dark mode like this? + +Above is a contrived example. In reality, dark mode is set in two ways: the preference that the browser exposes and the user's own manual setting (usually through a toggle switch in the header or similar). You obviously don't want to start in light mode and then flicker to dark mode once you know the user's preference, that would be awful, so it's far better to rely on a class in the HTML (e.g. if `dark` is set on the ``, certain things should be styled in different ways) that you set based on a cookie that you've stored, falling back to the `prefers-color-scheme` if there's no cookie yet. Perseus is designed to load content and then make it interactive, so if you do this cookie-checking in your Wasm ode, you'll be too late to avoid that flicker, which is why it's better to either do this with a separate Wasm bundle, or with a quick bit of JS written directly into your `index.html` file. There are plenty of guides on how to achieve this online. + +The role of dark mode comes in in styling that toggle switch mostly, and whenever it changes, you should toggle the `dark` class on the `` or similar and update the global state. YOu could to the class toggling with a `create_effect` that listens for changes in the global state. So, in this case, global state actually isn't crucial, it just makes things cleaner and easier to set up. Unfortunately though, dark mode is irritating with any prerendering because you want to avoid that flicker. (That said, if you don't mind temporarily blinding your 3am users, do whatever you like!) + +
+ ## Example All the following examples are taken from [here](https://github.com/arctic-hen7/perseus/blob/main/examples/rx_state).