From dba7932e3ed1cdbc980b7ad352f15adde5f37294 Mon Sep 17 00:00:00 2001 From: Wez Furlong Date: Thu, 14 Jul 2022 16:44:00 -0700 Subject: [PATCH] add wezterm.gui.get_appearance to retrieve dark mode This simplifies the "change scheme based on dark mode" example a lot. This was previously impossible to do because we didn't have a lua module associated with the gui until recently, so the only way to reference a gui-related object was via an event callback. refs: https://github.com/wez/wezterm/issues/2258 --- docs/changelog.md | 1 + docs/config/lua/wezterm.gui/get_appearance.md | 41 +++++++++++++++++++ docs/config/lua/window/get_appearance.md | 2 + lua-api-crates/window-funcs/src/lib.rs | 15 ++++++- wezterm-gui/src/frontend.rs | 4 ++ 5 files changed, 62 insertions(+), 1 deletion(-) create mode 100644 docs/config/lua/wezterm.gui/get_appearance.md diff --git a/docs/changelog.md b/docs/changelog.md index 73d1e03e6e8..87e92e3ba99 100644 --- a/docs/changelog.md +++ b/docs/changelog.md @@ -21,6 +21,7 @@ As features stabilize some brief notes about them will accumulate here. * New [wezterm.color](config/lua/wezterm.color/index.md) module for working with colors. * New [wezterm.gui](config/lua/wezterm.gui/index.md) module and [mux_window:gui_window](config/lua/mux-window/gui_window.md) method. * New [wezterm.gui.screens()](config/lua/wezterm.gui/screens.md) function for getting information about the available screens/monitors/displays +* New [wezterm.gui.get_appearance()](config/lua/wezterm.gui/get_appearance.md) function for a simpler way to get system dark mode state * You may now use [wezterm.format](config/lua/wezterm/format.md) (or otherwise use strings with escape sequences) in the labels of the [Launcher Menu](config/launch.md#the-launcher-menu). * You may now specify `assume_emoji_presentation = true` (or `false`) in [wezterm.font()](config/lua/wezterm/font.md) and [wezterm.font_with_fallback()](config/lua/wezterm/font_with_fallback.md) * Wayland: `zwp_text_input_v3` is now supported, which enables IME to work in wezterm if your compositor also implements this protocol. diff --git a/docs/config/lua/wezterm.gui/get_appearance.md b/docs/config/lua/wezterm.gui/get_appearance.md new file mode 100644 index 00000000000..8754e131c1b --- /dev/null +++ b/docs/config/lua/wezterm.gui/get_appearance.md @@ -0,0 +1,41 @@ +# `wezterm.gui.get_appearance()` + +*Since: nightly builds only* + +This function returns the appearance of the window environment. The appearance +can be one of the following 4 values: + +* `"Light"` - the normal appearance, with dark text on a light background +* `"Dark"` - "dark mode", with predominantly dark colors and probably a lighter, lower contrasting, text color on a dark background +* `"LightHighContrast"` - light mode but with high contrast colors (not reported on all systems) +* `"DarkHighContrast"` - dark mode but with high contrast colors (not reported on all systems) + +wezterm is able to detect when the appearance has changed and will generate a +[window-config-reloaded](../window-events/window-config-reloaded.md) event for +each window. + +This example configuration shows how you can have your color scheme +automatically adjust to the current appearance: + +```lua +local wezterm = require 'wezterm' + +function scheme_for_appearance(appearance) + if appearance:find("Dark") then + return "Builtin Solarized Dark" + else + return "Builtin Solarized Light" + end +end + +return { + color_scheme = scheme_for_appearance(wezterm.gui.get_appearance()), +} +``` + +### Wayland GNOME Appearance + +wezterm uses [XDG Desktop +Portal](https://flatpak.github.io/xdg-desktop-portal/) to determine the +appearance in a desktop-environment independent way. + diff --git a/docs/config/lua/window/get_appearance.md b/docs/config/lua/window/get_appearance.md index 0de84cf58aa..2d7ce8b4d6b 100644 --- a/docs/config/lua/window/get_appearance.md +++ b/docs/config/lua/window/get_appearance.md @@ -1,5 +1,7 @@ # window:get_appearance() +**NOTE: You probably want to use [wezterm.gui.get_appearance()](../wezterm.gui/get_appearance.md) instead, as it is easier to use!** + *Since: 20210814-124438-54e29167* This method returns the appearance of the window environment. The appearance diff --git a/lua-api-crates/window-funcs/src/lib.rs b/lua-api-crates/window-funcs/src/lib.rs index 1a6eac5ea04..2367bfc2336 100644 --- a/lua-api-crates/window-funcs/src/lib.rs +++ b/lua-api-crates/window-funcs/src/lib.rs @@ -4,7 +4,7 @@ use luahelper::impl_lua_conversion_dynamic; use std::collections::HashMap; use std::rc::Rc; use wezterm_dynamic::{FromDynamic, ToDynamic}; -use window::{Connection, ConnectionOps}; +use window::{Appearance, Connection, ConnectionOps}; fn get_conn() -> mlua::Result> { Connection::get().ok_or_else(|| { @@ -85,5 +85,18 @@ pub fn register(lua: &Lua) -> anyhow::Result<()> { })?, )?; + window_mod.set( + "get_appearance", + lua.create_function(|_, _: ()| { + Ok(match Connection::get() { + Some(conn) => conn.get_appearance().to_string(), + None => { + // Gui hasn't started yet, assume light + Appearance::Light.to_string() + } + }) + })?, + )?; + Ok(()) } diff --git a/wezterm-gui/src/frontend.rs b/wezterm-gui/src/frontend.rs index 0b7075cb531..8fe8400e9eb 100644 --- a/wezterm-gui/src/frontend.rs +++ b/wezterm-gui/src/frontend.rs @@ -144,6 +144,10 @@ impl GuiFrontEnd { false } }); + // Re-evaluate the config so that folks that are using + // `wezterm.gui.get_appearance()` can have that take effect + // before any windows are created + config::reload(); Ok(front_end) }