Merge pull request #95

550087f PasswordDialog: accept/reject with Enter/Esc, Tab navigation (Ilya Kitaev)
513f7eb StandardButton: indicating "focused" state (Ilya Kitaev)
7973d0c Custom password dialog. fixes issue with standard dialog (Ilya Kitaev)
This commit is contained in:
Riccardo Spagni 2016-11-05 10:08:50 +02:00
commit bfebc2e356
No known key found for this signature in database
GPG key ID: 55432DF31CCD4FCD
4 changed files with 138 additions and 27 deletions

View file

@ -31,37 +31,143 @@ import QtQuick.Controls 1.4
import QtQuick.Dialogs 1.2 import QtQuick.Dialogs 1.2
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import QtQuick.Controls.Styles 1.4 import QtQuick.Controls.Styles 1.4
import QtQuick.Window 2.0
// import "../components" import "../components" as MoneroComponents
Dialog { Window {
id: root id: root
modality: Qt.ApplicationModal
flags: Qt.Window | Qt.FramelessWindowHint
property alias password: passwordInput.text property alias password: passwordInput.text
standardButtons: StandardButton.Ok + StandardButton.Cancel
// same signals as Dialog has
signal accepted()
signal rejected()
function open() {
show()
}
// TODO: implement without hardcoding sizes
width: 480
height: 200
ColumnLayout { ColumnLayout {
id: column id: mainLayout
anchors.fill: parent spacing: 10
anchors { fill: parent; margins: 35 }
Label { ColumnLayout {
text: qsTr("Please enter wallet password") id: column
Layout.columnSpan: 2 //anchors {fill: parent; margins: 16 }
Layout.fillWidth: true Layout.alignment: Qt.AlignHCenter
font.family: "Arial"
font.pixelSize: 32 Label {
text: qsTr("Please enter wallet password")
Layout.alignment: Qt.AlignHCenter
Layout.columnSpan: 2
Layout.fillWidth: true
horizontalAlignment: Text.AlignHCenter
font.pixelSize: 24
font.family: "Arial"
color: "#555555"
}
TextField {
id : passwordInput
focus: true
Layout.fillWidth: true
Layout.alignment: Qt.AlignHCenter
horizontalAlignment: TextInput.AlignHCenter
verticalAlignment: TextInput.AlignVCenter
font.family: "Arial"
font.pixelSize: 32
echoMode: TextInput.Password
KeyNavigation.tab: okButton
style: TextFieldStyle {
renderType: Text.NativeRendering
textColor: "#35B05A"
passwordCharacter: "•"
// no background
background: Rectangle {
radius: 0
border.width: 0
}
}
Keys.onReturnPressed: {
root.accepted()
root.close()
}
Keys.onEscapePressed: {
root.rejected()
root.close()
}
}
// underline
Rectangle {
height: 1
color: "#DBDBDB"
Layout.fillWidth: true
Layout.alignment: Qt.AlignHCenter
anchors.bottomMargin: 3
}
// padding
Rectangle {
Layout.fillWidth: true
Layout.alignment: Qt.AlignHCenter
height: 10
opacity: 0
color: "black"
}
} }
// Ok/Cancel buttons
RowLayout {
id: buttons
spacing: 60
Layout.alignment: Qt.AlignHCenter
TextField { MoneroComponents.StandardButton {
id : passwordInput id: okButton
width: 120
fontSize: 14
shadowReleasedColor: "#FF4304"
shadowPressedColor: "#B32D00"
releasedColor: "#FF6C3C"
pressedColor: "#FF4304"
text: qsTr("Ok")
KeyNavigation.tab: cancelButton
onClicked: {
root.accepted()
root.close()
}
}
echoMode: TextInput.Password MoneroComponents.StandardButton {
focus: true id: cancelButton
Layout.fillWidth: true width: 120
font.family: "Arial" fontSize: 14
font.pixelSize: 24 shadowReleasedColor: "#FF4304"
style: TextFieldStyle { shadowPressedColor: "#B32D00"
passwordCharacter: "•" releasedColor: "#FF6C3C"
pressedColor: "#FF4304"
text: qsTr("Cancel")
KeyNavigation.tab: passwordInput
onClicked: {
root.rejected()
root.close()
}
} }
} }
} }
} }

View file

@ -41,6 +41,7 @@ Item {
property alias text: label.text property alias text: label.text
signal clicked() signal clicked()
Rectangle { Rectangle {
anchors.left: parent.left anchors.left: parent.left
anchors.right: parent.right anchors.right: parent.right
@ -51,6 +52,9 @@ Item {
parent.enabled ? (buttonArea.pressed ? parent.shadowPressedColor : parent.shadowReleasedColor) parent.enabled ? (buttonArea.pressed ? parent.shadowPressedColor : parent.shadowReleasedColor)
: Qt.lighter(parent.shadowReleasedColor) : Qt.lighter(parent.shadowReleasedColor)
} }
border.color: Qt.darker(parent.releasedColor)
border.width: parent.focus ? 1 : 0
} }
Rectangle { Rectangle {
@ -64,6 +68,8 @@ Item {
} }
//radius: 4 //radius: 4
} }
Text { Text {
@ -92,4 +98,7 @@ Item {
anchors.fill: parent anchors.fill: parent
onClicked: parent.clicked() onClicked: parent.clicked()
} }
Keys.onSpacePressed: clicked()
Keys.onReturnPressed: clicked()
} }

View file

@ -546,7 +546,7 @@ ApplicationWindow {
PasswordDialog { PasswordDialog {
id: passwordDialog id: passwordDialog
standardButtons: StandardButton.Ok + StandardButton.Cancel
onAccepted: { onAccepted: {
appWindow.currentWallet = null appWindow.currentWallet = null
appWindow.initialize(); appWindow.initialize();
@ -555,9 +555,7 @@ ApplicationWindow {
//appWindow.enableUI(false) //appWindow.enableUI(false)
rootItem.state = "wizard" rootItem.state = "wizard"
} }
onDiscard: {
appWindow.enableUI(false)
}
} }

View file

@ -61,7 +61,7 @@ Rectangle {
PasswordDialog { PasswordDialog {
id: settingsPasswordDialog id: settingsPasswordDialog
standardButtons: StandardButton.Ok + StandardButton.Cancel
onAccepted: { onAccepted: {
if(appWindow.password === settingsPasswordDialog.password){ if(appWindow.password === settingsPasswordDialog.password){
memoTextInput.text = currentWallet.seed memoTextInput.text = currentWallet.seed
@ -72,9 +72,7 @@ Rectangle {
onRejected: { onRejected: {
} }
onDiscard: {
}
} }