1 // Copyright (c) 2012 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.
5 #include "content/public/browser/web_contents_delegate.h"
7 #include "base/compiler_specific.h"
8 #include "base/logging.h"
9 #include "base/memory/singleton.h"
10 #include "content/public/browser/render_view_host.h"
11 #include "content/public/browser/web_contents.h"
12 #include "content/public/common/bindings_policy.h"
13 #include "content/public/common/url_constants.h"
14 #include "ui/gfx/geometry/rect.h"
18 WebContentsDelegate::WebContentsDelegate() {
21 WebContents
* WebContentsDelegate::OpenURLFromTab(WebContents
* source
,
22 const OpenURLParams
& params
) {
26 bool WebContentsDelegate::IsPopupOrPanel(const WebContents
* source
) const {
30 bool WebContentsDelegate::CanOverscrollContent() const { return false; }
32 gfx::Rect
WebContentsDelegate::GetRootWindowResizerRect() const {
36 bool WebContentsDelegate::ShouldSuppressDialogs(WebContents
* source
) {
40 bool WebContentsDelegate::ShouldPreserveAbortedURLs(WebContents
* source
) {
44 bool WebContentsDelegate::AddMessageToConsole(WebContents
* source
,
46 const base::string16
& message
,
48 const base::string16
& source_id
) {
52 void WebContentsDelegate::BeforeUnloadFired(WebContents
* web_contents
,
54 bool* proceed_to_fire_unload
) {
55 *proceed_to_fire_unload
= true;
58 bool WebContentsDelegate::ShouldFocusLocationBarByDefault(WebContents
* source
) {
62 bool WebContentsDelegate::ShouldFocusPageAfterCrash() {
66 bool WebContentsDelegate::TakeFocus(WebContents
* source
, bool reverse
) {
70 void WebContentsDelegate::CanDownload(
71 RenderViewHost
* render_view_host
,
73 const std::string
& request_method
,
74 const base::Callback
<void(bool)>& callback
) {
78 bool WebContentsDelegate::HandleContextMenu(
79 const content::ContextMenuParams
& params
) {
83 void WebContentsDelegate::ViewSourceForTab(WebContents
* source
,
84 const GURL
& page_url
) {
85 // Fall back implementation based entirely on the view-source scheme.
86 // It suffers from http://crbug.com/523 and that is why browser overrides
87 // it with proper implementation.
88 GURL url
= GURL(kViewSourceScheme
+ std::string(":") + page_url
.spec());
89 OpenURLFromTab(source
, OpenURLParams(url
, Referrer(),
91 ui::PAGE_TRANSITION_LINK
, false));
94 void WebContentsDelegate::ViewSourceForFrame(WebContents
* source
,
95 const GURL
& frame_url
,
96 const PageState
& page_state
) {
97 // Same as ViewSourceForTab, but for given subframe.
98 GURL url
= GURL(kViewSourceScheme
+ std::string(":") + frame_url
.spec());
99 OpenURLFromTab(source
, OpenURLParams(url
, Referrer(),
101 ui::PAGE_TRANSITION_LINK
, false));
104 bool WebContentsDelegate::PreHandleKeyboardEvent(
106 const NativeWebKeyboardEvent
& event
,
107 bool* is_keyboard_shortcut
) {
111 bool WebContentsDelegate::PreHandleGestureEvent(
113 const blink::WebGestureEvent
& event
) {
117 bool WebContentsDelegate::CanDragEnter(
119 const DropData
& data
,
120 blink::WebDragOperationsMask operations_allowed
) {
124 bool WebContentsDelegate::OnGoToEntryOffset(int offset
) {
128 bool WebContentsDelegate::ShouldCreateWebContents(
129 WebContents
* web_contents
,
131 int main_frame_route_id
,
132 WindowContainerType window_container_type
,
133 const base::string16
& frame_name
,
134 const GURL
& target_url
,
135 const std::string
& partition_id
,
136 SessionStorageNamespace
* session_storage_namespace
) {
140 JavaScriptDialogManager
* WebContentsDelegate::GetJavaScriptDialogManager(
141 WebContents
* source
) {
145 bool WebContentsDelegate::EmbedsFullscreenWidget() const {
149 bool WebContentsDelegate::IsFullscreenForTabOrPending(
150 const WebContents
* web_contents
) const {
154 blink::WebDisplayMode
WebContentsDelegate::GetDisplayMode(
155 const WebContents
* web_contents
) const {
156 return blink::WebDisplayModeBrowser
;
159 content::ColorChooser
* WebContentsDelegate::OpenColorChooser(
160 WebContents
* web_contents
,
162 const std::vector
<ColorSuggestion
>& suggestions
) {
166 void WebContentsDelegate::RequestMediaAccessPermission(
167 WebContents
* web_contents
,
168 const MediaStreamRequest
& request
,
169 const MediaResponseCallback
& callback
) {
170 LOG(ERROR
) << "WebContentsDelegate::RequestMediaAccessPermission: "
172 callback
.Run(MediaStreamDevices(),
173 MEDIA_DEVICE_NOT_SUPPORTED
,
174 scoped_ptr
<MediaStreamUI
>());
177 bool WebContentsDelegate::CheckMediaAccessPermission(
178 WebContents
* web_contents
,
179 const GURL
& security_origin
,
180 MediaStreamType type
) {
181 LOG(ERROR
) << "WebContentsDelegate::CheckMediaAccessPermission: "
186 bool WebContentsDelegate::RequestPpapiBrokerPermission(
187 WebContents
* web_contents
,
189 const base::FilePath
& plugin_path
,
190 const base::Callback
<void(bool)>& callback
) {
194 WebContentsDelegate::~WebContentsDelegate() {
195 while (!attached_contents_
.empty()) {
196 WebContents
* web_contents
= *attached_contents_
.begin();
197 web_contents
->SetDelegate(nullptr);
199 DCHECK(attached_contents_
.empty());
202 void WebContentsDelegate::Attach(WebContents
* web_contents
) {
203 DCHECK(attached_contents_
.find(web_contents
) == attached_contents_
.end());
204 attached_contents_
.insert(web_contents
);
207 void WebContentsDelegate::Detach(WebContents
* web_contents
) {
208 DCHECK(attached_contents_
.find(web_contents
) != attached_contents_
.end());
209 attached_contents_
.erase(web_contents
);
212 gfx::Size
WebContentsDelegate::GetSizeForNewRenderView(
213 WebContents
* web_contents
) const {
217 bool WebContentsDelegate::IsNeverVisible(WebContents
* web_contents
) {
221 bool WebContentsDelegate::SaveFrame(const GURL
& url
, const Referrer
& referrer
) {
225 } // namespace content