| 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_2.h" | |
| 17 #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" |
| 18 #include "views/controls/menu/submenu_view.h" |
| 19 #include "views/window/window.h" |
| 18 | 20 |
| 19 BrowserActionOverflowMenuController::BrowserActionOverflowMenuController( | 21 BrowserActionOverflowMenuController::BrowserActionOverflowMenuController( |
| 20 BrowserActionsContainer* owner, | 22 BrowserActionsContainer* owner, |
| 21 views::MenuButton* menu_button, | 23 views::MenuButton* menu_button, |
| 22 const std::vector<BrowserActionView*>& views, | 24 const std::vector<BrowserActionView*>& views, |
| 23 int start_index) | 25 int start_index) |
| 24 : owner_(owner), | 26 : owner_(owner), |
| 25 observer_(NULL), | 27 observer_(NULL), |
| 26 menu_button_(menu_button), | 28 menu_button_(menu_button), |
| 27 views_(&views), | 29 views_(&views), |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 89 bool BrowserActionOverflowMenuController::ShowContextMenu( | 91 bool BrowserActionOverflowMenuController::ShowContextMenu( |
| 90 views::MenuItemView* source, | 92 views::MenuItemView* source, |
| 91 int id, | 93 int id, |
| 92 const gfx::Point& p, | 94 const gfx::Point& p, |
| 93 bool is_mouse_gesture) { | 95 bool is_mouse_gesture) { |
| 94 const Extension* extension = | 96 const Extension* extension = |
| 95 (*views_)[start_index_ + id - 1]->button()->extension(); | 97 (*views_)[start_index_ + id - 1]->button()->extension(); |
| 96 if (!extension->ShowConfigureContextMenus()) | 98 if (!extension->ShowConfigureContextMenus()) |
| 97 return false; | 99 return false; |
| 98 | 100 |
| 99 context_menu_contents_ = new ExtensionContextMenuModel( | 101 scoped_refptr<ExtensionContextMenuModel> context_menu_contents = |
| 100 extension, | 102 new ExtensionContextMenuModel(extension, owner_->browser(), owner_); |
| 101 owner_->browser(), | 103 views::MenuModelAdapter context_menu_model_adapter( |
| 102 owner_); | 104 context_menu_contents.get()); |
| 103 context_menu_menu_.reset(new views::Menu2(context_menu_contents_.get())); | 105 views::MenuItemView context_menu(&context_menu_model_adapter); |
| 106 context_menu_model_adapter.BuildMenu(&context_menu); |
| 107 |
| 104 // This blocks until the user choses something or dismisses the menu. | 108 // This blocks until the user choses something or dismisses the menu. |
| 105 context_menu_menu_->RunContextMenuAt(p); | 109 context_menu.RunMenuAt(menu_button_->GetWidget()->GetNativeWindow(), |
| 110 NULL, gfx::Rect(p, gfx::Size()), views::MenuItemView::TOPLEFT, true); |
| 106 | 111 |
| 107 // The user is done with the context menu, so we can close the underlying | 112 // The user is done with the context menu, so we can close the underlying |
| 108 // menu. | 113 // menu. |
| 109 menu_->Cancel(); | 114 menu_->Cancel(); |
| 110 | 115 |
| 111 return true; | 116 return true; |
| 112 } | 117 } |
| 113 | 118 |
| 114 void BrowserActionOverflowMenuController::DropMenuClosed( | 119 void BrowserActionOverflowMenuController::DropMenuClosed( |
| 115 views::MenuItemView* menu) { | 120 views::MenuItemView* menu) { |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 202 | 207 |
| 203 BrowserActionView* BrowserActionOverflowMenuController::ViewForId( | 208 BrowserActionView* BrowserActionOverflowMenuController::ViewForId( |
| 204 int id, size_t* index) { | 209 int id, size_t* index) { |
| 205 // The index of the view being dragged (GetCommand gives a 1-based index into | 210 // The index of the view being dragged (GetCommand gives a 1-based index into |
| 206 // the overflow menu). | 211 // the overflow menu). |
| 207 size_t view_index = owner_->VisibleBrowserActions() + id - 1; | 212 size_t view_index = owner_->VisibleBrowserActions() + id - 1; |
| 208 if (index) | 213 if (index) |
| 209 *index = view_index; | 214 *index = view_index; |
| 210 return owner_->GetBrowserActionViewAt(view_index); | 215 return owner_->GetBrowserActionViewAt(view_index); |
| 211 } | 216 } |
| OLD | NEW |