monero-gui/wizard/WizardOptions.qml

395 lines
14 KiB
QML
Raw Normal View History

2018-01-07 05:20:45 +00:00
// Copyright (c) 2014-2018, The Monero Project
2015-04-01 08:56:05 +00:00
//
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification, are
// permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice, this list of
// conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
// of conditions and the following disclaimer in the documentation and/or other
// materials provided with the distribution.
//
// 3. Neither the name of the copyright holder nor the names of its contributors may be
// used to endorse or promote products derived from this software without specific
// prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2014-08-19 12:58:02 +00:00
import QtQuick 2.2
2016-09-22 21:05:20 +00:00
import QtQml 2.2
import QtQuick.Controls 2.0
2016-09-22 21:05:20 +00:00
import QtQuick.Layouts 1.1
2018-03-05 16:19:45 +00:00
import moneroComponents.NetworkType 1.0
2016-09-22 21:05:20 +00:00
import "../components"
2014-08-19 12:58:02 +00:00
2017-01-30 09:37:14 +00:00
ColumnLayout {
2014-08-20 19:19:21 +00:00
id: page
signal createWalletClicked()
signal recoveryWalletClicked()
2016-10-29 14:39:32 +00:00
signal openWalletClicked()
signal createWalletFromDeviceClicked()
2014-08-19 12:58:02 +00:00
opacity: 0
visible: false
property int buttonSize: (isMobile) ? 80 * scaleRatio : 140 * scaleRatio
2017-08-06 15:03:16 +00:00
property int buttonImageSize: (isMobile) ? buttonSize - 10 * scaleRatio : buttonSize - 30 * scaleRatio
2016-09-22 21:05:20 +00:00
function onPageClosed() {
// Save settings used in open from file.
// other wizard settings are saved on last page in applySettings()
appWindow.persistentSettings.language = wizard.settings.language
appWindow.persistentSettings.locale = wizard.settings.locale
return true;
}
2014-08-19 12:58:02 +00:00
Behavior on opacity {
NumberAnimation { duration: 100; easing.type: Easing.InQuad }
}
onOpacityChanged: visible = opacity !== 0
2017-01-30 09:37:14 +00:00
ColumnLayout {
2014-08-19 12:58:02 +00:00
id: headerColumn
2017-01-30 09:37:14 +00:00
Layout.leftMargin: wizardLeftMargin
Layout.rightMargin: wizardRightMargin
2017-08-06 15:03:16 +00:00
Layout.bottomMargin: (!isMobile) ? 40 * scaleRatio : 20
spacing: 30 * scaleRatio
2014-08-19 12:58:02 +00:00
Text {
2017-01-30 09:37:14 +00:00
Layout.fillWidth: true
2014-08-19 12:58:02 +00:00
font.family: "Arial"
2017-08-06 15:03:16 +00:00
font.pixelSize: 28 * scaleRatio
2014-08-19 12:58:02 +00:00
//renderType: Text.NativeRendering
color: "#3F3F3F"
2014-08-21 10:09:52 +00:00
wrapMode: Text.Wrap
horizontalAlignment: Text.AlignHCenter
text: qsTr("Welcome to Monero!") + translationManager.emptyString
2014-08-19 12:58:02 +00:00
}
Text {
2017-01-30 09:37:14 +00:00
Layout.fillWidth: true
2014-08-19 12:58:02 +00:00
font.family: "Arial"
2017-08-06 15:03:16 +00:00
font.pixelSize: 18 * scaleRatio
2014-08-19 12:58:02 +00:00
//renderType: Text.NativeRendering
color: "#4A4646"
2014-08-21 10:09:52 +00:00
wrapMode: Text.Wrap
horizontalAlignment: Text.AlignHCenter
text: qsTr("Please select one of the following options:") + translationManager.emptyString
2014-08-19 12:58:02 +00:00
}
}
2017-01-30 09:37:14 +00:00
GridLayout {
Layout.leftMargin: wizardLeftMargin
Layout.rightMargin: wizardRightMargin
Layout.alignment: Qt.AlignCenter
id: actionButtons
2017-08-06 15:03:16 +00:00
columnSpacing: 40 * scaleRatio
rowSpacing: 10 * scaleRatio
2017-01-30 09:37:14 +00:00
Layout.fillWidth: true
Layout.fillHeight: true
flow: isMobile ? GridLayout.TopToBottom : GridLayout.LeftToRight
GridLayout {
Layout.fillHeight: true
Layout.fillWidth: true
flow: !isMobile ? GridLayout.TopToBottom : GridLayout.LeftToRight
2017-08-06 15:03:16 +00:00
rowSpacing: 20 * scaleRatio
columnSpacing: 10 * scaleRatio
2014-08-19 12:58:02 +00:00
Rectangle {
2017-01-30 09:37:14 +00:00
Layout.preferredHeight: page.buttonSize
Layout.preferredWidth: page.buttonSize
2016-10-29 14:39:32 +00:00
radius: page.buttonSize
2014-08-19 12:58:02 +00:00
color: createWalletArea.containsMouse ? "#DBDBDB" : "#FFFFFF"
2016-10-29 14:39:32 +00:00
2014-08-19 12:58:02 +00:00
Image {
2017-01-30 09:37:14 +00:00
width: page.buttonImageSize
height: page.buttonImageSize
2016-10-29 14:39:32 +00:00
fillMode: Image.PreserveAspectFit
horizontalAlignment: Image.AlignRight
verticalAlignment: Image.AlignTop
2014-08-19 12:58:02 +00:00
anchors.centerIn: parent
source: "qrc:///images/createWallet.png"
}
MouseArea {
id: createWalletArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
2014-08-19 12:58:02 +00:00
hoverEnabled: true
2016-09-22 21:05:20 +00:00
onClicked: {
page.createWalletClicked()
}
2014-08-19 12:58:02 +00:00
}
}
Text {
2017-08-06 15:03:16 +00:00
Layout.preferredWidth: page.buttonSize
2014-08-19 12:58:02 +00:00
font.family: "Arial"
2017-08-06 15:03:16 +00:00
font.pixelSize: 16 * scaleRatio
2014-08-19 12:58:02 +00:00
color: "#4A4949"
horizontalAlignment: Text.AlignHCenter
2016-10-29 14:39:32 +00:00
wrapMode: Text.WordWrap
2016-12-17 23:05:42 +00:00
text: qsTr("Create a new wallet") + translationManager.emptyString
2014-08-19 12:58:02 +00:00
}
}
2017-01-30 09:37:14 +00:00
GridLayout {
Layout.fillWidth: true
Layout.fillHeight: true
flow: !isMobile ? GridLayout.TopToBottom : GridLayout.LeftToRight
2017-08-06 15:03:16 +00:00
rowSpacing: 20 * scaleRatio
columnSpacing: 10 * scaleRatio
2014-08-19 12:58:02 +00:00
Rectangle {
2017-01-30 09:37:14 +00:00
Layout.preferredHeight: page.buttonSize
Layout.preferredWidth: page.buttonSize
2016-10-29 14:39:32 +00:00
radius: page.buttonSize
2014-08-19 12:58:02 +00:00
color: recoverWalletArea.containsMouse ? "#DBDBDB" : "#FFFFFF"
Image {
2017-08-06 15:03:16 +00:00
width: page.buttonImageSize
2017-01-30 09:37:14 +00:00
height: page.buttonImageSize
2016-10-29 14:39:32 +00:00
fillMode: Image.PreserveAspectFit
2014-08-19 12:58:02 +00:00
anchors.centerIn: parent
source: "qrc:///images/recoverWallet.png"
}
MouseArea {
id: recoverWalletArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
2014-08-19 12:58:02 +00:00
hoverEnabled: true
2016-09-22 21:05:20 +00:00
onClicked: {
page.recoveryWalletClicked()
}
2014-08-19 12:58:02 +00:00
}
}
Text {
2017-08-06 15:03:16 +00:00
Layout.preferredWidth: page.buttonSize
2014-08-19 12:58:02 +00:00
font.family: "Arial"
2017-08-06 15:03:16 +00:00
font.pixelSize: 16 * scaleRatio
2014-08-19 12:58:02 +00:00
color: "#4A4949"
horizontalAlignment: Text.AlignHCenter
2017-01-26 20:54:31 +00:00
text: qsTr("Restore wallet from keys or mnemonic seed") + translationManager.emptyString
2016-10-29 14:39:32 +00:00
width:page.buttonSize
wrapMode: Text.WordWrap
2014-08-19 12:58:02 +00:00
}
}
2016-10-29 14:39:32 +00:00
2017-01-30 09:37:14 +00:00
GridLayout {
Layout.fillHeight: true
Layout.fillWidth: true
flow: !isMobile ? GridLayout.TopToBottom : GridLayout.LeftToRight
2017-08-06 15:03:16 +00:00
rowSpacing: 20 * scaleRatio
columnSpacing: 10 * scaleRatio
2016-10-29 14:39:32 +00:00
Rectangle {
2017-01-30 09:37:14 +00:00
Layout.preferredHeight: page.buttonSize
Layout.preferredWidth: page.buttonSize
2016-10-29 14:39:32 +00:00
radius: page.buttonSize
color: openWalletArea.containsMouse ? "#DBDBDB" : "#FFFFFF"
Image {
2017-01-30 09:37:14 +00:00
width: page.buttonImageSize
height: page.buttonImageSize
2016-10-29 14:39:32 +00:00
fillMode: Image.PreserveAspectFit
anchors.centerIn: parent
2016-10-30 17:08:37 +00:00
source: "qrc:///images/openAccount.png"
2016-10-29 14:39:32 +00:00
}
MouseArea {
id: openWalletArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
2016-10-29 14:39:32 +00:00
hoverEnabled: true
onClicked: {
page.openWalletClicked()
}
}
}
Text {
2017-08-06 15:03:16 +00:00
Layout.preferredWidth: page.buttonSize
2016-10-29 14:39:32 +00:00
font.family: "Arial"
2017-08-06 15:03:16 +00:00
font.pixelSize: 16 * scaleRatio
2016-10-29 14:39:32 +00:00
color: "#4A4949"
horizontalAlignment: Text.AlignHCenter
2016-12-17 23:05:42 +00:00
text: qsTr("Open a wallet from file") + translationManager.emptyString
2016-10-29 14:39:32 +00:00
wrapMode: Text.WordWrap
}
}
GridLayout {
Layout.fillHeight: true
Layout.fillWidth: true
flow: !isMobile ? GridLayout.TopToBottom : GridLayout.LeftToRight
rowSpacing: 20 * scaleRatio
columnSpacing: 10 * scaleRatio
Rectangle {
Layout.preferredHeight: page.buttonSize
Layout.preferredWidth: page.buttonSize
radius: page.buttonSize
color: createWalletFromDeviceArea.containsMouse ? "#DBDBDB" : "#FFFFFF"
Image {
width: page.buttonImageSize
height: page.buttonImageSize
fillMode: Image.PreserveAspectFit
horizontalAlignment: Image.AlignRight
verticalAlignment: Image.AlignTop
anchors.centerIn: parent
source: "qrc:///images/createWalletFromDevice.png"
}
MouseArea {
id: createWalletFromDeviceArea
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
hoverEnabled: true
onClicked: {
page.createWalletFromDeviceClicked()
}
}
}
Text {
Layout.preferredWidth: page.buttonSize
font.family: "Arial"
font.pixelSize: 16 * scaleRatio
color: "#4A4949"
horizontalAlignment: Text.AlignHCenter
wrapMode: Text.WordWrap
text: qsTr("Create a new wallet from hardware device") + translationManager.emptyString
}
}
2014-08-19 12:58:02 +00:00
}
2016-09-22 21:05:20 +00:00
2018-03-05 16:19:45 +00:00
ColumnLayout {
2017-01-30 09:37:14 +00:00
Layout.leftMargin: wizardLeftMargin
Layout.rightMargin: wizardRightMargin
2017-08-06 15:36:17 +00:00
Layout.topMargin: 30 * scaleRatio
2017-01-30 09:37:14 +00:00
Layout.alignment: Qt.AlignCenter
2017-10-23 17:49:57 +00:00
Layout.fillWidth: true
2018-04-28 14:40:01 +00:00
spacing: 38 * scaleRatio
2016-09-22 21:05:20 +00:00
RowLayout {
CheckBox2 {
id: showAdvancedCheckbox
darkDropIndicator: true
text: qsTr("Advanced options") + translationManager.emptyString
fontColor: "#4A4646"
}
}
Rectangle {
width: 100 * scaleRatio
RadioButton {
visible: showAdvancedCheckbox.checked
enabled: !this.checked
id: mainNet
text: qsTr("Mainnet") + translationManager.emptyString
checkedColor: Qt.rgba(0, 0, 0, 0.75)
borderColor: Qt.rgba(0, 0, 0, 0.45)
fontColor: "#4A4646"
fontSize: 16 * scaleRatio
checked: appWindow.persistentSettings.nettype == NetworkType.MAINNET;
onClicked: {
persistentSettings.nettype = NetworkType.MAINNET
testNet.checked = false;
stageNet.checked = false;
console.log("Network type set to MainNet")
}
}
}
2017-10-23 17:49:57 +00:00
Rectangle {
2017-08-06 15:36:17 +00:00
width: 100 * scaleRatio
2018-04-28 14:40:01 +00:00
RadioButton {
visible: showAdvancedCheckbox.checked
enabled: !this.checked
2017-10-23 17:49:57 +00:00
id: testNet
text: qsTr("Testnet") + translationManager.emptyString
2018-04-28 14:40:01 +00:00
checkedColor: Qt.rgba(0, 0, 0, 0.75)
borderColor: Qt.rgba(0, 0, 0, 0.45)
2018-03-27 00:03:59 +00:00
fontColor: "#4A4646"
fontSize: 16 * scaleRatio
2018-03-27 18:41:15 +00:00
checked: appWindow.persistentSettings.nettype == NetworkType.TESTNET;
2018-03-27 00:03:59 +00:00
onClicked: {
persistentSettings.nettype = testNet.checked ? NetworkType.TESTNET : NetworkType.MAINNET
mainNet.checked = false;
2018-03-27 00:03:59 +00:00
stageNet.checked = false;
2018-03-27 18:41:15 +00:00
console.log("Network type set to ", persistentSettings.nettype == NetworkType.TESTNET ? "Testnet" : "Mainnet")
2018-03-27 00:03:59 +00:00
}
}
}
Rectangle {
width: 100 * scaleRatio
2018-04-28 14:40:01 +00:00
RadioButton {
visible: showAdvancedCheckbox.checked
enabled: !this.checked
2018-03-27 00:03:59 +00:00
id: stageNet
text: qsTr("Stagenet") + translationManager.emptyString
2018-04-28 14:40:01 +00:00
checkedColor: Qt.rgba(0, 0, 0, 0.75)
borderColor: Qt.rgba(0, 0, 0, 0.45)
2017-10-23 17:49:57 +00:00
fontColor: "#4A4646"
2017-08-06 15:36:17 +00:00
fontSize: 16 * scaleRatio
2018-03-27 18:41:15 +00:00
checked: appWindow.persistentSettings.nettype == NetworkType.STAGENET;
2017-10-23 17:49:57 +00:00
onClicked: {
2018-03-05 16:19:45 +00:00
persistentSettings.nettype = stageNet.checked ? NetworkType.STAGENET : NetworkType.MAINNET
mainNet.checked = false;
2018-03-05 16:19:45 +00:00
testNet.checked = false;
2018-03-27 18:41:15 +00:00
console.log("Network type set to ", persistentSettings.nettype == NetworkType.STAGENET ? "Stagenet" : "Mainnet")
2016-09-22 21:05:20 +00:00
}
}
}
2017-01-30 09:37:14 +00:00
}
RowLayout {
Layout.leftMargin: wizardLeftMargin
Layout.rightMargin: wizardRightMargin
Layout.topMargin: 50 * scaleRatio
Layout.alignment: Qt.AlignHCenter
Layout.fillWidth: true
visible: showAdvancedCheckbox.checked
Text {
font.family: "Arial"
font.pixelSize: 16 * scaleRatio
color: "#4A4949"
text: qsTr("Number of KDF rounds:") + translationManager.emptyString
}
TextField {
id: kdfRoundsText
font.family: "Arial"
font.pixelSize: 16 * scaleRatio
Layout.preferredWidth: 60
horizontalAlignment: TextInput.AlignRight
selectByMouse: true
color: "#4A4949"
text: persistentSettings.kdfRounds
validator: IntValidator { bottom: 1 }
onEditingFinished: {
kdfRoundsText.text = persistentSettings.kdfRounds = parseInt(kdfRoundsText.text) >= 1 ? parseInt(kdfRoundsText.text) : 1;
}
}
}
2014-08-19 12:58:02 +00:00
}
2016-09-22 21:05:20 +00:00