Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/renderer_context_menu/open_with_menu_observer.h" | |
| 6 | |
| 7 #include "chrome/app/chrome_command_ids.h" | |
| 8 #include "content/public/browser/browser_thread.h" | |
| 9 #include "content/public/common/context_menu_params.h" | |
| 10 | |
| 11 #if defined(USE_ASH) | |
| 12 #include "ash/renderer_context_menu/open_with_menu_controller.h" | |
| 13 #include "ash/shell.h" | |
| 14 | |
| 15 namespace { | |
| 16 | |
| 17 const size_t kMaxOpenWithMenuItems = | |
| 18 IDC_CONTENT_CONTEXT_OPEN_WITH_LAST - IDC_CONTENT_CONTEXT_OPEN_WITH1 + 1; | |
| 19 | |
| 20 ash::OpenWithMenuController* GetController() { | |
| 21 if (!ash::Shell::HasInstance()) | |
| 22 return nullptr; | |
| 23 return ash::Shell::GetInstance()->open_with_menu_controller(); | |
| 24 } | |
| 25 | |
| 26 } // namespace | |
| 27 #endif | |
| 28 | |
| 29 OpenWithMenuObserver::OpenWithMenuObserver(RenderViewContextMenuProxy* proxy) | |
| 30 : proxy_(proxy), num_items_initially_enabled_(0) {} | |
| 31 | |
| 32 OpenWithMenuObserver::~OpenWithMenuObserver() {} | |
| 33 | |
| 34 void OpenWithMenuObserver::InitMenu(const content::ContextMenuParams& params) { | |
| 35 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | |
| 36 if (params.link_url.is_empty()) | |
| 37 return; | |
| 38 #if defined(USE_ASH) | |
|
hidehiko
2016/03/14 12:07:05
No error handling is needed?
Yusuke Sato
2016/03/15 00:00:13
For non-ASH configurations, InitMenu does nothing
| |
| 39 ash::OpenWithMenuController* controller = GetController(); | |
| 40 if (controller) { | |
| 41 num_items_initially_enabled_ = controller->PopulateOpenWithMenu( | |
| 42 proxy_, IDC_CONTENT_CONTEXT_OPEN_WITH1, kMaxOpenWithMenuItems, | |
| 43 params.link_url); | |
| 44 } | |
| 45 #endif | |
| 46 } | |
| 47 | |
| 48 bool OpenWithMenuObserver::IsCommandIdSupported(int command_id) { | |
| 49 return (command_id >= IDC_CONTENT_CONTEXT_OPEN_WITH1) && | |
| 50 (command_id <= IDC_CONTENT_CONTEXT_OPEN_WITH_LAST); | |
|
hidehiko
2016/03/14 12:07:05
Handled value range was changed from, at least, PS
Yusuke Sato
2016/03/15 00:00:13
PS4's also works fine, but was overkill. The funct
| |
| 51 } | |
| 52 | |
| 53 bool OpenWithMenuObserver::IsCommandIdChecked(int command_id) { | |
| 54 return false; | |
| 55 } | |
| 56 | |
| 57 bool OpenWithMenuObserver::IsCommandIdEnabled(int command_id) { | |
| 58 return (command_id >= IDC_CONTENT_CONTEXT_OPEN_WITH1) && | |
| 59 (command_id < | |
| 60 IDC_CONTENT_CONTEXT_OPEN_WITH1 + num_items_initially_enabled_); | |
| 61 } | |
| 62 | |
| 63 void OpenWithMenuObserver::ExecuteCommand(int command_id) { | |
| 64 #if defined(USE_ASH) | |
| 65 ash::OpenWithMenuController* controller = GetController(); | |
| 66 if (controller) { | |
| 67 controller->ExecuteCommand(command_id); | |
| 68 controller->MenuClosed(); | |
| 69 } | |
| 70 #endif | |
| 71 } | |
| 72 | |
| 73 void OpenWithMenuObserver::OnMenuCancel() { | |
| 74 #if defined(USE_ASH) | |
| 75 ash::OpenWithMenuController* controller = GetController(); | |
| 76 if (controller) | |
| 77 controller->MenuClosed(); | |
| 78 #endif | |
| 79 } | |
| OLD | NEW |