1 // Copyright 2013 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. 4 5 #ifndef APPS_SHELL_WINDOW_REGISTRY_H_ 6 #define APPS_SHELL_WINDOW_REGISTRY_H_ 7 8 #include <list> 9 10 #include "base/callback.h" 11 #include "base/compiler_specific.h" 12 #include "base/memory/singleton.h" 13 #include "base/observer_list.h" 14 #include "components/browser_context_keyed_service/browser_context_keyed_service.h" 15 #include "components/browser_context_keyed_service/browser_context_keyed_service_factory.h" 16 #include "ui/gfx/native_widget_types.h" 17 18 namespace content { 19 class BrowserContext; 20 class DevToolsAgentHost; 21 class RenderViewHost; 22 } 23 24 namespace apps { 25 26 class ShellWindow; 27 28 // The ShellWindowRegistry tracks the ShellWindows for all platform apps for a 29 // particular browser context. 30 class ShellWindowRegistry : public BrowserContextKeyedService { 31 public: 32 class Observer { 33 public: 34 // Called just after a shell window was added. 35 virtual void OnShellWindowAdded(apps::ShellWindow* shell_window) = 0; 36 // Called when the window icon changes. 37 virtual void OnShellWindowIconChanged(apps::ShellWindow* shell_window) = 0; 38 // Called just after a shell window was removed. 39 virtual void OnShellWindowRemoved(apps::ShellWindow* shell_window) = 0; 40 41 protected: 42 virtual ~Observer() {} 43 }; 44 45 typedef std::list<apps::ShellWindow*> ShellWindowList; 46 typedef ShellWindowList::const_iterator const_iterator; 47 typedef std::set<std::string> InspectedWindowSet; 48 49 explicit ShellWindowRegistry(content::BrowserContext* context); 50 virtual ~ShellWindowRegistry(); 51 52 // Returns the instance for the given browser context, or NULL if none. This 53 // is a convenience wrapper around 54 // ShellWindowRegistry::Factory::GetForBrowserContext(). 55 static ShellWindowRegistry* Get(content::BrowserContext* context); 56 57 void AddShellWindow(apps::ShellWindow* shell_window); 58 void ShellWindowIconChanged(apps::ShellWindow* shell_window); 59 // Called by |shell_window| when it is activated. 60 void ShellWindowActivated(apps::ShellWindow* shell_window); 61 void RemoveShellWindow(apps::ShellWindow* shell_window); 62 63 void AddObserver(Observer* observer); 64 void RemoveObserver(Observer* observer); 65 66 // Returns a set of windows owned by the application identified by app_id. 67 ShellWindowList GetShellWindowsForApp(const std::string& app_id) const; 68 const ShellWindowList& shell_windows() const { return shell_windows_; } 69 70 // Close all shell windows associated with an app. 71 void CloseAllShellWindowsForApp(const std::string& app_id); 72 73 // Helper functions to find shell windows with particular attributes. 74 apps::ShellWindow* GetShellWindowForRenderViewHost( 75 content::RenderViewHost* render_view_host) const; 76 apps::ShellWindow* GetShellWindowForNativeWindow( 77 gfx::NativeWindow window) const; 78 // Returns an app window for the given app, or NULL if no shell windows are 79 // open. If there is a window for the given app that is active, that one will 80 // be returned, otherwise an arbitrary window will be returned. 81 apps::ShellWindow* GetCurrentShellWindowForApp( 82 const std::string& app_id) const; 83 // Returns an app window for the given app and window key, or NULL if no shell 84 // window with the key are open. If there is a window for the given app and 85 // key that is active, that one will be returned, otherwise an arbitrary 86 // window will be returned. 87 apps::ShellWindow* GetShellWindowForAppAndKey( 88 const std::string& app_id, 89 const std::string& window_key) const; 90 91 // Returns whether a ShellWindow's ID was last known to have a DevToolsAgent 92 // attached to it, which should be restored during a reload of a corresponding 93 // newly created |render_view_host|. 94 bool HadDevToolsAttached(content::RenderViewHost* render_view_host) const; 95 96 // Returns the shell window for |window|, looking in all browser contexts. 97 static apps::ShellWindow* GetShellWindowForNativeWindowAnyProfile( 98 gfx::NativeWindow window); 99 100 // Returns true if the number of shell windows registered across all browser 101 // contexts is non-zero. |window_type_mask| is a bitwise OR filter of 102 // ShellWindow::WindowType, or 0 for any window type. 103 static bool IsShellWindowRegisteredInAnyProfile(int window_type_mask); 104 105 class Factory : public BrowserContextKeyedServiceFactory { 106 public: 107 static ShellWindowRegistry* GetForBrowserContext( 108 content::BrowserContext* context, bool create); 109 110 static Factory* GetInstance(); 111 private: 112 friend struct DefaultSingletonTraits<Factory>; 113 114 Factory(); 115 virtual ~Factory(); 116 117 // BrowserContextKeyedServiceFactory 118 virtual BrowserContextKeyedService* BuildServiceInstanceFor( 119 content::BrowserContext* context) const OVERRIDE; 120 virtual bool ServiceIsCreatedWithBrowserContext() const OVERRIDE; 121 virtual bool ServiceIsNULLWhileTesting() const OVERRIDE; 122 virtual content::BrowserContext* GetBrowserContextToUse( 123 content::BrowserContext* context) const OVERRIDE; 124 }; 125 126 protected: 127 void OnDevToolsStateChanged(content::DevToolsAgentHost*, bool attached); 128 129 private: 130 // Ensures the specified |shell_window| is included in |shell_windows_|. 131 // Otherwise adds |shell_window| to the back of |shell_windows_|. 132 void AddShellWindowToList(apps::ShellWindow* shell_window); 133 134 // Bring |shell_window| to the front of |shell_windows_|. If it is not in the 135 // list, add it first. 136 void BringToFront(apps::ShellWindow* shell_window); 137 138 content::BrowserContext* context_; 139 ShellWindowList shell_windows_; 140 InspectedWindowSet inspected_windows_; 141 ObserverList<Observer> observers_; 142 base::Callback<void(content::DevToolsAgentHost*, bool)> devtools_callback_; 143 }; 144 145 } // namespace extensions 146 147 #endif // APPS_SHELL_WINDOW_REGISTRY_H_ 148