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

Unified Diff: chrome/browser/extensions/extension_context_menu_model.cc

Issue 359493005: Extend contextMenus API to support browser/page actions (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/extensions/extension_context_menu_model.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/extensions/extension_context_menu_model.cc
diff --git a/chrome/browser/extensions/extension_context_menu_model.cc b/chrome/browser/extensions/extension_context_menu_model.cc
index e2774b619dbb4f86c402c70754e4ea68cbfc8ff5..29cb111880995f5aa28d700ae6e74375a1cf73c5 100644
--- a/chrome/browser/extensions/extension_context_menu_model.cc
+++ b/chrome/browser/extensions/extension_context_menu_model.cc
@@ -6,6 +6,8 @@
#include "base/prefs/pref_service.h"
#include "base/strings/utf_string_conversions.h"
+#include "chrome/app/chrome_command_ids.h"
+#include "chrome/browser/browser_process.h"
#include "chrome/browser/extensions/api/extension_action/extension_action_api.h"
#include "chrome/browser/extensions/extension_action.h"
#include "chrome/browser/extensions/extension_action_manager.h"
@@ -20,6 +22,7 @@
#include "chrome/common/pref_names.h"
#include "chrome/common/url_constants.h"
#include "content/public/browser/web_contents.h"
+#include "content/public/common/context_menu_params.h"
#include "extensions/browser/extension_prefs.h"
#include "extensions/browser/extension_system.h"
#include "extensions/browser/management_policy.h"
@@ -27,11 +30,14 @@
#include "grit/chromium_strings.h"
#include "grit/generated_resources.h"
#include "ui/base/l10n/l10n_util.h"
+#include "ui/gfx/text_elider.h"
using content::OpenURLParams;
using content::Referrer;
using content::WebContents;
using extensions::Extension;
+using extensions::MenuItem;
+using extensions::MenuManager;
ExtensionContextMenuModel::ExtensionContextMenuModel(const Extension* extension,
Browser* browser,
@@ -40,7 +46,11 @@ ExtensionContextMenuModel::ExtensionContextMenuModel(const Extension* extension,
extension_id_(extension->id()),
browser_(browser),
profile_(browser->profile()),
- delegate_(delegate) {
+ delegate_(delegate),
+ extension_items_(profile_,
+ this,
+ this,
+ base::Bind(MenuItemMatchesParams)) {
InitMenu(extension);
if (profile_->GetPrefs()->GetBoolean(prefs::kExtensionsUIDeveloperMode) &&
@@ -56,11 +66,18 @@ ExtensionContextMenuModel::ExtensionContextMenuModel(const Extension* extension,
extension_id_(extension->id()),
browser_(browser),
profile_(browser->profile()),
- delegate_(NULL) {
+ delegate_(NULL),
+ extension_items_(profile_,
+ this,
+ this,
+ base::Bind(MenuItemMatchesParams)) {
InitMenu(extension);
}
bool ExtensionContextMenuModel::IsCommandIdChecked(int command_id) const {
+ if (command_id >= IDC_EXTENSIONS_CONTEXT_CUSTOM_FIRST &&
+ command_id <= IDC_EXTENSIONS_CONTEXT_CUSTOM_LAST)
+ return extension_items_.IsCommandIdChecked(command_id);
return false;
}
@@ -103,6 +120,15 @@ void ExtensionContextMenuModel::ExecuteCommand(int command_id,
if (!extension)
return;
+ if (command_id >= IDC_EXTENSIONS_CONTEXT_CUSTOM_FIRST &&
+ command_id <= IDC_EXTENSIONS_CONTEXT_CUSTOM_LAST) {
+ WebContents* web_contents =
+ browser_->tab_strip_model()->GetActiveWebContents();
+ content::ContextMenuParams *params = new content::ContextMenuParams();
+ extension_items_.ExecuteCommand(command_id, web_contents, *params);
gpdavis 2014/06/26 18:16:02 I had to remove params when I was porting over all
+ return;
+ }
+
switch (command_id) {
case NAME: {
OpenURLParams params(extensions::ManifestURL::GetHomepageURL(extension),
@@ -177,6 +203,7 @@ void ExtensionContextMenuModel::InitMenu(const Extension* extension) {
AddItemWithStringId(HIDE, IDS_EXTENSIONS_HIDE_BUTTON);
AddSeparator(ui::NORMAL_SEPARATOR);
AddItemWithStringId(MANAGE, IDS_MANAGE_EXTENSION);
+ AppendExtensionItems();
}
const Extension* ExtensionContextMenuModel::GetExtension() const {
@@ -184,3 +211,77 @@ const Extension* ExtensionContextMenuModel::GetExtension() const {
extensions::ExtensionSystem::Get(profile_)->extension_service();
return extension_service->GetExtensionById(extension_id_, false);
}
+
+void ExtensionContextMenuModel::AppendExtensionItems() {
+ LOG(WARNING) << "AppendExtensionItems";
+ extension_items_.Clear();
+ ExtensionService* service =
+ extensions::ExtensionSystem::Get(profile_)->extension_service();
+ if (!service)
+ return; // In unit-tests, we may not have an ExtensionService.
+
+ MenuManager* menu_manager = MenuManager::Get(profile_);
+ if (!menu_manager)
+ return;
+
+ base::string16 *null_string = new base::string16();
+
+ // Get a list of extension id's that have context menu items, and sort by the
+ // top level context menu title of the extension.
+ std::set<MenuItem::ExtensionKey> ids = menu_manager->ExtensionIds();
+ std::vector<base::string16> sorted_menu_titles;
+ std::map<base::string16, std::string> map_ids;
+ for (std::set<MenuItem::ExtensionKey>::iterator i = ids.begin();
+ i != ids.end();
+ ++i) {
+ const Extension* extension =
+ service->GetExtensionById(i->extension_id, false);
+ // Platform apps have their context menus created directly in
+ // AppendPlatformAppItems.
+ if (extension && !extension->is_platform_app()) {
+ base::string16 menu_title = extension_items_.GetTopLevelContextMenuTitle(
+ *i, *null_string);
+ map_ids[menu_title] = i->extension_id;
+ sorted_menu_titles.push_back(menu_title);
+ }
+ }
+ if (sorted_menu_titles.empty())
+ return;
+
+ const std::string app_locale = g_browser_process->GetApplicationLocale();
+ l10n_util::SortStrings16(app_locale, &sorted_menu_titles);
+
+ int index = 0;
+// base::TimeTicks begin = base::TimeTicks::Now();
+ for (size_t i = 0; i < sorted_menu_titles.size(); ++i) {
+ LOG(WARNING) << "LOOP " << sorted_menu_titles[i];
+ const std::string& id = map_ids[sorted_menu_titles[i]];
+ const MenuItem::ExtensionKey extension_key(id);
+ extension_items_.AppendExtensionItems(
+ extension_key, *null_string, &index);
+ }
+ LOG(WARNING) << "COMPLETE";
+/*
+ UMA_HISTOGRAM_TIMES("Extensions.ContextMenus_BuildTime",
+ base::TimeTicks::Now() - begin);
+ UMA_HISTOGRAM_COUNTS("Extensions.ContextMenus_ItemCount", index);
gpdavis 2014/06/26 18:16:02 I wanted to get some clarification on that to make
+ */
+}
+
+bool ExtensionContextMenuModel::MenuItemMatchesParams(
+ const extensions::MenuItem* item) {
+// MenuItem::ContextList contexts = item->contexts();
+
+// if (contexts.Contains(MenuItem::ALL)
+// || context.Contains(MenuItem::BROWSERACTION)
+// )
+ return true;
gpdavis 2014/06/26 18:16:02 I haven't added a browser_context string yet-- ins
+
+ return false;
+}
+
+// Helper function to escape "&" as "&&".
+void ExtensionContextMenuModel::EscapeAmpersands(base::string16* text) {
+ base::ReplaceChars(*text, base::ASCIIToUTF16("&"), base::ASCIIToUTF16("&&"),
+ text);
+}
« no previous file with comments | « chrome/browser/extensions/extension_context_menu_model.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698