// Copyright (c) 2012 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.
#ifndef ASH_SCREENSAVER_SCREENSAVER_VIEW_H_
#define ASH_SCREENSAVER_SCREENSAVER_VIEW_H_
#include "ash/content_support/ash_with_content_export.h"
#include "base/callback.h"
#include "content/public/browser/web_contents_observer.h"
#include "ui/views/widget/widget_delegate.h"
#include "url/gurl.h"
namespace content {
class BrowserContent;
}
namespace views {
class WebView;
}
namespace ash {
namespace test {
class ScreensaverViewTest;
}
ASH_WITH_CONTENT_EXPORT void ShowScreensaver(const GURL& url);
ASH_WITH_CONTENT_EXPORT void CloseScreensaver();
ASH_WITH_CONTENT_EXPORT bool IsScreensaverShown();
typedef
base::Callback<views::WebView*(content::BrowserContext*)> WebViewFactory;
// Shows a URL as a screensaver. The screensaver window is fullscreen,
// always on top of every other window and will reload the URL if the
// renderer crashes for any reason.
class ScreensaverView : public views::WidgetDelegateView,
public content::WebContentsObserver {
public:
static void ShowScreensaver(const GURL& url);
static void CloseScreensaver();
static bool IsScreensaverShown();
private:
friend class test::ScreensaverViewTest;
explicit ScreensaverView(const GURL& url);
virtual ~ScreensaverView();
// views::WidgetDelegate overrides.
virtual views::View* GetContentsView() OVERRIDE;
// content::WebContentsObserver overrides.
virtual void RenderProcessGone(base::TerminationStatus status) OVERRIDE;
void Show();
void Close();
// Creates and adds web contents to our view.
void AddChildWebContents();
// Load the screensaver in the WebView's webcontent. If the webcontents
// don't exist, they'll be created by WebView.
void LoadScreensaver();
// Creates and shows a frameless full screen window containing our view.
void ShowWindow();
// For testing purposes.
static ASH_WITH_CONTENT_EXPORT ScreensaverView* GetInstance();
ASH_WITH_CONTENT_EXPORT bool IsScreensaverShowingURL(const GURL& url);
// URL to show in the screensaver.
GURL url_;
// Number of times the screensaver has been terminated (usually this will be
// synonymous with the number of times it has crashed).
int termination_count_;
// Host for the extension that implements this dialog.
views::WebView* screensaver_webview_;
// Window that holds the screensaver webview.
views::Widget* container_window_;
DISALLOW_COPY_AND_ASSIGN(ScreensaverView);
};
} // namespace ash
#endif // ASH_SCREENSAVER_SCREENSAVER_VIEW_H_