1 // Copyright 2013 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 #ifndef CONTENT_BROWSER_FRAME_HOST_INTERSTITIAL_PAGE_IMPL_H_
6 #define CONTENT_BROWSER_FRAME_HOST_INTERSTITIAL_PAGE_IMPL_H_
8 #include "base/compiler_specific.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/weak_ptr.h"
11 #include "content/browser/frame_host/frame_tree.h"
12 #include "content/browser/frame_host/navigator_delegate.h"
13 #include "content/browser/frame_host/render_frame_host_delegate.h"
14 #include "content/browser/renderer_host/render_view_host_delegate.h"
15 #include "content/browser/renderer_host/render_widget_host_delegate.h"
16 #include "content/public/browser/dom_operation_notification_details.h"
17 #include "content/public/browser/interstitial_page.h"
18 #include "content/public/browser/notification_observer.h"
19 #include "content/public/browser/notification_registrar.h"
20 #include "content/public/browser/web_contents_observer.h"
21 #include "content/public/common/renderer_preferences.h"
25 class NavigationEntry
;
26 class NavigationControllerImpl
;
27 class RenderViewHostImpl
;
28 class RenderWidgetHostView
;
29 class WebContentsView
;
30 class WebContentsImpl
;
32 enum ResourceRequestAction
{
38 class CONTENT_EXPORT InterstitialPageImpl
39 : public NON_EXPORTED_BASE(InterstitialPage
),
40 public NotificationObserver
,
41 public WebContentsObserver
,
42 public NON_EXPORTED_BASE(RenderFrameHostDelegate
),
43 public RenderViewHostDelegate
,
44 public RenderWidgetHostDelegate
,
45 public NON_EXPORTED_BASE(NavigatorDelegate
) {
47 // The different state of actions the user can take in an interstitial.
49 NO_ACTION
, // No action has been taken yet.
50 PROCEED_ACTION
, // "Proceed" was selected.
51 DONT_PROCEED_ACTION
// "Don't proceed" was selected.
54 InterstitialPageImpl(WebContents
* web_contents
,
55 RenderWidgetHostDelegate
* render_widget_host_delegate
,
58 InterstitialPageDelegate
* delegate
);
59 virtual ~InterstitialPageImpl();
61 // InterstitialPage implementation:
62 virtual void Show() OVERRIDE
;
63 virtual void Hide() OVERRIDE
;
64 virtual void DontProceed() OVERRIDE
;
65 virtual void Proceed() OVERRIDE
;
66 virtual RenderViewHost
* GetRenderViewHostForTesting() const OVERRIDE
;
67 virtual InterstitialPageDelegate
* GetDelegateForTesting() OVERRIDE
;
68 virtual void DontCreateViewForTesting() OVERRIDE
;
69 virtual void SetSize(const gfx::Size
& size
) OVERRIDE
;
70 virtual void Focus() OVERRIDE
;
72 // Allows the user to navigate away by disabling the interstitial, canceling
73 // the pending request, and unblocking the hidden renderer. The interstitial
74 // will stay visible until the navigation completes.
75 void CancelForNavigation();
77 // Focus the first (last if reverse is true) element in the interstitial page.
78 // Called when tab traversing.
79 void FocusThroughTabTraversal(bool reverse
);
81 RenderWidgetHostView
* GetView();
83 // See description above field.
84 void set_reload_on_dont_proceed(bool value
) {
85 reload_on_dont_proceed_
= value
;
87 bool reload_on_dont_proceed() const { return reload_on_dont_proceed_
; }
89 #if defined(OS_ANDROID)
90 // Android shares a single platform window for all tabs, so we need to expose
91 // the RenderViewHost to properly route gestures to the interstitial.
92 RenderViewHost
* GetRenderViewHost() const;
95 // TODO(nasko): This should move to InterstitialPageNavigatorImpl, but in
96 // the meantime make it public, so it can be called directly.
98 RenderViewHost
* render_view_host
,
99 const FrameHostMsg_DidCommitProvisionalLoad_Params
& params
);
102 // NotificationObserver method:
103 virtual void Observe(int type
,
104 const NotificationSource
& source
,
105 const NotificationDetails
& details
) OVERRIDE
;
107 // WebContentsObserver implementation:
108 virtual bool OnMessageReceived(const IPC::Message
& message
) OVERRIDE
;
109 virtual void WebContentsDestroyed(WebContents
* web_contents
) OVERRIDE
;
110 virtual void NavigationEntryCommitted(
111 const LoadCommittedDetails
& load_details
) OVERRIDE
;
113 // RenderFrameHostDelegate implementation:
114 virtual bool OnMessageReceived(RenderFrameHost
* render_frame_host
,
115 const IPC::Message
& message
) OVERRIDE
;
116 virtual void RenderFrameCreated(RenderFrameHost
* render_frame_host
) OVERRIDE
;
118 // RenderViewHostDelegate implementation:
119 virtual RenderViewHostDelegateView
* GetDelegateView() OVERRIDE
;
120 virtual bool OnMessageReceived(RenderViewHost
* render_view_host
,
121 const IPC::Message
& message
) OVERRIDE
;
122 virtual const GURL
& GetURL() const OVERRIDE
;
123 virtual void RenderViewTerminated(RenderViewHost
* render_view_host
,
124 base::TerminationStatus status
,
125 int error_code
) OVERRIDE
;
126 virtual void UpdateTitle(RenderViewHost
* render_view_host
,
128 const base::string16
& title
,
129 base::i18n::TextDirection title_direction
) OVERRIDE
;
130 virtual RendererPreferences
GetRendererPrefs(
131 BrowserContext
* browser_context
) const OVERRIDE
;
132 virtual WebPreferences
GetWebkitPrefs() OVERRIDE
;
133 virtual gfx::Rect
GetRootWindowResizerRect() const OVERRIDE
;
134 virtual void CreateNewWindow(
135 int render_process_id
,
137 int main_frame_route_id
,
138 const ViewHostMsg_CreateWindow_Params
& params
,
139 SessionStorageNamespace
* session_storage_namespace
) OVERRIDE
;
140 virtual void CreateNewWidget(int render_process_id
,
142 blink::WebPopupType popup_type
) OVERRIDE
;
143 virtual void CreateNewFullscreenWidget(int render_process_id
,
144 int route_id
) OVERRIDE
;
145 virtual void ShowCreatedWindow(int route_id
,
146 WindowOpenDisposition disposition
,
147 const gfx::Rect
& initial_pos
,
148 bool user_gesture
) OVERRIDE
;
149 virtual void ShowCreatedWidget(int route_id
,
150 const gfx::Rect
& initial_pos
) OVERRIDE
;
151 virtual void ShowCreatedFullscreenWidget(int route_id
) OVERRIDE
;
153 virtual SessionStorageNamespace
* GetSessionStorageNamespace(
154 SiteInstance
* instance
) OVERRIDE
;
156 virtual FrameTree
* GetFrameTree() OVERRIDE
;
158 // RenderWidgetHostDelegate implementation:
159 virtual void RenderWidgetDeleted(
160 RenderWidgetHostImpl
* render_widget_host
) OVERRIDE
;
161 virtual bool PreHandleKeyboardEvent(
162 const NativeWebKeyboardEvent
& event
,
163 bool* is_keyboard_shortcut
) OVERRIDE
;
164 virtual void HandleKeyboardEvent(
165 const NativeWebKeyboardEvent
& event
) OVERRIDE
;
167 virtual gfx::NativeViewAccessible
GetParentNativeViewAccessible() OVERRIDE
;
170 bool enabled() const { return enabled_
; }
171 WebContents
* web_contents() const;
172 const GURL
& url() const { return url_
; }
174 // Creates the RenderViewHost containing the interstitial content.
175 // Overriden in unit tests.
176 virtual RenderViewHost
* CreateRenderViewHost();
178 // Creates the WebContentsView that shows the interstitial RVH.
179 // Overriden in unit tests.
180 virtual WebContentsView
* CreateWebContentsView();
182 // Notification magic.
183 NotificationRegistrar notification_registrar_
;
186 class InterstitialPageRVHDelegateView
;
188 // Disable the interstitial:
189 // - if it is not yet showing, then it won't be shown.
190 // - any command sent by the RenderViewHost will be ignored.
193 // Delete ourselves, causing Shutdown on the RVH to be called.
196 void OnNavigatingAwayOrTabClosing();
198 // Executes the passed action on the ResourceDispatcher (on the IO thread).
199 // Used to block/resume/cancel requests for the RenderViewHost hidden by this
201 void TakeActionOnResourceDispatcher(ResourceRequestAction action
);
203 // IPC message handlers.
204 void OnDomOperationResponse(const std::string
& json_string
,
207 // The contents in which we are displayed. This is valid until Hide is
208 // called, at which point it will be set to NULL because the WebContents
209 // itself may be deleted.
210 WebContents
* web_contents_
;
212 // The NavigationController for the content this page is being displayed over.
213 NavigationControllerImpl
* controller_
;
215 // Delegate for dispatching keyboard events and accessing the native view.
216 RenderWidgetHostDelegate
* render_widget_host_delegate_
;
218 // The URL that is shown when the interstitial is showing.
221 // Whether this interstitial is shown as a result of a new navigation (in
222 // which case a transient navigation entry is created).
223 bool new_navigation_
;
225 // Whether we should discard the pending navigation entry when not proceeding.
226 // This is to deal with cases where |new_navigation_| is true but a new
227 // pending entry was created since this interstitial was shown and we should
229 bool should_discard_pending_nav_entry_
;
231 // If true and the user chooses not to proceed the target NavigationController
232 // is reloaded. This is used when two NavigationControllers are merged
233 // (CopyStateFromAndPrune).
234 // The default is false.
235 bool reload_on_dont_proceed_
;
237 // Whether this interstitial is enabled. See Disable() for more info.
240 // Whether the Proceed or DontProceed methods have been called yet.
241 ActionState action_taken_
;
243 // The RenderViewHost displaying the interstitial contents. This is valid
244 // until Hide is called, at which point it will be set to NULL, signifying
245 // that shutdown has started.
246 // TODO(creis): This is now owned by the FrameTree. We should route things
247 // through the tree's root RenderFrameHost instead.
248 RenderViewHostImpl
* render_view_host_
;
250 // The frame tree structure of the current page.
251 FrameTree frame_tree_
;
253 // The IDs for the Render[View|Process]Host hidden by this interstitial.
254 int original_child_id_
;
255 int original_rvh_id_
;
257 // Whether or not we should change the title of the contents when hidden (to
258 // revert it to its original value).
259 bool should_revert_web_contents_title_
;
261 // Whether or not the contents was loading resources when the interstitial was
262 // shown. We restore this state if the user proceeds from the interstitial.
263 bool web_contents_was_loading_
;
265 // Whether the ResourceDispatcherHost has been notified to cancel/resume the
266 // resource requests blocked for the RenderViewHost.
267 bool resource_dispatcher_host_notified_
;
269 // The original title of the contents that should be reverted to when the
270 // interstitial is hidden.
271 base::string16 original_web_contents_title_
;
273 // Our RenderViewHostViewDelegate, necessary for accelerators to work.
274 scoped_ptr
<InterstitialPageRVHDelegateView
> rvh_delegate_view_
;
276 // Settings passed to the renderer.
277 mutable RendererPreferences renderer_preferences_
;
281 scoped_ptr
<InterstitialPageDelegate
> delegate_
;
283 base::WeakPtrFactory
<InterstitialPageImpl
> weak_ptr_factory_
;
285 scoped_refptr
<SessionStorageNamespace
> session_storage_namespace_
;
287 DISALLOW_COPY_AND_ASSIGN(InterstitialPageImpl
);
290 } // namespace content
292 #endif // CONTENT_BROWSER_FRAME_HOST_INTERSTITIAL_PAGE_IMPL_H_