summaryrefslogtreecommitdiff
path: root/gui/qml/main.qml
diff options
context:
space:
mode:
Diffstat (limited to 'gui/qml/main.qml')
-rw-r--r--gui/qml/main.qml93
1 files changed, 52 insertions, 41 deletions
diff --git a/gui/qml/main.qml b/gui/qml/main.qml
index bbc3f69..5401b97 100644
--- a/gui/qml/main.qml
+++ b/gui/qml/main.qml
@@ -18,10 +18,10 @@ ApplicationWindow {
minimumWidth: 300
maximumHeight: 600
minimumHeight: 600
- // TODO get a nice background color
flags: Qt.WindowsStaysOnTopHint | Qt.Popup
+ // TODO get a nice background color
property var ctx
property var loginDone
property var allowEmptyPass
@@ -42,14 +42,14 @@ ApplicationWindow {
ColumnLayout {
Layout.alignment: Qt.AlignHCenter
- Text{
+ Text {
id: mainStatus
text: "off"
font.pixelSize: 26
Layout.alignment: Text.AlignHCenter
}
- Text{
+ Text {
id: mainCurrentGateway
text: ""
font.pixelSize: 20
@@ -79,8 +79,8 @@ ApplicationWindow {
editable: false
model: [qsTr("Automatic")]
onActivated: {
- console.debug("Selected gateway:", currentText);
- backend.useGateway(currentText.toString());
+ console.debug("Selected gateway:", currentText)
+ backend.useGateway(currentText.toString())
}
}
}
@@ -110,18 +110,31 @@ ApplicationWindow {
color: "red"
z: worldMap.z + 1
}
-
}
}
-
function displayGatewayMarker() {
let coords = {
- 'paris': {'x': 48, 'y': 2},
- 'miami': {'x': 25.7 , 'y': -80.2 },
- 'amsterdam': {'x': 52.4, 'y': 4.9 },
- 'montreal': {'x': 45.3, 'y': -73.4 },
- 'seattle': {'x': 47.4, 'y': -122.2 },
+ "paris": {
+ "x": 48,
+ "y": 2
+ },
+ "miami": {
+ "x": 25.7,
+ "y": -80.2
+ },
+ "amsterdam": {
+ "x": 52.4,
+ "y": 4.9
+ },
+ "montreal": {
+ "x": 45.3,
+ "y": -73.4
+ },
+ "seattle": {
+ "x": 47.4,
+ "y": -122.2
+ }
}
let city = ctx.currentGateway.split('-')[0]
let coord = coords[city]
@@ -130,16 +143,16 @@ ApplicationWindow {
// our map, and this offset doesn't work with bigg-ish sizes. But good
// enough for a proof of concept - if we avoid resizing the window.
let xOffset = -1 * 0.10 * worldMap.width
- let p = Maps.projectAbsolute(coord.x, coord.y, worldMap.width, 1, xOffset)
+ let p = Maps.projectAbsolute(coord.x, coord.y, worldMap.width,
+ 1, xOffset)
gwMarker.x = p.x
gwMarker.y = p.y
}
-
Connections {
target: jsonModel
onDataChanged: {
- ctx = JSON.parse(jsonModel.getJson());
+ ctx = JSON.parse(jsonModel.getJson())
gwSelector.model = Object.keys(ctx.gateways)
if (ctx.donateDialog == 'true') {
@@ -220,9 +233,8 @@ ApplicationWindow {
allowEmptyPass = shouldAllowEmptyPass()
/* TODO get appVisible flag from backend */
- app.visible = true;
- show();
- hide();
+ app.visible = true
+ app.raise()
}
function toHuman(st) {
@@ -247,24 +259,26 @@ ApplicationWindow {
}
function toHumanWithLocation(st) {
- switch(st) {
- case "off":
- //: %1 -> application name
- return qsTr("%1 off").arg(ctx.appName);
- case "on":
- //: %1 -> application name
- //: %2 -> current gateway
- return qsTr("%1 on - %2").arg(ctx.appName).arg(ctx.currentGateway);
- case "connecting":
- //: %1 -> application name
- //: %2 -> current gateway
- return qsTr("Connecting to %1 - %2").arg(ctx.appName).arg(ctx.currentGateway);
- case "stopping":
- //: %1 -> application name
- return qsTr("Stopping %1").arg(ctx.appName);
- case "failed":
- //: %1 -> application name
- return qsTr("%1 blocking internet").arg(ctx.appName); // TODO failed is not handed yet
+ switch (st) {
+ case "off":
+ //: %1 -> application name
+ return qsTr("%1 off").arg(ctx.appName)
+ case "on":
+ //: %1 -> application name
+ //: %2 -> current gateway
+ return qsTr("%1 on - %2").arg(ctx.appName).arg(ctx.currentGateway)
+ case "connecting":
+ //: %1 -> application name
+ //: %2 -> current gateway
+ return qsTr("Connecting to %1 - %2").arg(ctx.appName).arg(
+ ctx.currentGateway)
+ case "stopping":
+ //: %1 -> application name
+ return qsTr("Stopping %1").arg(ctx.appName)
+ case "failed":
+ //: %1 -> application name
+ return qsTr("%1 blocking internet").arg(
+ ctx.appName) // TODO failed is not handed yet
}
}
@@ -279,7 +293,6 @@ ApplicationWindow {
id: vpn
}
- SystemTrayIcon {
LabsPlatform.SystemTrayIcon {
id: systray
@@ -298,13 +311,12 @@ ApplicationWindow {
target: systray
onActivatedSignal: {
if (Qt.platform.os === "windows" || desktop === "LXQt") {
- console.debug("open systray menu");
- systrayMenu.open();
+ console.debug("open systray menu")
+ systrayMenu.open()
}
}
}
-
LabsPlatform.MenuItem {
id: statusItem
text: qsTr("Checking status…")
@@ -388,7 +400,6 @@ ApplicationWindow {
}
}
-
Component.onCompleted: {
icon.source = icons["off"]
tooltip = qsTr("Checking status…")