Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(104)

Side by Side Diff: chrome/browser/ui/views/toolbar/chevron_menu_button.cc

Issue 670463004: Make a platform-independent ToolbarActionViewController (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/chevron_menu_button.h" 5 #include "chrome/browser/ui/views/toolbar/chevron_menu_button.h"
6 6
7 #include "base/memory/scoped_vector.h" 7 #include "base/memory/scoped_vector.h"
8 #include "base/message_loop/message_loop.h" 8 #include "base/message_loop/message_loop.h"
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "chrome/browser/extensions/extension_action.h" 10 #include "chrome/browser/extensions/extension_action.h"
11 #include "chrome/browser/extensions/extension_action_icon_factory.h" 11 #include "chrome/browser/extensions/extension_action_icon_factory.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_toolbar_model.h" 13 #include "chrome/browser/extensions/extension_toolbar_model.h"
14 #include "chrome/browser/profiles/profile.h" 14 #include "chrome/browser/profiles/profile.h"
15 #include "chrome/browser/ui/browser.h" 15 #include "chrome/browser/ui/browser.h"
16 #include "chrome/browser/ui/extensions/extension_action_view_controller.h"
16 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h" 17 #include "chrome/browser/ui/views/extensions/browser_action_drag_data.h"
17 #include "chrome/browser/ui/views/extensions/extension_action_view_controller.h"
18 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" 18 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h"
19 #include "chrome/browser/ui/views/toolbar/toolbar_action_view.h" 19 #include "chrome/browser/ui/views/toolbar/toolbar_action_view.h"
20 #include "extensions/common/extension.h" 20 #include "extensions/common/extension.h"
21 #include "ui/views/border.h" 21 #include "ui/views/border.h"
22 #include "ui/views/controls/button/label_button_border.h" 22 #include "ui/views/controls/button/label_button_border.h"
23 #include "ui/views/controls/menu/menu_delegate.h" 23 #include "ui/views/controls/menu/menu_delegate.h"
24 #include "ui/views/controls/menu/menu_item_view.h" 24 #include "ui/views/controls/menu/menu_item_view.h"
25 #include "ui/views/controls/menu/menu_runner.h" 25 #include "ui/views/controls/menu/menu_runner.h"
26 #include "ui/views/metrics.h" 26 #include "ui/views/metrics.h"
27 27
28 namespace { 28 namespace {
29 29
30 // In the browser actions container's chevron menu, a menu item view's icon 30 // In the browser actions container's chevron menu, a menu item view's icon
31 // comes from ToolbarActionView::GetIconWithBadge() when the menu item view is 31 // comes from ToolbarActionView::GetIconWithBadge() when the menu item view is
32 // created. But, the browser action's icon may not be loaded in time because it 32 // created. But, the browser action's icon may not be loaded in time because it
33 // is read from file system in another thread. 33 // is read from file system in another thread.
34 // The IconUpdater will update the menu item view's icon when the browser 34 // The IconUpdater will update the menu item view's icon when the browser
35 // action's icon has been updated. 35 // action's icon has been updated.
36 class IconUpdater : public ExtensionActionIconFactory::Observer { 36 class IconUpdater : public ExtensionActionIconFactory::Observer {
37 public: 37 public:
38 IconUpdater(views::MenuItemView* menu_item_view, 38 IconUpdater(views::MenuItemView* menu_item_view,
39 ExtensionActionViewController* view_controller) 39 ExtensionActionViewController* view_controller)
40 : menu_item_view_(menu_item_view), 40 : menu_item_view_(menu_item_view),
41 view_controller_(view_controller) { 41 view_controller_(view_controller) {
42 DCHECK(menu_item_view); 42 DCHECK(menu_item_view);
43 DCHECK(view_controller); 43 DCHECK(view_controller);
44 view_controller->set_icon_observer(this); 44 view_controller->set_icon_observer(this);
45 } 45 }
46 ~IconUpdater() override { view_controller_->set_icon_observer(NULL); } 46 ~IconUpdater() override { view_controller_->set_icon_observer(nullptr); }
47 47
48 // ExtensionActionIconFactory::Observer: 48 // ExtensionActionIconFactory::Observer:
49 void OnIconUpdated() override { 49 void OnIconUpdated() override {
50 menu_item_view_->SetIcon(view_controller_->GetIconWithBadge()); 50 menu_item_view_->SetIcon(view_controller_->GetIconWithBadge());
51 } 51 }
52 52
53 private: 53 private:
54 // The menu item view whose icon might be updated. 54 // The menu item view whose icon might be updated.
55 views::MenuItemView* menu_item_view_; 55 views::MenuItemView* menu_item_view_;
56 56
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after
151 menu_ = new views::MenuItemView(this); 151 menu_ = new views::MenuItemView(this);
152 menu_runner_.reset(new views::MenuRunner( 152 menu_runner_.reset(new views::MenuRunner(
153 menu_, for_drop_ ? views::MenuRunner::FOR_DROP : 0)); 153 menu_, for_drop_ ? views::MenuRunner::FOR_DROP : 0));
154 menu_->set_has_icons(true); 154 menu_->set_has_icons(true);
155 155
156 size_t command_id = 1; // Menu id 0 is reserved, start with 1. 156 size_t command_id = 1; // Menu id 0 is reserved, start with 1.
157 for (size_t i = start_index_; 157 for (size_t i = start_index_;
158 i < browser_actions_container_->num_toolbar_actions(); ++i) { 158 i < browser_actions_container_->num_toolbar_actions(); ++i) {
159 ToolbarActionView* view = 159 ToolbarActionView* view =
160 browser_actions_container_->GetToolbarActionViewAt(i); 160 browser_actions_container_->GetToolbarActionViewAt(i);
161 ExtensionActionViewController* view_controller =
162 static_cast<ExtensionActionViewController*>(view->view_controller());
163 views::MenuItemView* menu_item = menu_->AppendMenuItemWithIcon( 161 views::MenuItemView* menu_item = menu_->AppendMenuItemWithIcon(
164 command_id, 162 command_id,
165 base::UTF8ToUTF16(view_controller->extension()->name()), 163 view->view_controller()->GetActionName(),
166 view_controller->GetIconWithBadge()); 164 view->view_controller()->GetIconWithBadge());
167 165
168 // Set the tooltip for this item. 166 // Set the tooltip for this item.
169 menu_->SetTooltip( 167 menu_->SetTooltip(
170 view_controller->GetTooltip(view->GetCurrentWebContents()), 168 view->view_controller()->GetTooltip(view->GetCurrentWebContents()),
171 command_id); 169 command_id);
172 170
173 icon_updaters_.push_back(new IconUpdater(menu_item, view_controller)); 171 icon_updaters_.push_back(new IconUpdater(
172 menu_item,
173 static_cast<ExtensionActionViewController*>(view->view_controller())));
174 174
175 ++command_id; 175 ++command_id;
176 } 176 }
177 } 177 }
178 178
179 ChevronMenuButton::MenuController::~MenuController() { 179 ChevronMenuButton::MenuController::~MenuController() {
180 } 180 }
181 181
182 void ChevronMenuButton::MenuController::RunMenu(views::Widget* window) { 182 void ChevronMenuButton::MenuController::RunMenu(views::Widget* window) {
183 gfx::Rect bounds = owner_->bounds(); 183 gfx::Rect bounds = owner_->bounds();
(...skipping 244 matching lines...) Expand 10 before | Expand all | Expand 10 after
428 void ChevronMenuButton::ShowOverflowMenu(bool for_drop) { 428 void ChevronMenuButton::ShowOverflowMenu(bool for_drop) {
429 DCHECK(!menu_controller_); 429 DCHECK(!menu_controller_);
430 menu_controller_.reset(new MenuController( 430 menu_controller_.reset(new MenuController(
431 this, browser_actions_container_, for_drop)); 431 this, browser_actions_container_, for_drop));
432 menu_controller_->RunMenu(GetWidget()); 432 menu_controller_->RunMenu(GetWidget());
433 } 433 }
434 434
435 void ChevronMenuButton::MenuDone() { 435 void ChevronMenuButton::MenuDone() {
436 menu_controller_.reset(); 436 menu_controller_.reset();
437 } 437 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698