status-desktop/ui/imports/shared/popups/NicknamePopup.qml

86 lines
2.3 KiB
QML
Raw Normal View History

import QtQuick 2.14
import utils 1.0
import shared.controls 1.0
import StatusQ 0.1
import StatusQ.Core 0.1
import StatusQ.Core.Theme 0.1
import StatusQ.Controls 0.1
import StatusQ.Controls.Validators 0.1
import StatusQ.Popups 0.1
StatusModal {
2020-09-16 12:00:21 -04:00
id: popup
width: 400
height: 340
anchors.centerIn: parent
header.title: qsTr("Nickname")
2022-09-27 23:26:26 +02:00
header.subTitleElide: Text.ElideMiddle
/*required*/ property string publicKey
property string nickname
2020-09-16 12:00:21 -04:00
readonly property int nicknameLength: nicknameInput.text.length
readonly property int maxNicknameLength: 32
signal editDone(string newNickname)
onOpened: {
2022-09-27 23:26:26 +02:00
nicknameInput.input.edit.forceActiveFocus()
}
contentItem: Item {
width: popup.width
height: childrenRect.height
2020-09-16 12:00:21 -04:00
Column {
anchors.top: parent.top
anchors.topMargin: 16
anchors.horizontalCenter: parent.horizontalCenter
width: parent.width - 32
spacing: 16
StatusBaseText {
id: descriptionText
text: qsTr("Nicknames help you identify others in Status. Only you can see the nicknames youve added")
wrapMode: Text.WordWrap
color: Theme.palette.baseColor1
width: parent.width
}
2020-09-16 12:00:21 -04:00
StatusInput {
id: nicknameInput
placeholderText: qsTr("Nickname")
2022-09-27 23:26:26 +02:00
input.clearable: true
width: parent.width
2022-09-27 23:26:26 +02:00
text: popup.nickname
charLimit: maxNicknameLength
validationMode: StatusInput.ValidationMode.IgnoreInvalidInput
validators: [
StatusValidator {
validatorObj: RXValidator { regularExpression: /^[\w\d_ -]*$/u }
validate: (value) => validatorObj.test(value)
}
]
Keys.onReleased: {
if (event.key === Qt.Key_Return) {
editDone(nicknameInput.text)
}
}
}
}
2020-09-16 12:00:21 -04:00
}
rightButtons: [
StatusButton {
id: doneBtn
text: qsTr("Done")
enabled: nicknameInput.valid
onClicked: editDone(nicknameInput.text)
2020-09-16 12:00:21 -04:00
}
]
2020-09-16 12:00:21 -04:00
}