// Copyright 2014 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 "apps/custom_launcher_page_contents.h" #include #include "chrome/browser/chrome_notification_types.h" #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h" #include "content/public/browser/render_view_host.h" #include "content/public/browser/site_instance.h" #include "content/public/browser/web_contents.h" #include "content/public/common/renderer_preferences.h" #include "extensions/browser/app_window/app_delegate.h" #include "extensions/browser/app_window/app_web_contents_helper.h" #include "extensions/browser/view_type_utils.h" #include "extensions/common/extension_messages.h" namespace apps { CustomLauncherPageContents::CustomLauncherPageContents( scoped_ptr app_delegate, const std::string& extension_id) : app_delegate_(app_delegate.Pass()), extension_id_(extension_id) { } CustomLauncherPageContents::~CustomLauncherPageContents() { } void CustomLauncherPageContents::Initialize(content::BrowserContext* context, const GURL& url) { extension_function_dispatcher_.reset( new extensions::ExtensionFunctionDispatcher(context, this)); web_contents_.reset( content::WebContents::Create(content::WebContents::CreateParams( context, content::SiteInstance::CreateForURL(context, url)))); Observe(web_contents()); web_contents_->GetMutableRendererPrefs() ->browser_handles_all_top_level_requests = true; web_contents_->GetRenderViewHost()->SyncRendererPrefs(); helper_.reset(new extensions::AppWebContentsHelper( context, extension_id_, web_contents_.get(), app_delegate_.get())); web_contents_->SetDelegate(this); extensions::SetViewType(web_contents(), extensions::VIEW_TYPE_LAUNCHER_PAGE); // This observer will activate the extension when it is navigated to, which // allows Dispatcher to give it the proper context and makes it behave like an // extension. extensions::ChromeExtensionWebContentsObserver::CreateForWebContents( web_contents()); web_contents_->GetController().LoadURL(url, content::Referrer(), ui::PAGE_TRANSITION_AUTO_TOPLEVEL, std::string()); } content::WebContents* CustomLauncherPageContents::OpenURLFromTab( content::WebContents* source, const content::OpenURLParams& params) { DCHECK_EQ(web_contents_.get(), source); return helper_->OpenURLFromTab(params); } void CustomLauncherPageContents::AddNewContents( content::WebContents* source, content::WebContents* new_contents, WindowOpenDisposition disposition, const gfx::Rect& initial_pos, bool user_gesture, bool* was_blocked) { app_delegate_->AddNewContents(new_contents->GetBrowserContext(), new_contents, disposition, initial_pos, user_gesture, was_blocked); } bool CustomLauncherPageContents::IsPopupOrPanel( const content::WebContents* source) const { return true; } bool CustomLauncherPageContents::ShouldSuppressDialogs() { return true; } bool CustomLauncherPageContents::PreHandleGestureEvent( content::WebContents* source, const blink::WebGestureEvent& event) { return extensions::AppWebContentsHelper::ShouldSuppressGestureEvent(event); } content::ColorChooser* CustomLauncherPageContents::OpenColorChooser( content::WebContents* web_contents, SkColor initial_color, const std::vector& suggestionss) { return app_delegate_->ShowColorChooser(web_contents, initial_color); } void CustomLauncherPageContents::RunFileChooser( content::WebContents* tab, const content::FileChooserParams& params) { app_delegate_->RunFileChooser(tab, params); } void CustomLauncherPageContents::RequestToLockMouse( content::WebContents* web_contents, bool user_gesture, bool last_unlocked_by_target) { DCHECK_EQ(web_contents_.get(), web_contents); helper_->RequestToLockMouse(); } void CustomLauncherPageContents::RequestMediaAccessPermission( content::WebContents* web_contents, const content::MediaStreamRequest& request, const content::MediaResponseCallback& callback) { DCHECK_EQ(web_contents_.get(), web_contents); helper_->RequestMediaAccessPermission(request, callback); } bool CustomLauncherPageContents::CheckMediaAccessPermission( content::WebContents* web_contents, const GURL& security_origin, content::MediaStreamType type) { DCHECK_EQ(web_contents_.get(), web_contents); return helper_->CheckMediaAccessPermission(security_origin, type); } bool CustomLauncherPageContents::OnMessageReceived( const IPC::Message& message) { bool handled = true; IPC_BEGIN_MESSAGE_MAP(CustomLauncherPageContents, message) IPC_MESSAGE_HANDLER(ExtensionHostMsg_Request, OnRequest) IPC_MESSAGE_UNHANDLED(handled = false) IPC_END_MESSAGE_MAP() return handled; } extensions::WindowController* CustomLauncherPageContents::GetExtensionWindowController() const { return NULL; } content::WebContents* CustomLauncherPageContents::GetAssociatedWebContents() const { return web_contents(); } void CustomLauncherPageContents::OnRequest( const ExtensionHostMsg_Request_Params& params) { extension_function_dispatcher_->Dispatch(params, web_contents_->GetRenderViewHost()); } } // namespace apps