| 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 #include "chrome/browser/extensions/extension_context_menu_model.h" | 5 #include "chrome/browser/extensions/extension_context_menu_model.h" |
| 6 | 6 |
| 7 #include "base/prefs/pref_service.h" | 7 #include "base/prefs/pref_service.h" |
| 8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 9 #include "chrome/app/chrome_command_ids.h" | 9 #include "chrome/app/chrome_command_ids.h" |
| 10 #include "chrome/browser/extensions/active_script_controller.h" | 10 #include "chrome/browser/extensions/active_script_controller.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 #include "chrome/common/pref_names.h" | 26 #include "chrome/common/pref_names.h" |
| 27 #include "chrome/common/url_constants.h" | 27 #include "chrome/common/url_constants.h" |
| 28 #include "content/public/browser/web_contents.h" | 28 #include "content/public/browser/web_contents.h" |
| 29 #include "content/public/common/context_menu_params.h" | 29 #include "content/public/common/context_menu_params.h" |
| 30 #include "extensions/browser/extension_prefs.h" | 30 #include "extensions/browser/extension_prefs.h" |
| 31 #include "extensions/browser/extension_registry.h" | 31 #include "extensions/browser/extension_registry.h" |
| 32 #include "extensions/browser/extension_system.h" | 32 #include "extensions/browser/extension_system.h" |
| 33 #include "extensions/browser/management_policy.h" | 33 #include "extensions/browser/management_policy.h" |
| 34 #include "extensions/browser/uninstall_reason.h" | 34 #include "extensions/browser/uninstall_reason.h" |
| 35 #include "extensions/common/extension.h" | 35 #include "extensions/common/extension.h" |
| 36 #include "extensions/common/feature_switch.h" |
| 36 #include "grit/chromium_strings.h" | 37 #include "grit/chromium_strings.h" |
| 37 #include "grit/generated_resources.h" | 38 #include "grit/generated_resources.h" |
| 38 #include "ui/base/l10n/l10n_util.h" | 39 #include "ui/base/l10n/l10n_util.h" |
| 39 | 40 |
| 40 using content::OpenURLParams; | 41 using content::OpenURLParams; |
| 41 using content::Referrer; | 42 using content::Referrer; |
| 42 using content::WebContents; | 43 using content::WebContents; |
| 43 using extensions::Extension; | 44 using extensions::Extension; |
| 45 using extensions::ExtensionActionAPI; |
| 46 using extensions::ExtensionPrefs; |
| 44 using extensions::MenuItem; | 47 using extensions::MenuItem; |
| 45 using extensions::MenuManager; | 48 using extensions::MenuManager; |
| 46 | 49 |
| 47 namespace { | 50 namespace { |
| 48 | 51 |
| 49 // Returns true if the given |item| is of the given |type|. | 52 // Returns true if the given |item| is of the given |type|. |
| 50 bool MenuItemMatchesAction(ExtensionContextMenuModel::ActionType type, | 53 bool MenuItemMatchesAction(ExtensionContextMenuModel::ActionType type, |
| 51 const MenuItem* item) { | 54 const MenuItem* item) { |
| 52 if (type == ExtensionContextMenuModel::NO_ACTION) | 55 if (type == ExtensionContextMenuModel::NO_ACTION) |
| 53 return false; | 56 return false; |
| 54 | 57 |
| 55 const MenuItem::ContextList& contexts = item->contexts(); | 58 const MenuItem::ContextList& contexts = item->contexts(); |
| 56 | 59 |
| 57 if (contexts.Contains(MenuItem::ALL)) | 60 if (contexts.Contains(MenuItem::ALL)) |
| 58 return true; | 61 return true; |
| 59 if (contexts.Contains(MenuItem::PAGE_ACTION) && | 62 if (contexts.Contains(MenuItem::PAGE_ACTION) && |
| 60 (type == ExtensionContextMenuModel::PAGE_ACTION)) | 63 (type == ExtensionContextMenuModel::PAGE_ACTION)) |
| 61 return true; | 64 return true; |
| 62 if (contexts.Contains(MenuItem::BROWSER_ACTION) && | 65 if (contexts.Contains(MenuItem::BROWSER_ACTION) && |
| 63 (type == ExtensionContextMenuModel::BROWSER_ACTION)) | 66 (type == ExtensionContextMenuModel::BROWSER_ACTION)) |
| 64 return true; | 67 return true; |
| 65 | 68 |
| 66 return false; | 69 return false; |
| 67 } | 70 } |
| 68 | 71 |
| 72 // Returns the id for the visibility command for the given |extension|, or -1 |
| 73 // if none should be shown. |
| 74 int GetVisibilityStringId(Profile* profile, const Extension* extension) { |
| 75 DCHECK(profile); |
| 76 int string_id = -1; |
| 77 if (!extensions::FeatureSwitch::extension_action_redesign()->IsEnabled()) { |
| 78 // Without the toolbar redesign, we only show the visibility toggle for |
| 79 // browser actions, and only give the option to hide. |
| 80 if (extensions::ExtensionActionManager::Get(profile)->GetBrowserAction( |
| 81 *extension)) { |
| 82 string_id = IDS_EXTENSIONS_HIDE_BUTTON; |
| 83 } |
| 84 } else { |
| 85 // With the redesign, we display "show" or "hide" based on the icon's |
| 86 // visibility. |
| 87 bool visible = ExtensionActionAPI::GetBrowserActionVisibility( |
| 88 ExtensionPrefs::Get(profile), extension->id()); |
| 89 string_id = |
| 90 visible ? IDS_EXTENSIONS_HIDE_BUTTON : IDS_EXTENSIONS_SHOW_BUTTON; |
| 91 } |
| 92 return string_id; |
| 93 } |
| 94 |
| 69 } // namespace | 95 } // namespace |
| 70 | 96 |
| 71 ExtensionContextMenuModel::ExtensionContextMenuModel(const Extension* extension, | 97 ExtensionContextMenuModel::ExtensionContextMenuModel(const Extension* extension, |
| 72 Browser* browser, | 98 Browser* browser, |
| 73 PopupDelegate* delegate) | 99 PopupDelegate* delegate) |
| 74 : SimpleMenuModel(this), | 100 : SimpleMenuModel(this), |
| 75 extension_id_(extension->id()), | 101 extension_id_(extension->id()), |
| 76 browser_(browser), | 102 browser_(browser), |
| 77 profile_(browser->profile()), | 103 profile_(browser->profile()), |
| 78 delegate_(delegate), | 104 delegate_(delegate), |
| (...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 170 if (web_contents) { | 196 if (web_contents) { |
| 171 extensions::ActiveScriptController::GetForWebContents(web_contents) | 197 extensions::ActiveScriptController::GetForWebContents(web_contents) |
| 172 ->AlwaysRunOnVisibleOrigin(extension); | 198 ->AlwaysRunOnVisibleOrigin(extension); |
| 173 } | 199 } |
| 174 break; | 200 break; |
| 175 } | 201 } |
| 176 case CONFIGURE: | 202 case CONFIGURE: |
| 177 DCHECK(!extensions::ManifestURL::GetOptionsPage(extension).is_empty()); | 203 DCHECK(!extensions::ManifestURL::GetOptionsPage(extension).is_empty()); |
| 178 extensions::ExtensionTabUtil::OpenOptionsPage(extension, browser_); | 204 extensions::ExtensionTabUtil::OpenOptionsPage(extension, browser_); |
| 179 break; | 205 break; |
| 180 case HIDE: { | 206 case TOGGLE_VISIBILITY: { |
| 181 extensions::ExtensionActionAPI::SetBrowserActionVisibility( | 207 ExtensionPrefs* prefs = ExtensionPrefs::Get(profile_); |
| 182 extensions::ExtensionPrefs::Get(profile_), extension->id(), false); | 208 bool visible = ExtensionActionAPI::GetBrowserActionVisibility( |
| 209 prefs, extension->id()); |
| 210 ExtensionActionAPI::SetBrowserActionVisibility( |
| 211 prefs, extension->id(), !visible); |
| 183 break; | 212 break; |
| 184 } | 213 } |
| 185 case UNINSTALL: { | 214 case UNINSTALL: { |
| 186 AddRef(); // Balanced in Accepted() and Canceled() | 215 AddRef(); // Balanced in Accepted() and Canceled() |
| 187 extension_uninstall_dialog_.reset( | 216 extension_uninstall_dialog_.reset( |
| 188 extensions::ExtensionUninstallDialog::Create( | 217 extensions::ExtensionUninstallDialog::Create( |
| 189 profile_, browser_->window()->GetNativeWindow(), this)); | 218 profile_, browser_->window()->GetNativeWindow(), this)); |
| 190 extension_uninstall_dialog_->ConfirmUninstall(extension); | 219 extension_uninstall_dialog_->ConfirmUninstall(extension); |
| 191 break; | 220 break; |
| 192 } | 221 } |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 253 // attached to the script injection request icon, but that's okay. | 282 // attached to the script injection request icon, but that's okay. |
| 254 WebContents* web_contents = GetActiveWebContents(); | 283 WebContents* web_contents = GetActiveWebContents(); |
| 255 if (web_contents && | 284 if (web_contents && |
| 256 extensions::ActiveScriptController::GetForWebContents(web_contents) | 285 extensions::ActiveScriptController::GetForWebContents(web_contents) |
| 257 ->HasActiveScriptAction(extension)) { | 286 ->HasActiveScriptAction(extension)) { |
| 258 AddItemWithStringId(ALWAYS_RUN, IDS_EXTENSIONS_ALWAYS_RUN); | 287 AddItemWithStringId(ALWAYS_RUN, IDS_EXTENSIONS_ALWAYS_RUN); |
| 259 } | 288 } |
| 260 | 289 |
| 261 AddItemWithStringId(CONFIGURE, IDS_EXTENSIONS_OPTIONS_MENU_ITEM); | 290 AddItemWithStringId(CONFIGURE, IDS_EXTENSIONS_OPTIONS_MENU_ITEM); |
| 262 AddItem(UNINSTALL, l10n_util::GetStringUTF16(IDS_EXTENSIONS_UNINSTALL)); | 291 AddItem(UNINSTALL, l10n_util::GetStringUTF16(IDS_EXTENSIONS_UNINSTALL)); |
| 263 if (extension_action_manager->GetBrowserAction(*extension)) | 292 |
| 264 AddItemWithStringId(HIDE, IDS_EXTENSIONS_HIDE_BUTTON); | 293 // Add a toggle visibility (show/hide) if the extension icon is shown on the |
| 294 // toolbar. |
| 295 int visibility_string_id = GetVisibilityStringId(profile_, extension); |
| 296 if (visibility_string_id != -1) |
| 297 AddItemWithStringId(TOGGLE_VISIBILITY, visibility_string_id); |
| 298 |
| 265 AddSeparator(ui::NORMAL_SEPARATOR); | 299 AddSeparator(ui::NORMAL_SEPARATOR); |
| 266 AddItemWithStringId(MANAGE, IDS_MANAGE_EXTENSION); | 300 AddItemWithStringId(MANAGE, IDS_MANAGE_EXTENSION); |
| 267 } | 301 } |
| 268 | 302 |
| 269 const Extension* ExtensionContextMenuModel::GetExtension() const { | 303 const Extension* ExtensionContextMenuModel::GetExtension() const { |
| 270 return extensions::ExtensionRegistry::Get(profile_) | 304 return extensions::ExtensionRegistry::Get(profile_) |
| 271 ->enabled_extensions() | 305 ->enabled_extensions() |
| 272 .GetByID(extension_id_); | 306 .GetByID(extension_id_); |
| 273 } | 307 } |
| 274 | 308 |
| (...skipping 10 matching lines...) Expand all Loading... |
| 285 extension_items_count_ = 0; | 319 extension_items_count_ = 0; |
| 286 extension_items_->AppendExtensionItems(MenuItem::ExtensionKey(extension_id_), | 320 extension_items_->AppendExtensionItems(MenuItem::ExtensionKey(extension_id_), |
| 287 base::string16(), | 321 base::string16(), |
| 288 &extension_items_count_, | 322 &extension_items_count_, |
| 289 true); // is_action_menu | 323 true); // is_action_menu |
| 290 } | 324 } |
| 291 | 325 |
| 292 content::WebContents* ExtensionContextMenuModel::GetActiveWebContents() const { | 326 content::WebContents* ExtensionContextMenuModel::GetActiveWebContents() const { |
| 293 return browser_->tab_strip_model()->GetActiveWebContents(); | 327 return browser_->tab_strip_model()->GetActiveWebContents(); |
| 294 } | 328 } |
| OLD | NEW |