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

Side by Side Diff: chrome/browser/ui/views/download/download_shelf_context_menu_view.cc

Issue 331993009: MacViews: Run native Cocoa context menus to support Services. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add VIEWS_EXPORT for unit test access Created 6 years, 5 months 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 | Annotate | Revision Log
OLDNEW
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/download/download_shelf_context_menu_view.h" 5 #include "chrome/browser/ui/views/download/download_shelf_context_menu_view.h"
6 6
7 #include "base/i18n/rtl.h" 7 #include "base/i18n/rtl.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "chrome/browser/download/download_item_model.h" 9 #include "chrome/browser/download/download_item_model.h"
10 #include "content/public/browser/download_item.h" 10 #include "content/public/browser/download_item.h"
11 #include "content/public/browser/page_navigator.h" 11 #include "content/public/browser/page_navigator.h"
12 #include "ui/gfx/point.h" 12 #include "ui/gfx/point.h"
13 #include "ui/views/controls/menu/menu_runner.h" 13 #include "ui/views/controls/menu/menu_runner.h"
14 14
15 DownloadShelfContextMenuView::DownloadShelfContextMenuView( 15 DownloadShelfContextMenuView::DownloadShelfContextMenuView(
16 content::DownloadItem* download_item, 16 content::DownloadItem* download_item,
17 content::PageNavigator* navigator) 17 content::PageNavigator* navigator)
18 : DownloadShelfContextMenu(download_item, navigator) { 18 : DownloadShelfContextMenu(download_item, navigator) {
19 } 19 }
20 20
21 DownloadShelfContextMenuView::~DownloadShelfContextMenuView() {} 21 DownloadShelfContextMenuView::~DownloadShelfContextMenuView() {}
22 22
23 void DownloadShelfContextMenuView::Run(views::Widget* parent_widget, 23 void DownloadShelfContextMenuView::Run(views::Widget* parent_widget,
24 const gfx::Rect& rect, 24 const gfx::Rect& rect,
25 ui::MenuSourceType source_type) { 25 ui::MenuSourceType source_type) {
26 ui::MenuModel* menu_model = GetMenuModel(); 26 ui::MenuModel* menu_model = GetMenuModel();
27 // Run() should not be getting called if the DownloadItem was destroyed. 27 // Run() should not be getting called if the DownloadItem was destroyed.
28 DCHECK(menu_model); 28 DCHECK(menu_model);
29 29
30 menu_runner_.reset(new views::MenuRunner(menu_model)); 30 menu_runner_.reset(new views::MenuRunner(
31 menu_model,
32 views::MenuRunner::HAS_MNEMONICS | views::MenuRunner::CONTEXT_MENU));
31 33
32 // The menu's alignment is determined based on the UI layout. 34 // The menu's alignment is determined based on the UI layout.
33 views::MenuAnchorPosition position; 35 views::MenuAnchorPosition position;
34 if (base::i18n::IsRTL()) 36 if (base::i18n::IsRTL())
35 position = views::MENU_ANCHOR_TOPRIGHT; 37 position = views::MENU_ANCHOR_TOPRIGHT;
36 else 38 else
37 position = views::MENU_ANCHOR_TOPLEFT; 39 position = views::MENU_ANCHOR_TOPLEFT;
38 40
39 // The return value of RunMenuAt indicates whether the MenuRunner was deleted 41 // The return value of RunMenuAt indicates whether the MenuRunner was deleted
40 // while running the menu, which indicates that the containing view may have 42 // while running the menu, which indicates that the containing view may have
41 // been deleted. We ignore the return value because our caller already assumes 43 // been deleted. We ignore the return value because our caller already assumes
42 // that the view could be deleted by the time we return from here. 44 // that the view could be deleted by the time we return from here.
43 if (menu_runner_->RunMenuAt( 45 if (menu_runner_->RunMenuAt(
44 parent_widget, 46 parent_widget, NULL, rect, position, source_type) ==
45 NULL,
46 rect,
47 position,
48 source_type,
49 views::MenuRunner::HAS_MNEMONICS | views::MenuRunner::CONTEXT_MENU) ==
50 views::MenuRunner::MENU_DELETED) { 47 views::MenuRunner::MENU_DELETED) {
51 return; 48 return;
52 } 49 }
53 close_time_ = base::TimeTicks::Now(); 50 close_time_ = base::TimeTicks::Now();
54 } 51 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698