/*
* Copyright (C) 2006, 2007, 2008, 2009 Apple Inc. All rights reserved.
* Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef Chrome_h
#define Chrome_h
#include "Cursor.h"
#include "FileChooser.h"
#include "FocusDirection.h"
#include "HostWindow.h"
#include "PopupMenu.h"
#include "SearchPopupMenu.h"
#include <wtf/Forward.h>
#include <wtf/RefPtr.h>
#if PLATFORM(MAC)
#ifndef __OBJC__
class NSView;
#endif
#endif
namespace WebCore {
class ChromeClient;
class ContextMenu;
class FloatRect;
class Frame;
class Geolocation;
class HitTestResult;
class IntRect;
class NavigationAction;
class Node;
class Page;
class PopupMenuClient;
#if ENABLE(NOTIFICATIONS)
class NotificationPresenter;
#endif
struct FrameLoadRequest;
struct ViewportArguments;
struct WindowFeatures;
class Chrome : public HostWindow {
public:
Chrome(Page*, ChromeClient*);
~Chrome();
ChromeClient* client() { return m_client; }
// HostWindow methods.
virtual void invalidateWindow(const IntRect&, bool);
virtual void invalidateContentsAndWindow(const IntRect&, bool);
virtual void invalidateContentsForSlowScroll(const IntRect&, bool);
virtual void scroll(const IntSize&, const IntRect&, const IntRect&);
#if ENABLE(TILED_BACKING_STORE)
virtual void delegatedScrollRequested(const IntPoint& scrollPoint);
#endif
virtual IntPoint screenToWindow(const IntPoint&) const;
virtual IntRect windowToScreen(const IntRect&) const;
virtual PlatformPageClient platformPageClient() const;
virtual void scrollbarsModeDidChange() const;
virtual void setCursor(const Cursor&);
#if ENABLE(REQUEST_ANIMATION_FRAME)
virtual void scheduleAnimation();
#endif
void scrollRectIntoView(const IntRect&) const;
void contentsSizeChanged(Frame*, const IntSize&) const;
void setWindowRect(const FloatRect&) const;
FloatRect windowRect() const;
FloatRect pageRect() const;
float scaleFactor();
void focus() const;
void unfocus() const;
bool canTakeFocus(FocusDirection) const;
void takeFocus(FocusDirection) const;
void focusedNodeChanged(Node*) const;
void focusedFrameChanged(Frame*) const;
Page* createWindow(Frame*, const FrameLoadRequest&, const WindowFeatures&, const NavigationAction&) const;
void show() const;
bool canRunModal() const;
bool canRunModalNow() const;
void runModal() const;
void setToolbarsVisible(bool) const;
bool toolbarsVisible() const;
void setStatusbarVisible(bool) const;
bool statusbarVisible() const;
void setScrollbarsVisible(bool) const;
bool scrollbarsVisible() const;
void setMenubarVisible(bool) const;
bool menubarVisible() const;
void setResizable(bool) const;
bool canRunBeforeUnloadConfirmPanel();
bool runBeforeUnloadConfirmPanel(const String& message, Frame* frame);
void closeWindowSoon();
void runJavaScriptAlert(Frame*, const String&);
bool runJavaScriptConfirm(Frame*, const String&);
bool runJavaScriptPrompt(Frame*, const String& message, const String& defaultValue, String& result);
void setStatusbarText(Frame*, const String&);
bool shouldInterruptJavaScript();
#if ENABLE(REGISTER_PROTOCOL_HANDLER)
void registerProtocolHandler(const String& scheme, const String& baseURL, const String& url, const String& title);
#endif
IntRect windowResizerRect() const;
void mouseDidMoveOverElement(const HitTestResult&, unsigned modifierFlags);
void setToolTip(const HitTestResult&);
void print(Frame*);
// FIXME: Remove once all ports are using client-based geolocation. https://bugs.webkit.org/show_bug.cgi?id=40373
// For client-based geolocation, these two methods have moved to GeolocationClient. https://bugs.webkit.org/show_bug.cgi?id=50061
void requestGeolocationPermissionForFrame(Frame*, Geolocation*);
void cancelGeolocationPermissionRequestForFrame(Frame*, Geolocation*);
void runOpenPanel(Frame*, PassRefPtr<FileChooser>);
void chooseIconForFiles(const Vector<String>&, FileChooser*);
#if ENABLE(DIRECTORY_UPLOAD)
void enumerateChosenDirectory(const String&, FileChooser*);
#endif
void dispatchViewportDataDidChange(const ViewportArguments&) const;
bool requiresFullscreenForVideoPlayback();
#if PLATFORM(MAC)
void focusNSView(NSView*);
#endif
#if ENABLE(NOTIFICATIONS)
NotificationPresenter* notificationPresenter() const;
#endif
bool selectItemWritingDirectionIsNatural();
bool selectItemAlignmentFollowsMenuWritingDirection();
PassRefPtr<PopupMenu> createPopupMenu(PopupMenuClient*) const;
PassRefPtr<SearchPopupMenu> createSearchPopupMenu(PopupMenuClient*) const;
#if ENABLE(CONTEXT_MENUS)
void showContextMenu();
#endif
void willRunModalHTMLDialog(const Frame*) const;
private:
Page* m_page;
ChromeClient* m_client;
};
}
#endif // Chrome_h