2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2020-06-24 13:23:49 +10:00
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2021-10-01 18:58:36 +03:00
|
|
|
|
|
|
|
import "../panels"
|
|
|
|
import "../popups"
|
|
|
|
import "../popups/community"
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2021-06-30 16:17:05 +02:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2021-07-26 15:34:19 +02:00
|
|
|
import StatusQ.Controls 0.1
|
2021-06-30 16:17:05 +02:00
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
|
|
|
Item {
|
2021-10-22 01:39:53 +03:00
|
|
|
id: root
|
2021-07-22 17:53:19 +03:00
|
|
|
width: 304
|
|
|
|
height: parent.height
|
|
|
|
|
2021-11-26 16:37:57 +01:00
|
|
|
// Important:
|
|
|
|
// We're here in case of ChatSection
|
|
|
|
// This module is set from `ChatLayout` (each `ChatLayout` has its own chatSectionModule)
|
|
|
|
property var chatSectionModule
|
|
|
|
|
2021-10-22 01:39:53 +03:00
|
|
|
property var store
|
2022-01-04 13:06:05 +01:00
|
|
|
property var contactsStore
|
2022-03-07 09:56:05 -05:00
|
|
|
property var emojiPopup
|
2022-01-04 13:06:05 +01:00
|
|
|
|
2021-11-26 16:37:57 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
//property int chatGroupsListViewCount: channelList.model.count
|
2021-07-20 18:22:09 +03:00
|
|
|
signal openProfileClicked()
|
2021-11-10 09:09:31 +01:00
|
|
|
signal openAppSearch()
|
2021-06-30 16:17:05 +02:00
|
|
|
|
2021-08-18 16:43:59 +02:00
|
|
|
Component.onCompleted: {
|
|
|
|
appMain.openContactsPopup.connect(function(){
|
2021-12-09 11:25:38 -05:00
|
|
|
Global.openPopup(contactRequestsPopup, {chatSectionModule})
|
2021-08-18 16:43:59 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-07-15 18:50:50 +03:00
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
//steal focus from search field
|
2021-07-26 15:34:19 +02:00
|
|
|
actionButton.forceActiveFocus();
|
2021-07-15 18:50:50 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-30 16:17:05 +02:00
|
|
|
StatusNavigationPanelHeadline {
|
|
|
|
id: headline
|
2020-05-27 14:40:58 -04:00
|
|
|
anchors.top: parent.top
|
2021-06-30 16:17:05 +02:00
|
|
|
anchors.topMargin: 16
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-07-16 22:22:50 +02:00
|
|
|
//% "Chat"
|
|
|
|
text: qsTrId("chat")
|
2021-06-30 16:17:05 +02:00
|
|
|
}
|
|
|
|
|
2022-02-15 23:00:05 +02:00
|
|
|
RowLayout {
|
2021-07-26 15:34:19 +02:00
|
|
|
id: searchInputWrapper
|
|
|
|
width: parent.width
|
|
|
|
height: searchInput.height
|
2022-02-15 23:00:05 +02:00
|
|
|
anchors.top: headline.bottom
|
|
|
|
anchors.topMargin: 16
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 8
|
|
|
|
|
|
|
|
|
|
|
|
StatusBaseInput {
|
|
|
|
id: searchInput
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.alignment: Qt.AlignVCenter | Qt.AlignLeft
|
|
|
|
Layout.leftMargin: 17
|
|
|
|
implicitHeight: 36
|
|
|
|
topPadding: 9
|
|
|
|
//% "Search"
|
|
|
|
placeholderText: qsTrId("search")
|
|
|
|
icon.name: "search"
|
2021-08-16 10:54:20 +02:00
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
2021-11-10 09:09:31 +01:00
|
|
|
onClicked: root.openAppSearch()
|
2021-07-26 15:34:19 +02:00
|
|
|
}
|
2021-07-15 18:50:50 +03:00
|
|
|
}
|
2021-06-30 16:17:05 +02:00
|
|
|
|
2022-02-15 23:00:05 +02:00
|
|
|
StatusIconTabButton {
|
|
|
|
icon.name: "public-chat"
|
|
|
|
onClicked: { publicChatCommunityContextMenu.popup(); }
|
2021-07-26 15:34:19 +02:00
|
|
|
StatusPopupMenu {
|
2022-02-15 23:00:05 +02:00
|
|
|
id: publicChatCommunityContextMenu
|
|
|
|
closePolicy: Popup.CloseOnReleaseOutsideParent | Popup.CloseOnEscape
|
|
|
|
StatusMenuItem {
|
|
|
|
//% "Join public chat"
|
|
|
|
text: qsTrId("new-public-group-chat")
|
|
|
|
icon.name: "public-chat"
|
|
|
|
onTriggered: Global.openPopup(publicChatPopupComponent)
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
//% "Communities"
|
|
|
|
text: qsTrId("communities")
|
|
|
|
icon.name: "communities"
|
|
|
|
onTriggered: Global.openPopup(communitiesPopupComponent)
|
|
|
|
enabled: localAccountSensitiveSettings.communitiesEnabled
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-07-26 15:34:19 +02:00
|
|
|
|
|
|
|
|
2022-02-15 23:00:05 +02:00
|
|
|
StatusIconTabButton {
|
|
|
|
icon.name: "edit"
|
|
|
|
onClicked: {
|
|
|
|
root.store.openCreateChat = !root.store.openCreateChat;
|
2021-07-26 15:34:19 +02:00
|
|
|
}
|
|
|
|
}
|
2021-06-30 16:17:05 +02:00
|
|
|
}
|
|
|
|
|
2022-02-15 23:00:05 +02:00
|
|
|
|
2021-06-30 16:17:05 +02:00
|
|
|
StatusContactRequestsIndicatorListItem {
|
|
|
|
id: contactRequests
|
|
|
|
|
2022-01-04 13:06:05 +01:00
|
|
|
property int nbRequests: root.store.contactRequestsModel.count
|
2021-06-30 16:17:05 +02:00
|
|
|
|
2021-07-26 15:34:19 +02:00
|
|
|
anchors.top: searchInputWrapper.bottom
|
2021-06-30 16:17:05 +02:00
|
|
|
anchors.topMargin: visible ? Style.current.padding : 0
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
|
|
|
visible: nbRequests > 0
|
|
|
|
height: visible ? implicitHeight : 0
|
|
|
|
|
2021-07-16 22:22:50 +02:00
|
|
|
//% "Contact requests"
|
|
|
|
title: qsTrId("contact-requests")
|
2021-06-30 16:17:05 +02:00
|
|
|
requestsCount: nbRequests
|
|
|
|
|
2021-12-07 22:33:12 +02:00
|
|
|
sensor.onClicked: Global.openPopup(contactRequestsPopup)
|
2021-06-30 16:17:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ScrollView {
|
|
|
|
id: chatGroupsContainer
|
|
|
|
|
2021-07-15 18:50:50 +03:00
|
|
|
width: parent.width
|
|
|
|
height: (contentHeight < (parent.height - contactRequests.height - Style.current.padding)) ? contentHeight : (parent.height - contactRequests.height - Style.current.padding)
|
2021-06-30 16:17:05 +02:00
|
|
|
anchors.top: contactRequests.bottom
|
2020-07-15 15:38:03 -04:00
|
|
|
anchors.topMargin: Style.current.padding
|
2021-10-22 01:39:53 +03:00
|
|
|
anchors.bottom: root.bottom
|
2021-08-24 12:58:55 +03:00
|
|
|
contentHeight: channelList.childrenRect.height + emptyViewAndSuggestions.childrenRect.height
|
2020-05-27 14:40:58 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-06-30 16:17:05 +02:00
|
|
|
|
|
|
|
leftPadding: Style.current.halfPadding
|
|
|
|
rightPadding: Style.current.halfPadding
|
|
|
|
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
|
|
|
|
clip: true
|
|
|
|
|
|
|
|
StatusChatList {
|
|
|
|
id: channelList
|
|
|
|
|
2021-11-26 16:37:57 +01:00
|
|
|
model: root.chatSectionModule.model
|
2022-02-15 23:00:05 +02:00
|
|
|
onChatItemSelected: {
|
|
|
|
root.chatSectionModule.setActiveItem(id, "")
|
|
|
|
}
|
2021-12-09 13:53:40 +01:00
|
|
|
onChatItemUnmuted: root.chatSectionModule.unmuteChat(id)
|
2021-06-30 16:17:05 +02:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
popupMenu: ChatContextMenuView {
|
2021-11-03 15:35:12 -04:00
|
|
|
id: chatContextMenuView
|
2022-03-07 09:56:05 -05:00
|
|
|
emojiPopup: root.emojiPopup
|
2021-12-09 13:53:40 +01:00
|
|
|
|
2021-06-30 16:17:05 +02:00
|
|
|
openHandler: function (id) {
|
2021-12-09 13:53:40 +01:00
|
|
|
let jsonObj = root.chatSectionModule.getItemAsJson(id)
|
|
|
|
let obj = JSON.parse(jsonObj)
|
|
|
|
if (obj.error) {
|
|
|
|
console.error("error parsing chat item json object, id: ", id, " error: ", obj.error)
|
|
|
|
close()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-12-21 10:26:13 +01:00
|
|
|
currentFleet = root.chatSectionModule.getCurrentFleet()
|
2021-12-09 13:53:40 +01:00
|
|
|
isCommunityChat = root.chatSectionModule.isCommunity()
|
2022-01-05 16:50:03 +01:00
|
|
|
amIChatAdmin = obj.amIChatAdmin
|
2021-12-09 13:53:40 +01:00
|
|
|
chatId = obj.itemId
|
|
|
|
chatName = obj.name
|
2021-12-21 10:26:13 +01:00
|
|
|
chatDescription = obj.description
|
2022-03-07 09:56:05 -05:00
|
|
|
chatEmoji = obj.emoji
|
2022-03-10 14:28:37 -05:00
|
|
|
chatColor = obj.color
|
2021-12-09 13:53:40 +01:00
|
|
|
chatType = obj.type
|
|
|
|
chatMuted = obj.muted
|
|
|
|
}
|
|
|
|
|
|
|
|
onMuteChat: {
|
2021-12-21 10:26:13 +01:00
|
|
|
root.chatSectionModule.muteChat(chatId)
|
2021-12-09 13:53:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
onUnmuteChat: {
|
2021-12-21 10:26:13 +01:00
|
|
|
root.chatSectionModule.unmuteChat(chatId)
|
2021-06-30 16:17:05 +02:00
|
|
|
}
|
2021-12-08 12:10:34 +01:00
|
|
|
|
|
|
|
onMarkAllMessagesRead: {
|
2021-12-21 10:26:13 +01:00
|
|
|
root.chatSectionModule.markAllMessagesRead(chatId)
|
2021-12-08 12:10:34 +01:00
|
|
|
}
|
2021-12-08 14:06:31 +01:00
|
|
|
|
|
|
|
onClearChatHistory: {
|
2021-12-21 10:26:13 +01:00
|
|
|
root.chatSectionModule.clearChatHistory(chatId)
|
|
|
|
}
|
|
|
|
|
|
|
|
onRequestAllHistoricMessages: {
|
|
|
|
// Not Refactored Yet - Check in the `master` branch if this is applicable here.
|
|
|
|
}
|
|
|
|
|
|
|
|
onLeaveChat: {
|
|
|
|
root.chatSectionModule.leaveChat(chatId)
|
|
|
|
}
|
|
|
|
|
2022-01-25 13:09:27 +01:00
|
|
|
onDeleteCommunityChat: {
|
2021-12-21 10:26:13 +01:00
|
|
|
// Not Refactored Yet
|
|
|
|
}
|
|
|
|
|
|
|
|
onDownloadMessages: {
|
|
|
|
// Not Refactored Yet
|
|
|
|
}
|
|
|
|
|
|
|
|
onDisplayProfilePopup: {
|
2022-01-05 16:50:03 +01:00
|
|
|
Global.openProfilePopup(publicKey)
|
2021-12-21 10:26:13 +01:00
|
|
|
}
|
2022-02-15 23:00:05 +02:00
|
|
|
onLeaveGroup: {
|
|
|
|
chatSectionModule.leaveChat("", chatId, true);
|
|
|
|
}
|
2021-12-21 10:26:13 +01:00
|
|
|
onDisplayGroupInfoPopup: {
|
2022-01-31 16:18:51 +03:00
|
|
|
chatSectionModule.prepareChatContentModuleForChatId(chatId)
|
|
|
|
let chatContentModule = chatSectionModule.getChatContentModule()
|
|
|
|
Global.openPopup(groupInfoPopupComponent, {
|
2022-02-14 15:18:25 +03:00
|
|
|
chatContentModule: chatContentModule,
|
|
|
|
chatDetails: chatContentModule.chatDetails
|
2022-01-31 16:18:51 +03:00
|
|
|
})
|
2021-12-21 10:26:13 +01:00
|
|
|
}
|
2021-06-30 16:17:05 +02:00
|
|
|
}
|
|
|
|
}
|
2021-08-24 12:58:55 +03:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
EmptyViewPanel {
|
2021-08-24 12:58:55 +03:00
|
|
|
id: emptyViewAndSuggestions
|
2021-10-20 11:50:50 +02:00
|
|
|
visible: !localAccountSensitiveSettings.hideChannelSuggestions
|
2021-08-24 12:58:55 +03:00
|
|
|
width: parent.width
|
|
|
|
anchors.top: channelList.bottom
|
|
|
|
anchors.topMargin: Style.current.padding
|
2022-01-28 09:19:49 +01:00
|
|
|
rootStore: root.store
|
2021-12-01 17:47:57 +01:00
|
|
|
onSuggestedMessageClicked: chatSectionModule.createPublicChat(channel)
|
2021-08-24 12:58:55 +03:00
|
|
|
}
|
2020-05-27 14:40:58 -04:00
|
|
|
}
|
2020-05-25 16:34:26 -04:00
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
Component {
|
|
|
|
id: publicChatPopupComponent
|
|
|
|
PublicChatPopup {
|
2021-10-22 23:49:47 +03:00
|
|
|
onJoinPublicChat: {
|
2021-12-01 17:47:57 +01:00
|
|
|
chatSectionModule.createPublicChat(name)
|
2021-10-22 23:49:47 +03:00
|
|
|
}
|
|
|
|
onSuggestedMessageClicked: {
|
2021-12-01 17:47:57 +01:00
|
|
|
chatSectionModule.createPublicChat(channel)
|
2021-10-22 23:49:47 +03:00
|
|
|
}
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
2020-05-27 16:11:56 -04:00
|
|
|
}
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
Component {
|
|
|
|
id: privateChatPopupComponent
|
|
|
|
PrivateChatPopup {
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.store
|
2022-01-04 13:06:05 +01:00
|
|
|
contactsStore: root.contactsStore
|
2021-12-09 11:25:38 -05:00
|
|
|
onJoinPrivateChat: {
|
2022-02-15 23:00:05 +02:00
|
|
|
chatSectionModule.createOneToOneChat("", publicKey, ensName)
|
2021-12-09 11:25:38 -05:00
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
2021-07-20 18:22:09 +03:00
|
|
|
onProfileClicked: {
|
2021-10-22 01:39:53 +03:00
|
|
|
root.openProfileClicked();
|
2021-07-20 18:22:09 +03:00
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: communitiesPopupComponent
|
|
|
|
CommunitiesPopup {
|
2021-07-19 13:21:05 +02:00
|
|
|
anchors.centerIn: parent
|
2022-02-02 18:54:28 +01:00
|
|
|
communitiesList: root.store.communitiesList
|
2022-01-25 15:07:03 -05:00
|
|
|
onSetActiveCommunity: {
|
|
|
|
root.store.setActiveCommunity(id)
|
|
|
|
}
|
|
|
|
onSetObservedCommunity: {
|
|
|
|
root.store.setObservedCommunity(id)
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: createCommunitiesPopupComponent
|
|
|
|
CreateCommunityPopup {
|
2021-07-16 12:11:03 +02:00
|
|
|
anchors.centerIn: parent
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.store
|
2020-12-11 15:29:46 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-18 15:55:33 -05:00
|
|
|
Component {
|
|
|
|
id: importCommunitiesPopupComponent
|
2021-02-12 13:19:31 -05:00
|
|
|
AccessExistingCommunityPopup {
|
2021-10-22 23:49:47 +03:00
|
|
|
anchors.centerIn: parent
|
2022-02-02 18:54:28 +01:00
|
|
|
store: root.store
|
2020-12-18 15:55:33 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
Component {
|
|
|
|
id: communityDetailPopup
|
|
|
|
CommunityDetailPopup {
|
2021-07-19 14:25:52 +02:00
|
|
|
anchors.centerIn: parent
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.store
|
2020-12-11 15:29:46 -05:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
2020-05-28 08:56:43 -04:00
|
|
|
}
|
|
|
|
|
2021-05-26 13:36:24 -04:00
|
|
|
Component {
|
|
|
|
id: contactRequestsPopup
|
|
|
|
ContactRequestsPopup {
|
2021-10-22 23:49:47 +03:00
|
|
|
store: root.store
|
2021-05-26 13:36:24 -04:00
|
|
|
onClosed: {
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-07-08 15:19:34 -04:00
|
|
|
|
2022-02-02 18:54:28 +01:00
|
|
|
Connections {
|
|
|
|
target: root.store.communitiesModuleInst
|
|
|
|
onImportingCommunityStateChanged: {
|
|
|
|
if (state !== Constants.communityImported &&
|
|
|
|
state !== Constants.communityImportingInProgress &&
|
|
|
|
state !== Constants.communityImportingError)
|
|
|
|
{
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
Global.toastMessage.close()
|
|
|
|
|
|
|
|
if (state === Constants.communityImported)
|
|
|
|
{
|
|
|
|
//% "Community imported"
|
|
|
|
Global.toastMessage.title = qsTrId("community-imported")
|
|
|
|
Global.toastMessage.source = ""
|
|
|
|
Global.toastMessage.iconRotates = false
|
|
|
|
Global.toastMessage.dissapearInMs = 4000
|
|
|
|
}
|
|
|
|
else if (state === Constants.communityImportingInProgress)
|
|
|
|
{
|
|
|
|
//% "Importing community is in progress"
|
|
|
|
Global.toastMessage.title = qsTrId("importing-community-is-in-progress")
|
|
|
|
Global.toastMessage.source = Style.svg("loading")
|
|
|
|
Global.toastMessage.iconRotates = true
|
|
|
|
Global.toastMessage.dissapearInMs = -1
|
|
|
|
}
|
|
|
|
else if (state === Constants.communityImportingError)
|
|
|
|
{
|
|
|
|
Global.toastMessage.title = errorMsg
|
|
|
|
Global.toastMessage.source = ""
|
|
|
|
Global.toastMessage.iconRotates = false
|
|
|
|
Global.toastMessage.dissapearInMs = 4000
|
|
|
|
}
|
|
|
|
|
|
|
|
Global.toastMessage.displayCloseButton = false
|
|
|
|
Global.toastMessage.displayLink = false
|
|
|
|
Global.toastMessage.iconColor = Style.current.primary
|
|
|
|
Global.toastMessage.open()
|
|
|
|
}
|
|
|
|
}
|
2022-02-09 18:35:59 +01:00
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: root.store.mainModuleInst
|
|
|
|
|
|
|
|
onOpenContactRequestsPopup:{
|
|
|
|
Global.openPopup(contactRequestsPopup)
|
|
|
|
}
|
|
|
|
}
|
2020-07-08 15:19:34 -04:00
|
|
|
}
|