Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(261)

Side by Side Diff: chrome/browser/extensions/extension_toolbar_model.h

Issue 25305002: Implement initial chrome.browserAction.openPopup API. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: comments Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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_EXTENSION_TOOLBAR_MODEL_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLBAR_MODEL_H_
6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLBAR_MODEL_H_ 6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLBAR_MODEL_H_
7 7
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/observer_list.h" 9 #include "base/observer_list.h"
10 #include "base/prefs/pref_change_registrar.h" 10 #include "base/prefs/pref_change_registrar.h"
(...skipping 15 matching lines...) Expand all
26 // The action that should be taken as a result of clicking a browser action. 26 // The action that should be taken as a result of clicking a browser action.
27 enum Action { 27 enum Action {
28 ACTION_NONE, 28 ACTION_NONE,
29 ACTION_SHOW_POPUP, 29 ACTION_SHOW_POPUP,
30 // Unlike LocationBarController there is no ACTION_SHOW_CONTEXT_MENU, 30 // Unlike LocationBarController there is no ACTION_SHOW_CONTEXT_MENU,
31 // because UI implementations tend to handle this themselves at a higher 31 // because UI implementations tend to handle this themselves at a higher
32 // level. 32 // level.
33 }; 33 };
34 34
35 // A class which is informed of changes to the model; represents the view of 35 // A class which is informed of changes to the model; represents the view of
36 // MVC. 36 // MVC.
Matt Perry 2013/10/16 20:34:35 With the new method, this class is no longer reall
justinlin 2013/10/16 21:16:23 Done.
37 class Observer { 37 class Observer {
38 public: 38 public:
39 // An extension with a browser action button has been added, and should go 39 // An extension with a browser action button has been added, and should go
40 // in the toolbar at |index|. 40 // in the toolbar at |index|.
41 virtual void BrowserActionAdded(const extensions::Extension* extension, 41 virtual void BrowserActionAdded(const extensions::Extension* extension,
42 int index) {} 42 int index) {}
43 43
44 // The browser action button for |extension| should no longer show. 44 // The browser action button for |extension| should no longer show.
45 virtual void BrowserActionRemoved(const extensions::Extension* extension) {} 45 virtual void BrowserActionRemoved(const extensions::Extension* extension) {}
46 46
47 // The browser action button for |extension| has been moved to |index|. 47 // The browser action button for |extension| has been moved to |index|.
48 virtual void BrowserActionMoved(const extensions::Extension* extension, 48 virtual void BrowserActionMoved(const extensions::Extension* extension,
49 int index) {} 49 int index) {}
50 50
51 // The browser action button for |extension| should show the popup now if it
52 // is in the active window.
53 virtual void BrowserActionShowPopup(const extensions::Extension* extension)
54 {}
55
51 // Called when the model has finished loading. 56 // Called when the model has finished loading.
52 virtual void ModelLoaded() {} 57 virtual void ModelLoaded() {}
53 58
54 protected: 59 protected:
55 virtual ~Observer() {} 60 virtual ~Observer() {}
56 }; 61 };
57 62
58 // Functions called by the view. 63 // Functions called by the view.
59 void AddObserver(Observer* observer); 64 void AddObserver(Observer* observer);
60 void RemoveObserver(Observer* observer); 65 void RemoveObserver(Observer* observer);
61 void MoveBrowserAction(const extensions::Extension* extension, int index); 66 void MoveBrowserAction(const extensions::Extension* extension, int index);
62 // Executes the browser action for an extension and returns the action that 67 // Executes the browser action for an extension and returns the action that
63 // the UI should perform in response. 68 // the UI should perform in response.
64 // |popup_url_out| will be set if the extension should show a popup, with 69 // |popup_url_out| will be set if the extension should show a popup, with
65 // the URL that should be shown, if non-NULL. 70 // the URL that should be shown, if non-NULL. |should_grant| controls whether
71 // the browser action should grant the page tab permissions. The showPopup API
72 // does not grant permissions.
73 Action ExecuteBrowserAction(const extensions::Extension* extension,
74 Browser* browser,
75 GURL* popup_url_out,
76 bool should_grant);
66 Action ExecuteBrowserAction(const extensions::Extension* extension, 77 Action ExecuteBrowserAction(const extensions::Extension* extension,
67 Browser* browser, 78 Browser* browser,
68 GURL* popup_url_out); 79 GURL* popup_url_out);
69 // If count == size(), this will set the visible icon count to -1, meaning 80 // If count == size(), this will set the visible icon count to -1, meaning
70 // "show all actions". 81 // "show all actions".
71 void SetVisibleIconCount(int count); 82 void SetVisibleIconCount(int count);
72 // As above, a return value of -1 represents "show all actions". 83 // As above, a return value of -1 represents "show all actions".
73 int GetVisibleIconCount() const { return visible_icon_count_; } 84 int GetVisibleIconCount() const { return visible_icon_count_; }
74 85
75 bool extensions_initialized() const { return extensions_initialized_; } 86 bool extensions_initialized() const { return extensions_initialized_; }
76 87
77 const extensions::ExtensionList& toolbar_items() const { 88 const extensions::ExtensionList& toolbar_items() const {
78 return toolbar_items_; 89 return toolbar_items_;
79 } 90 }
80 91
81 // Utility functions for converting between an index into the list of 92 // Utility functions for converting between an index into the list of
82 // incognito-enabled browser actions, and the list of all browser actions. 93 // incognito-enabled browser actions, and the list of all browser actions.
83 int IncognitoIndexToOriginal(int incognito_index); 94 int IncognitoIndexToOriginal(int incognito_index);
84 int OriginalIndexToIncognito(int original_index); 95 int OriginalIndexToIncognito(int original_index);
85 96
86 void OnExtensionToolbarPrefChange(); 97 void OnExtensionToolbarPrefChange();
87 98
99 // Tells observers to display a popup without granting tab permissions.
100 void ShowBrowserActionPopup(const extensions::Extension* extension);
101
88 private: 102 private:
89 // content::NotificationObserver implementation. 103 // content::NotificationObserver implementation.
90 virtual void Observe(int type, 104 virtual void Observe(int type,
91 const content::NotificationSource& source, 105 const content::NotificationSource& source,
92 const content::NotificationDetails& details) OVERRIDE; 106 const content::NotificationDetails& details) OVERRIDE;
93 107
94 // To be called after the extension service is ready; gets loaded extensions 108 // To be called after the extension service is ready; gets loaded extensions
95 // from the extension service and their saved order from the pref service 109 // from the extension service and their saved order from the pref service
96 // and constructs |toolbar_items_| from these data. 110 // and constructs |toolbar_items_| from these data.
97 void InitializeExtensionList(); 111 void InitializeExtensionList();
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
137 // For observing change of toolbar order preference by external entity (sync). 151 // For observing change of toolbar order preference by external entity (sync).
138 PrefChangeRegistrar pref_change_registrar_; 152 PrefChangeRegistrar pref_change_registrar_;
139 base::Closure pref_change_callback_; 153 base::Closure pref_change_callback_;
140 154
141 base::WeakPtrFactory<ExtensionToolbarModel> weak_ptr_factory_; 155 base::WeakPtrFactory<ExtensionToolbarModel> weak_ptr_factory_;
142 156
143 DISALLOW_COPY_AND_ASSIGN(ExtensionToolbarModel); 157 DISALLOW_COPY_AND_ASSIGN(ExtensionToolbarModel);
144 }; 158 };
145 159
146 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLBAR_MODEL_H_ 160 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_TOOLBAR_MODEL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698