remove QR for macos
This commit is contained in:
parent
09ac1fa679
commit
8a713b74f2
1 changed files with 139 additions and 149 deletions
|
|
@ -25,29 +25,32 @@ PageType {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ListView {
|
defaultActiveFocusItem: focusItem
|
||||||
id: listView
|
|
||||||
|
|
||||||
anchors.fill: parent
|
FlickableType {
|
||||||
|
id: fl
|
||||||
|
anchors.top: parent.top
|
||||||
|
anchors.bottom: parent.bottom
|
||||||
|
contentHeight: content.height
|
||||||
|
|
||||||
property bool isFocusable: true
|
ColumnLayout {
|
||||||
|
id: content
|
||||||
|
|
||||||
ScrollBar.vertical: ScrollBarType {}
|
anchors.top: parent.top
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.right: parent.right
|
||||||
|
|
||||||
model: variants
|
spacing: 0
|
||||||
|
|
||||||
clip: true
|
Item {
|
||||||
|
id: focusItem
|
||||||
|
KeyNavigation.tab: textKey.textField
|
||||||
|
}
|
||||||
|
|
||||||
reuseItems: true
|
|
||||||
|
|
||||||
header: ColumnLayout {
|
|
||||||
width: listView.width
|
|
||||||
|
|
||||||
HeaderType {
|
HeaderType {
|
||||||
id: moreButton
|
|
||||||
|
|
||||||
property bool isVisible: SettingsController.getInstallationUuid() !== "" || PageController.isStartPageVisible()
|
property bool isVisible: SettingsController.getInstallationUuid() !== "" || PageController.isStartPageVisible()
|
||||||
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.topMargin: 24
|
Layout.topMargin: 24
|
||||||
Layout.rightMargin: 16
|
Layout.rightMargin: 16
|
||||||
|
|
@ -57,7 +60,7 @@ PageType {
|
||||||
|
|
||||||
actionButtonImage: isVisible ? "qrc:/images/controls/more-vertical.svg" : ""
|
actionButtonImage: isVisible ? "qrc:/images/controls/more-vertical.svg" : ""
|
||||||
actionButtonFunction: function() {
|
actionButtonFunction: function() {
|
||||||
moreActionsDrawer.openTriggered()
|
moreActionsDrawer.open()
|
||||||
}
|
}
|
||||||
|
|
||||||
DrawerType2 {
|
DrawerType2 {
|
||||||
|
|
@ -68,7 +71,7 @@ PageType {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
expandedHeight: root.height * 0.5
|
expandedHeight: root.height * 0.5
|
||||||
|
|
||||||
expandedStateContent: ColumnLayout {
|
expandedContent: ColumnLayout {
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
|
|
@ -128,8 +131,6 @@ PageType {
|
||||||
}
|
}
|
||||||
|
|
||||||
ParagraphTextType {
|
ParagraphTextType {
|
||||||
objectName: "insertKeyLabel"
|
|
||||||
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.topMargin: 32
|
Layout.topMargin: 32
|
||||||
Layout.rightMargin: 16
|
Layout.rightMargin: 16
|
||||||
|
|
@ -153,6 +154,8 @@ PageType {
|
||||||
textField.text = ""
|
textField.text = ""
|
||||||
textField.paste()
|
textField.paste()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
KeyNavigation.tab: continueButton
|
||||||
}
|
}
|
||||||
|
|
||||||
BasicButtonType {
|
BasicButtonType {
|
||||||
|
|
@ -163,12 +166,13 @@ PageType {
|
||||||
Layout.rightMargin: 16
|
Layout.rightMargin: 16
|
||||||
Layout.leftMargin: 16
|
Layout.leftMargin: 16
|
||||||
|
|
||||||
visible: textKey.textField.text !== ""
|
visible: textKey.textFieldText !== ""
|
||||||
|
|
||||||
text: qsTr("Continue")
|
text: qsTr("Continue")
|
||||||
|
Keys.onTabPressed: lastItemTabClicked(focusItem)
|
||||||
|
|
||||||
clickedFunc: function() {
|
clickedFunc: function() {
|
||||||
if (ImportController.extractConfigFromData(textKey.textField.text)) {
|
if (ImportController.extractConfigFromData(textKey.textFieldText)) {
|
||||||
PageController.goToPage(PageEnum.PageSetupWizardViewConfig)
|
PageController.goToPage(PageEnum.PageSetupWizardViewConfig)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -184,157 +188,143 @@ PageType {
|
||||||
color: AmneziaStyle.color.charcoalGray
|
color: AmneziaStyle.color.charcoalGray
|
||||||
text: qsTr("Other connection options")
|
text: qsTr("Other connection options")
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
delegate: ColumnLayout {
|
|
||||||
width: listView.width
|
|
||||||
|
|
||||||
CardWithIconsType {
|
CardWithIconsType {
|
||||||
|
id: apiInstalling
|
||||||
|
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.rightMargin: 16
|
Layout.rightMargin: 16
|
||||||
Layout.leftMargin: 16
|
Layout.leftMargin: 16
|
||||||
Layout.bottomMargin: 16
|
Layout.bottomMargin: 16
|
||||||
|
|
||||||
visible: isVisible
|
headerText: qsTr("VPN by Amnezia")
|
||||||
|
bodyText: qsTr("Connect to classic paid and free VPN services from Amnezia")
|
||||||
headerText: title
|
|
||||||
bodyText: description
|
|
||||||
|
|
||||||
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
leftImageSource: imageSource
|
leftImageSource: "qrc:/images/controls/amnezia.svg"
|
||||||
|
|
||||||
onClicked: { handler() }
|
onClicked: function() {
|
||||||
|
PageController.showBusyIndicator(true)
|
||||||
|
var result = InstallController.fillAvailableServices()
|
||||||
|
PageController.showBusyIndicator(false)
|
||||||
|
if (result) {
|
||||||
|
PageController.goToPage(PageEnum.PageSetupWizardApiServicesList)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
footer: ColumnLayout {
|
CardWithIconsType {
|
||||||
width: listView.width
|
id: manualInstalling
|
||||||
|
|
||||||
BasicButtonType {
|
Layout.fillWidth: true
|
||||||
id: siteLink2
|
Layout.rightMargin: 16
|
||||||
Layout.topMargin: 24
|
Layout.leftMargin: 16
|
||||||
Layout.bottomMargin: 16
|
Layout.bottomMargin: 16
|
||||||
Layout.alignment: Qt.AlignHCenter
|
|
||||||
implicitHeight: 32
|
|
||||||
|
|
||||||
visible: Qt.platform.os !== "ios"
|
headerText: qsTr("Self-hosted VPN")
|
||||||
|
bodyText: qsTr("Configure Amnezia VPN on your own server")
|
||||||
|
|
||||||
defaultColor: AmneziaStyle.color.transparent
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
hoveredColor: AmneziaStyle.color.translucentWhite
|
leftImageSource: "qrc:/images/controls/server.svg"
|
||||||
pressedColor: AmneziaStyle.color.sheerWhite
|
|
||||||
disabledColor: AmneziaStyle.color.mutedGray
|
|
||||||
textColor: AmneziaStyle.color.goldenApricot
|
|
||||||
|
|
||||||
text: qsTr("Site Amnezia")
|
onClicked: {
|
||||||
|
PageController.goToPage(PageEnum.PageSetupWizardCredentials)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
rightImageSource: "qrc:/images/controls/external-link.svg"
|
CardWithIconsType {
|
||||||
|
id: backupRestore
|
||||||
|
|
||||||
clickedFunc: function() {
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: 16
|
||||||
|
|
||||||
|
visible: PageController.isStartPageVisible()
|
||||||
|
|
||||||
|
headerText: qsTr("Restore from backup")
|
||||||
|
|
||||||
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
|
leftImageSource: "qrc:/images/controls/archive-restore.svg"
|
||||||
|
|
||||||
|
onClicked: {
|
||||||
|
var filePath = SystemController.getFileName(qsTr("Open backup file"),
|
||||||
|
qsTr("Backup files (*.backup)"))
|
||||||
|
if (filePath !== "") {
|
||||||
|
PageController.showBusyIndicator(true)
|
||||||
|
SettingsController.restoreAppConfig(filePath)
|
||||||
|
PageController.showBusyIndicator(false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CardWithIconsType {
|
||||||
|
id: openFile
|
||||||
|
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: 16
|
||||||
|
|
||||||
|
headerText: qsTr("File with connection settings")
|
||||||
|
|
||||||
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
|
leftImageSource: "qrc:/images/controls/folder-search-2.svg"
|
||||||
|
|
||||||
|
onClicked: {
|
||||||
|
var nameFilter = !ServersModel.getServersCount() ? "Config or backup files (*.vpn *.ovpn *.conf *.json *.backup)" :
|
||||||
|
"Config files (*.vpn *.ovpn *.conf *.json)"
|
||||||
|
var fileName = SystemController.getFileName(qsTr("Open config file"), nameFilter)
|
||||||
|
if (fileName !== "") {
|
||||||
|
if (ImportController.extractConfigFromFile(fileName)) {
|
||||||
|
PageController.goToPage(PageEnum.PageSetupWizardViewConfig)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CardWithIconsType {
|
||||||
|
id: scanQr
|
||||||
|
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: 16
|
||||||
|
|
||||||
|
visible: (Qt.platform.os === "android" || Qt.platform.os === "ios") && SettingsController.isCameraPresent()
|
||||||
|
|
||||||
|
headerText: qsTr("QR code")
|
||||||
|
|
||||||
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
|
leftImageSource: "qrc:/images/controls/scan-line.svg"
|
||||||
|
|
||||||
|
onClicked: {
|
||||||
|
ImportController.startDecodingQr()
|
||||||
|
if (Qt.platform.os === "ios") {
|
||||||
|
PageController.goToPage(PageEnum.PageSetupWizardQrReader)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CardWithIconsType {
|
||||||
|
id: siteLink
|
||||||
|
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: 16
|
||||||
|
Layout.leftMargin: 16
|
||||||
|
Layout.bottomMargin: 16
|
||||||
|
|
||||||
|
visible: PageController.isStartPageVisible()
|
||||||
|
|
||||||
|
headerText: qsTr("I have nothing")
|
||||||
|
|
||||||
|
rightImageSource: "qrc:/images/controls/chevron-right.svg"
|
||||||
|
leftImageSource: "qrc:/images/controls/help-circle.svg"
|
||||||
|
|
||||||
|
onClicked: {
|
||||||
Qt.openUrlExternally(LanguageModel.getCurrentSiteUrl())
|
Qt.openUrlExternally(LanguageModel.getCurrentSiteUrl())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
property list<QtObject> variants: [
|
|
||||||
amneziaVpn,
|
|
||||||
selfHostVpn,
|
|
||||||
backupRestore,
|
|
||||||
fileOpen,
|
|
||||||
qrScan,
|
|
||||||
siteLink
|
|
||||||
]
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: amneziaVpn
|
|
||||||
|
|
||||||
property string title: qsTr("VPN by Amnezia")
|
|
||||||
property string description: qsTr("Connect to classic paid and free VPN services from Amnezia")
|
|
||||||
property string imageSource: "qrc:/images/controls/amnezia.svg"
|
|
||||||
property bool isVisible: true
|
|
||||||
property var handler: function() {
|
|
||||||
PageController.showBusyIndicator(true)
|
|
||||||
var result = InstallController.fillAvailableServices()
|
|
||||||
PageController.showBusyIndicator(false)
|
|
||||||
if (result) {
|
|
||||||
PageController.goToPage(PageEnum.PageSetupWizardApiServicesList)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: selfHostVpn
|
|
||||||
|
|
||||||
property string title: qsTr("Self-hosted VPN")
|
|
||||||
property string description: qsTr("Configure Amnezia VPN on your own server")
|
|
||||||
property string imageSource: "qrc:/images/controls/server.svg"
|
|
||||||
property bool isVisible: true
|
|
||||||
property var handler: function() {
|
|
||||||
PageController.goToPage(PageEnum.PageSetupWizardCredentials)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: backupRestore
|
|
||||||
|
|
||||||
property string title: qsTr("Restore from backup")
|
|
||||||
property string description: qsTr("")
|
|
||||||
property string imageSource: "qrc:/images/controls/archive-restore.svg"
|
|
||||||
property bool isVisible: PageController.isStartPageVisible()
|
|
||||||
property var handler: function() {
|
|
||||||
var filePath = SystemController.getFileName(qsTr("Open backup file"),
|
|
||||||
qsTr("Backup files (*.backup)"))
|
|
||||||
if (filePath !== "") {
|
|
||||||
PageController.showBusyIndicator(true)
|
|
||||||
SettingsController.restoreAppConfig(filePath)
|
|
||||||
PageController.showBusyIndicator(false)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: fileOpen
|
|
||||||
|
|
||||||
property string title: qsTr("File with connection settings")
|
|
||||||
property string description: qsTr("")
|
|
||||||
property string imageSource: "qrc:/images/controls/folder-search-2.svg"
|
|
||||||
property bool isVisible: true
|
|
||||||
property var handler: function() {
|
|
||||||
var nameFilter = !ServersModel.getServersCount() ? "Config or backup files (*.vpn *.ovpn *.conf *.json *.backup)" :
|
|
||||||
"Config files (*.vpn *.ovpn *.conf *.json)"
|
|
||||||
var fileName = SystemController.getFileName(qsTr("Open config file"), nameFilter)
|
|
||||||
if (fileName !== "") {
|
|
||||||
if (ImportController.extractConfigFromFile(fileName)) {
|
|
||||||
PageController.goToPage(PageEnum.PageSetupWizardViewConfig)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: qrScan
|
|
||||||
|
|
||||||
property string title: qsTr("QR code")
|
|
||||||
property string description: qsTr("")
|
|
||||||
property string imageSource: "qrc:/images/controls/scan-line.svg"
|
|
||||||
property bool isVisible: SettingsController.isCameraPresent()
|
|
||||||
property var handler: function() {
|
|
||||||
ImportController.startDecodingQr()
|
|
||||||
if (Qt.platform.os === "ios") {
|
|
||||||
PageController.goToPage(PageEnum.PageSetupWizardQrReader)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: siteLink
|
|
||||||
|
|
||||||
property string title: qsTr("I have nothing")
|
|
||||||
property string description: qsTr("")
|
|
||||||
property string imageSource: "qrc:/images/controls/help-circle.svg"
|
|
||||||
property bool isVisible: PageController.isStartPageVisible() && Qt.platform.os !== "ios"
|
|
||||||
property var handler: function() {
|
|
||||||
Qt.openUrlExternally(LanguageModel.getCurrentSiteUrl())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue