2023-04-07 15:06:41 +00:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQml 2.15
|
2024-10-15 19:26:12 +00:00
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
2020-11-30 21:24:01 +00:00
|
|
|
import QtQuick.Dialogs 1.3
|
2021-10-27 21:27:49 +00:00
|
|
|
|
2024-07-12 09:46:43 +00:00
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
2022-07-14 11:03:36 +00:00
|
|
|
import StatusQ.Core 0.1
|
2024-07-12 09:46:43 +00:00
|
|
|
import StatusQ.Core.Backpressure 0.1
|
2022-09-19 08:40:02 +00:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2022-07-14 11:03:36 +00:00
|
|
|
|
2021-10-27 21:27:49 +00:00
|
|
|
import utils 1.0
|
|
|
|
import shared 1.0
|
2024-10-02 20:47:14 +00:00
|
|
|
import shared.stores 1.0 as SharedStores
|
2021-10-28 20:23:30 +00:00
|
|
|
import shared.views 1.0
|
2021-10-27 21:27:49 +00:00
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.status 1.0
|
|
|
|
import shared.controls 1.0
|
2021-10-28 20:23:30 +00:00
|
|
|
import shared.views.chat 1.0
|
2021-09-28 15:04:06 +00:00
|
|
|
|
2024-05-22 08:13:39 +00:00
|
|
|
import AppLayouts.Chat.stores 1.0
|
|
|
|
import AppLayouts.Profile.stores 1.0
|
|
|
|
|
2021-10-01 15:58:36 +00:00
|
|
|
import "../controls"
|
2023-04-11 21:24:10 +00:00
|
|
|
import "../panels"
|
2021-10-01 15:58:36 +00:00
|
|
|
|
2021-07-22 14:53:19 +00:00
|
|
|
Item {
|
2021-08-02 13:38:03 +00:00
|
|
|
id: root
|
2021-07-22 14:53:19 +00:00
|
|
|
|
2022-07-05 10:12:27 +00:00
|
|
|
property var chatContentModule
|
2024-10-02 20:47:14 +00:00
|
|
|
|
|
|
|
property SharedStores.RootStore sharedRootStore
|
2024-10-22 12:39:42 +00:00
|
|
|
property SharedStores.UtilsStore utilsStore
|
|
|
|
|
2024-05-22 08:13:39 +00:00
|
|
|
property RootStore rootStore
|
|
|
|
property MessageStore messageStore
|
|
|
|
property UsersStore usersStore
|
|
|
|
property ContactsStore contactsStore
|
2022-03-14 19:32:52 +00:00
|
|
|
property string channelEmoji
|
2021-10-21 22:39:53 +00:00
|
|
|
|
2022-04-13 09:59:16 +00:00
|
|
|
property var emojiPopup
|
2022-11-14 20:21:00 +00:00
|
|
|
property var stickersPopup
|
2022-04-13 09:59:16 +00:00
|
|
|
|
2023-05-19 16:07:50 +00:00
|
|
|
property string chatId: ""
|
2021-12-08 21:20:43 +00:00
|
|
|
property bool stickersLoaded: false
|
2020-11-19 18:30:09 +00:00
|
|
|
property alias chatLogView: chatLogView
|
fix(contacts): fix inconsistency when banning or unbanning contact
Fixes #10501
The problem was that didn't have access to the updated contact from status-go after banning or unbanning, so we just changed the banned property, but there is more that gets changed in the backend, like `removed` being set to `true` as well.
With this fix, when you unban someone, you go back to a fresh start, as **non** contact, so you need to send a request again. That was the state you got if you restarted the app, so "re-sync" the state with status-go.
Another issue was on the frontend (QML). When banned, and after restarting to get the right state, the unban button would be disabled and the Add contact request button would show, which is not good. We only want to send requests when unbanned.
2023-05-31 19:09:37 +00:00
|
|
|
property bool isContactBlocked: false
|
2022-02-24 12:15:02 +00:00
|
|
|
property bool isChatBlocked: false
|
2023-04-21 15:05:34 +00:00
|
|
|
property bool isOneToOne: false
|
2021-07-08 15:20:03 +00:00
|
|
|
|
2024-09-17 11:34:24 +00:00
|
|
|
property bool sendViaPersonalChatEnabled
|
|
|
|
|
2021-12-08 21:20:43 +00:00
|
|
|
signal openStickerPackPopup(string stickerPackId)
|
2022-01-12 12:55:26 +00:00
|
|
|
signal showReplyArea(string messageId, string author)
|
2023-01-05 03:14:12 +00:00
|
|
|
signal editModeChanged(bool editModeOn)
|
2021-12-08 21:20:43 +00:00
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
readonly property real scrollY: chatLogView.visibleArea.yPosition * chatLogView.contentHeight
|
|
|
|
readonly property bool isMostRecentMessageInViewport: chatLogView.visibleArea.yPosition >= 0.999 - chatLogView.visibleArea.heightRatio
|
2023-04-21 19:47:04 +00:00
|
|
|
readonly property var chatDetails: chatContentModule && chatContentModule.chatDetails || null
|
2023-12-12 02:16:06 +00:00
|
|
|
readonly property bool keepUnread: messageStore.keepUnread
|
2022-12-05 07:52:41 +00:00
|
|
|
|
2023-04-06 17:39:13 +00:00
|
|
|
readonly property var loadMoreMessagesIfScrollBelowThreshold: Backpressure.oneInTimeQueued(root, 100, function() {
|
2023-01-10 11:40:01 +00:00
|
|
|
if(scrollY < 1000) messageStore.loadMoreMessages()
|
2022-12-20 10:58:50 +00:00
|
|
|
})
|
|
|
|
|
2023-12-12 02:16:06 +00:00
|
|
|
function setKeepUnread(flag: bool) {
|
|
|
|
root.messageStore.setKeepUnread(flag)
|
|
|
|
}
|
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
function markAllMessagesReadIfMostRecentMessageIsInViewport() {
|
2023-12-12 02:16:06 +00:00
|
|
|
if (!isMostRecentMessageInViewport || !chatLogView.visible || keepUnread) {
|
2022-12-05 07:52:41 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-10-02 18:44:32 +00:00
|
|
|
if (chatDetails && chatDetails.active && (chatDetails.hasUnreadMessages || chatDetails.highlight) && !messageStore.loading) {
|
2022-12-05 07:52:41 +00:00
|
|
|
chatContentModule.markAllMessagesRead()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-04 18:48:46 +00:00
|
|
|
function goToMessage(messageIndex) {
|
|
|
|
chatLogView.currentIndex = -1
|
|
|
|
chatLogView.currentIndex = messageIndex
|
|
|
|
}
|
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
onIsMostRecentMessageInViewportChanged: markAllMessagesReadIfMostRecentMessageIsInViewport()
|
|
|
|
}
|
|
|
|
|
2022-01-27 11:28:27 +00:00
|
|
|
Connections {
|
|
|
|
target: root.messageStore.messageModule
|
|
|
|
|
2022-09-22 22:01:29 +00:00
|
|
|
function onMessageSuccessfullySent() {
|
2022-12-05 07:52:41 +00:00
|
|
|
chatLogView.positionViewAtBeginning()
|
2022-01-27 11:28:27 +00:00
|
|
|
}
|
|
|
|
|
2024-06-20 22:46:12 +00:00
|
|
|
function onSendingMessageFailed(error) {
|
|
|
|
sendingMsgFailedPopup.error = error
|
2022-09-22 22:01:29 +00:00
|
|
|
sendingMsgFailedPopup.open()
|
2022-01-27 11:28:27 +00:00
|
|
|
}
|
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
function onScrollToMessage(messageIndex) {
|
2023-04-04 18:48:46 +00:00
|
|
|
d.goToMessage(messageIndex)
|
2022-01-27 12:44:33 +00:00
|
|
|
}
|
2023-04-04 11:01:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: root.messageStore
|
2023-03-24 12:41:33 +00:00
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
function onMessageSearchOngoingChanged() {
|
|
|
|
d.markAllMessagesReadIfMostRecentMessageIsInViewport()
|
2022-01-27 11:28:27 +00:00
|
|
|
}
|
2023-04-04 11:01:30 +00:00
|
|
|
|
2023-04-14 09:32:06 +00:00
|
|
|
function onLoadingChanged() {
|
2023-04-04 11:01:30 +00:00
|
|
|
d.markAllMessagesReadIfMostRecentMessageIsInViewport()
|
|
|
|
}
|
2022-12-05 07:52:41 +00:00
|
|
|
}
|
2022-01-27 11:28:27 +00:00
|
|
|
|
2022-12-05 07:52:41 +00:00
|
|
|
Connections {
|
2022-12-20 15:23:49 +00:00
|
|
|
target: !!d.chatDetails ? d.chatDetails : null
|
2022-12-05 07:52:41 +00:00
|
|
|
|
|
|
|
function onActiveChanged() {
|
2023-12-12 02:16:06 +00:00
|
|
|
d.setKeepUnread(false)
|
2022-12-05 07:52:41 +00:00
|
|
|
d.markAllMessagesReadIfMostRecentMessageIsInViewport()
|
2022-12-20 10:58:50 +00:00
|
|
|
d.loadMoreMessagesIfScrollBelowThreshold()
|
2022-12-05 07:52:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function onHasUnreadMessagesChanged() {
|
2023-01-06 09:17:39 +00:00
|
|
|
if (!d.chatDetails.hasUnreadMessages) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// HACK: we call `addNewMessagesMarker` later because messages model
|
|
|
|
// may not be yet propagated with unread messages when this signal is emitted
|
2023-04-14 09:32:06 +00:00
|
|
|
if (chatLogView.visible && !d.isMostRecentMessageInViewport) {
|
2022-12-05 07:52:41 +00:00
|
|
|
Qt.callLater(() => messageStore.addNewMessagesMarker())
|
|
|
|
}
|
|
|
|
}
|
2022-01-27 11:28:27 +00:00
|
|
|
}
|
|
|
|
|
2022-12-20 10:58:50 +00:00
|
|
|
Connections {
|
|
|
|
target: root.rootStore
|
|
|
|
enabled: d.chatDetails && d.chatDetails.active
|
|
|
|
|
|
|
|
function onLoadingHistoryMessagesInProgressChanged() {
|
|
|
|
if(!root.rootStore.loadingHistoryMessagesInProgress) {
|
|
|
|
d.loadMoreMessagesIfScrollBelowThreshold()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-22 12:00:44 +00:00
|
|
|
Item {
|
|
|
|
id: loadingMessagesIndicator
|
2022-07-05 10:12:27 +00:00
|
|
|
visible: root.rootStore.loadingHistoryMessagesInProgress
|
2021-12-22 12:00:44 +00:00
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
height: visible? 20 : 0
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
Loader {
|
2022-07-05 10:12:27 +00:00
|
|
|
active: root.rootStore.loadingHistoryMessagesInProgress
|
2021-12-22 12:00:44 +00:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
sourceComponent: Component {
|
|
|
|
LoadingAnimation {
|
|
|
|
width: 18
|
|
|
|
height: 18
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-03-24 12:41:33 +00:00
|
|
|
Loader {
|
|
|
|
id: loadingMessagesView
|
|
|
|
|
|
|
|
anchors.top: loadingMessagesIndicator.bottom
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2023-04-14 09:32:06 +00:00
|
|
|
|
|
|
|
active: messageStore.loading
|
|
|
|
visible: active
|
|
|
|
sourceComponent: MessagesLoadingView {
|
2023-03-24 12:41:33 +00:00
|
|
|
anchors.margins: 16
|
|
|
|
anchors.fill: parent
|
2023-04-14 09:32:06 +00:00
|
|
|
}
|
2023-03-24 12:41:33 +00:00
|
|
|
}
|
|
|
|
|
2022-07-14 11:03:36 +00:00
|
|
|
StatusListView {
|
2021-08-02 13:38:03 +00:00
|
|
|
id: chatLogView
|
2023-03-24 12:41:33 +00:00
|
|
|
visible: !loadingMessagesView.visible
|
2022-07-20 12:14:50 +00:00
|
|
|
objectName: "chatLogView"
|
2021-12-22 12:00:44 +00:00
|
|
|
anchors.top: loadingMessagesIndicator.bottom
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2021-12-10 11:29:33 +00:00
|
|
|
spacing: 0
|
2021-08-02 13:38:03 +00:00
|
|
|
verticalLayoutDirection: ListView.BottomToTop
|
2023-04-04 18:48:46 +00:00
|
|
|
cacheBuffer: height > 0 ? height * 2 : 0 // cache 2 screens worth of items
|
2020-09-24 15:05:17 +00:00
|
|
|
|
2023-04-04 18:48:46 +00:00
|
|
|
highlightRangeMode: ListView.ApplyRange
|
|
|
|
highlightMoveDuration: 200
|
|
|
|
preferredHighlightBegin: 0
|
2023-04-21 15:05:34 +00:00
|
|
|
preferredHighlightEnd: chatLogView.height / 2
|
2023-04-11 21:24:10 +00:00
|
|
|
|
2023-04-07 15:06:41 +00:00
|
|
|
Binding on flickDeceleration {
|
|
|
|
when: localAppSettings.isCustomMouseScrollingEnabled
|
|
|
|
value: localAppSettings.scrollDeceleration
|
|
|
|
restoreMode: Binding.RestoreBindingOrValue
|
|
|
|
}
|
|
|
|
|
|
|
|
Binding on maximumFlickVelocity {
|
|
|
|
when: localAppSettings.isCustomMouseScrollingEnabled
|
|
|
|
value: localAppSettings.scrollVelocity
|
|
|
|
restoreMode: Binding.RestoreBindingOrValue
|
|
|
|
}
|
|
|
|
|
2022-07-05 10:12:27 +00:00
|
|
|
model: messageStore.messagesModel
|
|
|
|
|
2023-04-11 21:24:10 +00:00
|
|
|
onContentYChanged: d.loadMoreMessagesIfScrollBelowThreshold()
|
2022-07-05 10:12:27 +00:00
|
|
|
|
2023-04-06 17:39:13 +00:00
|
|
|
onCountChanged: {
|
|
|
|
d.markAllMessagesReadIfMostRecentMessageIsInViewport()
|
|
|
|
|
|
|
|
// after inilial messages are loaded
|
|
|
|
// load as much messages as the view requires
|
2023-04-14 09:32:06 +00:00
|
|
|
if (!messageStore.loading) {
|
2023-04-06 17:39:13 +00:00
|
|
|
d.loadMoreMessagesIfScrollBelowThreshold()
|
|
|
|
}
|
|
|
|
}
|
2022-12-05 07:52:41 +00:00
|
|
|
|
2023-01-06 09:17:39 +00:00
|
|
|
onVisibleChanged: d.markAllMessagesReadIfMostRecentMessageIsInViewport()
|
|
|
|
|
2023-04-04 18:48:46 +00:00
|
|
|
onCurrentItemChanged: {
|
|
|
|
if(currentItem && currentIndex > 0) {
|
|
|
|
currentItem.startMessageFoundAnimation()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-14 11:03:36 +00:00
|
|
|
ScrollBar.vertical: StatusScrollBar {
|
2021-12-22 12:00:44 +00:00
|
|
|
visible: chatLogView.visibleArea.heightRatio < 1
|
|
|
|
}
|
2021-12-09 12:53:40 +00:00
|
|
|
|
2023-04-11 21:24:10 +00:00
|
|
|
ChatAnchorButtonsPanel {
|
2021-12-22 12:00:44 +00:00
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.right: parent.right
|
2024-10-15 19:26:12 +00:00
|
|
|
anchors.rightMargin: Theme.padding
|
2022-12-05 07:52:41 +00:00
|
|
|
|
2023-04-11 21:24:10 +00:00
|
|
|
mentionsCount: d.chatDetails ? d.chatDetails.notificationCount : 0
|
|
|
|
recentMessagesButtonVisible: {
|
|
|
|
chatLogView.contentY // trigger binding on contentY change
|
|
|
|
return chatLogView.contentHeight - (d.scrollY + chatLogView.height) > 400
|
2021-12-22 12:00:44 +00:00
|
|
|
}
|
2022-07-05 10:12:27 +00:00
|
|
|
|
2023-04-11 21:24:10 +00:00
|
|
|
onRecentMessagesButtonClicked: chatLogView.positionViewAtBeginning()
|
|
|
|
onMentionsButtonClicked: {
|
|
|
|
let id = messageStore.firstUnseenMentionMessageId()
|
|
|
|
if (id !== "") {
|
|
|
|
messageStore.jumpToMessage(id)
|
|
|
|
chatContentModule.markMessageRead(id)
|
|
|
|
}
|
2021-12-22 12:00:44 +00:00
|
|
|
}
|
|
|
|
}
|
2020-11-30 21:24:01 +00:00
|
|
|
|
2021-10-01 15:58:36 +00:00
|
|
|
delegate: MessageView {
|
2021-08-02 13:38:03 +00:00
|
|
|
id: msgDelegate
|
2022-07-05 10:12:27 +00:00
|
|
|
|
|
|
|
width: ListView.view.width
|
|
|
|
|
2022-07-21 16:16:25 +00:00
|
|
|
objectName: "chatMessageViewDelegate"
|
2024-10-02 20:47:14 +00:00
|
|
|
|
|
|
|
sharedRootStore: root.sharedRootStore
|
2024-10-22 12:39:42 +00:00
|
|
|
utilsStore: root.utilsStore
|
2022-07-05 10:12:27 +00:00
|
|
|
rootStore: root.rootStore
|
2021-12-09 12:53:40 +00:00
|
|
|
messageStore: root.messageStore
|
2022-02-08 12:08:02 +00:00
|
|
|
usersStore: root.usersStore
|
2022-01-04 12:06:05 +00:00
|
|
|
contactsStore: root.contactsStore
|
2022-03-14 19:32:52 +00:00
|
|
|
channelEmoji: root.channelEmoji
|
2022-04-13 09:59:16 +00:00
|
|
|
emojiPopup: root.emojiPopup
|
2022-11-14 20:21:00 +00:00
|
|
|
stickersPopup: root.stickersPopup
|
2022-07-25 12:43:05 +00:00
|
|
|
chatLogView: ListView.view
|
2023-05-19 16:07:50 +00:00
|
|
|
chatContentModule: root.chatContentModule
|
2022-01-04 12:06:05 +00:00
|
|
|
|
2023-04-28 10:28:19 +00:00
|
|
|
isChatBlocked: root.isChatBlocked
|
2021-12-09 12:53:40 +00:00
|
|
|
|
2024-09-17 11:34:24 +00:00
|
|
|
sendViaPersonalChatEnabled: root.sendViaPersonalChatEnabled
|
|
|
|
|
2023-05-19 16:07:50 +00:00
|
|
|
chatId: root.chatId
|
2021-12-09 12:53:40 +00:00
|
|
|
messageId: model.id
|
2022-02-24 15:04:59 +00:00
|
|
|
communityId: model.communityId
|
2021-12-09 12:53:40 +00:00
|
|
|
responseToMessageWithId: model.responseToMessageWithId
|
|
|
|
senderId: model.senderId
|
|
|
|
senderDisplayName: model.senderDisplayName
|
2022-09-14 07:35:26 +00:00
|
|
|
senderOptionalName: model.senderOptionalName
|
|
|
|
senderIsEnsVerified: model.senderEnsVerified
|
2021-12-09 12:53:40 +00:00
|
|
|
senderIcon: model.senderIcon
|
2023-01-10 11:29:24 +00:00
|
|
|
senderColorHash: model.senderColorHash
|
2022-03-04 21:33:48 +00:00
|
|
|
senderIsAdded: model.senderIsAdded
|
2022-09-30 14:36:49 +00:00
|
|
|
senderTrustStatus: model.senderTrustStatus
|
2021-12-09 12:53:40 +00:00
|
|
|
amISender: model.amISender
|
2022-07-05 10:12:27 +00:00
|
|
|
messageText: model.messageText
|
2023-01-06 20:19:27 +00:00
|
|
|
unparsedText: model.unparsedText
|
2021-12-09 12:53:40 +00:00
|
|
|
messageImage: model.messageImage
|
2023-03-06 09:47:35 +00:00
|
|
|
album: model.albumMessageImages.split(" ")
|
2023-04-05 16:13:41 +00:00
|
|
|
albumCount: model.albumImagesCount
|
2021-12-09 12:53:40 +00:00
|
|
|
messageTimestamp: model.timestamp
|
|
|
|
messageOutgoingStatus: model.outgoingStatus
|
2022-12-08 21:01:08 +00:00
|
|
|
resendError: model.resendError
|
2021-12-09 12:53:40 +00:00
|
|
|
messageContentType: model.contentType
|
|
|
|
pinnedMessage: model.pinned
|
2022-01-05 15:50:03 +00:00
|
|
|
messagePinnedBy: model.pinnedBy
|
2021-12-20 14:21:35 +00:00
|
|
|
reactionsModel: model.reactions
|
2023-12-18 22:34:10 +00:00
|
|
|
emojiReactionsModel: model.emojiReactionsModel
|
2022-01-13 19:25:38 +00:00
|
|
|
sticker: model.sticker
|
|
|
|
stickerPack: model.stickerPack
|
2022-01-17 18:46:46 +00:00
|
|
|
editModeOn: model.editMode
|
2023-01-05 03:14:12 +00:00
|
|
|
onEditModeOnChanged: root.editModeChanged(editModeOn)
|
2022-01-17 18:46:46 +00:00
|
|
|
isEdited: model.isEdited
|
2023-11-22 20:07:38 +00:00
|
|
|
deleted: model.deleted
|
|
|
|
deletedBy: model.deletedBy
|
|
|
|
deletedByContactDisplayName: model.deletedByContactDisplayName
|
|
|
|
deletedByContactIcon: model.deletedByContactIcon
|
|
|
|
deletedByContactColorHash: model.deletedByContactColorHash
|
2023-07-21 23:08:44 +00:00
|
|
|
linkPreviewModel: model.linkPreviewModel
|
2023-08-22 15:46:26 +00:00
|
|
|
links: model.links
|
2022-09-15 07:31:38 +00:00
|
|
|
messageAttachments: model.messageAttachments
|
2022-02-09 00:04:49 +00:00
|
|
|
transactionParams: model.transactionParameters
|
2022-12-19 14:55:44 +00:00
|
|
|
hasMention: model.mentioned
|
2023-01-12 19:23:26 +00:00
|
|
|
quotedMessageText: model.quotedMessageParsedText
|
|
|
|
quotedMessageFrom: model.quotedMessageFrom
|
|
|
|
quotedMessageContentType: model.quotedMessageContentType
|
2023-01-11 21:16:35 +00:00
|
|
|
quotedMessageDeleted: model.quotedMessageDeleted
|
2023-01-10 11:29:24 +00:00
|
|
|
quotedMessageAuthorDetailsName: model.quotedMessageAuthorName
|
|
|
|
quotedMessageAuthorDetailsDisplayName: model.quotedMessageAuthorDisplayName
|
|
|
|
quotedMessageAuthorDetailsThumbnailImage: model.quotedMessageAuthorThumbnailImage
|
|
|
|
quotedMessageAuthorDetailsEnsVerified: model.quotedMessageAuthorEnsVerified
|
|
|
|
quotedMessageAuthorDetailsIsContact: model.quotedMessageAuthorIsContact
|
|
|
|
quotedMessageAuthorDetailsColorHash: model.quotedMessageAuthorColorHash
|
2023-11-22 22:32:50 +00:00
|
|
|
quotedMessageAlbumMessageImages: model.quotedMessageAlbumMessageImages.split(" ")
|
|
|
|
quotedMessageAlbumImagesCount: model.quotedMessageAlbumImagesCount
|
2024-01-05 15:34:20 +00:00
|
|
|
bridgeName: model.bridgeName
|
2023-03-24 12:41:33 +00:00
|
|
|
|
2022-02-25 10:42:32 +00:00
|
|
|
gapFrom: model.gapFrom
|
|
|
|
gapTo: model.gapTo
|
|
|
|
|
2023-01-10 11:29:24 +00:00
|
|
|
// This is possible since we have all data loaded before we load qml.
|
|
|
|
// When we fetch messages to fulfill a gap we have to set them at once.
|
|
|
|
// Also one important thing here is that messages are set in descending order
|
|
|
|
// in terms of `timestamp` of a message, that means a message with the most
|
|
|
|
// recent time is added at index 0.
|
2023-11-22 20:07:38 +00:00
|
|
|
prevMessageIndex: model.prevMsgIndex
|
|
|
|
prevMessageTimestamp: model.prevMsgTimestamp
|
|
|
|
prevMessageSenderId: model.prevMsgSenderId
|
|
|
|
prevMessageContentType: model.prevMsgContentType
|
|
|
|
prevMessageDeleted: model.prevMsgDeleted
|
|
|
|
nextMessageIndex: model.nextMsgIndex
|
|
|
|
nextMessageTimestamp: model.nextMsgTimestamp
|
2022-07-05 10:12:27 +00:00
|
|
|
|
2021-12-08 21:20:43 +00:00
|
|
|
onOpenStickerPackPopup: {
|
|
|
|
root.openStickerPackPopup(stickerPackId);
|
|
|
|
}
|
2022-01-05 15:50:03 +00:00
|
|
|
|
2022-01-12 12:55:26 +00:00
|
|
|
onShowReplyArea: {
|
|
|
|
root.showReplyArea(messageId, author)
|
|
|
|
}
|
|
|
|
|
2022-01-05 15:50:03 +00:00
|
|
|
stickersLoaded: root.stickersLoaded
|
2022-01-17 18:46:46 +00:00
|
|
|
|
|
|
|
onVisibleChanged: {
|
|
|
|
if(!visible && model.editMode)
|
|
|
|
messageStore.setEditModeOff(model.id)
|
|
|
|
}
|
2021-08-02 13:38:03 +00:00
|
|
|
}
|
2023-04-21 15:05:34 +00:00
|
|
|
header: {
|
fix(contacts): fix inconsistency when banning or unbanning contact
Fixes #10501
The problem was that didn't have access to the updated contact from status-go after banning or unbanning, so we just changed the banned property, but there is more that gets changed in the backend, like `removed` being set to `true` as well.
With this fix, when you unban someone, you go back to a fresh start, as **non** contact, so you need to send a request again. That was the state you got if you restarted the app, so "re-sync" the state with status-go.
Another issue was on the frontend (QML). When banned, and after restarting to get the right state, the unban button would be disabled and the Add contact request button would show, which is not good. We only want to send requests when unbanned.
2023-05-31 19:09:37 +00:00
|
|
|
if (!root.isContactBlocked && root.isOneToOne && root.rootStore.oneToOneChatContact) {
|
2023-04-28 10:28:19 +00:00
|
|
|
switch (root.rootStore.oneToOneChatContact.contactRequestState) {
|
2023-04-21 15:05:34 +00:00
|
|
|
case Constants.ContactRequestState.None: // no break
|
|
|
|
case Constants.ContactRequestState.Dismissed:
|
|
|
|
return sendContactRequestComponent
|
|
|
|
case Constants.ContactRequestState.Received:
|
2023-04-26 09:20:17 +00:00
|
|
|
return acceptOrDeclineContactRequestComponent
|
2023-04-21 15:05:34 +00:00
|
|
|
case Constants.ContactRequestState.Sent:
|
|
|
|
return pendingContactRequestComponent
|
|
|
|
default:
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
onHeaderChanged: chatLogView.positionViewAtBeginning()
|
2021-06-30 18:46:26 +00:00
|
|
|
}
|
2021-12-10 16:11:18 +00:00
|
|
|
|
2021-12-22 12:00:44 +00:00
|
|
|
MessageDialog {
|
2024-06-20 22:46:12 +00:00
|
|
|
property string error
|
|
|
|
|
2021-12-22 12:00:44 +00:00
|
|
|
id: sendingMsgFailedPopup
|
|
|
|
standardButtons: StandardButton.Ok
|
2024-06-20 22:46:12 +00:00
|
|
|
text: qsTr("Failed to send message.\n" + error)
|
2021-12-22 12:00:44 +00:00
|
|
|
icon: StandardIcon.Critical
|
|
|
|
}
|
2023-04-21 15:05:34 +00:00
|
|
|
|
|
|
|
Component {
|
|
|
|
id: sendContactRequestComponent
|
|
|
|
|
|
|
|
StatusButton {
|
2023-06-28 20:19:00 +00:00
|
|
|
anchors.horizontalCenter: parent ? parent.horizontalCenter : undefined
|
2023-04-21 15:05:34 +00:00
|
|
|
text: qsTr("Send Contact Request")
|
|
|
|
onClicked: {
|
2024-11-06 20:53:41 +00:00
|
|
|
Global.openContactRequestPopup(root.chatId, null)
|
2023-04-21 15:05:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
2023-04-26 09:20:17 +00:00
|
|
|
id: acceptOrDeclineContactRequestComponent
|
2023-04-21 15:05:34 +00:00
|
|
|
|
2023-04-26 09:20:17 +00:00
|
|
|
RowLayout {
|
2023-06-28 20:19:00 +00:00
|
|
|
anchors.horizontalCenter: parent ? parent.horizontalCenter : undefined
|
2023-04-26 09:20:17 +00:00
|
|
|
|
|
|
|
StatusButton {
|
|
|
|
text: qsTr("Reject Contact Request")
|
|
|
|
type: StatusBaseButton.Type.Danger
|
|
|
|
onClicked: {
|
2023-05-19 16:07:50 +00:00
|
|
|
root.contactsStore.dismissContactRequest(root.chatId, "")
|
2023-04-26 09:20:17 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusButton {
|
|
|
|
text: qsTr("Accept Contact Request")
|
|
|
|
onClicked: {
|
2023-05-19 16:07:50 +00:00
|
|
|
root.contactsStore.acceptContactRequest(root.chatId, "")
|
2023-04-26 09:20:17 +00:00
|
|
|
}
|
2023-04-21 15:05:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: pendingContactRequestComponent
|
|
|
|
|
|
|
|
StatusButton {
|
2023-06-28 20:19:00 +00:00
|
|
|
anchors.horizontalCenter: parent ? parent.horizontalCenter : undefined
|
2023-04-21 15:05:34 +00:00
|
|
|
enabled: false
|
|
|
|
text: qsTr("Contact Request Pending...")
|
|
|
|
}
|
|
|
|
}
|
2020-05-27 22:59:17 +00:00
|
|
|
}
|