#include "chrome/browser/themes/custom_theme_supplier.h"
#include "chrome/common/pref_names.h"
#include "ui/gfx/image/image.h"
+#include "ui/native_theme/native_theme_aura.h"
#include "ui/views/linux_ui/linux_ui.h"
namespace {
void NativeThemeX11::StartUsingTheme() {
pref_service_->SetBoolean(prefs::kUsesSystemTheme, true);
+ // Have the former theme notify its observers of change.
+ ui::NativeThemeAura::instance()->NotifyObservers();
}
void NativeThemeX11::StopUsingTheme() {
pref_service_->SetBoolean(prefs::kUsesSystemTheme, false);
+ // Have the former theme notify its observers of change.
+ if (linux_ui_)
+ linux_ui_->GetNativeTheme(NULL)->NotifyObservers();
}
bool NativeThemeX11::GetColor(int id, SkColor* color) const {
} // namespace
-ThemeServiceAuraX11::ThemeServiceAuraX11() {
- views::LinuxUI* linux_ui = views::LinuxUI::instance();
- if (linux_ui)
- linux_ui->AddNativeThemeChangeObserver(this);
-}
+ThemeServiceAuraX11::ThemeServiceAuraX11() {}
-ThemeServiceAuraX11::~ThemeServiceAuraX11() {
- views::LinuxUI* linux_ui = views::LinuxUI::instance();
- if (linux_ui)
- linux_ui->RemoveNativeThemeChangeObserver(this);
-}
+ThemeServiceAuraX11::~ThemeServiceAuraX11() {}
bool ThemeServiceAuraX11::ShouldInitWithNativeTheme() const {
return profile()->GetPrefs()->GetBoolean(prefs::kUsesSystemTheme);
return theme_supplier &&
theme_supplier->get_theme_type() == CustomThemeSupplier::NATIVE_X11;
}
-
-void ThemeServiceAuraX11::OnNativeThemeChanged() {
- if (UsingNativeTheme())
- NotifyThemeChanged();
-}