fix: add support for prefers-color-scheme CSS query (#19228)
The wiring to update prefs when you toggle between dark mode and light mode exists in the content layer but the actual value setting is done in either //chrome or in shell. We need to set the preferred_color_scheme pref value in order for the CSS query to work correctly. The DarkModeObserver in content will automatically regenerate prefs when dark mode is toggled. Fixes #15540
This commit is contained in:
parent
079a173a72
commit
ab8b940151
1 changed files with 6 additions and 0 deletions
|
@ -79,6 +79,7 @@
|
||||||
#include "shell/common/platform_util.h"
|
#include "shell/common/platform_util.h"
|
||||||
#include "ui/base/l10n/l10n_util.h"
|
#include "ui/base/l10n/l10n_util.h"
|
||||||
#include "ui/base/resource/resource_bundle.h"
|
#include "ui/base/resource/resource_bundle.h"
|
||||||
|
#include "ui/native_theme/native_theme.h"
|
||||||
#include "v8/include/v8.h"
|
#include "v8/include/v8.h"
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
|
@ -408,6 +409,11 @@ void AtomBrowserClient::OverrideWebkitPrefs(content::RenderViewHost* host,
|
||||||
prefs->default_maximum_page_scale_factor = 1.f;
|
prefs->default_maximum_page_scale_factor = 1.f;
|
||||||
prefs->navigate_on_drag_drop = false;
|
prefs->navigate_on_drag_drop = false;
|
||||||
|
|
||||||
|
ui::NativeTheme* native_theme = ui::NativeTheme::GetInstanceForNativeUi();
|
||||||
|
prefs->preferred_color_scheme = native_theme->SystemDarkModeEnabled()
|
||||||
|
? blink::PreferredColorScheme::kDark
|
||||||
|
: blink::PreferredColorScheme::kLight;
|
||||||
|
|
||||||
SetFontDefaults(prefs);
|
SetFontDefaults(prefs);
|
||||||
|
|
||||||
// Custom preferences of guest page.
|
// Custom preferences of guest page.
|
||||||
|
|
Loading…
Reference in a new issue