OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/extensions/browser_action_overflow_menu_contro
ller.h" | 5 #include "chrome/browser/ui/views/extensions/browser_action_overflow_menu_contro
ller.h" |
6 | 6 |
7 #include "base/utf_string_conversions.h" | 7 #include "base/utf_string_conversions.h" |
8 #include "chrome/browser/extensions/extension_context_menu_model.h" | 8 #include "chrome/browser/extensions/extension_context_menu_model.h" |
9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
10 #include "chrome/browser/ui/browser_list.h" | 10 #include "chrome/browser/ui/browser_list.h" |
11 #include "chrome/browser/ui/views/browser_actions_container.h" | 11 #include "chrome/browser/ui/views/browser_actions_container.h" |
12 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" | 12 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" |
13 #include "chrome/common/extensions/extension.h" | 13 #include "chrome/common/extensions/extension.h" |
14 #include "chrome/common/extensions/extension_action.h" | 14 #include "chrome/common/extensions/extension_action.h" |
15 #include "ui/gfx/canvas_skia.h" | 15 #include "ui/gfx/canvas_skia.h" |
16 #include "views/controls/menu/menu_item_view.h" | 16 #include "views/controls/menu/menu_item_view.h" |
17 #include "views/controls/menu/menu_model_adapter.h" | 17 #include "views/controls/menu/menu_model_adapter.h" |
| 18 #include "views/controls/menu/menu_runner.h" |
18 #include "views/controls/menu/submenu_view.h" | 19 #include "views/controls/menu/submenu_view.h" |
19 #include "views/widget/widget.h" | 20 #include "views/widget/widget.h" |
20 | 21 |
21 BrowserActionOverflowMenuController::BrowserActionOverflowMenuController( | 22 BrowserActionOverflowMenuController::BrowserActionOverflowMenuController( |
22 BrowserActionsContainer* owner, | 23 BrowserActionsContainer* owner, |
23 views::MenuButton* menu_button, | 24 views::MenuButton* menu_button, |
24 const std::vector<BrowserActionView*>& views, | 25 const std::vector<BrowserActionView*>& views, |
25 int start_index) | 26 int start_index) |
26 : owner_(owner), | 27 : owner_(owner), |
27 observer_(NULL), | 28 observer_(NULL), |
28 menu_button_(menu_button), | 29 menu_button_(menu_button), |
| 30 menu_(NULL), |
29 views_(&views), | 31 views_(&views), |
30 start_index_(start_index), | 32 start_index_(start_index), |
31 for_drop_(false) { | 33 for_drop_(false) { |
32 menu_.reset(new views::MenuItemView(this)); | 34 menu_ = new views::MenuItemView(this); |
| 35 menu_runner_.reset(new views::MenuRunner(menu_)); |
33 menu_->set_has_icons(true); | 36 menu_->set_has_icons(true); |
34 | 37 |
35 size_t command_id = 1; // Menu id 0 is reserved, start with 1. | 38 size_t command_id = 1; // Menu id 0 is reserved, start with 1. |
36 for (size_t i = start_index; i < views_->size(); ++i) { | 39 for (size_t i = start_index; i < views_->size(); ++i) { |
37 BrowserActionView* view = (*views_)[i]; | 40 BrowserActionView* view = (*views_)[i]; |
38 scoped_ptr<gfx::Canvas> canvas(view->GetIconWithBadge()); | 41 scoped_ptr<gfx::Canvas> canvas(view->GetIconWithBadge()); |
39 menu_->AppendMenuItemWithIcon( | 42 menu_->AppendMenuItemWithIcon( |
40 command_id, | 43 command_id, |
41 UTF8ToWide(view->button()->extension()->name()), | 44 UTF8ToWide(view->button()->extension()->name()), |
42 canvas->AsCanvasSkia()->ExtractBitmap()); | 45 canvas->AsCanvasSkia()->ExtractBitmap()); |
(...skipping 17 matching lines...) Expand all Loading... |
60 bool for_drop) { | 63 bool for_drop) { |
61 for_drop_ = for_drop; | 64 for_drop_ = for_drop; |
62 | 65 |
63 gfx::Rect bounds = menu_button_->bounds(); | 66 gfx::Rect bounds = menu_button_->bounds(); |
64 gfx::Point screen_loc; | 67 gfx::Point screen_loc; |
65 views::View::ConvertPointToScreen(menu_button_, &screen_loc); | 68 views::View::ConvertPointToScreen(menu_button_, &screen_loc); |
66 bounds.set_x(screen_loc.x()); | 69 bounds.set_x(screen_loc.x()); |
67 bounds.set_y(screen_loc.y()); | 70 bounds.set_y(screen_loc.y()); |
68 | 71 |
69 views::MenuItemView::AnchorPosition anchor = views::MenuItemView::TOPRIGHT; | 72 views::MenuItemView::AnchorPosition anchor = views::MenuItemView::TOPRIGHT; |
70 if (for_drop) { | 73 // As we maintain our own lifetime we can safely ignore the result. |
71 menu_->RunMenuForDropAt(window, bounds, anchor); | 74 ignore_result(menu_runner_->RunMenuAt(window, menu_button_, bounds, anchor, |
72 } else { | 75 for_drop_ ? views::MenuRunner::FOR_DROP : 0)); |
73 menu_->RunMenuAt(window, menu_button_, bounds, anchor, false); | 76 if (!for_drop_) { |
74 // Give the context menu (if any) a chance to execute the user-selected | 77 // Give the context menu (if any) a chance to execute the user-selected |
75 // command. | 78 // command. |
76 MessageLoop::current()->DeleteSoon(FROM_HERE, this); | 79 MessageLoop::current()->DeleteSoon(FROM_HERE, this); |
77 } | 80 } |
78 return true; | 81 return true; |
79 } | 82 } |
80 | 83 |
81 void BrowserActionOverflowMenuController::CancelMenu() { | 84 void BrowserActionOverflowMenuController::CancelMenu() { |
82 menu_->Cancel(); | 85 menu_->Cancel(); |
83 } | 86 } |
(...skipping 11 matching lines...) Expand all Loading... |
95 bool is_mouse_gesture) { | 98 bool is_mouse_gesture) { |
96 const Extension* extension = | 99 const Extension* extension = |
97 (*views_)[start_index_ + id - 1]->button()->extension(); | 100 (*views_)[start_index_ + id - 1]->button()->extension(); |
98 if (!extension->ShowConfigureContextMenus()) | 101 if (!extension->ShowConfigureContextMenus()) |
99 return false; | 102 return false; |
100 | 103 |
101 scoped_refptr<ExtensionContextMenuModel> context_menu_contents = | 104 scoped_refptr<ExtensionContextMenuModel> context_menu_contents = |
102 new ExtensionContextMenuModel(extension, owner_->browser(), owner_); | 105 new ExtensionContextMenuModel(extension, owner_->browser(), owner_); |
103 views::MenuModelAdapter context_menu_model_adapter( | 106 views::MenuModelAdapter context_menu_model_adapter( |
104 context_menu_contents.get()); | 107 context_menu_contents.get()); |
105 views::MenuItemView context_menu(&context_menu_model_adapter); | 108 views::MenuRunner context_menu_runner( |
106 context_menu_model_adapter.BuildMenu(&context_menu); | 109 context_menu_model_adapter.CreateMenu()); |
107 | 110 |
| 111 // We can ignore the result as we delete ourself. |
108 // This blocks until the user choses something or dismisses the menu. | 112 // This blocks until the user choses something or dismisses the menu. |
109 context_menu.RunMenuAt(menu_button_->GetWidget(), | 113 ignore_result(context_menu_runner.RunMenuAt(menu_button_->GetWidget(), |
110 NULL, gfx::Rect(p, gfx::Size()), views::MenuItemView::TOPLEFT, true); | 114 NULL, gfx::Rect(p, gfx::Size()), views::MenuItemView::TOPLEFT, |
| 115 views::MenuRunner::HAS_MNEMONICS | views::MenuRunner::IS_NESTED)); |
111 | 116 |
112 // The user is done with the context menu, so we can close the underlying | 117 // The user is done with the context menu, so we can close the underlying |
113 // menu. | 118 // menu. |
114 menu_->Cancel(); | 119 menu_->Cancel(); |
115 | 120 |
116 return true; | 121 return true; |
117 } | 122 } |
118 | 123 |
119 void BrowserActionOverflowMenuController::DropMenuClosed( | 124 void BrowserActionOverflowMenuController::DropMenuClosed( |
120 views::MenuItemView* menu) { | 125 views::MenuItemView* menu) { |
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
207 | 212 |
208 BrowserActionView* BrowserActionOverflowMenuController::ViewForId( | 213 BrowserActionView* BrowserActionOverflowMenuController::ViewForId( |
209 int id, size_t* index) { | 214 int id, size_t* index) { |
210 // The index of the view being dragged (GetCommand gives a 1-based index into | 215 // The index of the view being dragged (GetCommand gives a 1-based index into |
211 // the overflow menu). | 216 // the overflow menu). |
212 size_t view_index = owner_->VisibleBrowserActions() + id - 1; | 217 size_t view_index = owner_->VisibleBrowserActions() + id - 1; |
213 if (index) | 218 if (index) |
214 *index = view_index; | 219 *index = view_index; |
215 return owner_->GetBrowserActionViewAt(view_index); | 220 return owner_->GetBrowserActionViewAt(view_index); |
216 } | 221 } |
OLD | NEW |