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/security_style.h"
14 #include "content/public/common/url_constants.h"
15 #include "ui/gfx/geometry/rect.h"
19 WebContentsDelegate::WebContentsDelegate() {
22 WebContents
* WebContentsDelegate::OpenURLFromTab(WebContents
* source
,
23 const OpenURLParams
& params
) {
27 bool WebContentsDelegate::IsPopupOrPanel(const WebContents
* source
) const {
31 bool WebContentsDelegate::CanOverscrollContent() const { return false; }
33 gfx::Rect
WebContentsDelegate::GetRootWindowResizerRect() const {
37 bool WebContentsDelegate::ShouldSuppressDialogs(WebContents
* source
) {
41 bool WebContentsDelegate::ShouldPreserveAbortedURLs(WebContents
* source
) {
45 bool WebContentsDelegate::AddMessageToConsole(WebContents
* source
,
47 const base::string16
& message
,
49 const base::string16
& source_id
) {
53 void WebContentsDelegate::BeforeUnloadFired(WebContents
* web_contents
,
55 bool* proceed_to_fire_unload
) {
56 *proceed_to_fire_unload
= true;
59 bool WebContentsDelegate::ShouldFocusLocationBarByDefault(WebContents
* source
) {
63 bool WebContentsDelegate::ShouldFocusPageAfterCrash() {
67 bool WebContentsDelegate::ShouldResumeRequestsForCreatedWindow() {
71 bool WebContentsDelegate::TakeFocus(WebContents
* source
, bool reverse
) {
75 void WebContentsDelegate::CanDownload(
77 const std::string
& request_method
,
78 const base::Callback
<void(bool)>& callback
) {
82 bool WebContentsDelegate::HandleContextMenu(
83 const content::ContextMenuParams
& params
) {
87 void WebContentsDelegate::ViewSourceForTab(WebContents
* source
,
88 const GURL
& page_url
) {
89 // Fall back implementation based entirely on the view-source scheme.
90 // It suffers from http://crbug.com/523 and that is why browser overrides
91 // it with proper implementation.
92 GURL url
= GURL(kViewSourceScheme
+ std::string(":") + page_url
.spec());
93 OpenURLFromTab(source
, OpenURLParams(url
, Referrer(),
95 ui::PAGE_TRANSITION_LINK
, false));
98 void WebContentsDelegate::ViewSourceForFrame(WebContents
* source
,
99 const GURL
& frame_url
,
100 const PageState
& page_state
) {
101 // Same as ViewSourceForTab, but for given subframe.
102 GURL url
= GURL(kViewSourceScheme
+ std::string(":") + frame_url
.spec());
103 OpenURLFromTab(source
, OpenURLParams(url
, Referrer(),
105 ui::PAGE_TRANSITION_LINK
, false));
108 bool WebContentsDelegate::PreHandleKeyboardEvent(
110 const NativeWebKeyboardEvent
& event
,
111 bool* is_keyboard_shortcut
) {
115 bool WebContentsDelegate::PreHandleGestureEvent(
117 const blink::WebGestureEvent
& event
) {
121 bool WebContentsDelegate::CanDragEnter(
123 const DropData
& data
,
124 blink::WebDragOperationsMask operations_allowed
) {
128 bool WebContentsDelegate::OnGoToEntryOffset(int offset
) {
132 bool WebContentsDelegate::ShouldCreateWebContents(
133 WebContents
* web_contents
,
135 int main_frame_route_id
,
136 WindowContainerType window_container_type
,
137 const base::string16
& frame_name
,
138 const GURL
& target_url
,
139 const std::string
& partition_id
,
140 SessionStorageNamespace
* session_storage_namespace
) {
144 JavaScriptDialogManager
* WebContentsDelegate::GetJavaScriptDialogManager(
145 WebContents
* source
) {
149 bool WebContentsDelegate::EmbedsFullscreenWidget() const {
153 bool WebContentsDelegate::IsFullscreenForTabOrPending(
154 const WebContents
* web_contents
) const {
158 blink::WebDisplayMode
WebContentsDelegate::GetDisplayMode(
159 const WebContents
* web_contents
) const {
160 return blink::WebDisplayModeBrowser
;
163 content::ColorChooser
* WebContentsDelegate::OpenColorChooser(
164 WebContents
* web_contents
,
166 const std::vector
<ColorSuggestion
>& suggestions
) {
170 void WebContentsDelegate::RequestMediaAccessPermission(
171 WebContents
* web_contents
,
172 const MediaStreamRequest
& request
,
173 const MediaResponseCallback
& callback
) {
174 LOG(ERROR
) << "WebContentsDelegate::RequestMediaAccessPermission: "
176 callback
.Run(MediaStreamDevices(),
177 MEDIA_DEVICE_NOT_SUPPORTED
,
178 scoped_ptr
<MediaStreamUI
>());
181 bool WebContentsDelegate::CheckMediaAccessPermission(
182 WebContents
* web_contents
,
183 const GURL
& security_origin
,
184 MediaStreamType type
) {
185 LOG(ERROR
) << "WebContentsDelegate::CheckMediaAccessPermission: "
190 bool WebContentsDelegate::RequestPpapiBrokerPermission(
191 WebContents
* web_contents
,
193 const base::FilePath
& plugin_path
,
194 const base::Callback
<void(bool)>& callback
) {
198 WebContentsDelegate::~WebContentsDelegate() {
199 while (!attached_contents_
.empty()) {
200 WebContents
* web_contents
= *attached_contents_
.begin();
201 web_contents
->SetDelegate(nullptr);
203 DCHECK(attached_contents_
.empty());
206 void WebContentsDelegate::Attach(WebContents
* web_contents
) {
207 DCHECK(attached_contents_
.find(web_contents
) == attached_contents_
.end());
208 attached_contents_
.insert(web_contents
);
211 void WebContentsDelegate::Detach(WebContents
* web_contents
) {
212 DCHECK(attached_contents_
.find(web_contents
) != attached_contents_
.end());
213 attached_contents_
.erase(web_contents
);
216 gfx::Size
WebContentsDelegate::GetSizeForNewRenderView(
217 WebContents
* web_contents
) const {
221 bool WebContentsDelegate::IsNeverVisible(WebContents
* web_contents
) {
225 bool WebContentsDelegate::SaveFrame(const GURL
& url
, const Referrer
& referrer
) {
229 SecurityStyle
WebContentsDelegate::GetSecurityStyle(WebContents
* web_contents
) {
230 return content::SECURITY_STYLE_UNKNOWN
;
233 } // namespace content