diff options
author | obscuren <geffobscura@gmail.com> | 2014-04-21 06:58:02 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-04-21 06:58:02 +0800 |
commit | aec3e26ea0074842ca36a5d918cc3ed049a547cf (patch) | |
tree | 09187c6682cfce438118283a414fa610c23763f3 /ethereal/assets/qml | |
parent | 6d5d539a859cae43a1e97acd6fc5675d45b09063 (diff) | |
download | dexon-aec3e26ea0074842ca36a5d918cc3ed049a547cf.tar.gz dexon-aec3e26ea0074842ca36a5d918cc3ed049a547cf.tar.zst dexon-aec3e26ea0074842ca36a5d918cc3ed049a547cf.zip |
Round one HTML external applications using QML(Qt5) WebKit2 w/o native bindings
Diffstat (limited to 'ethereal/assets/qml')
-rw-r--r-- | ethereal/assets/qml/webapp.qml | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/ethereal/assets/qml/webapp.qml b/ethereal/assets/qml/webapp.qml new file mode 100644 index 000000000..4695903e8 --- /dev/null +++ b/ethereal/assets/qml/webapp.qml @@ -0,0 +1,85 @@ +import QtQuick 2.0 +import QtWebKit 3.0 +import QtWebKit.experimental 1.0 +import QtQuick.Controls 1.0; +import QtQuick.Layouts 1.0; +import QtQuick.Window 2.1; +import Ethereum 1.0 + +ApplicationWindow { + id: window + title: "Webapp" + width: 900 + height: 600 + minimumHeight: 300 + property alias url: webview.url + + Item { + id: root + anchors.fill: parent + state: "inspectorShown" + + WebView { + id: webview + anchors { + left: parent.left + right: parent.right + bottom: sizeGrip.top + top: parent.top + } + onTitleChanged: { window.title = title } + experimental.preferences.javascriptEnabled: true + experimental.preferences.navigatorQtObjectEnabled: true + experimental.preferences.developerExtrasEnabled: true + experimental.userScripts: [ui.assetPath("ethereum.js")] + experimental.onMessageReceived: { + console.log("[onMessageReceived]: ", message.data) + var data = JSON.parse(message.data) + + webview.experimental.postMessage(JSON.stringify({data: {message: data.message}, _seed: data._seed})) + } + } + + Rectangle { + id: sizeGrip + color: "gray" + visible: true + height: 10 + anchors { + left: root.left + right: root.right + } + y: Math.round(root.height * 2 / 3) + + MouseArea { + anchors.fill: parent + drag.target: sizeGrip + drag.minimumY: 0 + drag.maximumY: root.height + drag.axis: Drag.YAxis + } + } + + WebView { + id: inspector + visible: true + url: webview.experimental.remoteInspectorUrl + anchors { + left: root.left + right: root.right + top: sizeGrip.bottom + bottom: root.bottom + } + } + + states: [ + State { + name: "inspectorShown" + PropertyChanges { + target: inspector + url: webview.experimental.remoteInspectorUrl + } + } + ] + } +} |