/* * Copyright (C) 2011 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 program 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 program; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. * */ #include "config.h" #include "QtPageClient.h" #include "QtWebPageEventHandler.h" #include "QtWebUndoController.h" #include "WebContextMenuProxyQt.h" #include "WebEditCommandProxy.h" #include "WebPopupMenuProxyQt.h" #include "qquickwebview_p.h" #include "qquickwebview_p_p.h" #include #include #include #include #include using namespace WebKit; using namespace WebCore; QtPageClient::QtPageClient() : m_webView(0) , m_eventHandler(0) , m_undoController(0) { } QtPageClient::~QtPageClient() { } void QtPageClient::initialize(QQuickWebView* webView, QtWebPageEventHandler* eventHandler, QtWebUndoController* undoController) { m_webView = webView; m_eventHandler = eventHandler; m_undoController = undoController; } PassOwnPtr QtPageClient::createDrawingAreaProxy() { return QQuickWebViewPrivate::get(m_webView)->createDrawingAreaProxy(); } void QtPageClient::setViewNeedsDisplay(const WebCore::IntRect& rect) { m_webView->page()->update(); } void QtPageClient::pageDidRequestScroll(const IntPoint& pos) { QQuickWebViewPrivate::get(m_webView)->pageDidRequestScroll(pos); } void QtPageClient::processDidCrash() { QQuickWebViewPrivate::get(m_webView)->processDidCrash(); } void QtPageClient::didRelaunchProcess() { QQuickWebViewPrivate::get(m_webView)->didRelaunchProcess(); } void QtPageClient::didChangeContentsSize(const IntSize& newSize) { QQuickWebViewPrivate::get(m_webView)->didChangeContentsSize(newSize); } void QtPageClient::didChangeViewportProperties(const WebCore::ViewportArguments& args) { QQuickWebViewPrivate::get(m_webView)->didChangeViewportProperties(args); } void QtPageClient::startDrag(const WebCore::DragData& dragData, PassRefPtr dragImage) { m_eventHandler->startDrag(dragData, dragImage); } void QtPageClient::handleDownloadRequest(DownloadProxy* download) { QQuickWebViewPrivate::get(m_webView)->handleDownloadRequest(download); } void QtPageClient::handleApplicationSchemeRequest(PassRefPtr requestData) { if (!m_webView || !m_webView->experimental()) return; m_webView->experimental()->invokeApplicationSchemeHandler(requestData.get()); } void QtPageClient::setCursor(const WebCore::Cursor& cursor) { // FIXME: This is a temporary fix until we get cursor support in QML items. QGuiApplication::setOverrideCursor(*cursor.platformCursor()); } void QtPageClient::setCursorHiddenUntilMouseMoves(bool hiddenUntilMouseMoves) { notImplemented(); } void QtPageClient::toolTipChanged(const String&, const String& newTooltip) { // There is not yet any UI defined for the tooltips for mobile so we ignore the change. } void QtPageClient::registerEditCommand(PassRefPtr command, WebPageProxy::UndoOrRedo undoOrRedo) { m_undoController->registerEditCommand(command, undoOrRedo); } void QtPageClient::clearAllEditCommands() { m_undoController->clearAllEditCommands(); } bool QtPageClient::canUndoRedo(WebPageProxy::UndoOrRedo undoOrRedo) { return m_undoController->canUndoRedo(undoOrRedo); } void QtPageClient::executeUndoRedo(WebPageProxy::UndoOrRedo undoOrRedo) { m_undoController->executeUndoRedo(undoOrRedo); } FloatRect QtPageClient::convertToDeviceSpace(const FloatRect& rect) { return rect; } FloatRect QtPageClient::convertToUserSpace(const FloatRect& rect) { return rect; } IntPoint QtPageClient::screenToWindow(const IntPoint& point) { return point; } IntRect QtPageClient::windowToScreen(const IntRect& rect) { return rect; } PassRefPtr QtPageClient::createPopupMenuProxy(WebPageProxy* webPageProxy) { return WebPopupMenuProxyQt::create(webPageProxy, m_webView); } PassRefPtr QtPageClient::createContextMenuProxy(WebPageProxy* webPageProxy) { return WebContextMenuProxyQt::create(webPageProxy); } void QtPageClient::flashBackingStoreUpdates(const Vector&) { notImplemented(); } void QtPageClient::didFindZoomableArea(const IntPoint& target, const IntRect& area) { ASSERT(m_eventHandler); m_eventHandler->didFindZoomableArea(target, area); } void QtPageClient::focusEditableArea(const IntRect& caret, const IntRect& area) { ASSERT(m_eventHandler); m_eventHandler->focusEditableArea(caret, area); } void QtPageClient::didReceiveMessageFromNavigatorQtObject(const String& message) { QQuickWebViewPrivate::get(m_webView)->didReceiveMessageFromNavigatorQtObject(message); } #if ENABLE(TOUCH_EVENTS) void QtPageClient::doneWithTouchEvent(const NativeWebTouchEvent& event, bool wasEventHandled) { ASSERT(m_eventHandler); m_eventHandler->doneWithTouchEvent(event, wasEventHandled); } #endif void QtPageClient::displayView() { // FIXME: Implement. } void QtPageClient::scrollView(const WebCore::IntRect& scrollRect, const WebCore::IntSize& scrollOffset) { // FIXME: Implement. } WebCore::IntSize QtPageClient::viewSize() { return QQuickWebViewPrivate::get(m_webView)->viewSize(); } bool QtPageClient::isViewWindowActive() { // FIXME: The scene graph does not have the concept of being active or not when this was written. return true; } bool QtPageClient::isViewFocused() { if (!m_webView) return false; return m_webView->hasFocus(); } bool QtPageClient::isViewVisible() { if (!m_webView) return false; return m_webView->isVisible() && m_webView->page()->isVisible(); } bool QtPageClient::isViewInWindow() { // FIXME: Implement. return true; } void QtPageClient::enterAcceleratedCompositingMode(const LayerTreeContext&) { // FIXME: Implement. } void QtPageClient::exitAcceleratedCompositingMode() { // FIXME: Implement. }