2020-06-17 15:18:31 -04:00
|
|
|
|
import QtQuick 2.13
|
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
|
import QtQuick.Layouts 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
2021-10-26 16:21:08 +02:00
|
|
|
|
import StatusQ.Components 0.1
|
2021-10-25 21:37:44 +02:00
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
|
import utils 1.0
|
2021-10-26 16:21:08 +02:00
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
|
import shared.views 1.0
|
|
|
|
|
import shared.panels 1.0
|
|
|
|
|
import shared.popups 1.0
|
|
|
|
|
import shared.controls 1.0
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
2021-12-31 13:29:51 +01:00
|
|
|
|
import "../stores"
|
2021-10-06 11:16:39 +02:00
|
|
|
|
import "../panels"
|
|
|
|
|
import "../popups"
|
2020-05-27 17:28:25 -04:00
|
|
|
|
|
|
|
|
|
Item {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
id: root
|
|
|
|
|
|
2021-12-31 13:29:51 +01:00
|
|
|
|
property ContactsStore contactsStore
|
2021-12-09 14:28:02 +01:00
|
|
|
|
property int profileContentWidth
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
2020-07-24 13:27:26 +02:00
|
|
|
|
property alias searchStr: searchBox.text
|
2020-09-17 10:47:14 +02:00
|
|
|
|
property bool isPending: false
|
2021-01-14 15:09:07 -05:00
|
|
|
|
height: parent.height
|
|
|
|
|
Layout.fillWidth: true
|
2021-04-08 11:44:58 -04:00
|
|
|
|
clip: true
|
2020-05-27 17:28:25 -04:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
Item {
|
2020-05-27 17:28:25 -04:00
|
|
|
|
anchors.top: parent.top
|
2020-07-21 17:03:22 -04:00
|
|
|
|
anchors.topMargin: 32
|
2021-01-14 15:09:07 -05:00
|
|
|
|
anchors.bottom: parent.bottom
|
2021-12-09 14:28:02 +01:00
|
|
|
|
width: profileContentWidth
|
2021-04-08 11:44:58 -04:00
|
|
|
|
|
2021-03-18 10:33:39 +01:00
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-07-21 17:03:22 -04:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
SearchBox {
|
|
|
|
|
id: searchBox
|
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
fontPixelSize: 15
|
2020-07-21 17:03:22 -04:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
Item {
|
|
|
|
|
id: addNewContact
|
|
|
|
|
anchors.top: searchBox.bottom
|
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
|
|
|
|
width: addButton.width + usernameText.width + Style.current.padding
|
|
|
|
|
height: addButton.height
|
2020-07-21 17:03:22 -04:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
|
|
|
|
|
StatusRoundButton {
|
|
|
|
|
id: addButton
|
2021-10-25 21:37:44 +02:00
|
|
|
|
width: 40
|
|
|
|
|
height: 40
|
|
|
|
|
icon.name: "add"
|
|
|
|
|
type: StatusRoundButton.Type.Secondary
|
2021-01-14 15:09:07 -05:00
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2020-07-21 17:03:22 -04:00
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
StyledText {
|
|
|
|
|
id: usernameText
|
|
|
|
|
//% "Add new contact"
|
|
|
|
|
text: qsTrId("add-new-contact")
|
|
|
|
|
color: Style.current.blue
|
|
|
|
|
anchors.left: addButton.right
|
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
|
anchors.verticalCenter: addButton.verticalCenter
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
MouseArea {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
|
onClicked: {
|
|
|
|
|
addContactModal.open()
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
Item {
|
|
|
|
|
id: blockedContactsButton
|
|
|
|
|
anchors.top: addNewContact.bottom
|
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2021-09-17 17:08:16 +02:00
|
|
|
|
width: parent.width
|
2021-12-31 13:29:51 +01:00
|
|
|
|
visible: root.contactsStore.blockedContactsModel.count > 0
|
2021-09-17 17:08:16 +02:00
|
|
|
|
height: 64
|
2021-01-14 15:09:07 -05:00
|
|
|
|
|
|
|
|
|
StatusRoundButton {
|
|
|
|
|
id: blockButton
|
|
|
|
|
width: 40
|
|
|
|
|
height: 40
|
2021-10-25 21:37:44 +02:00
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
icon.name: "cancel"
|
|
|
|
|
icon.color: Theme.palette.primaryColor1
|
2020-07-21 17:03:22 -04:00
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
StyledText {
|
|
|
|
|
id: blockButtonLabel
|
|
|
|
|
//% "Blocked contacts"
|
|
|
|
|
text: qsTrId("blocked-contacts")
|
|
|
|
|
color: Style.current.blue
|
|
|
|
|
anchors.left: blockButton.right
|
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
|
anchors.verticalCenter: blockButton.verticalCenter
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
}
|
2020-07-21 17:03:22 -04:00
|
|
|
|
|
2021-09-17 17:08:16 +02:00
|
|
|
|
StyledText {
|
|
|
|
|
id: numberOfBlockedContacts
|
2021-12-31 13:29:51 +01:00
|
|
|
|
text: root.contactsStore.blockedContactsModel.count
|
2021-09-17 17:08:16 +02:00
|
|
|
|
color: Style.current.darkGrey
|
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
|
anchors.verticalCenter: blockButton.verticalCenter
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
MouseArea {
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
|
onClicked: {
|
|
|
|
|
blockedContactsModal.open()
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-21 17:03:22 -04:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
ModalPopup {
|
|
|
|
|
id: blockedContactsModal
|
|
|
|
|
//% "Blocked contacts"
|
|
|
|
|
title: qsTrId("blocked-contacts")
|
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
ContactsListPanel {
|
2021-01-14 15:09:07 -05:00
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
anchors.bottom: parent.bottom
|
2021-12-31 13:29:51 +01:00
|
|
|
|
contactsModel: root.contactsStore.blockedContactsModel
|
|
|
|
|
|
|
|
|
|
onOpenProfilePopup: {
|
|
|
|
|
Global.openProfilePopup(contact.pubKey)
|
|
|
|
|
}
|
2021-10-21 15:13:13 -04:00
|
|
|
|
|
|
|
|
|
onRemoveContactActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
removeContactConfirmationDialog.value = contact.pubKey
|
2021-10-21 15:13:13 -04:00
|
|
|
|
removeContactConfirmationDialog.open()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onUnblockContactActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.unblockContact(contact.pubKey)
|
2021-10-21 15:13:13 -04:00
|
|
|
|
}
|
2021-01-14 15:09:07 -05:00
|
|
|
|
}
|
2020-09-17 10:47:14 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
Component {
|
|
|
|
|
id: loadingIndicator
|
2021-04-26 12:25:01 +02:00
|
|
|
|
StatusLoadingIndicator {
|
2021-01-14 15:09:07 -05:00
|
|
|
|
width: 12
|
|
|
|
|
height: 12
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-21 17:03:22 -04:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
ModalPopup {
|
|
|
|
|
id: addContactModal
|
|
|
|
|
//% "Add contact"
|
|
|
|
|
title: qsTrId("add-contact")
|
2021-03-22 15:51:17 +01:00
|
|
|
|
property string validationError: ""
|
|
|
|
|
|
|
|
|
|
function validate(value) {
|
|
|
|
|
if (!Utils.isChatKey(value) && !Utils.isValidETHNamePrefix(value)) {
|
2021-09-17 09:48:09 +10:00
|
|
|
|
addContactModal.validationError = qsTr("Enter a valid chat key or ENS username");
|
2021-12-31 13:29:51 +01:00
|
|
|
|
} else if (root.contactsStore.myPublicKey === value) {
|
2021-07-16 22:22:50 +02:00
|
|
|
|
//% "You can't add yourself"
|
|
|
|
|
addContactModal.validationError = qsTrId("you-can-t-add-yourself");
|
2021-03-22 15:51:17 +01:00
|
|
|
|
} else {
|
2021-07-13 19:05:44 +03:00
|
|
|
|
addContactModal.validationError = "";
|
2021-03-22 15:51:17 +01:00
|
|
|
|
}
|
2021-07-13 19:05:44 +03:00
|
|
|
|
return addContactModal.validationError === "";
|
2021-03-22 15:51:17 +01:00
|
|
|
|
}
|
2020-09-17 10:47:14 +02:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
property var lookupContact: Backpressure.debounce(addContactSearchInput, 400, function (value) {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
root.isPending = true
|
2021-03-22 15:51:17 +01:00
|
|
|
|
searchResults.showProfileNotFoundMessage = false
|
2022-01-04 13:06:05 +01:00
|
|
|
|
root.contactsStore.resolveENS(value)
|
2021-01-14 15:09:07 -05:00
|
|
|
|
})
|
2020-11-19 15:23:16 -04:00
|
|
|
|
|
2021-01-14 15:09:07 -05:00
|
|
|
|
onOpened: {
|
|
|
|
|
addContactSearchInput.text = ""
|
2021-03-22 15:51:17 +01:00
|
|
|
|
searchResults.reset()
|
2021-11-01 12:04:00 -04:00
|
|
|
|
addContactSearchInput.forceActiveFocus()
|
2020-09-17 10:47:14 +02:00
|
|
|
|
}
|
2021-01-14 15:09:07 -05:00
|
|
|
|
|
|
|
|
|
Input {
|
|
|
|
|
id: addContactSearchInput
|
|
|
|
|
//% "Enter ENS username or chat key"
|
|
|
|
|
placeholderText: qsTrId("enter-contact-code")
|
|
|
|
|
customHeight: 44
|
|
|
|
|
fontPixelSize: 15
|
2021-07-29 11:54:00 +02:00
|
|
|
|
onTextEdited: {
|
|
|
|
|
if (addContactSearchInput.text === "") {
|
|
|
|
|
searchResults.reset();
|
|
|
|
|
return;
|
2021-07-13 19:05:44 +03:00
|
|
|
|
}
|
2021-07-29 11:54:00 +02:00
|
|
|
|
if (!addContactModal.validate(addContactSearchInput.text)) {
|
|
|
|
|
searchResults.reset();
|
2021-10-06 11:16:39 +02:00
|
|
|
|
root.isPending = false;
|
2021-07-29 11:54:00 +02:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Qt.callLater(addContactModal.lookupContact, addContactSearchInput.text);
|
2020-09-17 10:47:14 +02:00
|
|
|
|
}
|
2021-01-14 15:09:07 -05:00
|
|
|
|
|
2020-09-17 10:47:14 +02:00
|
|
|
|
|
2021-02-08 16:03:09 -04:00
|
|
|
|
Connections {
|
2022-01-04 13:06:05 +01:00
|
|
|
|
target: root.contactsStore.mainModuleInst
|
|
|
|
|
onResolvedENS: function (resolvedPubKey) {
|
2021-03-22 15:51:17 +01:00
|
|
|
|
if (resolvedPubKey === "") {
|
|
|
|
|
searchResults.pubKey = ""
|
|
|
|
|
searchResults.showProfileNotFoundMessage = true
|
2021-10-06 11:16:39 +02:00
|
|
|
|
root.isPending = false
|
2021-03-22 15:51:17 +01:00
|
|
|
|
return
|
2021-02-08 16:03:09 -04:00
|
|
|
|
}
|
2021-12-31 13:29:51 +01:00
|
|
|
|
searchResults.username = Utils.isChatKey(addContactSearchInput.text) ? root.contactsStore.generateAlias(resolvedPubKey) : Utils.addStatusEns(addContactSearchInput.text.trim())
|
2021-03-22 15:51:17 +01:00
|
|
|
|
searchResults.userAlias = Utils.compactAddress(resolvedPubKey, 4)
|
|
|
|
|
searchResults.pubKey = resolvedPubKey
|
|
|
|
|
searchResults.showProfileNotFoundMessage = false
|
2021-10-06 11:16:39 +02:00
|
|
|
|
root.isPending = false
|
2021-02-08 16:03:09 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-03-22 15:51:17 +01:00
|
|
|
|
}
|
2021-02-08 16:03:09 -04:00
|
|
|
|
|
2021-03-22 15:51:17 +01:00
|
|
|
|
StyledText {
|
|
|
|
|
id: validationErrorMessage
|
|
|
|
|
text: addContactModal.validationError
|
|
|
|
|
visible: addContactModal.validationError !== ""
|
|
|
|
|
font.pixelSize: 13
|
|
|
|
|
color: Style.current.danger
|
|
|
|
|
anchors.top: addContactSearchInput.bottom
|
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-01-14 15:09:07 -05:00
|
|
|
|
}
|
2021-03-22 15:51:17 +01:00
|
|
|
|
|
2021-03-31 15:14:09 -04:00
|
|
|
|
SearchResults {
|
2021-03-22 15:51:17 +01:00
|
|
|
|
id: searchResults
|
|
|
|
|
anchors.top: addContactSearchInput.bottom
|
|
|
|
|
anchors.topMargin: Style.current.xlPadding
|
2021-10-06 11:16:39 +02:00
|
|
|
|
loading: root.isPending
|
2021-03-22 15:51:17 +01:00
|
|
|
|
resultClickable: false
|
2021-12-31 13:29:51 +01:00
|
|
|
|
onAddToContactsButtonClicked: root.contactsStore.addContact(pubKey)
|
2021-01-14 15:09:07 -05:00
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
}
|
2021-01-14 15:09:07 -05:00
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
ContactsListPanel {
|
2021-01-14 15:09:07 -05:00
|
|
|
|
id: contactListView
|
2021-09-17 17:08:16 +02:00
|
|
|
|
anchors.top: blockedContactsButton.visible ? blockedContactsButton.bottom : addNewContact.bottom
|
2021-01-14 15:09:07 -05:00
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2020-07-24 13:27:26 +02:00
|
|
|
|
anchors.bottom: parent.bottom
|
2021-12-31 13:29:51 +01:00
|
|
|
|
contactsModel: root.contactsStore.myContactsModel
|
2021-08-09 13:11:04 +02:00
|
|
|
|
hideBlocked: true
|
2021-01-14 15:09:07 -05:00
|
|
|
|
searchString: searchBox.text
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
2021-11-11 17:09:38 +01:00
|
|
|
|
// To show the correct status (added/not added)in the addContactModal.
|
|
|
|
|
onCountChanged: searchResults.isAddedContact = searchResults.isContactAdded()
|
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
onContactClicked: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.joinPrivateChat(contact.pubKey)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onOpenProfilePopup: {
|
|
|
|
|
Global.openProfilePopup(contact.pubKey)
|
2021-10-06 11:16:39 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onSendMessageActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.joinPrivateChat(contact.pubKey)
|
2021-10-06 11:16:39 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onBlockContactActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
blockContactConfirmationDialog.contactName = contact.name
|
|
|
|
|
blockContactConfirmationDialog.contactAddress = contact.pubKey
|
2021-10-06 11:16:39 +02:00
|
|
|
|
blockContactConfirmationDialog.open()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onRemoveContactActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
removeContactConfirmationDialog.value = contact.pubKey
|
2021-10-06 11:16:39 +02:00
|
|
|
|
removeContactConfirmationDialog.open()
|
|
|
|
|
}
|
2021-10-21 15:13:13 -04:00
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
onUnblockContactActionTriggered: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.unblockContact(contact.pubKey)
|
2021-10-06 11:16:39 +02:00
|
|
|
|
}
|
2020-07-24 13:27:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-01 13:06:21 +01:00
|
|
|
|
NoFriendsRectangle {
|
2021-01-14 15:09:07 -05:00
|
|
|
|
id: element
|
2021-12-31 13:29:51 +01:00
|
|
|
|
visible: root.contactsStore.myContactsModel.count === 0
|
2021-02-18 11:36:05 -05:00
|
|
|
|
//% "You don’t have any contacts yet"
|
|
|
|
|
text: qsTrId("you-don-t-have-any-contacts-yet")
|
2021-01-26 18:25:39 +01:00
|
|
|
|
width: parent.width
|
2021-02-01 13:06:21 +01:00
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2020-07-24 13:27:26 +02:00
|
|
|
|
}
|
2020-05-27 17:28:25 -04:00
|
|
|
|
}
|
2020-06-16 14:04:56 -04:00
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
// TODO: Make BlockContactConfirmationDialog a dynamic component on a future refactor
|
|
|
|
|
BlockContactConfirmationDialog {
|
|
|
|
|
id: blockContactConfirmationDialog
|
|
|
|
|
onBlockButtonClicked: {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.blockContact(blockContactConfirmationDialog.contactAddress)
|
2021-10-06 11:16:39 +02:00
|
|
|
|
blockContactConfirmationDialog.close()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: Make ConfirmationDialog a dynamic component on a future refactor
|
|
|
|
|
ConfirmationDialog {
|
|
|
|
|
id: removeContactConfirmationDialog
|
|
|
|
|
//% "Remove contact"
|
|
|
|
|
header.title: qsTrId("remove-contact")
|
|
|
|
|
//% "Are you sure you want to remove this contact?"
|
|
|
|
|
confirmationText: qsTrId("are-you-sure-you-want-to-remove-this-contact-")
|
|
|
|
|
onConfirmButtonClicked: {
|
2022-01-04 13:06:05 +01:00
|
|
|
|
if (Utils.getContactDetailsAsJson(removeContactConfirmationDialog.value).isContact) {
|
2021-12-31 13:29:51 +01:00
|
|
|
|
root.contactsStore.removeContact(removeContactConfirmationDialog.value);
|
2021-10-06 11:16:39 +02:00
|
|
|
|
}
|
|
|
|
|
removeContactConfirmationDialog.close()
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-06-16 14:04:56 -04:00
|
|
|
|
}
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|