aboutsummaryrefslogtreecommitdiffstats
path: root/ethereal/assets/qml
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-04-21 06:58:02 +0800
committerobscuren <geffobscura@gmail.com>2014-04-21 06:58:02 +0800
commitaec3e26ea0074842ca36a5d918cc3ed049a547cf (patch)
tree09187c6682cfce438118283a414fa610c23763f3 /ethereal/assets/qml
parent6d5d539a859cae43a1e97acd6fc5675d45b09063 (diff)
downloaddexon-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.qml85
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
+ }
+ }
+ ]
+ }
+}