Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1164)

Unified Diff: chrome/browser/ui/webui/settings/appearance_handler.cc

Issue 2413623004: MD Settings: allow changing to GTK+ theme on Linux (Closed)
Patch Set: rejigger tests Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/webui/settings/appearance_handler.cc
diff --git a/chrome/browser/ui/webui/settings/appearance_handler.cc b/chrome/browser/ui/webui/settings/appearance_handler.cc
index 79ae0fd49b7895ae5789cd64845574e2eb5b6716..eac391fb59af3c80e4d6d2e6c09e5d424344aa95 100644
--- a/chrome/browser/ui/webui/settings/appearance_handler.cc
+++ b/chrome/browser/ui/webui/settings/appearance_handler.cc
@@ -7,11 +7,9 @@
#include "base/bind.h"
#include "base/logging.h"
#include "base/values.h"
-#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/themes/theme_service.h"
#include "chrome/browser/themes/theme_service_factory.h"
-#include "content/public/browser/notification_source.h"
#include "content/public/browser/web_ui.h"
#if defined(OS_CHROMEOS)
@@ -27,14 +25,20 @@ AppearanceHandler::AppearanceHandler(content::WebUI* webui)
AppearanceHandler::~AppearanceHandler() {}
+void AppearanceHandler::OnJavascriptAllowed() {}
+void AppearanceHandler::OnJavascriptDisallowed() {}
+
void AppearanceHandler::RegisterMessages() {
web_ui()->RegisterMessageCallback(
- "resetTheme",
- base::Bind(&AppearanceHandler::HandleResetTheme, base::Unretained(this)));
+ "useDefaultTheme",
+ base::Bind(&AppearanceHandler::HandleUseDefaultTheme,
+ base::Unretained(this)));
+#if defined(OS_LINUX) && !defined(OS_CHROMEOS)
web_ui()->RegisterMessageCallback(
- "getResetThemeEnabled",
- base::Bind(&AppearanceHandler::HandleGetResetThemeEnabled,
+ "useSystemTheme",
+ base::Bind(&AppearanceHandler::HandleUseSystemTheme,
base::Unretained(this)));
+#endif
#if defined(OS_CHROMEOS)
web_ui()->RegisterMessageCallback(
"openWallpaperManager",
@@ -43,46 +47,15 @@ void AppearanceHandler::RegisterMessages() {
#endif
}
-void AppearanceHandler::OnJavascriptAllowed() {
- registrar_.Add(this, chrome::NOTIFICATION_BROWSER_THEME_CHANGED,
- content::Source<ThemeService>(
- ThemeServiceFactory::GetForProfile(profile_)));
-}
-
-void AppearanceHandler::OnJavascriptDisallowed() {
- registrar_.RemoveAll();
-}
-
-void AppearanceHandler::Observe(
- int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- DCHECK_EQ(chrome::NOTIFICATION_BROWSER_THEME_CHANGED, type);
-
- CallJavascriptFunction("cr.webUIListenerCallback",
dpapad 2016/10/13 18:31:20 Why don't we need to listen to this anymore?
Dan Beam 2016/10/13 18:56:53 because observing the prefs is basically the same
- base::StringValue("reset-theme-enabled-changed"),
- base::FundamentalValue(ResetThemeEnabled()));
-}
-
-void AppearanceHandler::HandleResetTheme(const base::ListValue* /*args*/) {
+void AppearanceHandler::HandleUseDefaultTheme(const base::ListValue* args) {
ThemeServiceFactory::GetForProfile(profile_)->UseDefaultTheme();
}
-bool AppearanceHandler::ResetThemeEnabled() const {
- // TODO(jhawkins): Handle native/system theme button.
- return !ThemeServiceFactory::GetForProfile(profile_)->UsingDefaultTheme();
-}
-
-void AppearanceHandler::HandleGetResetThemeEnabled(
- const base::ListValue* args) {
- AllowJavascript();
-
- CHECK_EQ(1U, args->GetSize());
- const base::Value* callback_id;
- CHECK(args->Get(0, &callback_id));
- ResolveJavascriptCallback(*callback_id,
- base::FundamentalValue(ResetThemeEnabled()));
+#if defined(OS_LINUX) && !defined(OS_CHROMEOS)
+void AppearanceHandler::HandleUseSystemTheme(const base::ListValue* args) {
+ ThemeServiceFactory::GetForProfile(profile_)->UseSystemTheme();
}
+#endif
#if defined(OS_CHROMEOS)
void AppearanceHandler::HandleOpenWallpaperManager(

Powered by Google App Engine
This is Rietveld 408576698