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

Unified Diff: chrome/browser/guest_view/web_view/web_view_guest.cc

Issue 481003002: Introduce WebViewGuestDelegate. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@2_extensions_render_frame_observer
Patch Set: Created 6 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/guest_view/web_view/web_view_guest.cc
diff --git a/chrome/browser/guest_view/web_view/web_view_guest.cc b/chrome/browser/guest_view/web_view/web_view_guest.cc
index f5dac9d9c3932b2e63d36f8f3cca5bd1591216cf..7add119b3004232ac43e3ad7911e1e5ae45d9417 100644
--- a/chrome/browser/guest_view/web_view/web_view_guest.cc
+++ b/chrome/browser/guest_view/web_view/web_view_guest.cc
@@ -7,22 +7,13 @@
#include "base/message_loop/message_loop.h"
#include "base/strings/stringprintf.h"
#include "base/strings/utf_string_conversions.h"
-#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/extensions/api/web_request/web_request_api.h"
#include "chrome/browser/extensions/api/web_view/web_view_internal_api.h"
-#include "chrome/browser/extensions/chrome_extension_web_contents_observer.h"
-#include "chrome/browser/extensions/menu_manager.h"
-#include "chrome/browser/favicon/favicon_tab_helper.h"
+#include "chrome/browser/guest_view/web_view/chrome_web_view_guest_delegate.h"
#include "chrome/browser/guest_view/web_view/web_view_constants.h"
#include "chrome/browser/guest_view/web_view/web_view_permission_helper.h"
#include "chrome/browser/guest_view/web_view/web_view_permission_types.h"
#include "chrome/browser/guest_view/web_view/web_view_renderer_state.h"
-#include "chrome/browser/renderer_context_menu/render_view_context_menu.h"
-#include "chrome/browser/ui/pdf/pdf_tab_helper.h"
-#include "chrome/browser/ui/zoom/zoom_controller.h"
-#include "chrome/common/chrome_version_info.h"
-#include "chrome/common/render_messages.h"
-#include "components/renderer_context_menu/context_menu_delegate.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/child_process_security_policy.h"
#include "content/public/browser/native_web_keyboard_event.h"
@@ -55,19 +46,6 @@
#include "third_party/WebKit/public/web/WebFindOptions.h"
#include "ui/base/models/simple_menu_model.h"
-#if defined(ENABLE_PRINTING)
-#if defined(ENABLE_FULL_PRINTING)
-#include "chrome/browser/printing/print_preview_message_handler.h"
-#include "chrome/browser/printing/print_view_manager.h"
-#else
-#include "chrome/browser/printing/print_view_manager_basic.h"
-#endif // defined(ENABLE_FULL_PRINTING)
-#endif // defined(ENABLE_PRINTING)
-
-#if defined(OS_CHROMEOS)
-#include "chrome/browser/chromeos/accessibility/accessibility_manager.h"
-#endif
-
using base::UserMetricsAction;
using content::RenderFrameHost;
using content::ResourceType;
@@ -209,22 +187,6 @@ int WebViewGuest::GetViewInstanceId(WebContents* contents) {
return guest->view_instance_id();
}
-// static
-scoped_ptr<base::ListValue> WebViewGuest::MenuModelToValue(
- const ui::SimpleMenuModel& menu_model) {
- scoped_ptr<base::ListValue> items(new base::ListValue());
- for (int i = 0; i < menu_model.GetItemCount(); ++i) {
- base::DictionaryValue* item_value = new base::DictionaryValue();
- // TODO(lazyboy): We need to expose some kind of enum equivalent of
- // |command_id| instead of plain integers.
- item_value->SetInteger(webview::kMenuItemCommandId,
- menu_model.GetCommandIdAt(i));
- item_value->SetString(webview::kMenuItemLabel, menu_model.GetLabelAt(i));
- items->Append(item_value);
- }
- return items.Pass();
-}
-
const char* WebViewGuest::GetAPINamespace() {
return webview::kAPINamespace;
}
@@ -346,37 +308,14 @@ void WebViewGuest::DidInitialize() {
content::Source<WebContents>(guest_web_contents()));
#if defined(OS_CHROMEOS)
Fady Samuel 2014/08/18 20:11:22 Remove this?
Xi Han 2014/08/18 22:23:57 Done.
- chromeos::AccessibilityManager* accessibility_manager =
- chromeos::AccessibilityManager::Get();
- CHECK(accessibility_manager);
- accessibility_subscription_ = accessibility_manager->RegisterCallback(
- base::Bind(&WebViewGuest::OnAccessibilityStatusChanged,
- base::Unretained(this)));
+ web_view_guest_delegate_-> OnDidInitialize();
#endif
AttachWebViewHelpers(guest_web_contents());
}
void WebViewGuest::AttachWebViewHelpers(WebContents* contents) {
- // Create a zoom controller for the guest contents give it access to
- // GetZoomLevel() and and SetZoomLevel() in WebViewGuest.
- // TODO(wjmaclean) This currently uses the same HostZoomMap as the browser
- // context, but we eventually want to isolate the guest contents from zoom
- // changes outside the guest (e.g. in the main browser), so we should
- // create a separate HostZoomMap for the guest.
- ZoomController::CreateForWebContents(contents);
-
- FaviconTabHelper::CreateForWebContents(contents);
- ChromeExtensionWebContentsObserver::CreateForWebContents(contents);
-#if defined(ENABLE_PRINTING)
-#if defined(ENABLE_FULL_PRINTING)
- printing::PrintViewManager::CreateForWebContents(contents);
- printing::PrintPreviewMessageHandler::CreateForWebContents(contents);
-#else
- printing::PrintViewManagerBasic::CreateForWebContents(contents);
-#endif // defined(ENABLE_FULL_PRINTING)
-#endif // defined(ENABLE_PRINTING)
- PDFTabHelper::CreateForWebContents(contents);
+ web_view_guest_delegate_->OnAttachWebViewHelpers(contents);
web_view_permission_helper_.reset(new WebViewPermissionHelper(this));
}
@@ -406,11 +345,7 @@ void WebViewGuest::EmbedderDestroyed() {
void WebViewGuest::GuestDestroyed() {
// Clean up custom context menu items for this guest.
- MenuManager* menu_manager = MenuManager::Get(
- Profile::FromBrowserContext(browser_context()));
- menu_manager->RemoveAllContextItems(MenuItem::ExtensionKey(
- embedder_extension_id(), view_instance_id()));
-
+ web_view_guest_delegate_->OnGuestDestroyed();
RemoveWebViewStateFromIOThread(web_contents());
}
@@ -479,21 +414,9 @@ void WebViewGuest::FindReply(WebContents* source,
bool WebViewGuest::HandleContextMenu(
const content::ContextMenuParams& params) {
- ContextMenuDelegate* menu_delegate =
- ContextMenuDelegate::FromWebContents(guest_web_contents());
- DCHECK(menu_delegate);
-
- pending_menu_ = menu_delegate->BuildMenu(guest_web_contents(), params);
-
- // Pass it to embedder.
- int request_id = ++pending_context_menu_request_id_;
- scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue());
- scoped_ptr<base::ListValue> items =
- MenuModelToValue(pending_menu_->menu_model());
- args->Set(webview::kContextMenuItems, items.release());
- args->SetInteger(webview::kRequestId, request_id);
- DispatchEventToEmbedder(
- new GuestViewBase::Event(webview::kEventContextMenu, args.Pass()));
+ GuestViewBase::Event* event =
+ web_view_guest_delegate_->OnHandleContextMenu(params);
+ DispatchEventToEmbedder(event);
return true;
}
@@ -708,12 +631,11 @@ bool WebViewGuest::ClearData(const base::Time remove_since,
WebViewGuest::WebViewGuest(content::BrowserContext* browser_context,
int guest_instance_id)
: GuestView<WebViewGuest>(browser_context, guest_instance_id),
- pending_context_menu_request_id_(0),
is_overriding_user_agent_(false),
- chromevox_injected_(false),
current_zoom_factor_(1.0),
find_helper_(this),
javascript_dialog_helper_(this) {
+ web_view_guest_delegate_.reset(new ChromeWebViewGuestDelegate(*this));
}
WebViewGuest::~WebViewGuest() {
@@ -737,14 +659,10 @@ void WebViewGuest::DidCommitProvisionalLoadForFrame(
DispatchEventToEmbedder(
new GuestViewBase::Event(webview::kEventLoadCommit, args.Pass()));
- // Update the current zoom factor for the new page.
- ZoomController* zoom_controller =
- ZoomController::FromWebContents(guest_web_contents());
- DCHECK(zoom_controller);
- current_zoom_factor_ = zoom_controller->GetZoomLevel();
+ current_zoom_factor_ = web_view_guest_delegate_->GetZoomLevel();
Fady Samuel 2014/08/18 20:11:22 Let's move zoom entirely out until it is supported
Xi Han 2014/08/18 22:23:57 Done.
- if (!render_frame_host->GetParent())
- chromevox_injected_ = false;
+ web_view_guest_delegate_->OnDidCommitProvisionalLoadForFrame(
+ !render_frame_host->GetParent());
}
void WebViewGuest::DidFailProvisionalLoad(
@@ -974,32 +892,10 @@ void WebViewGuest::NavigateGuest(const std::string& src) {
guest_web_contents());
}
-#if defined(OS_CHROMEOS)
-void WebViewGuest::OnAccessibilityStatusChanged(
- const chromeos::AccessibilityStatusEventDetails& details) {
- if (details.notification_type == chromeos::ACCESSIBILITY_MANAGER_SHUTDOWN) {
- accessibility_subscription_.reset();
- } else if (details.notification_type ==
- chromeos::ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK) {
- if (details.enabled)
- InjectChromeVoxIfNeeded(guest_web_contents()->GetRenderViewHost());
- else
- chromevox_injected_ = false;
- }
-}
-#endif
-
void WebViewGuest::InjectChromeVoxIfNeeded(
content::RenderViewHost* render_view_host) {
#if defined(OS_CHROMEOS)
Fady Samuel 2014/08/18 20:11:22 Remove this. This is already decided on the other
Xi Han 2014/08/18 22:23:57 Done.
- if (!chromevox_injected_) {
- chromeos::AccessibilityManager* manager =
- chromeos::AccessibilityManager::Get();
- if (manager && manager->IsSpokenFeedbackEnabled()) {
- manager->InjectChromeVox(render_view_host);
- chromevox_injected_ = true;
- }
- }
+ web_view_guest_delegate_->InjectChromeVoxIfNeeded(render_view_host);
#endif
}
@@ -1065,21 +961,10 @@ void WebViewGuest::SetUpAutoSize() {
gfx::Size(max_width, max_height));
}
-void WebViewGuest::ShowContextMenu(int request_id,
- const MenuItemVector* items) {
- if (!pending_menu_.get())
- return;
-
- // Make sure this was the correct request.
- if (request_id != pending_context_menu_request_id_)
- return;
-
- // TODO(lazyboy): Implement.
- DCHECK(!items);
-
- ContextMenuDelegate* menu_delegate =
- ContextMenuDelegate::FromWebContents(guest_web_contents());
- menu_delegate->ShowMenu(pending_menu_.Pass());
+void WebViewGuest::ShowContextMenu(
+ int request_id,
+ const WebViewGuestDelegate::MenuItemVector* items) {
+ web_view_guest_delegate_->OnShowContextMenu(request_id, items);
}
void WebViewGuest::SetName(const std::string& name) {
@@ -1091,11 +976,7 @@ void WebViewGuest::SetName(const std::string& name) {
}
void WebViewGuest::SetZoom(double zoom_factor) {
- ZoomController* zoom_controller =
- ZoomController::FromWebContents(guest_web_contents());
- DCHECK(zoom_controller);
- double zoom_level = content::ZoomFactorToZoomLevel(zoom_factor);
- zoom_controller->SetZoomLevel(zoom_level);
+ web_view_guest_delegate_->OnSetZoom(zoom_factor);
Fady Samuel 2014/08/18 20:11:22 This conceptually to me is weird. Either zoom is a
Xi Han 2014/08/18 22:23:57 Done.
scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue());
args->SetDouble(webview::kOldZoomFactor, current_zoom_factor_);

Powered by Google App Engine
This is Rietveld 408576698