Files
amnezia-client/client/ui/qml/Pages/PageShareConnection.qml
T

421 lines
18 KiB
QML
Raw Normal View History

2021-07-28 16:13:29 +07:00
import QtQuick 2.12
import QtQuick.Controls 2.12
import "./"
2021-08-19 01:27:22 +03:00
import "../Controls"
import "../Config"
2021-07-28 16:13:29 +07:00
Item {
id: root
ImageButtonType {
id: back
x: 10
y: 10
width: 26
height: 20
icon.source: "qrc:/images/arrow_left.png"
onClicked: {
UiLogic.closePage()
}
}
ScrollView {
x: 10
y: 40
width: 360
height: 580
Item {
id: ct
width: parent.width
height: childrenRect.height + 10
property var contentList: [
full_access,
share_amezia,
share_openvpn,
share_shadowshock,
share_cloak
]
2021-08-09 00:41:52 +07:00
property int currentIndex: UiLogic.toolBoxShareConnectionCurrentIndex
onCurrentIndexChanged: {
UiLogic.toolBoxShareConnectionCurrentIndex = currentIndex
for (let i = 0; i < contentList.length; ++i) {
if (i == currentIndex) {
contentList[i].active = true
} else {
contentList[i].active = false
}
}
}
2021-07-28 16:13:29 +07:00
function clearActive() {
for (let i = 0; i < contentList.length; ++i) {
contentList[i].active = false
}
2021-08-09 00:41:52 +07:00
currentIndex = -1;
2021-07-28 16:13:29 +07:00
}
Column {
spacing: 5
ShareConnectionContent {
id: full_access
x: 0
text: qsTr("Full access")
2021-08-09 00:41:52 +07:00
visible: UiLogic.pageShareFullAccessVisible
2021-07-28 16:13:29 +07:00
content: Component {
Item {
width: 360
height: 380
Text {
x: 10
y: 250
width: 341
height: 111
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#181922"
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
wrapMode: Text.Wrap
text: qsTr("Anyone who logs in with this code will have the same permissions to use VPN and your server as you. \nThis code includes your server credentials!\nProvide this code only to TRUSTED users.")
}
ShareConnectionButtonType {
x: 10
y: 130
width: 341
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareFullCopyText
onClicked: {
UiLogic.onPushButtonShareFullCopyClicked()
}
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 180
width: 341
height: 40
text: qsTr("Save file")
2021-08-09 00:41:52 +07:00
onClicked: {
UiLogic.onPushButtonShareFullSaveClicked()
}
2021-07-28 16:13:29 +07:00
}
TextFieldType {
x: 10
y: 10
width: 341
height: 100
verticalAlignment: Text.AlignTop
2021-08-09 00:41:52 +07:00
text: UiLogic.textEditShareFullCodeText
onEditingFinished: {
UiLogic.textEditShareFullCodeText = text
}
2021-07-28 16:13:29 +07:00
}
}
}
onClicked: {
if (active) {
2021-08-09 00:41:52 +07:00
ct.currentIndex = -1
2021-07-28 16:13:29 +07:00
} else {
ct.clearActive()
2021-08-09 00:41:52 +07:00
ct.currentIndex = 0
2021-07-28 16:13:29 +07:00
}
}
}
ShareConnectionContent {
id: share_amezia
x: 0
text: qsTr("Share for Amnezia client")
2021-08-09 00:41:52 +07:00
visible: UiLogic.pageShareAmneziaVisible
2021-07-28 16:13:29 +07:00
content: Component {
Item {
width: 360
height: 380
Text {
x: 10
y: 280
width: 341
height: 111
font.family: "Lato"
font.styleName: "normal"
font.pixelSize: 16
color: "#181922"
horizontalAlignment: Text.AlignLeft
verticalAlignment: Text.AlignVCenter
wrapMode: Text.Wrap
text: qsTr("Anyone who logs in with this code will be able to connect to this VPN server. \nThis code does not include server credentials.")
}
ShareConnectionButtonType {
x: 10
y: 180
width: 341
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareAmneziaCopyText
onClicked: {
UiLogic.onPushButtonShareAmneziaCopyClicked()
}
enabled: UiLogic.pushButtonShareAmneziaCopyEnabled
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 130
width: 341
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareAmneziaGenerateText
enabled: UiLogic.pushButtonShareAmneziaGenerateEnabled
onClicked: {
UiLogic.onPushButtonShareAmneziaGenerateClicked()
}
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 230
width: 341
height: 40
text: qsTr("Save file")
2021-08-09 00:41:52 +07:00
onClicked: {
UiLogic.onPushButtonShareAmneziaSaveClicked()
}
2021-07-28 16:13:29 +07:00
}
TextFieldType {
x: 10
y: 10
width: 341
height: 100
verticalAlignment: Text.AlignTop
2021-08-09 00:41:52 +07:00
text: UiLogic.textEditShareAmneziaCodeText
onEditingFinished: {
UiLogic.textEditShareAmneziaCodeText = text
}
2021-07-28 16:13:29 +07:00
}
}
}
onClicked: {
if (active) {
2021-08-09 00:41:52 +07:00
ct.currentIndex = -1
2021-07-28 16:13:29 +07:00
} else {
ct.clearActive()
2021-08-09 00:41:52 +07:00
ct.currentIndex = 1
2021-07-28 16:13:29 +07:00
}
}
}
ShareConnectionContent {
id: share_openvpn
x: 0
text: qsTr("Share for OpenVPN client")
2021-08-09 00:41:52 +07:00
visible: UiLogic.pageShareOpenvpnVisible
2021-07-28 16:13:29 +07:00
content: Component {
Item {
width: 360
height: 380
ShareConnectionButtonType {
x: 10
y: 180
width: 341
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareOpenvpnCopyText
enabled: UiLogic.pushButtonShareOpenvpnCopyEnabled
onClicked: {
UiLogic.onPushButtonShareOpenvpnCopyClicked()
}
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 130
width: 341
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareOpenvpnGenerateText
onClicked: {
UiLogic.onPushButtonShareOpenvpnGenerateClicked()
}
enabled: UiLogic.pushButtonShareOpenvpnGenerateEnabled
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 230
width: 341
height: 40
text: qsTr("Save file")
2021-08-09 00:41:52 +07:00
enabled: UiLogic.pushButtonShareOpenvpnSaveEnabled
onClicked: {
UiLogic.onPushButtonShareOpenvpnSaveClicked()
}
2021-07-28 16:13:29 +07:00
}
TextFieldType {
x: 10
y: 10
width: 341
height: 100
verticalAlignment: Text.AlignTop
2021-08-09 00:41:52 +07:00
text: UiLogic.textEditShareOpenvpnCodeText
onEditingFinished: {
UiLogic.textEditShareOpenvpnCodeText = text
}
2021-07-28 16:13:29 +07:00
}
}
}
onClicked: {
if (active) {
2021-08-09 00:41:52 +07:00
ct.currentIndex = -1
2021-07-28 16:13:29 +07:00
} else {
ct.clearActive()
2021-08-09 00:41:52 +07:00
ct.currentIndex = 2
2021-07-28 16:13:29 +07:00
}
}
}
ShareConnectionContent {
id: share_shadowshock
x: 0
text: qsTr("Share for ShadowSocks client")
2021-08-09 00:41:52 +07:00
visible: UiLogic.pageShareShadowsocksVisible
2021-07-28 16:13:29 +07:00
content: Component {
Item {
width: 360
height: 380
LabelType {
x: 10
y: 70
width: 100
height: 20
text: qsTr("Password")
}
LabelType {
x: 10
y: 10
width: 100
height: 20
text: qsTr("Server:")
}
LabelType {
x: 10
y: 50
width: 100
height: 20
text: qsTr("Encryption:")
}
LabelType {
x: 10
y: 30
width: 100
height: 20
text: qsTr("Port:")
}
LabelType {
x: 10
y: 100
width: 191
height: 20
text: qsTr("Connection string")
}
LabelType {
x: 130
y: 70
width: 100
height: 20
2021-08-09 00:41:52 +07:00
text: UiLogic.labelShareSsPasswordText
2021-07-28 16:13:29 +07:00
}
LabelType {
x: 130
y: 10
width: 100
height: 20
2021-08-09 00:41:52 +07:00
text: UiLogic.labelShareSsServerText
2021-07-28 16:13:29 +07:00
}
LabelType {
x: 130
y: 50
width: 100
height: 20
2021-08-09 00:41:52 +07:00
text: UiLogic.labelShareSsMethodText
2021-07-28 16:13:29 +07:00
}
LabelType {
x: 130
y: 30
width: 100
height: 20
2021-08-09 00:41:52 +07:00
text: UiLogic.labelShareSsPortText
2021-07-28 16:13:29 +07:00
}
Image {
id: label_share_ss_qr_code
x: 85
y: 235
width: 200
height: 200
2021-08-09 00:41:52 +07:00
source: UiLogic.labelShareSsQrCodeText == "" ? "" : "data:image/png;base64," + UiLogic.labelShareSsQrCodeText
2021-07-28 16:13:29 +07:00
}
ShareConnectionButtonType {
x: 10
y: 180
width: 331
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareSsCopyText
enabled: UiLogic.pushButtonShareSsCopyEnabled
onClicked: {
UiLogic.onPushButtonShareSsCopyClicked()
}
2021-07-28 16:13:29 +07:00
}
TextFieldType {
x: 10
y: 130
width: 331
height: 100
horizontalAlignment: Text.AlignHCenter
2021-08-09 00:41:52 +07:00
text: UiLogic.lineEditShareSsStringText
onEditingFinished: {
UiLogic.lineEditShareSsStringText = text
}
2021-07-28 16:13:29 +07:00
}
}
}
onClicked: {
if (active) {
2021-08-09 00:41:52 +07:00
ct.currentIndex = -1
2021-07-28 16:13:29 +07:00
} else {
ct.clearActive()
2021-08-09 00:41:52 +07:00
ct.currentIndex = 3
2021-07-28 16:13:29 +07:00
}
}
}
ShareConnectionContent {
id: share_cloak
x: 0
text: qsTr("Share for Cloak client")
2021-08-09 00:41:52 +07:00
visible: UiLogic.pageShareCloakVisible
2021-07-28 16:13:29 +07:00
content: Component {
Item {
width: 360
height: 380
ShareConnectionButtonType {
x: 10
y: 290
width: 331
height: 40
2021-08-09 00:41:52 +07:00
text: UiLogic.pushButtonShareCloakCopyText
enabled: UiLogic.pushButtonShareCloakCopyEnabled
onClicked: {
UiLogic.onPushButtonShareCloakCopyClicked()
}
2021-07-28 16:13:29 +07:00
}
TextInput {
x: 10
y: 30
width: 331
height: 100
2021-08-09 00:41:52 +07:00
text: UiLogic.plainTextEditShareCloakText
onEditingFinished: {
UiLogic.plainTextEditShareCloakText = text
}
2021-07-28 16:13:29 +07:00
}
}
}
onClicked: {
if (active) {
2021-08-09 00:41:52 +07:00
ct.currentIndex = -1
2021-07-28 16:13:29 +07:00
} else {
ct.clearActive()
2021-08-09 00:41:52 +07:00
ct.currentIndex = 4
2021-07-28 16:13:29 +07:00
}
}
}
}
}
}
}