diff options
author | Lukáš Tinkl <lukas@kde.org> | 2019-11-21 13:49:40 +0100 |
---|---|---|
committer | Lukáš Tinkl <ltinkl@luxoft.com> | 2019-11-22 09:05:48 +0000 |
commit | 02118d951ca82d114b29c791848ff02e07b27372 (patch) | |
tree | fa8b6384e988987809a6ab50f0eff4d0f62cfa00 /com.luxoft.webbrowser/WBView.qml | |
parent | cee862cf1b3c9788a3cd71a6bf3b97a2b4022447 (diff) |
[webbrowser] implement a sample web browser app
based on Qt WebEngine
Change-Id: I58ecd3c40e0d3da0cf3424cf57542f7b1dfb7dc4
Reviewed-by: Georg Leugner <gleugner@luxoft.com>
Diffstat (limited to 'com.luxoft.webbrowser/WBView.qml')
-rw-r--r-- | com.luxoft.webbrowser/WBView.qml | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/com.luxoft.webbrowser/WBView.qml b/com.luxoft.webbrowser/WBView.qml new file mode 100644 index 0000000..bf8f89f --- /dev/null +++ b/com.luxoft.webbrowser/WBView.qml @@ -0,0 +1,107 @@ +/**************************************************************************** +** +** Copyright (C) 2019 Luxoft Sweden AB +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Neptune 3 IVI UI. +** +** $QT_BEGIN_LICENSE:GPL-QTAS$ +** Commercial License Usage +** Licensees holding valid commercial Qt Automotive Suite licenses may use +** this file in accordance with the commercial license agreement provided +** with the Software or, alternatively, in accordance with the terms +** contained in a written agreement between you and The Qt Company. For +** licensing terms and conditions see https://www.qt.io/terms-conditions. +** For further information use the contact form at https://www.qt.io/contact-us. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3 or (at your option) any later version +** approved by the KDE Free Qt Foundation. The licenses are as published by +** the Free Software Foundation and appearing in the file LICENSE.GPL3 +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +** SPDX-License-Identifier: GPL-3.0 +** +****************************************************************************/ + +import QtQuick 2.12 +import QtQuick.Controls 2.12 +import QtQuick.Layouts 1.12 +import QtWebEngine 1.8 + +import shared.animations 1.0 +import shared.controls 1.0 +import shared.utils 1.0 +import shared.Style 1.0 +import shared.Sizes 1.0 + +Item { + id: root + + property bool bottomWidgetHide: false + + // Top content background + Image { + id: topContentBg + anchors.left: parent.left + anchors.right: parent.right + anchors.top: parent.top + height: Sizes.dp(436) + source: Style.image("app-fullscreen-top-bg") + visible: root.state === "Maximized" + } + + ColumnLayout { + anchors.fill: parent + + ToolBar { + id: toolbar + Layout.fillWidth: true + Layout.preferredHeight: Sizes.dp(66) + padding: Sizes.dp(9) + RowLayout { + anchors.fill: parent + ToolButton { + id: btnBack + icon.name: LayoutMirroring.enabled ? "ic_forward" : "ic_back" + onClicked: webview.goBack() + enabled: webview.canGoBack + } + ToolButton { + id: btnForward + icon.name: LayoutMirroring.enabled ? "ic_back" : "ic_forward" + onClicked: webview.goForward() + enabled: webview.canGoForward + } + ToolButton { + id: btnStopReload + icon.name: webview.loading ? "ic-close" : "ic-update" + onClicked: webview.loading ? webview.stop() : webview.reload() + } + UrlField { + id: urlField + Layout.fillWidth: true + busy: webview.loading + onUrlRequested: webview.url = url + } + } + } + + WebEngineView { + Layout.fillWidth: true + Layout.fillHeight: true + id: webview + url: "https://www.luxoft.com/automotive/" + onLoadingChanged: { + if (loadRequest.status === WebEngineLoadRequest.LoadSucceededStatus) { + urlField.text = loadRequest.url; + } + } + } + } +} |