OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ |
6 #define CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ |
7 | 7 |
8 #include <set> | |
9 #include <string> | |
10 #include <vector> | 8 #include <vector> |
11 | 9 |
10 #include "base/macros.h" | |
11 #include "base/memory/scoped_ptr.h" | |
12 #include "content/public/browser/web_contents_observer.h" | |
13 | |
14 namespace content { | |
15 class WebContents; | |
16 } | |
17 | |
12 class ExtensionAction; | 18 class ExtensionAction; |
13 | 19 |
14 namespace extensions { | 20 namespace extensions { |
21 class ActiveScriptController; | |
22 class PageActionController; | |
15 | 23 |
16 // Interface for a class that controls the the extension icons that show up in | 24 // Interface for a class that controls the the extension icons that show up in |
17 // the location bar. Depending on switches, these icons can have differing | 25 // the location bar. Depending on switches, these icons can have differing |
not at google - send to devlin
2014/05/08 20:47:09
hey this comment makes sense again!
| |
18 // behavior. | 26 // behavior. |
19 class LocationBarController { | 27 class LocationBarController : public content::WebContentsObserver { |
20 public: | 28 public: |
21 // The reaction that the UI should take after executing |OnClicked|. | 29 // The action that the UI should take after executing |OnClicked|. |
22 enum Action { | 30 enum Action { |
23 ACTION_NONE, | 31 ACTION_NONE, |
24 ACTION_SHOW_POPUP, | 32 ACTION_SHOW_POPUP, |
25 ACTION_SHOW_CONTEXT_MENU, | 33 ACTION_SHOW_CONTEXT_MENU, |
26 }; | 34 }; |
27 | 35 |
28 virtual ~LocationBarController() {} | 36 explicit LocationBarController(content::WebContents* web_contents); |
37 virtual ~LocationBarController(); | |
29 | 38 |
30 // Gets the action data for all extensions. | 39 // Returns the actions which should be displayed in the location bar. |
31 virtual std::vector<ExtensionAction*> GetCurrentActions() const = 0; | 40 std::vector<ExtensionAction*> GetCurrentActions(); |
32 | 41 |
33 // Notifies this that the badge for an extension has been clicked with some | 42 // Notifies this that an ExtensionAction has been clicked, and returns the |
34 // mouse button (1 for left, 2 for middle, and 3 for right click), and | 43 // action which should be taken in response (if any). |
35 // returns the action that should be taken in response (if any). | 44 Action OnClicked(const ExtensionAction* action); |
36 // TODO(kalman): make mouse_button an enum. | |
37 virtual Action OnClicked(const std::string& extension_id, | |
38 int mouse_button) = 0; | |
39 | 45 |
40 // Notifies clients that the icons have changed. | 46 // Notifies the window that the actions have changed. |
41 virtual void NotifyChange() = 0; | 47 static void NotifyChange(content::WebContents* web_contents); |
48 | |
49 ActiveScriptController* active_script_controller() { | |
not at google - send to devlin
2014/05/08 20:47:09
hey if the activity log exposed an observer interf
| |
50 return active_script_controller_.get(); | |
51 } | |
52 | |
53 PageActionController* page_action_controller() { | |
54 return page_action_controller_.get(); | |
55 } | |
not at google - send to devlin
2014/05/08 20:47:09
if you don't need to expose this, don't. the activ
Devlin
2014/05/08 23:01:00
Done.
| |
56 | |
57 private: | |
58 // content::WebContentsObserver implementation. | |
59 virtual void DidNavigateMainFrame( | |
60 const content::LoadCommittedDetails& details, | |
61 const content::FrameNavigateParams& params) OVERRIDE; | |
62 | |
63 // The associated WebContents. | |
64 content::WebContents* web_contents_; | |
65 | |
66 // The controllers for different sources of actions in the location bar. | |
67 // Currently, this is only page actions and active script actions, so we | |
68 // explicitly own and create both. If there are ever more, it will be worth | |
69 // considering making this class own a list of LocationBarControllerProviders | |
70 // instead. | |
71 scoped_ptr<ActiveScriptController> active_script_controller_; | |
72 scoped_ptr<PageActionController> page_action_controller_; | |
73 | |
74 DISALLOW_COPY_AND_ASSIGN(LocationBarController); | |
42 }; | 75 }; |
43 | 76 |
44 } // namespace extensions | 77 } // namespace extensions |
45 | 78 |
46 #endif // CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ | 79 #endif // CHROME_BROWSER_EXTENSIONS_LOCATION_BAR_CONTROLLER_H_ |
OLD | NEW |