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

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

Issue 359493005: Extend contextMenus API to support browser/page actions (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Small changes, formatting Created 6 years, 5 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_CONTEXT_MENU_MATCHER_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_CONTEXT_MENU_MATCHER_H_
6 #define CHROME_BROWSER_EXTENSIONS_CONTEXT_MENU_MATCHER_H_ 6 #define CHROME_BROWSER_EXTENSIONS_CONTEXT_MENU_MATCHER_H_
7 7
8 #include <map> 8 #include <map>
9 9
10 #include "base/callback.h" 10 #include "base/callback.h"
(...skipping 15 matching lines...) Expand all
26 26
27 // The |filter| will be called on possibly matching menu items, and its 27 // The |filter| will be called on possibly matching menu items, and its
28 // result is used to determine which items to actually append to the menu. 28 // result is used to determine which items to actually append to the menu.
29 ContextMenuMatcher(Profile* profile, 29 ContextMenuMatcher(Profile* profile,
30 ui::SimpleMenuModel::Delegate* delegate, 30 ui::SimpleMenuModel::Delegate* delegate,
31 ui::SimpleMenuModel* menu_model, 31 ui::SimpleMenuModel* menu_model,
32 const base::Callback<bool(const MenuItem*)>& filter); 32 const base::Callback<bool(const MenuItem*)>& filter);
33 33
34 // This is a helper function to append items for one particular extension. 34 // This is a helper function to append items for one particular extension.
35 // The |index| parameter is used for assigning id's, and is incremented for 35 // The |index| parameter is used for assigning id's, and is incremented for
36 // each item actually added. 36 // each item actually added. |is_action_menu| is used for browser and page
37 // action context menus, in which menu items are not placed in submenus
38 // and the extension's icon is not shown.
37 void AppendExtensionItems(const MenuItem::ExtensionKey& extension_key, 39 void AppendExtensionItems(const MenuItem::ExtensionKey& extension_key,
38 const base::string16& selection_text, 40 const base::string16& selection_text,
39 int* index); 41 int* index,
42 bool is_action_menu);
40 43
41 void Clear(); 44 void Clear();
42 45
43 // This function returns the top level context menu title of an extension 46 // This function returns the top level context menu title of an extension
44 // based on a printable selection text. 47 // based on a printable selection text.
45 base::string16 GetTopLevelContextMenuTitle( 48 base::string16 GetTopLevelContextMenuTitle(
46 const MenuItem::ExtensionKey& extension_key, 49 const MenuItem::ExtensionKey& extension_key,
47 const base::string16& selection_text); 50 const base::string16& selection_text);
48 51
49 bool IsCommandIdChecked(int command_id) const; 52 bool IsCommandIdChecked(int command_id) const;
50 bool IsCommandIdEnabled(int command_id) const; 53 bool IsCommandIdEnabled(int command_id) const;
51 void ExecuteCommand(int command_id, 54 void ExecuteCommand(int command_id,
52 content::WebContents* web_contents, 55 content::WebContents* web_contents,
53 const content::ContextMenuParams& params); 56 const content::ContextMenuParams& params);
54 57
55 private: 58 private:
56 friend class ::ExtensionContextMenuBrowserTest; 59 friend class ::ExtensionContextMenuBrowserTest;
60 friend class ExtensionContextMenuModelTest;
57 61
58 bool GetRelevantExtensionTopLevelItems( 62 bool GetRelevantExtensionTopLevelItems(
59 const MenuItem::ExtensionKey& extension_key, 63 const MenuItem::ExtensionKey& extension_key,
60 const Extension** extension, 64 const Extension** extension,
61 bool* can_cross_incognito, 65 bool* can_cross_incognito,
62 MenuItem::List& items); 66 MenuItem::List& items);
63 67
64 MenuItem::List GetRelevantExtensionItems( 68 MenuItem::List GetRelevantExtensionItems(
65 const MenuItem::List& items, 69 const MenuItem::List& items,
66 bool can_cross_incognito); 70 bool can_cross_incognito);
67 71
68 // Used for recursively adding submenus of extension items. 72 // Used for recursively adding submenus of extension items.
69 void RecursivelyAppendExtensionItems(const MenuItem::List& items, 73 void RecursivelyAppendExtensionItems(const MenuItem::List& items,
70 bool can_cross_incognito, 74 bool can_cross_incognito,
71 const base::string16& selection_text, 75 const base::string16& selection_text,
72 ui::SimpleMenuModel* menu_model, 76 ui::SimpleMenuModel* menu_model,
73 int* index); 77 int* index,
78 bool is_action_menu_top_level);
74 79
75 // Attempts to get an MenuItem given the id of a context menu item. 80 // Attempts to get an MenuItem given the id of a context menu item.
76 extensions::MenuItem* GetExtensionMenuItem(int id) const; 81 extensions::MenuItem* GetExtensionMenuItem(int id) const;
77 82
78 // This will set the icon on the most recently-added item in the menu_model_. 83 // This will set the icon on the most recently-added item in the menu_model_.
79 void SetExtensionIcon(const std::string& extension_id); 84 void SetExtensionIcon(const std::string& extension_id);
80 85
81 Profile* profile_; 86 Profile* profile_;
82 ui::SimpleMenuModel* menu_model_; 87 ui::SimpleMenuModel* menu_model_;
83 ui::SimpleMenuModel::Delegate* delegate_; 88 ui::SimpleMenuModel::Delegate* delegate_;
84 89
85 base::Callback<bool(const MenuItem*)> filter_; 90 base::Callback<bool(const MenuItem*)> filter_;
86 91
87 // Maps the id from a context menu item to the MenuItem's internal id. 92 // Maps the id from a context menu item to the MenuItem's internal id.
88 std::map<int, extensions::MenuItem::Id> extension_item_map_; 93 std::map<int, extensions::MenuItem::Id> extension_item_map_;
89 94
90 // Keep track of and clean up menu models for submenus. 95 // Keep track of and clean up menu models for submenus.
91 ScopedVector<ui::SimpleMenuModel> extension_menu_models_; 96 ScopedVector<ui::SimpleMenuModel> extension_menu_models_;
92 97
93 DISALLOW_COPY_AND_ASSIGN(ContextMenuMatcher); 98 DISALLOW_COPY_AND_ASSIGN(ContextMenuMatcher);
94 }; 99 };
95 100
96 } // namespace extensions 101 } // namespace extensions
97 102
98 #endif // CHROME_BROWSER_EXTENSIONS_CONTEXT_MENU_MATCHER_H_ 103 #endif // CHROME_BROWSER_EXTENSIONS_CONTEXT_MENU_MATCHER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698