Index: chrome/browser/ui/views/download/download_shelf_context_menu_view.cc |
diff --git a/chrome/browser/ui/views/download/download_shelf_context_menu_view.cc b/chrome/browser/ui/views/download/download_shelf_context_menu_view.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..fb2736d5785bad1043f1e942b03b06f9934d5478 |
--- /dev/null |
+++ b/chrome/browser/ui/views/download/download_shelf_context_menu_view.cc |
@@ -0,0 +1,39 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/ui/views/download/download_shelf_context_menu_view.h" |
+ |
+#include "base/i18n/rtl.h" |
+#include "base/logging.h" |
+#include "chrome/browser/download/download_item.h" |
+#include "chrome/browser/download/download_item_model.h" |
+#include "ui/gfx/point.h" |
+#include "views/controls/menu/menu_2.h" |
+ |
+DownloadShelfContextMenuView::DownloadShelfContextMenuView( |
+ BaseDownloadItemModel* model) |
+ : DownloadShelfContextMenu(model) { |
+ DCHECK(model); |
+} |
+ |
+DownloadShelfContextMenuView::~DownloadShelfContextMenuView() {} |
+ |
+void DownloadShelfContextMenuView::Run(const gfx::Point& point) { |
+ if (download_item()->IsComplete()) |
dmazzoni
2011/05/22 04:39:49
Just a thought, but I wonder why DownloadShelfCont
|
+ menu_.reset(new views::Menu2(GetFinishedMenuModel())); |
+ else |
+ menu_.reset(new views::Menu2(GetInProgressMenuModel())); |
+ |
+ // The menu's alignment is determined based on the UI layout. |
+ views::Menu2::Alignment alignment; |
+ if (base::i18n::IsRTL()) |
+ alignment = views::Menu2::ALIGN_TOPRIGHT; |
+ else |
+ alignment = views::Menu2::ALIGN_TOPLEFT; |
+ menu_->RunMenuAt(point, alignment); |
+} |
+ |
+void DownloadShelfContextMenuView::Stop() { |
+ set_download_item(NULL); |
+} |