ExtensionSyncService: listen for relevant changes instead of being explicitly called...
[chromium-blink-merge.git] / chrome / browser / themes / theme_service.h
blobb30be1e08646139ab5f79620c42c3672ef51ffae
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_THEMES_THEME_SERVICE_H_
6 #define CHROME_BROWSER_THEMES_THEME_SERVICE_H_
8 #include <map>
9 #include <set>
10 #include <string>
11 #include <utility>
13 #include "base/compiler_specific.h"
14 #include "base/memory/ref_counted.h"
15 #include "base/memory/scoped_ptr.h"
16 #include "base/memory/weak_ptr.h"
17 #include "base/threading/non_thread_safe.h"
18 #include "components/keyed_service/core/keyed_service.h"
19 #include "content/public/browser/notification_observer.h"
20 #include "content/public/browser/notification_registrar.h"
21 #include "ui/base/theme_provider.h"
23 class CustomThemeSupplier;
24 class BrowserThemePack;
25 class ThemeSyncableService;
26 class Profile;
28 namespace base {
29 class FilePath;
32 namespace color_utils {
33 struct HSL;
36 namespace extensions {
37 class Extension;
40 namespace gfx {
41 class Image;
44 namespace theme_service_internal {
45 class ThemeServiceTest;
48 namespace ui {
49 class ResourceBundle;
52 #ifdef __OBJC__
53 @class NSString;
54 // Sent whenever the browser theme changes. Object => NSValue wrapping the
55 // ThemeService that changed.
56 extern "C" NSString* const kBrowserThemeDidChangeNotification;
57 #endif // __OBJC__
59 class ThemeService : public base::NonThreadSafe,
60 public content::NotificationObserver,
61 public KeyedService,
62 public ui::ThemeProvider {
63 public:
64 // Public constants used in ThemeService and its subclasses:
65 static const char* kDefaultThemeID;
67 ThemeService();
68 ~ThemeService() override;
70 virtual void Init(Profile* profile);
72 // Returns a cross platform image for an id.
74 // TODO(erg): Make this part of the ui::ThemeProvider and the main way to get
75 // theme properties out of the theme provider since it's cross platform.
76 virtual gfx::Image GetImageNamed(int id) const;
78 // Overridden from ui::ThemeProvider:
79 bool UsingSystemTheme() const override;
80 gfx::ImageSkia* GetImageSkiaNamed(int id) const override;
81 SkColor GetColor(int id) const override;
82 int GetDisplayProperty(int id) const override;
83 bool ShouldUseNativeFrame() const override;
84 bool HasCustomImage(int id) const override;
85 base::RefCountedMemory* GetRawData(int id, ui::ScaleFactor scale_factor)
86 const override;
87 #if defined(OS_MACOSX)
88 NSImage* GetNSImageNamed(int id) const override;
89 NSColor* GetNSImageColorNamed(int id) const override;
90 NSColor* GetNSColor(int id) const override;
91 NSColor* GetNSColorTint(int id) const override;
92 NSGradient* GetNSGradient(int id) const override;
93 #endif
95 // KeyedService:
96 void Shutdown() override;
98 // Overridden from content::NotificationObserver:
99 void Observe(int type,
100 const content::NotificationSource& source,
101 const content::NotificationDetails& details) override;
103 // Set the current theme to the theme defined in |extension|.
104 // |extension| must already be added to this profile's
105 // ExtensionService.
106 virtual void SetTheme(const extensions::Extension* extension);
108 // Reset the theme to default.
109 virtual void UseDefaultTheme();
111 // Set the current theme to the system theme. On some platforms, the system
112 // theme is the default theme.
113 virtual void UseSystemTheme();
115 // Returns true if the default theme and system theme are not the same on
116 // this platform.
117 virtual bool IsSystemThemeDistinctFromDefaultTheme() const;
119 // Whether we're using the chrome default theme. Virtual so linux can check
120 // if we're using the GTK theme.
121 virtual bool UsingDefaultTheme() const;
123 // Gets the id of the last installed theme. (The theme may have been further
124 // locally customized.)
125 virtual std::string GetThemeID() const;
127 // This class needs to keep track of the number of theme infobars so that we
128 // clean up unused themes.
129 void OnInfobarDisplayed();
131 // Decrements the number of theme infobars. If the last infobar has been
132 // destroyed, uninstalls all themes that aren't the currently selected.
133 void OnInfobarDestroyed();
135 // Uninstall theme extensions which are no longer in use. |ignore_infobars| is
136 // whether unused themes should be removed despite a theme infobar being
137 // visible.
138 void RemoveUnusedThemes(bool ignore_infobars);
140 // Returns the syncable service for syncing theme. The returned service is
141 // owned by |this| object.
142 virtual ThemeSyncableService* GetThemeSyncableService() const;
144 // Save the images to be written to disk, mapping file path to id.
145 typedef std::map<base::FilePath, int> ImagesDiskCache;
147 protected:
148 // Set a custom default theme instead of the normal default theme.
149 virtual void SetCustomDefaultTheme(
150 scoped_refptr<CustomThemeSupplier> theme_supplier);
152 // Returns true if the ThemeService should use the system theme on startup.
153 virtual bool ShouldInitWithSystemTheme() const;
155 // Get the specified tint - |id| is one of the TINT_* enum values.
156 color_utils::HSL GetTint(int id) const;
158 // Clears all the override fields and saves the dictionary.
159 virtual void ClearAllThemeData();
161 // Load theme data from preferences.
162 virtual void LoadThemePrefs();
164 // Let all the browser views know that themes have changed.
165 virtual void NotifyThemeChanged();
167 #if defined(OS_MACOSX)
168 // Let all the browser views know that themes have changed in a platform way.
169 virtual void NotifyPlatformThemeChanged();
170 #endif // OS_MACOSX
172 // Clears the platform-specific caches. Do not call directly; it's called
173 // from ClearAllThemeData().
174 virtual void FreePlatformCaches();
176 Profile* profile() const { return profile_; }
178 void set_ready() { ready_ = true; }
180 const CustomThemeSupplier* get_theme_supplier() const {
181 return theme_supplier_.get();
184 // True if the theme service is ready to be used.
185 // TODO(pkotwicz): Add DCHECKS to the theme service's getters once
186 // ThemeSource no longer uses the ThemeService when it is not ready.
187 bool ready_;
189 private:
190 friend class theme_service_internal::ThemeServiceTest;
192 // Called when the extension service is ready.
193 void OnExtensionServiceReady();
195 // Migrate the theme to the new theme pack schema by recreating the data pack
196 // from the extension.
197 void MigrateTheme();
199 // Replaces the current theme supplier with a new one and calls
200 // StopUsingTheme() or StartUsingTheme() as appropriate.
201 void SwapThemeSupplier(scoped_refptr<CustomThemeSupplier> theme_supplier);
203 // Saves the filename of the cached theme pack.
204 void SavePackName(const base::FilePath& pack_path);
206 // Save the id of the last theme installed.
207 void SaveThemeID(const std::string& id);
209 // Implementation of SetTheme() (and the fallback from LoadThemePrefs() in
210 // case we don't have a theme pack).
211 void BuildFromExtension(const extensions::Extension* extension);
213 #if defined(ENABLE_SUPERVISED_USERS)
214 // Returns true if the profile belongs to a supervised user.
215 bool IsSupervisedUser() const;
217 // Sets the current theme to the supervised user theme. Should only be used
218 // for supervised user profiles.
219 void SetSupervisedUserTheme();
220 #endif
222 #if defined(OS_MACOSX)
223 // |nsimage_cache_| retains the images it has cached.
224 typedef std::map<int, NSImage*> NSImageMap;
225 mutable NSImageMap nsimage_cache_;
227 // |nscolor_cache_| retains the colors it has cached.
228 typedef std::map<int, NSColor*> NSColorMap;
229 mutable NSColorMap nscolor_cache_;
231 typedef std::map<int, NSGradient*> NSGradientMap;
232 mutable NSGradientMap nsgradient_cache_;
233 #endif
235 ui::ResourceBundle& rb_;
236 Profile* profile_;
238 scoped_refptr<CustomThemeSupplier> theme_supplier_;
240 // The id of the theme extension which has just been installed but has not
241 // been loaded yet. The theme extension with |installed_pending_load_id_| may
242 // never be loaded if the install is due to updating a disabled theme.
243 // |pending_install_id_| should be set to |kDefaultThemeID| if there are no
244 // recently installed theme extensions
245 std::string installed_pending_load_id_;
247 // The number of infobars currently displayed.
248 int number_of_infobars_;
250 content::NotificationRegistrar registrar_;
252 scoped_ptr<ThemeSyncableService> theme_syncable_service_;
254 #if defined(ENABLE_EXTENSIONS)
255 class ThemeObserver;
256 scoped_ptr<ThemeObserver> theme_observer_;
257 #endif
259 base::WeakPtrFactory<ThemeService> weak_ptr_factory_;
261 DISALLOW_COPY_AND_ASSIGN(ThemeService);
264 #endif // CHROME_BROWSER_THEMES_THEME_SERVICE_H_