2022-03-28 16:42:26 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
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 {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property var contactsStore
|
|
|
|
|
|
|
|
header.title: qsTr("Send Contact Request to chat key")
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
2022-05-27 11:57:18 +03:00
|
|
|
|
2022-03-28 16:42:26 +02:00
|
|
|
readonly property int maxMsgLength: 280
|
2022-05-27 11:57:18 +03:00
|
|
|
readonly property int minMsgLength: 1
|
2022-03-28 16:42:26 +02:00
|
|
|
readonly property int msgHeight: 152
|
2022-05-27 11:57:18 +03:00
|
|
|
readonly property int contentSpacing: 5
|
|
|
|
readonly property int contentMargins: 16
|
2022-03-28 16:42:26 +02:00
|
|
|
|
|
|
|
property int minChatKeyLength: 4 // ens or chat key
|
|
|
|
property string realChatKey: ""
|
|
|
|
property string elidedChatKey: realChatKey.length > 32?
|
|
|
|
realChatKey.substring(0, 15) + "..." + realChatKey.substring(realChatKey.length - 16) :
|
|
|
|
realChatKey
|
|
|
|
|
|
|
|
property bool validChatKey: false
|
|
|
|
property bool showPasteButton: true
|
|
|
|
property bool showChatKeyValidationIndicator: false
|
|
|
|
property int showChatKeyValidationIndicatorSize: 24
|
|
|
|
|
|
|
|
property var lookupContact: Backpressure.debounce(root, 400, function (value) {
|
|
|
|
root.contactsStore.resolveENS(value)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: contactsStore.mainModuleInst
|
|
|
|
onResolvedENS: {
|
|
|
|
if(!d.showChatKeyValidationIndicator){
|
|
|
|
d.showPasteButton = false
|
|
|
|
d.showChatKeyValidationIndicator = true
|
|
|
|
}
|
|
|
|
d.validChatKey = resolvedPubKey !== ""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: chatKeyValidationIndicator
|
|
|
|
Item {
|
|
|
|
implicitWidth: d.showChatKeyValidationIndicatorSize
|
|
|
|
implicitHeight: d.showChatKeyValidationIndicatorSize
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
StatusIcon {
|
|
|
|
anchors.fill: parent
|
|
|
|
icon: d.validChatKey? "checkmark-circle" : "close-circle"
|
|
|
|
color: d.validChatKey? Style.current.success : Style.current.danger
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: pasteButtonComponent
|
|
|
|
StatusButton {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2022-09-13 09:37:09 +02:00
|
|
|
borderColor: Theme.palette.primaryColor1
|
2022-03-28 16:42:26 +02:00
|
|
|
size: StatusBaseButton.Size.Tiny
|
|
|
|
text: qsTr("Paste")
|
|
|
|
onClicked: {
|
|
|
|
d.realChatKey = root.contactsStore.getFromClipboard()
|
|
|
|
d.showPasteButton = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-06 18:42:12 +03:00
|
|
|
contentItem: Item {
|
|
|
|
Column {
|
|
|
|
id: content
|
2022-05-27 11:57:18 +03:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.margins: d.contentMargins
|
2022-06-06 18:42:12 +03:00
|
|
|
spacing: d.contentSpacing
|
|
|
|
|
|
|
|
StatusInput {
|
|
|
|
id: chatKeyInput
|
|
|
|
|
2022-07-22 13:28:04 +03:00
|
|
|
placeholderText: qsTr("Enter chat key here")
|
2022-06-06 18:42:12 +03:00
|
|
|
input.text: input.edit.focus? d.realChatKey : d.elidedChatKey
|
|
|
|
input.rightComponent: {
|
|
|
|
if(d.showPasteButton)
|
|
|
|
return pasteButtonComponent
|
|
|
|
else if(d.showChatKeyValidationIndicator)
|
|
|
|
return chatKeyValidationIndicator
|
|
|
|
else
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
input.onTextChanged: {
|
|
|
|
if(input.edit.focus)
|
|
|
|
{
|
|
|
|
d.realChatKey = text
|
|
|
|
|
|
|
|
if(d.realChatKey === "") {
|
|
|
|
d.showPasteButton = true
|
|
|
|
d.showChatKeyValidationIndicator = false
|
|
|
|
}
|
|
|
|
|
|
|
|
if (text.length < d.minChatKeyLength) {
|
|
|
|
d.validChatKey = false
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
Qt.callLater(d.lookupContact, text);
|
2022-03-28 16:42:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-06 18:42:12 +03:00
|
|
|
StatusInput {
|
|
|
|
id: messageInput
|
|
|
|
charLimit: d.maxMsgLength
|
2022-03-28 16:42:26 +02:00
|
|
|
|
2022-07-22 13:28:04 +03:00
|
|
|
placeholderText: qsTr("Say who you are / why you want to become a contact...")
|
2022-06-06 18:42:12 +03:00
|
|
|
input.multiline: true
|
2022-07-26 12:49:28 +03:00
|
|
|
minimumHeight: d.msgHeight
|
|
|
|
maximumHeight: d.msgHeight
|
2022-06-06 18:42:12 +03:00
|
|
|
input.verticalAlignment: TextEdit.AlignTop
|
2022-03-28 16:42:26 +02:00
|
|
|
|
2022-06-06 18:42:12 +03:00
|
|
|
validators: [StatusMinLengthValidator {
|
|
|
|
minLength: d.minMsgLength
|
|
|
|
errorMessage: Utils.getErrorMessage(messageInput.errors, qsTr("who are you"))
|
|
|
|
}]
|
|
|
|
}
|
2022-03-28 16:42:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rightButtons: [
|
|
|
|
StatusButton {
|
|
|
|
id: btnCreateEdit
|
|
|
|
enabled: d.validChatKey && messageInput.valid
|
|
|
|
text: qsTr("Send Contact Request")
|
|
|
|
onClicked: {
|
2022-05-27 11:57:18 +03:00
|
|
|
root.contactsStore.sendContactRequest(d.realChatKey, messageInput.text)
|
2022-03-28 16:42:26 +02:00
|
|
|
root.close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|