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 25 matching lines...) Expand all Loading... |
54 | 55 |
55 BrowserActionView::~BrowserActionView() { | 56 BrowserActionView::~BrowserActionView() { |
56 button_->Destroy(); | 57 button_->Destroy(); |
57 } | 58 } |
58 | 59 |
59 gfx::ImageSkia BrowserActionView::GetIconWithBadge() { | 60 gfx::ImageSkia BrowserActionView::GetIconWithBadge() { |
60 return button_->GetIconWithBadge(); | 61 return button_->GetIconWithBadge(); |
61 } | 62 } |
62 | 63 |
63 void BrowserActionView::Layout() { | 64 void BrowserActionView::Layout() { |
64 button_->SetBounds(0, y(), width(), height()); | 65 button_->SetBounds(0, 0, width(), height()); |
65 } | 66 } |
66 | 67 |
67 void BrowserActionView::GetAccessibleState(ui::AXViewState* state) { | 68 void BrowserActionView::GetAccessibleState(ui::AXViewState* state) { |
68 state->name = l10n_util::GetStringUTF16( | 69 state->name = l10n_util::GetStringUTF16( |
69 IDS_ACCNAME_EXTENSIONS_BROWSER_ACTION); | 70 IDS_ACCNAME_EXTENSIONS_BROWSER_ACTION); |
70 state->role = ui::AX_ROLE_GROUP; | 71 state->role = ui::AX_ROLE_GROUP; |
71 } | 72 } |
72 | 73 |
73 gfx::Size BrowserActionView::GetPreferredSize() const { | 74 gfx::Size BrowserActionView::GetPreferredSize() const { |
74 return gfx::Size(BrowserActionsContainer::IconWidth(false), | 75 return gfx::Size(BrowserActionsContainer::IconWidth(false), |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
168 void BrowserActionButton::ShowContextMenuForView( | 169 void BrowserActionButton::ShowContextMenuForView( |
169 View* source, | 170 View* source, |
170 const gfx::Point& point, | 171 const gfx::Point& point, |
171 ui::MenuSourceType source_type) { | 172 ui::MenuSourceType source_type) { |
172 if (!extension()->ShowConfigureContextMenus()) | 173 if (!extension()->ShowConfigureContextMenus()) |
173 return; | 174 return; |
174 | 175 |
175 SetButtonPushed(); | 176 SetButtonPushed(); |
176 | 177 |
177 // Reconstructs the menu every time because the menu's contents are dynamic. | 178 // Reconstructs the menu every time because the menu's contents are dynamic. |
178 scoped_refptr<ExtensionContextMenuModel> context_menu_contents_( | 179 scoped_refptr<ExtensionContextMenuModel> context_menu_contents( |
179 new ExtensionContextMenuModel(extension(), browser_, delegate_)); | 180 new ExtensionContextMenuModel(extension(), browser_, delegate_)); |
180 menu_runner_.reset(new views::MenuRunner(context_menu_contents_.get())); | 181 menu_runner_.reset(new views::MenuRunner(context_menu_contents.get())); |
181 | 182 |
182 context_menu_ = menu_runner_->GetMenu(); | 183 context_menu_ = menu_runner_->GetMenu(); |
183 gfx::Point screen_loc; | 184 gfx::Point screen_loc; |
184 views::View::ConvertPointToScreen(this, &screen_loc); | 185 views::View::ConvertPointToScreen(this, &screen_loc); |
185 if (menu_runner_->RunMenuAt( | 186 |
186 GetWidget(), | 187 views::Widget* parent = NULL; |
187 NULL, | 188 int run_types = views::MenuRunner::HAS_MNEMONICS | |
188 gfx::Rect(screen_loc, size()), | 189 views::MenuRunner::CONTEXT_MENU; |
189 views::MENU_ANCHOR_TOPLEFT, | 190 if (delegate_->ShownInsideMenu()) { |
190 source_type, | 191 run_types |= views::MenuRunner::IS_NESTED; |
191 views::MenuRunner::HAS_MNEMONICS | views::MenuRunner::CONTEXT_MENU) == | 192 // RunMenuAt expects a nested menu to be parented by the same widget as the |
| 193 // already visible menu, in this case the wrench menu (hamburger). |
| 194 parent = BrowserView::GetBrowserViewForBrowser(browser_)->toolbar() |
| 195 ->app_menu() |
| 196 ->GetWidget(); |
| 197 } else { |
| 198 parent = GetWidget(); |
| 199 } |
| 200 |
| 201 if (menu_runner_->RunMenuAt(parent, |
| 202 NULL, |
| 203 gfx::Rect(screen_loc, size()), |
| 204 views::MENU_ANCHOR_TOPLEFT, |
| 205 source_type, |
| 206 run_types) == |
192 views::MenuRunner::MENU_DELETED) { | 207 views::MenuRunner::MENU_DELETED) { |
193 return; | 208 return; |
194 } | 209 } |
195 | 210 |
196 menu_runner_.reset(); | 211 menu_runner_.reset(); |
197 SetButtonNotPushed(); | 212 SetButtonNotPushed(); |
198 context_menu_ = NULL; | 213 context_menu_ = NULL; |
199 } | 214 } |
200 | 215 |
201 void BrowserActionButton::UpdateState() { | 216 void BrowserActionButton::UpdateState() { |
(...skipping 213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
415 extensions::Command browser_action_command; | 430 extensions::Command browser_action_command; |
416 if (!only_if_active || !command_service->GetBrowserActionCommand( | 431 if (!only_if_active || !command_service->GetBrowserActionCommand( |
417 extension_->id(), | 432 extension_->id(), |
418 extensions::CommandService::ACTIVE_ONLY, | 433 extensions::CommandService::ACTIVE_ONLY, |
419 &browser_action_command, | 434 &browser_action_command, |
420 NULL)) { | 435 NULL)) { |
421 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); | 436 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); |
422 keybinding_.reset(NULL); | 437 keybinding_.reset(NULL); |
423 } | 438 } |
424 } | 439 } |
OLD | NEW |