| 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 |