Roll src/third_party/WebKit a3b4a2e:7441784 (svn 202551:202552)
[chromium-blink-merge.git] / extensions / browser / app_window / app_window_registry.h
blobd273fbb131c14d62b8e91269f655058e4965b6a3
1 // Copyright 2014 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 EXTENSIONS_BROWSER_APP_WINDOW_APP_WINDOW_REGISTRY_H_
6 #define EXTENSIONS_BROWSER_APP_WINDOW_APP_WINDOW_REGISTRY_H_
8 #include <list>
9 #include <set>
10 #include <string>
12 #include "base/callback.h"
13 #include "base/compiler_specific.h"
14 #include "base/memory/singleton.h"
15 #include "base/observer_list.h"
16 #include "components/keyed_service/content/browser_context_keyed_service_factory.h"
17 #include "components/keyed_service/core/keyed_service.h"
18 #include "ui/gfx/native_widget_types.h"
20 namespace content {
21 class BrowserContext;
22 class DevToolsAgentHost;
23 class WebContents;
26 namespace extensions {
28 class AppWindow;
30 // The AppWindowRegistry tracks the AppWindows for all platform apps for a
31 // particular browser context.
32 class AppWindowRegistry : public KeyedService {
33 public:
34 class Observer {
35 public:
36 // Called just after a app window was added.
37 virtual void OnAppWindowAdded(AppWindow* app_window);
38 // Called when the window icon changes.
39 virtual void OnAppWindowIconChanged(AppWindow* app_window);
40 // Called just after a app window was removed.
41 virtual void OnAppWindowRemoved(AppWindow* app_window);
42 // Called just after a app window was hidden. This is different from
43 // window visibility as a minimize does not hide a window, but does make
44 // it not visible.
45 virtual void OnAppWindowHidden(AppWindow* app_window);
46 // Called just after a app window was shown.
47 virtual void OnAppWindowShown(AppWindow* app_window, bool was_hidden);
48 // Called just after a app window was activated.
49 virtual void OnAppWindowActivated(AppWindow* app_window);
51 protected:
52 virtual ~Observer();
55 typedef std::list<AppWindow*> AppWindowList;
56 typedef AppWindowList::const_iterator const_iterator;
57 typedef std::set<std::string> InspectedWindowSet;
59 explicit AppWindowRegistry(content::BrowserContext* context);
60 ~AppWindowRegistry() override;
62 // Returns the instance for the given browser context, or NULL if none. This
63 // is a convenience wrapper around
64 // AppWindowRegistry::Factory::GetForBrowserContext().
65 static AppWindowRegistry* Get(content::BrowserContext* context);
67 void AddAppWindow(AppWindow* app_window);
68 void AppWindowIconChanged(AppWindow* app_window);
69 // Called by |app_window| when it is activated.
70 void AppWindowActivated(AppWindow* app_window);
71 void AppWindowHidden(AppWindow* app_window);
72 void AppWindowShown(AppWindow* app_window, bool was_hidden);
73 void RemoveAppWindow(AppWindow* app_window);
75 void AddObserver(Observer* observer);
76 void RemoveObserver(Observer* observer);
78 // Returns a set of windows owned by the application identified by app_id.
79 AppWindowList GetAppWindowsForApp(const std::string& app_id) const;
80 const AppWindowList& app_windows() const { return app_windows_; }
82 // Close all app windows associated with an app.
83 void CloseAllAppWindowsForApp(const std::string& app_id);
85 // Helper functions to find app windows with particular attributes.
86 AppWindow* GetAppWindowForWebContents(
87 const content::WebContents* web_contents) const;
88 AppWindow* GetAppWindowForNativeWindow(gfx::NativeWindow window) const;
89 // Returns an app window for the given app, or NULL if no app windows are
90 // open. If there is a window for the given app that is active, that one will
91 // be returned, otherwise an arbitrary window will be returned.
92 AppWindow* GetCurrentAppWindowForApp(const std::string& app_id) const;
93 // Returns an app window for the given app and window key, or NULL if no app
94 // window with the key are open. If there is a window for the given app and
95 // key that is active, that one will be returned, otherwise an arbitrary
96 // window will be returned.
97 AppWindow* GetAppWindowForAppAndKey(const std::string& app_id,
98 const std::string& window_key) const;
100 // Returns whether a AppWindow's ID was last known to have a DevToolsAgent
101 // attached to it, which should be restored during a reload of a corresponding
102 // newly created |web_contents|.
103 bool HadDevToolsAttached(content::WebContents* web_contents) const;
105 class Factory : public BrowserContextKeyedServiceFactory {
106 public:
107 static AppWindowRegistry* GetForBrowserContext(
108 content::BrowserContext* context,
109 bool create);
111 static Factory* GetInstance();
113 private:
114 friend struct base::DefaultSingletonTraits<Factory>;
116 Factory();
117 ~Factory() override;
119 // BrowserContextKeyedServiceFactory
120 KeyedService* BuildServiceInstanceFor(
121 content::BrowserContext* context) const override;
122 bool ServiceIsCreatedWithBrowserContext() const override;
123 bool ServiceIsNULLWhileTesting() const override;
124 content::BrowserContext* GetBrowserContextToUse(
125 content::BrowserContext* context) const override;
128 protected:
129 void OnDevToolsStateChanged(content::DevToolsAgentHost*, bool attached);
131 private:
132 // Ensures the specified |app_window| is included in |app_windows_|.
133 // Otherwise adds |app_window| to the back of |app_windows_|.
134 void AddAppWindowToList(AppWindow* app_window);
136 // Bring |app_window| to the front of |app_windows_|. If it is not in the
137 // list, add it first.
138 void BringToFront(AppWindow* app_window);
140 // Create a key that identifies an AppWindow across App reloads. If the window
141 // was given an id in CreateParams, the key is the extension id, a colon
142 // separator, and the AppWindow's |id|. If there is no |id|, the
143 // chrome-extension://extension-id/page.html URL will be used. If the
144 // WebContents is not for a AppWindow, return an empty string.
145 std::string GetWindowKeyForWebContents(
146 content::WebContents* web_contents) const;
148 content::BrowserContext* context_;
149 AppWindowList app_windows_;
150 InspectedWindowSet inspected_windows_;
151 base::ObserverList<Observer> observers_;
152 base::Callback<void(content::DevToolsAgentHost*, bool)> devtools_callback_;
155 } // namespace extensions
157 #endif // EXTENSIONS_BROWSER_APP_WINDOW_APP_WINDOW_REGISTRY_H_