| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/ui/views/toolbar/browser_action_view.h" | 5 #include "chrome/browser/ui/views/toolbar/browser_action_view.h" |
| 6 | 6 |
| 7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 8 #include "chrome/browser/chrome_notification_types.h" | 8 #include "chrome/browser/chrome_notification_types.h" |
| 9 #include "chrome/browser/extensions/api/commands/command_service.h" | 9 #include "chrome/browser/extensions/api/commands/command_service.h" |
| 10 #include "chrome/browser/extensions/extension_action.h" | 10 #include "chrome/browser/extensions/extension_action.h" |
| 11 #include "chrome/browser/extensions/extension_action_manager.h" | 11 #include "chrome/browser/extensions/extension_action_manager.h" |
| 12 #include "chrome/browser/extensions/extension_context_menu_model.h" | 12 #include "chrome/browser/extensions/extension_context_menu_model.h" |
| 13 #include "chrome/browser/extensions/extension_service.h" | 13 #include "chrome/browser/extensions/extension_service.h" |
| 14 #include "chrome/browser/profiles/profile.h" | 14 #include "chrome/browser/profiles/profile.h" |
| 15 #include "chrome/browser/themes/theme_service.h" | 15 #include "chrome/browser/themes/theme_service.h" |
| 16 #include "chrome/browser/themes/theme_service_factory.h" | 16 #include "chrome/browser/themes/theme_service_factory.h" |
| 17 #include "chrome/browser/ui/browser.h" | 17 #include "chrome/browser/ui/browser.h" |
| 18 #include "chrome/browser/ui/view_ids.h" | 18 #include "chrome/browser/ui/view_ids.h" |
| 19 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 19 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" | 20 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" |
| 20 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" | 21 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
| 21 #include "extensions/common/extension.h" | 22 #include "extensions/common/extension.h" |
| 22 #include "extensions/common/manifest_constants.h" | 23 #include "extensions/common/manifest_constants.h" |
| 23 #include "grit/generated_resources.h" | 24 #include "grit/generated_resources.h" |
| 24 #include "grit/theme_resources.h" | 25 #include "grit/theme_resources.h" |
| 25 #include "ui/accessibility/ax_view_state.h" | 26 #include "ui/accessibility/ax_view_state.h" |
| 26 #include "ui/base/l10n/l10n_util.h" | 27 #include "ui/base/l10n/l10n_util.h" |
| 27 #include "ui/base/resource/resource_bundle.h" | 28 #include "ui/base/resource/resource_bundle.h" |
| 28 #include "ui/events/event.h" | 29 #include "ui/events/event.h" |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 | 65 |
| 65 BrowserActionView::~BrowserActionView() { | 66 BrowserActionView::~BrowserActionView() { |
| 66 button_->Destroy(); | 67 button_->Destroy(); |
| 67 } | 68 } |
| 68 | 69 |
| 69 gfx::ImageSkia BrowserActionView::GetIconWithBadge() { | 70 gfx::ImageSkia BrowserActionView::GetIconWithBadge() { |
| 70 return button_->GetIconWithBadge(); | 71 return button_->GetIconWithBadge(); |
| 71 } | 72 } |
| 72 | 73 |
| 73 void BrowserActionView::Layout() { | 74 void BrowserActionView::Layout() { |
| 74 button_->SetBounds(0, y(), width(), height()); | 75 button_->SetBounds(0, 0, width(), height()); |
| 75 } | 76 } |
| 76 | 77 |
| 77 void BrowserActionView::GetAccessibleState(ui::AXViewState* state) { | 78 void BrowserActionView::GetAccessibleState(ui::AXViewState* state) { |
| 78 state->name = l10n_util::GetStringUTF16( | 79 state->name = l10n_util::GetStringUTF16( |
| 79 IDS_ACCNAME_EXTENSIONS_BROWSER_ACTION); | 80 IDS_ACCNAME_EXTENSIONS_BROWSER_ACTION); |
| 80 state->role = ui::AX_ROLE_GROUP; | 81 state->role = ui::AX_ROLE_GROUP; |
| 81 } | 82 } |
| 82 | 83 |
| 83 gfx::Size BrowserActionView::GetPreferredSize() const { | 84 gfx::Size BrowserActionView::GetPreferredSize() const { |
| 84 return gfx::Size(BrowserActionsContainer::IconWidth(false), | 85 return gfx::Size(BrowserActionsContainer::IconWidth(false), |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 177 void BrowserActionButton::ShowContextMenuForView( | 178 void BrowserActionButton::ShowContextMenuForView( |
| 178 View* source, | 179 View* source, |
| 179 const gfx::Point& point, | 180 const gfx::Point& point, |
| 180 ui::MenuSourceType source_type) { | 181 ui::MenuSourceType source_type) { |
| 181 if (!extension()->ShowConfigureContextMenus()) | 182 if (!extension()->ShowConfigureContextMenus()) |
| 182 return; | 183 return; |
| 183 | 184 |
| 184 SetButtonPushed(); | 185 SetButtonPushed(); |
| 185 | 186 |
| 186 // Reconstructs the menu every time because the menu's contents are dynamic. | 187 // Reconstructs the menu every time because the menu's contents are dynamic. |
| 187 scoped_refptr<ExtensionContextMenuModel> context_menu_contents_( | 188 scoped_refptr<ExtensionContextMenuModel> context_menu_contents( |
| 188 new ExtensionContextMenuModel(extension(), browser_, delegate_)); | 189 new ExtensionContextMenuModel(extension(), browser_, delegate_)); |
| 189 menu_runner_.reset(new views::MenuRunner(context_menu_contents_.get())); | 190 menu_runner_.reset(new views::MenuRunner(context_menu_contents.get())); |
| 190 | 191 |
| 191 context_menu_ = menu_runner_->GetMenu(); | 192 context_menu_ = menu_runner_->GetMenu(); |
| 192 gfx::Point screen_loc; | 193 gfx::Point screen_loc; |
| 193 views::View::ConvertPointToScreen(this, &screen_loc); | 194 views::View::ConvertPointToScreen(this, &screen_loc); |
| 194 if (menu_runner_->RunMenuAt( | 195 |
| 195 GetWidget(), | 196 views::Widget* parent = NULL; |
| 196 NULL, | 197 int run_types = views::MenuRunner::HAS_MNEMONICS | |
| 197 gfx::Rect(screen_loc, size()), | 198 views::MenuRunner::CONTEXT_MENU; |
| 198 views::MENU_ANCHOR_TOPLEFT, | 199 if (delegate_->ShownInsideMenu()) { |
| 199 source_type, | 200 run_types |= views::MenuRunner::IS_NESTED; |
| 200 views::MenuRunner::HAS_MNEMONICS | views::MenuRunner::CONTEXT_MENU) == | 201 // RunMenuAt expects a nested menu to be parented by the same widget as the |
| 202 // already visible menu, in this case the Chrome menu. |
| 203 parent = BrowserView::GetBrowserViewForBrowser(browser_)->toolbar() |
| 204 ->app_menu() |
| 205 ->GetWidget(); |
| 206 } else { |
| 207 parent = GetWidget(); |
| 208 } |
| 209 |
| 210 if (menu_runner_->RunMenuAt(parent, |
| 211 NULL, |
| 212 gfx::Rect(screen_loc, size()), |
| 213 views::MENU_ANCHOR_TOPLEFT, |
| 214 source_type, |
| 215 run_types) == |
| 201 views::MenuRunner::MENU_DELETED) { | 216 views::MenuRunner::MENU_DELETED) { |
| 202 return; | 217 return; |
| 203 } | 218 } |
| 204 | 219 |
| 205 menu_runner_.reset(); | 220 menu_runner_.reset(); |
| 206 SetButtonNotPushed(); | 221 SetButtonNotPushed(); |
| 207 context_menu_ = NULL; | 222 context_menu_ = NULL; |
| 208 } | 223 } |
| 209 | 224 |
| 210 void BrowserActionButton::UpdateState() { | 225 void BrowserActionButton::UpdateState() { |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 423 extensions::Command browser_action_command; | 438 extensions::Command browser_action_command; |
| 424 if (!only_if_active || !command_service->GetBrowserActionCommand( | 439 if (!only_if_active || !command_service->GetBrowserActionCommand( |
| 425 extension_->id(), | 440 extension_->id(), |
| 426 extensions::CommandService::ACTIVE_ONLY, | 441 extensions::CommandService::ACTIVE_ONLY, |
| 427 &browser_action_command, | 442 &browser_action_command, |
| 428 NULL)) { | 443 NULL)) { |
| 429 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); | 444 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); |
| 430 keybinding_.reset(NULL); | 445 keybinding_.reset(NULL); |
| 431 } | 446 } |
| 432 } | 447 } |
| OLD | NEW |