Index: content/shell/browser/shell_web_contents_view_delegate_aura.cc |
diff --git a/content/shell/browser/shell_web_contents_view_delegate_aura.cc b/content/shell/browser/shell_web_contents_view_delegate_aura.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b06df3f5fdcb4d4871f5d070653b1b2cc32d2332 |
--- /dev/null |
+++ b/content/shell/browser/shell_web_contents_view_delegate_aura.cc |
@@ -0,0 +1,107 @@ |
+// Copyright 2016 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 "content/shell/browser/shell_web_contents_view_delegate.h" |
+ |
+#include "base/strings/utf_string_conversions.h" |
+#include "content/public/browser/web_contents.h" |
+#include "content/shell/browser/shell_devtools_frontend.h" |
+#include "content/shell/common/shell_switches.h" |
+#include "ui/aura/client/screen_position_client.h" |
+#include "ui/aura/window.h" |
+#include "ui/base/models/simple_menu_model.h" |
+#include "ui/views/controls/menu/menu_runner.h" |
+#include "ui/views/widget/widget.h" |
+ |
+namespace content { |
+namespace { |
+ |
+// Model for the "Debug" menu |
+class ContextMenuModel : public ui::SimpleMenuModel, |
+ public ui::SimpleMenuModel::Delegate { |
+ public: |
+ ContextMenuModel(WebContents* web_contents, |
+ const content::ContextMenuParams& params) |
Peter Beverloo
2016/07/20 16:40:14
micro nit: drop content::
mohsen
2016/07/20 22:16:31
Done.
|
+ : ui::SimpleMenuModel(this), |
+ web_contents_(web_contents), |
+ params_(params) { |
+ AddItem(COMMAND_OPEN_DEVTOOLS, base::ASCIIToUTF16("Inspect Element")); |
+ } |
+ ~ContextMenuModel() override {} |
+ |
+ // ui::SimpleMenuModel::Delegate: |
+ bool IsCommandIdChecked(int command_id) const override { return false; } |
+ bool IsCommandIdEnabled(int command_id) const override { return true; } |
+ bool GetAcceleratorForCommandId(int command_id, |
+ ui::Accelerator* accelerator) const override { |
+ return false; |
+ } |
+ void ExecuteCommand(int command_id, int event_flags) override { |
+ switch (command_id) { |
+ case COMMAND_OPEN_DEVTOOLS: |
+ ShellDevToolsFrontend* devtools_frontend = |
+ ShellDevToolsFrontend::Show(web_contents_); |
+ devtools_frontend->Activate(); |
+ devtools_frontend->Focus(); |
+ devtools_frontend->InspectElementAt(params_.x, params_.y); |
+ break; |
+ }; |
+ } |
+ |
+ private: |
+ enum CommandID { COMMAND_OPEN_DEVTOOLS }; |
+ |
+ WebContents* web_contents_; |
+ ContextMenuParams params_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ContextMenuModel); |
+}; |
+ |
+} // namespace |
+ |
+WebContentsViewDelegate* CreateShellWebContentsViewDelegate( |
+ WebContents* web_contents) { |
+ return new ShellWebContentsViewDelegate(web_contents); |
+} |
+ |
+ShellWebContentsViewDelegate::ShellWebContentsViewDelegate( |
+ WebContents* web_contents) |
+ : web_contents_(web_contents) {} |
+ |
+ShellWebContentsViewDelegate::~ShellWebContentsViewDelegate() {} |
+ |
+void ShellWebContentsViewDelegate::ShowContextMenu( |
+ RenderFrameHost* render_frame_host, |
+ const ContextMenuParams& params) { |
+ if (switches::IsRunLayoutTestSwitchPresent()) |
+ return; |
+ |
+ gfx::Point screen_point(params.x, params.y); |
+ |
+ // Convert from content coordinates to window coordinates. |
+ // This code copied from chrome_web_contents_view_delegate_views.cc |
+ aura::Window* web_contents_window = web_contents_->GetNativeView(); |
+ aura::Window* root_window = web_contents_window->GetRootWindow(); |
+ aura::client::ScreenPositionClient* screen_position_client = |
+ aura::client::GetScreenPositionClient(root_window); |
+ if (screen_position_client) { |
+ screen_position_client->ConvertPointToScreen(web_contents_window, |
+ &screen_point); |
+ } |
+ |
+ ContextMenuModel context_menu_model(web_contents_, params); |
+ views::MenuRunner context_menu_runner(&context_menu_model, |
+ views::MenuRunner::CONTEXT_MENU); |
+ |
+ views::Widget* widget = views::Widget::GetWidgetForNativeView( |
+ web_contents_->GetTopLevelNativeWindow()); |
+ if (context_menu_runner.RunMenuAt( |
+ widget, nullptr, gfx::Rect(screen_point, gfx::Size()), |
+ views::MENU_ANCHOR_TOPRIGHT, |
+ ui::MENU_SOURCE_NONE) == views::MenuRunner::MENU_DELETED) { |
+ return; |
Peter Beverloo
2016/07/20 16:40:14
I'll defer to Sadrul for the details here, but a f
mohsen
2016/07/20 22:16:31
(1) I think that might be possible. I allocated th
|
+ } |
+} |
+ |
+} // namespace content |