diff --git a/chromium_src/BUILD.gn b/chromium_src/BUILD.gn index f2c263fd3947..24a0b7540180 100644 --- a/chromium_src/BUILD.gn +++ b/chromium_src/BUILD.gn @@ -204,6 +204,10 @@ static_library("chrome") { "//chrome/browser/ui/views/status_icons/status_icon_linux_dbus.cc", "//chrome/browser/ui/views/status_icons/status_icon_linux_dbus.h", ] + sources += [ + "//chrome/browser/ui/views/dark_mode_manager_linux.cc", + "//chrome/browser/ui/views/dark_mode_manager_linux.h", + ] public_deps += [ "//components/dbus/menu", "//components/dbus/thread_linux", diff --git a/shell/browser/electron_browser_main_parts.cc b/shell/browser/electron_browser_main_parts.cc index 6d1a8da23a6a..7418f13fa66d 100644 --- a/shell/browser/electron_browser_main_parts.cc +++ b/shell/browser/electron_browser_main_parts.cc @@ -79,12 +79,12 @@ #if BUILDFLAG(IS_LINUX) #include "base/environment.h" +#include "chrome/browser/ui/views/dark_mode_manager_linux.h" #include "device/bluetooth/bluetooth_adapter_factory.h" #include "device/bluetooth/dbus/dbus_bluez_manager_wrapper_linux.h" #include "electron/electron_gtk_stubs.h" #include "ui/base/cursor/cursor_factory.h" #include "ui/base/ime/linux/linux_input_method_context_factory.h" -#include "ui/gfx/color_utils.h" #include "ui/gtk/gtk_compat.h" // nogncheck #include "ui/gtk/gtk_util.h" // nogncheck #include "ui/linux/linux_ui.h" @@ -169,36 +169,8 @@ std::u16string MediaStringProvider(media::MessageId id) { } } -#if BUILDFLAG(IS_LINUX) -// GTK does not provide a way to check if current theme is dark, so we compare -// the text and background luminosity to get a result. -// This trick comes from FireFox. -void UpdateDarkThemeSetting() { - float bg = color_utils::GetRelativeLuminance(gtk::GetBgColor("GtkLabel")); - float fg = color_utils::GetRelativeLuminance(gtk::GetFgColor("GtkLabel")); - bool is_dark = fg > bg; - // Pass it to NativeUi theme, which is used by the nativeTheme module and most - // places in Electron. - ui::NativeTheme::GetInstanceForNativeUi()->set_use_dark_colors(is_dark); - // Pass it to Web Theme, to make "prefers-color-scheme" media query work. - ui::NativeTheme::GetInstanceForWeb()->set_use_dark_colors(is_dark); -} -#endif - } // namespace -#if BUILDFLAG(IS_LINUX) -class DarkThemeObserver : public ui::NativeThemeObserver { - public: - DarkThemeObserver() = default; - - // ui::NativeThemeObserver: - void OnNativeThemeUpdated(ui::NativeTheme* observed_theme) override { - UpdateDarkThemeSetting(); - } -}; -#endif - // static ElectronBrowserMainParts* ElectronBrowserMainParts::self_ = nullptr; @@ -435,17 +407,10 @@ void ElectronBrowserMainParts::ToolkitInitialized() { CHECK(electron::IsElectron_gdk_pixbufInitialized()) << "Failed to initialize libgdk_pixbuf-2.0.so.0"; - // Chromium does not respect GTK dark theme setting, but they may change - // in future and this code might be no longer needed. Check the Chromium - // issue to keep updated: - // https://bugs.chromium.org/p/chromium/issues/detail?id=998903 - UpdateDarkThemeSetting(); - // Update the native theme when GTK theme changes. The GetNativeTheme - // here returns a NativeThemeGtk, which monitors GTK settings. - dark_theme_observer_ = std::make_unique(); - auto* linux_ui_theme = ui::LinuxUiTheme::GetForProfile(nullptr); - CHECK(linux_ui_theme); - linux_ui_theme->GetNativeTheme()->AddObserver(dark_theme_observer_.get()); + // source theme changes from system settings, including settings portal: + // https://flatpak.github.io/xdg-desktop-portal/#gdbus-org.freedesktop.portal.Settings + dark_mode_manager_ = std::make_unique(); + ui::LinuxUi::SetInstance(linux_ui); // Cursor theme changes are tracked by LinuxUI (via a CursorThemeManager diff --git a/shell/browser/electron_browser_main_parts.h b/shell/browser/electron_browser_main_parts.h index 0e49e8a66d20..62c8441b6628 100644 --- a/shell/browser/electron_browser_main_parts.h +++ b/shell/browser/electron_browser_main_parts.h @@ -43,7 +43,8 @@ class Environment; namespace ui { class LinuxUiGetter; -} +class DarkModeManagerLinux; +} // namespace ui namespace electron { @@ -65,10 +66,6 @@ class ViewsDelegate; class ViewsDelegateMac; #endif -#if BUILDFLAG(IS_LINUX) -class DarkThemeObserver; -#endif - class ElectronBrowserMainParts : public content::BrowserMainParts { public: ElectronBrowserMainParts(); @@ -145,9 +142,7 @@ class ElectronBrowserMainParts : public content::BrowserMainParts { #endif #if BUILDFLAG(IS_LINUX) - // Used to notify the native theme of changes to dark mode. - std::unique_ptr dark_theme_observer_; - + std::unique_ptr dark_mode_manager_; std::unique_ptr linux_ui_getter_; #endif