qml ui fixes

This commit is contained in:
pokamest 2021-08-19 01:27:22 +03:00
parent 57234bc793
commit 27171ed974
43 changed files with 311 additions and 262 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 63 KiB

After

Width:  |  Height:  |  Size: 53 KiB

Before After
Before After

Binary file not shown.

After

Width:  |  Height:  |  Size: 189 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 136 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1 KiB

View file

@ -3,7 +3,6 @@
<file>translations/amneziavpn_ru.qm</file> <file>translations/amneziavpn_ru.qm</file>
<file>images/close.png</file> <file>images/close.png</file>
<file>images/settings.png</file> <file>images/settings.png</file>
<file>images/min.png</file>
<file>images/favorites_disabled.png</file> <file>images/favorites_disabled.png</file>
<file>images/favorites_enabled.png</file> <file>images/favorites_enabled.png</file>
<file>images/favorites_hover.png</file> <file>images/favorites_hover.png</file>
@ -30,11 +29,9 @@
<file>fonts/Lato-Thin.ttf</file> <file>fonts/Lato-Thin.ttf</file>
<file>fonts/Lato-ThinItalic.ttf</file> <file>fonts/Lato-ThinItalic.ttf</file>
<file>images/AmneziaVPN.png</file> <file>images/AmneziaVPN.png</file>
<file>images/line.png</file>
<file>images/server_settings.png</file> <file>images/server_settings.png</file>
<file>images/share.png</file> <file>images/share.png</file>
<file>server_scripts/remove_container.sh</file> <file>server_scripts/remove_container.sh</file>
<file>images/background_connected.png</file>
<file>server_scripts/setup_host_firewall.sh</file> <file>server_scripts/setup_host_firewall.sh</file>
<file>images/reload.png</file> <file>images/reload.png</file>
<file>server_scripts/openvpn_cloak/Dockerfile</file> <file>server_scripts/openvpn_cloak/Dockerfile</file>
@ -68,40 +65,43 @@
<file>server_scripts/wireguard/start.sh</file> <file>server_scripts/wireguard/start.sh</file>
<file>server_scripts/wireguard/template.conf</file> <file>server_scripts/wireguard/template.conf</file>
<file>ui/qml/main.qml</file> <file>ui/qml/main.qml</file>
<file>ui/qml/GlobalConfig.qml</file>
<file>ui/qml/qmldir</file>
<file>ui/qml/TitleBar.qml</file> <file>ui/qml/TitleBar.qml</file>
<file>ui/qml/PageStart.qml</file> <file>ui/qml/Pages/PageAppSetting.qml</file>
<file>ui/qml/TextFieldType.qml</file> <file>ui/qml/Pages/PageGeneralSettings.qml</file>
<file>ui/qml/LabelType.qml</file> <file>ui/qml/Pages/PageNetworkSetting.qml</file>
<file>ui/qml/BasicButtonType.qml</file> <file>ui/qml/Pages/PageNewServer.qml</file>
<file>ui/qml/ImageButtonType.qml</file> <file>ui/qml/Pages/PageNewServerConfiguring.qml</file>
<file>ui/qml/PageNewServer.qml</file> <file>ui/qml/Pages/PageNewServerProtocol.qml</file>
<file>ui/qml/BlueButtonType.qml</file> <file>ui/qml/Pages/PageProtoCloak.qml</file>
<file>ui/qml/PageSetupWizard.qml</file> <file>ui/qml/Pages/PageProtoOpenVPN.qml</file>
<file>ui/qml/RadioButtonType.qml</file> <file>ui/qml/Pages/PageProtoShadowSock.qml</file>
<file>ui/qml/PageSetupWizardHighLevel.qml</file> <file>ui/qml/Pages/PageServer.qml</file>
<file>ui/qml/PageSetupWizardVPNMode.qml</file> <file>ui/qml/Pages/PageServerProtocols.qml</file>
<file>ui/qml/CheckBoxType.qml</file> <file>ui/qml/Pages/PageServerSetting.qml</file>
<file>ui/qml/PageSetupWizardMediumLevel.qml</file> <file>ui/qml/Pages/PageSetupWizard.qml</file>
<file>ui/qml/PageSetupWizardLowLevel.qml</file> <file>ui/qml/Pages/PageSetupWizardHighLevel.qml</file>
<file>ui/qml/PageNewServerConfiguring.qml</file> <file>ui/qml/Pages/PageSetupWizardLowLevel.qml</file>
<file>ui/qml/PageNewServerProtocol.qml</file> <file>ui/qml/Pages/PageSetupWizardMediumLevel.qml</file>
<file>ui/qml/ComboBoxType.qml</file> <file>ui/qml/Pages/PageSetupWizardVPNMode.qml</file>
<file>ui/qml/PageVPN.qml</file> <file>ui/qml/Pages/PageShareConnection.qml</file>
<file>ui/qml/PageSites.qml</file> <file>ui/qml/Pages/PageSites.qml</file>
<file>ui/qml/PageGeneralSettings.qml</file> <file>ui/qml/Pages/PageStart.qml</file>
<file>ui/qml/SettingButtonType.qml</file> <file>ui/qml/Pages/PageVPN.qml</file>
<file>ui/qml/PageServer.qml</file> <file>ui/qml/Controls/BasicButtonType.qml</file>
<file>ui/qml/PageAppSetting.qml</file> <file>ui/qml/Controls/BlueButtonType.qml</file>
<file>ui/qml/PageNetworkSetting.qml</file> <file>ui/qml/Controls/CheckBoxType.qml</file>
<file>ui/qml/PageServerSetting.qml</file> <file>ui/qml/Controls/ComboBoxType.qml</file>
<file>ui/qml/PageServerProtocols.qml</file> <file>ui/qml/Controls/ImageButtonType.qml</file>
<file>ui/qml/PageShareConnection.qml</file> <file>ui/qml/Controls/LabelType.qml</file>
<file>ui/qml/PageProtoOpenVPN.qml</file> <file>ui/qml/Controls/RadioButtonType.qml</file>
<file>ui/qml/PageProtoShadowSock.qml</file> <file>ui/qml/Controls/SettingButtonType.qml</file>
<file>ui/qml/PageProtoCloak.qml</file> <file>ui/qml/Controls/ShareConnectionButtonType.qml</file>
<file>ui/qml/ShareConnectionContent.qml</file> <file>ui/qml/Controls/ShareConnectionContent.qml</file>
<file>ui/qml/ShareConnectionButtonType.qml</file> <file>ui/qml/Controls/TextFieldType.qml</file>
<file>ui/qml/Pages/PageBase.qml</file>
<file>ui/qml/Config/GlobalConfig.qml</file>
<file>ui/qml/Config/qmldir</file>
<file>images/background_connected.png</file>
<file>images/background_connected@2x.png</file>
</qresource> </qresource>
</RCC> </RCC>

View file

@ -0,0 +1,36 @@
import QtQuick 2.12
import QtQuick.Controls 2.12
RadioButton {
id: root
indicator: Rectangle {
implicitWidth: 13
implicitHeight: 13
x: root.leftPadding
y: parent.height / 2 - height / 2
radius: 13
border.color: root.down ? "#777777" : "#777777"
Rectangle {
width: 7
height: 7
x: 3
y: 3
radius: 4
color: root.down ? "#15CDCB" : "#15CDCB"
visible: root.checked
}
}
contentItem: Text {
text: root.text
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#181922"
verticalAlignment: Text.AlignVCenter
leftPadding: root.indicator.width + root.spacing
}
height: 10
}

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { PageBase {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10

View file

@ -0,0 +1,13 @@
import QtQuick 2.12
import QtQuick.Controls 2.12
import "./"
import "../Controls"
import "../Config"
Item {
id: root
// width: GC.screenWidth
// height: GC.screenHeight
anchors.fill: parent
}

View file

@ -2,11 +2,11 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10
@ -18,69 +18,56 @@ Item {
UiLogic.closePage() UiLogic.closePage()
} }
} }
Image { Rectangle {
x: 10
y: 160
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 220
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 620
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 560
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 280
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 100
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 340
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 400
width: 360
height: 1
source: "qrc:/images/line.png"
}
Image {
x: 10
y: 40 y: 40
width: 360 x: 20
width: parent.width - 40
height: 1 height: 1
source: "qrc:/images/line.png" color: "#DDDDDD"
} }
Rectangle {
y: 100
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
Rectangle {
y: 160
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
Rectangle {
y: 220
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
Rectangle {
y: 280
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
Rectangle {
y: 340
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
Rectangle {
y: 400
x: 20
width: parent.width - 40
height: 1
color: "#DDDDDD"
}
SettingButtonType { SettingButtonType {
x: 30 x: 30
y: 355 y: 355
@ -103,17 +90,6 @@ Item {
UiLogic.goToPage(PageEnum.AppSettings) UiLogic.goToPage(PageEnum.AppSettings)
} }
} }
SettingButtonType {
x: 30
y: 575
width: 330
height: 30
icon.source: "qrc:/images/settings.png"
text: qsTr("Exit")
onClicked: {
Qt.quit()
}
}
SettingButtonType { SettingButtonType {
x: 30 x: 30
y: 115 y: 115
@ -159,4 +135,16 @@ Item {
UiLogic.onPushButtonGeneralSettingsShareConnectionClicked() UiLogic.onPushButtonGeneralSettingsShareConnectionClicked()
} }
} }
SettingButtonType {
x: 30
anchors.bottom: parent.bottom
anchors.bottomMargin: 20
width: 330
height: 30
icon.source: "qrc:/images/settings.png"
text: qsTr("Exit")
onClicked: {
Qt.quit()
}
}
} }

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10

View file

@ -2,11 +2,11 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
Text { Text {
font.family: "Lato" font.family: "Lato"
font.styleName: "normal" font.styleName: "normal"

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageNewServerConfiguringEnabled enabled: UiLogic.pageNewServerConfiguringEnabled
Text { Text {
font.family: "Lato" font.family: "Lato"

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageProtoCloakEnabled enabled: UiLogic.pageProtoCloakEnabled
ImageButtonType { ImageButtonType {
id: back id: back

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageProtoOpenvpnEnabled enabled: UiLogic.pageProtoOpenvpnEnabled
ImageButtonType { ImageButtonType {
id: back id: back

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageProtoShadowsocksEnabled enabled: UiLogic.pageProtoShadowsocksEnabled
ImageButtonType { ImageButtonType {
id: back id: back

View file

@ -1,13 +1,13 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./"
import QtGraphicalEffects 1.12 import QtGraphicalEffects 1.12
import PageEnum 1.0 import PageEnum 1.0
import "../Controls"
import "./"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageServerProtocolsEnabled enabled: UiLogic.pageServerProtocolsEnabled
ImageButtonType { ImageButtonType {
id: back id: back

View file

@ -1,12 +1,12 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./"
import PageEnum 1.0 import PageEnum 1.0
import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
enabled: UiLogic.pageServerSettingsEnabled enabled: UiLogic.pageServerSettingsEnabled
ImageButtonType { ImageButtonType {
@ -28,7 +28,7 @@ Item {
horizontalAlignment: Text.AlignHCenter horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter verticalAlignment: Text.AlignVCenter
text: qsTr("Server settings") text: qsTr("Server settings")
x: 10 anchors.horizontalCenter: parent.horizontalCenter
y: 35 y: 35
width: 361 width: 361
height: 31 height: 31
@ -50,7 +50,7 @@ Item {
text: UiLogic.labelServerSettingsCurrentVpnProtocolText text: UiLogic.labelServerSettingsCurrentVpnProtocolText
} }
LabelType { LabelType {
x: 20 anchors.horizontalCenter: parent.horizontalCenter
y: 120 y: 120
width: 341 width: 341
height: 31 height: 31
@ -59,7 +59,7 @@ Item {
text: UiLogic.labelServerSettingsServerText text: UiLogic.labelServerSettingsServerText
} }
LabelType { LabelType {
x: 40 anchors.horizontalCenter: parent.horizontalCenter
y: 530 y: 530
width: 301 width: 301
height: 41 height: 41
@ -67,7 +67,6 @@ Item {
visible: UiLogic.labelServerSettingsWaitInfoVisible visible: UiLogic.labelServerSettingsWaitInfoVisible
} }
TextFieldType { TextFieldType {
// x: 70
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
y: 80 y: 80
width: 251 width: 251

View file

@ -2,11 +2,11 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back_from_setup_wizard id: back_from_setup_wizard
x: 10 x: 10

View file

@ -2,11 +2,11 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back_from_setup_wizard id: back_from_setup_wizard
x: 10 x: 10

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back_from_setup_wizard id: back_from_setup_wizard
x: 10 x: 10

View file

@ -2,11 +2,11 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back_from_setup_wizard id: back_from_setup_wizard
x: 10 x: 10

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back_from_setup_wizard id: back_from_setup_wizard
x: 10 x: 10

View file

@ -1,11 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
ImageButtonType { ImageButtonType {
id: back id: back
x: 10 x: 10

View file

@ -1,13 +1,13 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./"
import Qt.labs.platform 1.0 import Qt.labs.platform 1.0
import QtQuick.Dialogs 1.0 import QtQuick.Dialogs 1.0
import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
Text { Text {
font.family: "Lato" font.family: "Lato"
font.styleName: "normal" font.styleName: "normal"

View file

@ -1,12 +1,11 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
Image { Image {
anchors.horizontalCenter: root.horizontalCenter anchors.horizontalCenter: root.horizontalCenter
width: GC.trW(150) width: GC.trW(150)

View file

@ -2,32 +2,33 @@ import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import PageEnum 1.0 import PageEnum 1.0
import "./" import "./"
import "../Controls"
import "../Config"
Item { Item {
id: root id: root
width: GC.screenWidth
height: GC.screenHeight
Image { Image {
x: 20 anchors.horizontalCenter: parent.horizontalCenter
y: 424 y: 0
width: 325 width: parent.width
height: 1
source: "qrc:/images/line.png" // width: 380
// height: 325
source: "qrc:/images/background_connected.png"
} }
Text {
x: 20 ImageButtonType {
y: 440 x: parent.width - 40
width: 281 y: 10
height: 21 width: 31
font.family: "Lato" height: 31
font.styleName: "normal" icon.source: "qrc:/images/settings_grey.png"
font.pixelSize: 15 onClicked: {
color: "#181922" UiLogic.goToPage(PageEnum.GeneralSettings)
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
wrapMode: Text.Wrap
text: qsTr("How to use VPN")
} }
}
LabelType { LabelType {
id: error_text id: error_text
x: 0 x: 0
@ -40,7 +41,7 @@ Item {
text: UiLogic.labelErrorText text: UiLogic.labelErrorText
} }
Text { Text {
x: 0 anchors.horizontalCenter: parent.horizontalCenter
y: 250 y: 250
width: 380 width: 380
height: 31 height: 31
@ -53,16 +54,10 @@ Item {
wrapMode: Text.Wrap wrapMode: Text.Wrap
text: UiLogic.labelStateText text: UiLogic.labelStateText
} }
Image {
x: 0
y: 0
width: 380
height: 325
source: "qrc:/images/background_connected.png"
}
BasicButtonType { BasicButtonType {
id: button_connect id: button_connect
x: 150 anchors.horizontalCenter: parent.horizontalCenter
y: 200 y: 200
width: 80 width: 80
height: 40 height: 40
@ -82,76 +77,31 @@ Item {
enabled: UiLogic.pushButtonConnectEnabled enabled: UiLogic.pushButtonConnectEnabled
} }
ImageButtonType {
x: 340
y: 10
width: 31
height: 31
icon.source: "qrc:/images/settings_grey.png"
onClicked: {
UiLogic.goToPage(PageEnum.GeneralSettings)
}
}
BasicButtonType {
id: button_add_site
x: 20
y: 560
width: 341
height: 40
text: qsTr("+ Add site")
enabled: UiLogic.pushButtonVpnAddSiteEnabled
background: Rectangle {
anchors.fill: parent
radius: 4
color: {
if (!button_add_site.enabled) {
return "#484952"
}
if (button_add_site.containsMouse) {
return "#282932"
}
return "#181922"
}
}
contentItem: Text {
anchors.fill: parent
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#D4D4D4"
text: button_add_site.text
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
}
antialiasing: true
onClicked: {
UiLogic.goToPage(PageEnum.Sites)
}
}
Item { Item {
x: 0 x: 0
y: 360 anchors.bottom: line.top
width: 380 anchors.bottomMargin: 10
width: parent.width
height: 51 height: 51
Image { Image {
x: 311 anchors.horizontalCenter: upload_label.horizontalCenter
y: 10 y: 10
width: 15 width: 15
height: 15 height: 15
source: "qrc:/images/upload.png" source: "qrc:/images/upload.png"
} }
Image { Image {
x: 53 anchors.horizontalCenter: download_label.horizontalCenter
y: 10 y: 10
width: 15 width: 15
height: 15 height: 15
source: "qrc:/images/download.png" source: "qrc:/images/download.png"
} }
Text { Text {
id: download_label
x: 0 x: 0
y: 20 y: 20
width: 127 width: 130
height: 30 height: 30
font.family: "Lato" font.family: "Lato"
font.styleName: "normal" font.styleName: "normal"
@ -163,9 +113,10 @@ Item {
text: UiLogic.labelSpeedReceivedText text: UiLogic.labelSpeedReceivedText
} }
Text { Text {
x: 260 id: upload_label
x: parent.width - width
y: 20 y: 20
width: 118 width: 130
height: 30 height: 30
font.family: "Lato" font.family: "Lato"
font.styleName: "normal" font.styleName: "normal"
@ -177,9 +128,38 @@ Item {
text: UiLogic.labelSpeedSentText text: UiLogic.labelSpeedSentText
} }
} }
Item {
Rectangle {
id: line
x: 20 x: 20
y: 470 width: parent.width - 40
height: 1
anchors.bottom: conn_type_label.top
anchors.bottomMargin: 10
color: "#DDDDDD"
}
Text {
id: conn_type_label
x: 20
anchors.bottom: conn_type_group.top
anchors.bottomMargin: 10
width: 281
height: 21
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 15
color: "#181922"
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
wrapMode: Text.Wrap
text: qsTr("How to use VPN")
}
Item {
id: conn_type_group
x: 20
anchors.bottom: button_add_site.top
width: 351 width: 351
height: 91 height: 91
enabled: UiLogic.widgetVpnModeEnabled enabled: UiLogic.widgetVpnModeEnabled
@ -221,4 +201,43 @@ Item {
} }
} }
} }
BasicButtonType {
id: button_add_site
anchors.horizontalCenter: parent.horizontalCenter
y: parent.height - 60
//anchors.bottom: parent.bottom
width: parent.width - 40
height: 40
text: qsTr("+ Add site")
enabled: UiLogic.pushButtonVpnAddSiteEnabled
background: Rectangle {
anchors.fill: parent
radius: 4
color: {
if (!button_add_site.enabled) {
return "#484952"
}
if (button_add_site.containsMouse) {
return "#282932"
}
return "#181922"
}
}
contentItem: Text {
anchors.fill: parent
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#D4D4D4"
text: button_add_site.text
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
}
antialiasing: true
onClicked: {
UiLogic.goToPage(PageEnum.Sites)
}
}
} }

View file

@ -1,15 +0,0 @@
import QtQuick 2.12
import QtQuick.Controls 2.12
RadioButton {
id: root
contentItem: Text {
text: root.text
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#181922"
verticalAlignment: Text.AlignVCenter
leftPadding: root.indicator.width + root.spacing
}
}

View file

@ -1,6 +1,7 @@
import QtQuick 2.12 import QtQuick 2.12
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import "./" import "./"
import "Config"
Rectangle { Rectangle {
id: root id: root

View file

@ -1,12 +1,18 @@
import QtQuick 2.14 import QtQuick 2.14
import QtQuick.Window 2.14 import QtQuick.Window 2.14
import QtQuick.Controls 2.12 import QtQuick.Controls 2.12
import QtQuick.Controls.Material 2.12
import PageEnum 1.0 import PageEnum 1.0
import Qt.labs.platform 1.1 import Qt.labs.platform 1.1
import QtQuick.Dialogs 1.1 import QtQuick.Dialogs 1.1
import "./" import "./"
import "Pages"
import "Config"
Window { Window {
Material.theme: Material.Dark
Material.accent: Material.Purple
id: root id: root
visible: true visible: true
width: GC.screenWidth width: GC.screenWidth
@ -15,7 +21,7 @@ Window {
UiLogic.onCloseWindow() UiLogic.onCloseWindow()
} }
flags: Qt.FramelessWindowHint //flags: Qt.FramelessWindowHint
title: "AmneziaVPN" title: "AmneziaVPN"
function getPageComponent(page) { function getPageComponent(page) {
switch (page) { switch (page) {
@ -232,16 +238,19 @@ Window {
Rectangle { Rectangle {
y: GC.isDesktop() ? titleBar.height : 0 y: GC.isDesktop() ? titleBar.height : 0
width: GC.screenWidth // width: GC.screenWidth
height: GC.screenHeight // height: GC.screenHeight
anchors.fill: parent
color: "white" color: "white"
} }
StackView { StackView {
id: pageLoader id: pageLoader
y: GC.isDesktop() ? titleBar.height : 0 y: GC.isDesktop() ? titleBar.height : 0
width: GC.screenWidth // width: GC.screenWidth
height: GC.screenHeight // height: GC.screenHeight
anchors.fill: parent
// initialItem: page_servers // initialItem: page_servers
onCurrentItemChanged: { onCurrentItemChanged: {
let pageEnum = root.getPageEnum(currentItem) let pageEnum = root.getPageEnum(currentItem)