2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
2021-08-06 17:31:42 +02:00
|
|
|
import Qt.labs.platform 1.1
|
2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2021-04-28 11:30:41 -04:00
|
|
|
import QtGraphicalEffects 1.0
|
2021-12-09 13:53:40 +01:00
|
|
|
import Qt.labs.qmlmodels 1.0
|
2021-07-06 11:42:51 +02:00
|
|
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.status 1.0
|
|
|
|
import shared.controls 1.0
|
2021-10-28 23:23:30 +03:00
|
|
|
import shared.views.chat 1.0
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
import "../helpers"
|
|
|
|
import "../controls"
|
|
|
|
import "../popups"
|
|
|
|
import "../panels"
|
|
|
|
import "../../Wallet"
|
2021-07-16 18:02:47 +03:00
|
|
|
|
|
|
|
Item {
|
2021-10-22 01:39:53 +03:00
|
|
|
id: root
|
2021-07-22 17:53:19 +03:00
|
|
|
anchors.fill: parent
|
2021-12-01 17:47:57 +01:00
|
|
|
|
|
|
|
// Important: we have parent module in this context only cause qml components
|
2021-12-09 13:53:40 +01:00
|
|
|
// don't follow struct we have on the backend.
|
2021-12-01 17:47:57 +01:00
|
|
|
property var parentModule
|
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
property var rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
property var contactsStore
|
|
|
|
|
2021-12-21 10:26:13 +01:00
|
|
|
property Component pinnedMessagesPopupComponent
|
2021-11-26 16:37:57 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
//property int chatGroupsListViewCount: 0
|
2020-07-09 13:47:36 -04:00
|
|
|
property bool isReply: false
|
2020-07-20 13:04:33 -04:00
|
|
|
property bool isImage: false
|
|
|
|
property bool isExtendedInput: isReply || isImage
|
2020-07-15 12:19:25 -04:00
|
|
|
property bool isConnected: false
|
2020-08-10 15:06:46 +02:00
|
|
|
property string contactToRemove: ""
|
2021-12-16 15:02:58 -05:00
|
|
|
property string activeChatId: parentModule && parentModule.activeItem.id
|
|
|
|
property string activeSubItemId: parentModule && parentModule.activeItem.activeSubItem.id
|
|
|
|
property string activeChatType: parentModule && parentModule.activeItem.type
|
2021-05-26 13:36:24 -04:00
|
|
|
property string currentNotificationChatId
|
|
|
|
property string currentNotificationCommunityId
|
2021-07-16 18:02:47 +03:00
|
|
|
property var currentTime: 0
|
|
|
|
property var idMap: ({})
|
2021-12-08 23:20:43 +02:00
|
|
|
property bool stickersLoaded: false
|
2021-07-16 18:02:47 +03:00
|
|
|
property Timer timer: Timer { }
|
2021-07-22 17:53:19 +03:00
|
|
|
property var userList
|
2021-09-21 14:26:32 +02:00
|
|
|
|
2022-01-12 00:16:17 +01:00
|
|
|
property var contactDetails: Utils.getContactDetailsAsJson(root.activeChatId)
|
|
|
|
property bool isBlocked: root.contactDetails.isBlocked
|
|
|
|
property bool isContact: root.contactDetails.isContact
|
2022-01-04 13:06:05 +01:00
|
|
|
property bool contactRequestReceived: root.contactDetails.requestReceived
|
|
|
|
|
2021-11-10 09:09:31 +01:00
|
|
|
signal openAppSearch()
|
2021-12-08 23:20:43 +02:00
|
|
|
signal openStickerPackPopup(string stickerPackId)
|
2021-11-10 09:09:31 +01:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// function hideChatInputExtendedArea () {
|
|
|
|
// if(stackLayoutChatMessages.currentIndex >= 0 && stackLayoutChatMessages.currentIndex < stackLayoutChatMessages.children.length)
|
|
|
|
// stackLayoutChatMessages.children[stackLayoutChatMessages.currentIndex].chatInput.hideExtendedArea()
|
|
|
|
// }
|
2021-05-25 15:38:18 -04:00
|
|
|
|
2020-09-23 12:13:39 -04:00
|
|
|
function showReplyArea() {
|
2020-07-20 13:04:33 -04:00
|
|
|
isReply = true;
|
|
|
|
isImage = false;
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// let replyMessageIndex = root.rootStore.chatsModelInst.messageView.messageList.getMessageIndex(SelectedMessage.messageId);
|
|
|
|
// if (replyMessageIndex === -1) return;
|
|
|
|
// let userName = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "userName")
|
|
|
|
// let message = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "message")
|
|
|
|
// let identicon = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "identicon")
|
|
|
|
// let image = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "image")
|
|
|
|
// let sticker = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "sticker")
|
|
|
|
// let contentType = root.rootStore.chatsModelInst.messageView.messageList.getMessageData(replyMessageIndex, "contentType")
|
2020-09-29 11:06:57 +02:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// if(stackLayoutChatMessages.currentIndex >= 0 && stackLayoutChatMessages.currentIndex < stackLayoutChatMessages.children.length)
|
|
|
|
// stackLayoutChatMessages.children[stackLayoutChatMessages.currentIndex].chatInput.showReplyArea(userName, message, identicon, contentType, image, sticker)
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
|
|
|
|
2020-09-29 11:06:57 +02:00
|
|
|
function requestAddressForTransaction(address, amount, tokenAddress, tokenDecimals = 18) {
|
2021-12-14 17:11:31 +01:00
|
|
|
amount = globalUtils.eth2Wei(amount.toString(), tokenDecimals)
|
2021-12-23 15:46:58 -05:00
|
|
|
|
|
|
|
parentModule.prepareChatContentModuleForChatId(activeChatId)
|
|
|
|
let chatContentModule = parentModule.getChatContentModule()
|
|
|
|
chatContentModule.inputAreaModule.requestAddress(address,
|
|
|
|
amount,
|
|
|
|
tokenAddress)
|
2020-11-03 21:29:56 +11:00
|
|
|
txModalLoader.close()
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
2020-09-29 11:06:57 +02:00
|
|
|
function requestTransaction(address, amount, tokenAddress, tokenDecimals = 18) {
|
2021-12-23 15:46:58 -05:00
|
|
|
amount = globalUtils.eth2Wei(amount.toString(), tokenDecimals)
|
|
|
|
|
|
|
|
|
|
|
|
parentModule.prepareChatContentModuleForChatId(activeChatId)
|
|
|
|
let chatContentModule = parentModule.getChatContentModule()
|
|
|
|
chatContentModule.inputAreaModule.request(address,
|
|
|
|
amount,
|
|
|
|
tokenAddress)
|
2020-07-20 13:04:33 -04:00
|
|
|
}
|
2020-09-29 11:06:57 +02:00
|
|
|
|
2021-05-26 13:36:24 -04:00
|
|
|
function clickOnNotification() {
|
2021-07-09 09:49:08 +02:00
|
|
|
// So far we're just showing this app as the top most window. Once we decide about the way
|
|
|
|
// how to notify the app what channle should be displayed within the app when user clicks
|
|
|
|
// notificaiton bubble this part should be updated accordingly.
|
|
|
|
//
|
|
|
|
// I removed part of this function which caused app crash.
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.applicationWindow.show()
|
|
|
|
Global.applicationWindow.raise()
|
|
|
|
Global.applicationWindow.requestActivate()
|
2021-05-26 13:36:24 -04:00
|
|
|
}
|
|
|
|
|
2021-09-24 17:04:49 +03:00
|
|
|
function positionAtMessage(messageId, isSearch = false) {
|
2021-12-09 13:53:40 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// stackLayoutChatMessages.children[stackLayoutChatMessages.currentIndex].message.scrollToMessage(messageId, isSearch);
|
2021-05-26 13:36:24 -04:00
|
|
|
}
|
|
|
|
|
2021-04-07 14:26:03 -04:00
|
|
|
Timer {
|
2021-07-16 18:02:47 +03:00
|
|
|
interval: 60000; // 1 min
|
|
|
|
running: true
|
|
|
|
repeat: true
|
|
|
|
triggeredOnStart: true
|
|
|
|
onTriggered: {
|
2021-10-22 01:39:53 +03:00
|
|
|
root.currentTime = Date.now()
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
2021-04-07 14:26:03 -04:00
|
|
|
}
|
2021-06-10 15:20:43 -04:00
|
|
|
|
2021-12-08 23:20:43 +02:00
|
|
|
MessageContextMenuView {
|
|
|
|
id: contextmenu
|
|
|
|
reactionModel: root.rootStore.emojiReactionsModel
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusImageModal {
|
|
|
|
id: imagePopup
|
|
|
|
onClicked: {
|
|
|
|
if (button === Qt.LeftButton) {
|
|
|
|
imagePopup.close()
|
|
|
|
} else if(button === Qt.RightButton) {
|
|
|
|
contextmenu.imageSource = imagePopup.imageSource
|
|
|
|
contextmenu.hideEmojiPicker = true
|
|
|
|
contextmenu.isRightClickOnImage = true;
|
|
|
|
contextmenu.show()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Connections {
|
|
|
|
target: Global
|
|
|
|
onOpenImagePopup: {
|
|
|
|
imagePopup.openPopup(image);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
StackLayout {
|
|
|
|
anchors.fill: parent
|
2021-12-09 13:53:40 +01:00
|
|
|
currentIndex: {
|
2021-12-16 15:02:58 -05:00
|
|
|
if(root.activeChatId !== "")
|
2021-12-09 13:53:40 +01:00
|
|
|
{
|
|
|
|
for(let i = 1; i < this.children.length; i++)
|
|
|
|
{
|
|
|
|
var obj = this.children[i];
|
|
|
|
if(obj && obj.chatContentModule)
|
|
|
|
{
|
|
|
|
let myChatId = obj.chatContentModule.getMyChatId()
|
2021-12-16 15:02:58 -05:00
|
|
|
if(myChatId === root.activeChatId || myChatId === root.activeSubItemId)
|
2021-12-09 13:53:40 +01:00
|
|
|
return i
|
2021-12-08 23:20:43 +02:00
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
2021-07-06 11:42:51 +02:00
|
|
|
}
|
|
|
|
}
|
2020-07-15 12:19:25 -04:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
return 0
|
|
|
|
}
|
2021-06-21 15:35:32 -04:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
EmptyChatPanel {
|
2021-12-31 13:29:51 +01:00
|
|
|
onShareChatKeyClicked: Global.openProfilePopup(userProfile.pubKey);
|
2021-12-09 13:53:40 +01:00
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
// This is kind of a solution for applying backend refactored changes with the minimal qml changes.
|
|
|
|
// The best would be if we made qml to follow the struct we have on the backend side.
|
|
|
|
Repeater {
|
2021-12-16 15:02:58 -05:00
|
|
|
model: parentModule && parentModule.model
|
2021-12-09 13:53:40 +01:00
|
|
|
delegate: delegateChooser
|
|
|
|
|
|
|
|
DelegateChooser {
|
|
|
|
id: delegateChooser
|
|
|
|
role: "type"
|
|
|
|
DelegateChoice { // In case of category
|
|
|
|
roleValue: Constants.chatType.unknown
|
|
|
|
delegate: Repeater {
|
2022-01-05 13:18:55 -05:00
|
|
|
model: {
|
|
|
|
if (!subItems) {
|
|
|
|
console.error("We got a category with no subitems. It is possible that the channel had a type unknown")
|
|
|
|
}
|
|
|
|
return subItems
|
|
|
|
}
|
2021-12-09 13:53:40 +01:00
|
|
|
delegate: ChatContentView {
|
2021-12-22 09:55:13 -05:00
|
|
|
rootStore: root.rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-12-23 15:46:58 -05:00
|
|
|
sendTransactionNoEnsModal: cmpSendTransactionNoEns
|
|
|
|
receiveTransactionModal: cmpReceiveTransaction
|
|
|
|
sendTransactionWithEnsModal: cmpSendTransactionWithEns
|
2022-01-05 16:50:03 +01:00
|
|
|
stickersLoaded: root.stickersLoaded
|
2021-12-09 13:53:40 +01:00
|
|
|
Component.onCompleted: {
|
|
|
|
parentModule.prepareChatContentModuleForChatId(model.itemId)
|
|
|
|
chatContentModule = parentModule.getChatContentModule()
|
2021-09-21 14:26:32 +02:00
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
2021-12-09 13:53:40 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
DelegateChoice { // In all other cases
|
|
|
|
delegate: ChatContentView {
|
2021-12-22 09:55:13 -05:00
|
|
|
rootStore: root.rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-12-23 15:46:58 -05:00
|
|
|
sendTransactionNoEnsModal: cmpSendTransactionNoEns
|
|
|
|
receiveTransactionModal: cmpReceiveTransaction
|
|
|
|
sendTransactionWithEnsModal: cmpSendTransactionWithEns
|
2022-01-05 16:50:03 +01:00
|
|
|
stickersLoaded: root.stickersLoaded
|
2021-12-09 13:53:40 +01:00
|
|
|
Component.onCompleted: {
|
|
|
|
parentModule.prepareChatContentModuleForChatId(itemId)
|
|
|
|
chatContentModule = parentModule.getChatContentModule()
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-09-21 14:26:32 +02:00
|
|
|
}
|
2021-12-09 13:53:40 +01:00
|
|
|
}
|
|
|
|
}
|
2021-08-09 13:11:04 +02:00
|
|
|
|
2021-12-09 13:53:40 +01:00
|
|
|
ChatRequestMessagePanel {
|
|
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignBottom
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.bottomMargin: Style.current.bigPadding
|
|
|
|
isContact: root.isContact
|
2021-12-16 15:02:58 -05:00
|
|
|
visible: root.activeChatType === Constants.chatType.oneToOne
|
|
|
|
&& (!root.isContact /*|| !contactRequestReceived*/)
|
2021-12-09 13:53:40 +01:00
|
|
|
onAddContactClicked: {
|
2021-12-16 15:02:58 -05:00
|
|
|
root.rootStore.addContact(root.activeChatId);
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
2021-12-01 17:47:57 +01:00
|
|
|
}
|
2021-05-18 13:17:04 -04:00
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
Component {
|
|
|
|
id: cmpSendTransactionNoEns
|
|
|
|
ChatCommandModal {
|
|
|
|
id: sendTransactionNoEns
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-12-08 23:20:43 +02:00
|
|
|
isContact: root.isContact
|
2021-07-16 18:02:47 +03:00
|
|
|
onClosed: {
|
2021-12-23 15:46:58 -05:00
|
|
|
destroy()
|
2021-05-18 13:17:04 -04:00
|
|
|
}
|
2021-10-22 01:39:53 +03:00
|
|
|
sendChatCommand: root.requestAddressForTransaction
|
2021-07-16 18:02:47 +03:00
|
|
|
isRequested: false
|
|
|
|
//% "Send"
|
|
|
|
commandTitle: qsTrId("command-button-send")
|
2021-10-18 12:55:07 +02:00
|
|
|
header.title: commandTitle
|
2021-07-16 18:02:47 +03:00
|
|
|
//% "Request Address"
|
|
|
|
finalButtonLabel: qsTrId("request-address")
|
|
|
|
selectRecipient.selectedRecipient: {
|
2021-12-23 15:46:58 -05:00
|
|
|
parentModule.prepareChatContentModuleForChatId(activeChatId)
|
|
|
|
let chatContentModule = parentModule.getChatContentModule()
|
2021-07-16 18:02:47 +03:00
|
|
|
return {
|
|
|
|
address: Constants.zeroAddress, // Setting as zero address since we don't have the address yet
|
2021-12-23 15:46:58 -05:00
|
|
|
alias: chatContentModule.chatDetails.name, // Do we need the alias for real or name works?
|
|
|
|
identicon: chatContentModule.chatDetails.icon,
|
|
|
|
name: chatContentModule.chatDetails.name,
|
2021-07-16 18:02:47 +03:00
|
|
|
type: RecipientSelector.Type.Contact
|
2021-05-18 13:17:04 -04:00
|
|
|
}
|
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
|
|
|
selectRecipient.readOnly: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: cmpReceiveTransaction
|
|
|
|
ChatCommandModal {
|
|
|
|
id: receiveTransaction
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-12-08 23:20:43 +02:00
|
|
|
isContact: root.isContact
|
2021-07-16 18:02:47 +03:00
|
|
|
onClosed: {
|
2021-12-23 15:46:58 -05:00
|
|
|
destroy()
|
2021-05-18 13:17:04 -04:00
|
|
|
}
|
2021-10-22 01:39:53 +03:00
|
|
|
sendChatCommand: root.requestTransaction
|
2021-07-16 18:02:47 +03:00
|
|
|
isRequested: true
|
|
|
|
//% "Request"
|
|
|
|
commandTitle: qsTrId("wallet-request")
|
2021-10-18 12:55:07 +02:00
|
|
|
header.title: commandTitle
|
2021-07-16 18:02:47 +03:00
|
|
|
//% "Request"
|
|
|
|
finalButtonLabel: qsTrId("wallet-request")
|
|
|
|
selectRecipient.selectedRecipient: {
|
2021-12-23 15:46:58 -05:00
|
|
|
parentModule.prepareChatContentModuleForChatId(activeChatId)
|
|
|
|
let chatContentModule = parentModule.getChatContentModule()
|
2021-07-16 18:02:47 +03:00
|
|
|
return {
|
|
|
|
address: Constants.zeroAddress, // Setting as zero address since we don't have the address yet
|
2021-12-23 15:46:58 -05:00
|
|
|
alias: chatContentModule.chatDetails.name, // Do we need the alias for real or name works?
|
|
|
|
identicon: chatContentModule.chatDetails.icon,
|
|
|
|
name: chatContentModule.chatDetails.name,
|
2021-07-16 18:02:47 +03:00
|
|
|
type: RecipientSelector.Type.Contact
|
2021-05-18 13:17:04 -04:00
|
|
|
}
|
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
|
|
|
selectRecipient.readOnly: true
|
2021-05-18 13:17:04 -04:00
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
Component {
|
|
|
|
id: cmpSendTransactionWithEns
|
|
|
|
SendModal {
|
|
|
|
id: sendTransactionWithEns
|
2021-12-23 15:46:58 -05:00
|
|
|
store: root.rootStore
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-07-16 18:02:47 +03:00
|
|
|
onOpened: {
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// root.rootStore.walletModelInst.gasView.getGasPrice()
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
|
|
|
onClosed: {
|
2021-12-23 15:46:58 -05:00
|
|
|
destroy()
|
2021-07-16 18:02:47 +03:00
|
|
|
}
|
2021-12-08 23:20:43 +02:00
|
|
|
isContact: root.isContact
|
2021-07-16 18:02:47 +03:00
|
|
|
selectRecipient.readOnly: true
|
|
|
|
selectRecipient.selectedRecipient: {
|
2021-12-23 15:46:58 -05:00
|
|
|
parentModule.prepareChatContentModuleForChatId(activeChatId)
|
|
|
|
let chatContentModule = parentModule.getChatContentModule()
|
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
return {
|
|
|
|
address: "",
|
2021-12-23 15:46:58 -05:00
|
|
|
alias: chatContentModule.chatDetails.name, // Do we need the alias for real or name works?
|
|
|
|
identicon: chatContentModule.chatDetails.icon,
|
|
|
|
name: chatContentModule.chatDetails.name,
|
2021-07-16 18:02:47 +03:00
|
|
|
type: RecipientSelector.Type.Contact,
|
|
|
|
ensVerified: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
selectRecipient.selectedType: RecipientSelector.Type.Contact
|
2020-11-03 21:29:56 +11:00
|
|
|
}
|
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
ActivityCenterPopup {
|
2021-07-16 18:02:47 +03:00
|
|
|
id: activityCenter
|
2021-12-09 13:53:40 +01:00
|
|
|
height: root.height - 56 * 2 // TODO get screen size // Taken from old code top bar height was fixed there to 56
|
|
|
|
y: 56
|
2021-10-22 01:39:53 +03:00
|
|
|
store: root.rootStore
|
2020-11-03 21:29:56 +11:00
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// Connections {
|
|
|
|
// target: root.rootStore.chatsModelInst.channelView
|
|
|
|
// onActiveChannelChanged: {
|
|
|
|
// root.rootStore.chatsModelInst.messageView.hideLoadingIndicator()
|
|
|
|
// SelectedMessage.reset();
|
|
|
|
// chatColumn.isReply = false;
|
|
|
|
// }
|
|
|
|
// }
|
2021-07-16 18:02:47 +03:00
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: systemTray
|
|
|
|
onMessageClicked: function () {
|
|
|
|
clickOnNotification()
|
2020-10-28 18:44:09 +11:00
|
|
|
}
|
|
|
|
}
|
2021-07-06 11:42:51 +02:00
|
|
|
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// Connections {
|
|
|
|
// target: root.rootStore.chatsModelInst.messageView
|
|
|
|
|
|
|
|
// onSearchedMessageLoaded: {
|
|
|
|
// positionAtMessage(messageId, true);
|
|
|
|
// }
|
|
|
|
|
|
|
|
// onMessageNotificationPushed: function(messageId, communityId, chatId, msg, contentType, chatType, timestamp, identicon, username, hasMention, isAddedContact, channelName) {
|
|
|
|
// if (localAccountSensitiveSettings.notificationSetting == Constants.notifyAllMessages ||
|
|
|
|
// (localAccountSensitiveSettings.notificationSetting == Constants.notifyJustMentions && hasMention)) {
|
|
|
|
// if (chatId === root.rootStore.chatsModelInst.channelView.activeChannel.id && applicationWindow.active === true) {
|
|
|
|
// // Do not show the notif if we are in the channel already and the window is active and focused
|
|
|
|
// return
|
|
|
|
// }
|
|
|
|
|
|
|
|
// root.currentNotificationChatId = chatId
|
|
|
|
// root.currentNotificationCommunityId = null
|
|
|
|
|
|
|
|
// let name;
|
|
|
|
// if (localAccountSensitiveSettings.notificationMessagePreviewSetting === Constants.notificationPreviewAnonymous) {
|
|
|
|
// name = "Status"
|
|
|
|
// } else if (chatType === Constants.chatType.publicChat) {
|
|
|
|
// name = chatId
|
|
|
|
// } else {
|
|
|
|
// name = chatType === Constants.chatType.privateGroupChat ? Utils.filterXSS(channelName) : Utils.removeStatusEns(username)
|
|
|
|
// }
|
|
|
|
|
|
|
|
// let message;
|
|
|
|
// if (localAccountSensitiveSettings.notificationMessagePreviewSetting > Constants.notificationPreviewNameOnly) {
|
|
|
|
// switch(contentType){
|
|
|
|
// //% "Image"
|
|
|
|
// case Constants.messageContentType.imageType: message = qsTrId("image"); break
|
|
|
|
// //% "Sticker"
|
|
|
|
// case Constants.messageContentType.stickerType: message = qsTrId("sticker"); break
|
|
|
|
// default: message = msg // don't parse emojis here as it emits HTML
|
|
|
|
// }
|
|
|
|
// } else {
|
|
|
|
// //% "You have a new message"
|
|
|
|
// message = qsTrId("you-have-a-new-message")
|
|
|
|
// }
|
|
|
|
|
|
|
|
// currentlyHasANotification = true
|
|
|
|
|
|
|
|
// if (Qt.platform.os === "linux") {
|
|
|
|
// // Linux Notifications are not implemented in Nim/C++ yet
|
|
|
|
// return systemTray.showMessage(name, message, systemTray.icon.source, 4000)
|
|
|
|
// }
|
|
|
|
|
|
|
|
// // Note:
|
|
|
|
// // Show notification should be moved to the nim side.
|
|
|
|
// // Left here only cause we don't have a way to deal with translations on the nim side.
|
|
|
|
// root.rootStore.chatsModelInst.showOSNotification(name,
|
|
|
|
// message,
|
|
|
|
// Constants.osNotificationType.newMessage,
|
|
|
|
// communityId,
|
|
|
|
// chatId,
|
|
|
|
// messageId,
|
|
|
|
// localAccountSensitiveSettings.useOSNotifications)
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
2021-07-27 10:04:05 -04:00
|
|
|
|
2021-12-13 15:24:21 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
// Connections {
|
|
|
|
// target: root.rootStore.chatsModelInst.stickers
|
|
|
|
// onTransactionWasSent: {
|
|
|
|
// //% "Transaction pending..."
|
|
|
|
// toastMessage.title = qsTr("Transaction pending...")
|
|
|
|
// toastMessage.source = Style.svg("loading")
|
|
|
|
// toastMessage.iconColor = Style.current.primary
|
|
|
|
// toastMessage.iconRotates = true
|
|
|
|
// toastMessage.link = `${walletModel.utilsView.etherscanLink}/${txResult}`
|
|
|
|
// toastMessage.open()
|
|
|
|
// }
|
|
|
|
// onTransactionCompleted: {
|
|
|
|
// toastMessage.title = !success ?
|
|
|
|
// //% "Could not buy Stickerpack"
|
|
|
|
// qsTrId("could-not-buy-stickerpack")
|
|
|
|
// :
|
|
|
|
// //% "Stickerpack bought successfully"
|
|
|
|
// qsTrId("stickerpack-bought-successfully");
|
|
|
|
// if (success) {
|
|
|
|
// toastMessage.source = Style.svg("check-circle")
|
|
|
|
// toastMessage.iconColor = Style.current.success
|
|
|
|
// } else {
|
|
|
|
// toastMessage.source = Style.svg("block-icon")
|
|
|
|
// toastMessage.iconColor = Style.current.danger
|
|
|
|
// }
|
|
|
|
|
|
|
|
// toastMessage.link = `${walletModel.utilsView.etherscanLink}/${txHash}`
|
|
|
|
// toastMessage.open()
|
|
|
|
// }
|
|
|
|
// }
|
2020-05-25 16:34:26 -04:00
|
|
|
}
|