mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-26 06:21:15 +00:00
b3f8af8e06
Qml code referring to the old code base commented out, but not deleted, due to easier refactoring the rest of the app.
442 lines
17 KiB
QML
442 lines
17 KiB
QML
import QtQuick 2.13
|
||
import QtQuick.Controls 2.13
|
||
import QtQuick.Dialogs 1.2
|
||
import QtGraphicalEffects 1.13
|
||
import QtQuick.Layouts 1.13
|
||
|
||
import StatusQ.Components 0.1
|
||
import StatusQ.Popups 0.1
|
||
|
||
|
||
import utils 1.0
|
||
import shared 1.0
|
||
import shared.popups 1.0
|
||
import shared.status 1.0
|
||
import "../popups/community"
|
||
import "../panels/communities"
|
||
|
||
Item {
|
||
id: root
|
||
width: 304
|
||
height: parent.height
|
||
|
||
// Important:
|
||
// We're here in case of CommunitySection
|
||
// This module is set from `ChatLayout` (each `ChatLayout` has its own communitySectionModule)
|
||
property var communitySectionModule
|
||
|
||
property var store
|
||
// TODO unhardcode
|
||
// Not Refactored Yet
|
||
//property int chatGroupsListViewCount: communityChatListAndCategories.chatList.count
|
||
property Component pinnedMessagesPopupComponent
|
||
|
||
StatusChatInfoToolBar {
|
||
id: communityHeader
|
||
anchors.top: parent.top
|
||
anchors.horizontalCenter: parent.horizontalCenter
|
||
|
||
// Not Refactored Yet
|
||
// chatInfoButton.title: root.store.chatsModelInst.communities.activeCommunity.name
|
||
// chatInfoButton.subTitle: root.store.chatsModelInst.communities.activeCommunity.nbMembers === 1 ?
|
||
// //% "1 Member"
|
||
// qsTrId("1-member") :
|
||
// //% "%1 Members"
|
||
// qsTrId("-1-members").arg(root.store.chatsModelInst.communities.activeCommunity.nbMembers)
|
||
// chatInfoButton.image.source: root.store.chatsModelInst.communities.activeCommunity.thumbnailImage
|
||
// chatInfoButton.icon.color: root.store.chatsModelInst.communities.activeCommunity.communityColor
|
||
// menuButton.visible: root.store.chatsModelInst.communities.activeCommunity.admin && root.store.chatsModelInst.communities.activeCommunity.canManageUsers
|
||
// chatInfoButton.onClicked: Global.openPopup(communityProfilePopup, {
|
||
// store: root.store,
|
||
// community: root.store.chatsModelInst.communities.activeCommunity
|
||
// })
|
||
|
||
popupMenu: StatusPopupMenu {
|
||
StatusMenuItem {
|
||
//% "Create channel"
|
||
text: qsTrId("create-channel")
|
||
icon.name: "channel"
|
||
// Not Refactored Yet
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
// onTriggered: Global.openPopup(createChannelPopup, {communityId: chatsModel.communities.activeCommunity.id})
|
||
}
|
||
|
||
StatusMenuItem {
|
||
//% "Create category"
|
||
text: qsTrId("create-category")
|
||
icon.name: "channel-category"
|
||
// Not Refactored Yet
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
// onTriggered: Global.openPopup(createCategoryPopup, {communityId: chatsModel.communities.activeCommunity.id})
|
||
}
|
||
|
||
StatusMenuSeparator {}
|
||
|
||
StatusMenuItem {
|
||
//% "Invite people"
|
||
text: qsTrId("invite-people")
|
||
icon.name: "share-ios"
|
||
// Not Refactored Yet
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.canManageUsers
|
||
// onTriggered: Global.openPopup(inviteFriendsToCommunityPopup, {
|
||
// community: root.store.chatsModelInst.communities.activeCommunity
|
||
// })
|
||
}
|
||
}
|
||
}
|
||
Loader {
|
||
id: membershipRequests
|
||
|
||
// Not Refactored Yet
|
||
property int nbRequests: 0
|
||
//property int nbRequests: root.store.chatsModelInst.communities.activeCommunity.communityMembershipRequests.nbRequests
|
||
|
||
anchors.top: communityHeader.bottom
|
||
anchors.topMargin: active ? 8 : 0
|
||
anchors.horizontalCenter: parent.horizontalCenter
|
||
|
||
// Not Refactored Yet
|
||
active: nbRequests > 0
|
||
//active: root.store.chatsModelInst.communities.activeCommunity.admin && nbRequests > 0
|
||
height: nbRequests > 0 ? 64 : 0
|
||
sourceComponent: Component {
|
||
StatusContactRequestsIndicatorListItem {
|
||
//% "Membership requests"
|
||
title: qsTrId("membership-requests")
|
||
requestsCount: membershipRequests.nbRequests
|
||
sensor.onClicked: Global.openPopup(membershipRequestPopup)
|
||
}
|
||
}
|
||
}
|
||
|
||
ScrollView {
|
||
id: chatGroupsContainer
|
||
anchors.top: membershipRequests.bottom
|
||
anchors.topMargin: Style.current.padding
|
||
anchors.bottom: parent.bottom
|
||
anchors.horizontalCenter: parent.horizontalCenter
|
||
|
||
width: parent.width
|
||
|
||
leftPadding: Style.current.halfPadding
|
||
rightPadding: Style.current.halfPadding
|
||
|
||
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
||
clip: true
|
||
contentHeight: communityChatListAndCategories.height
|
||
+ emptyViewAndSuggestionsLoader.height
|
||
+ backUpBannerLoader.height
|
||
+ 16
|
||
|
||
StatusChatListAndCategories {
|
||
id: communityChatListAndCategories
|
||
|
||
anchors.horizontalCenter: parent.horizontalCenter
|
||
width: root.width
|
||
height: {
|
||
if (!emptyViewAndSuggestionsLoader.active &&
|
||
!backUpBannerLoader.active) {
|
||
return implicitHeight > (root.height - 82) ? implicitHeight + 8 : root.height - 82
|
||
}
|
||
return implicitHeight
|
||
}
|
||
|
||
// draggableItems: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
// draggableCategories: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
//chatList.model: root.store.chatsModelInst.communities.activeCommunity.chats
|
||
|
||
//categoryList.model: root.store.chatsModelInst.communities.activeCommunity.categories
|
||
model: root.communitySectionModule.model
|
||
onChatItemSelected: {
|
||
if(categoryId === "")
|
||
root.communitySectionModule.setActiveItem(id, "")
|
||
else
|
||
root.communitySectionModule.setActiveItem(categoryId, id)
|
||
}
|
||
|
||
// showCategoryActionButtons: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
// showPopupMenu: root.store.chatsModelInst.communities.activeCommunity.admin && chatsModel.communities.activeCommunity.canManageUsers
|
||
//selectedChatId: root.store.chatsModelInst.channelView.activeChannel.id
|
||
|
||
// onChatItemSelected: root.store.chatsModelInst.channelView.setActiveChannel(id)
|
||
// onChatItemUnmuted: root.store.chatsModelInst.channelView.unmuteChatItem(id)
|
||
// onChatItemReordered: function (categoryId, id, from, to) {
|
||
// root.store.chatsModelInst.communities.reorderCommunityChannel(chatsModel.communities.activeCommunity.id, categoryId, id, to);
|
||
// }
|
||
// onChatListCategoryReordered: function (categoryId, from, to) {
|
||
// root.store.chatsModelInst.communities.reorderCommunityCategories(chatsModel.communities.activeCommunity.id, categoryId, to);
|
||
// }
|
||
|
||
// onCategoryAddButtonClicked: Global.openPopup(createChannelPopup, {
|
||
// communityId: root.store.chatsModelInst.communities.activeCommunity.id,
|
||
// categoryId: id
|
||
// })
|
||
|
||
popupMenu: StatusPopupMenu {
|
||
StatusMenuItem {
|
||
//% "Create channel"
|
||
text: qsTrId("create-channel")
|
||
icon.name: "channel"
|
||
// Not Refactored Yet
|
||
// enabled: chatsModel.communities.activeCommunity.admin
|
||
// onTriggered: Global.openPopup(createChannelPopup, {communityId: root.store.chatsModelInst.communities.activeCommunity.id})
|
||
}
|
||
|
||
StatusMenuItem {
|
||
//% "Create category"
|
||
text: qsTrId("create-category")
|
||
icon.name: "channel-category"
|
||
// Not Refactored Yet
|
||
enabled: false
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
// onTriggered: Global.openPopup(createCategoryPopup, {communityId: root.store.chatsModelInst.communities.activeCommunity.id})
|
||
}
|
||
|
||
StatusMenuSeparator {}
|
||
|
||
StatusMenuItem {
|
||
//% "Invite people"
|
||
text: qsTrId("invite-people")
|
||
icon.name: "share-ios"
|
||
// Not Refactored Yet
|
||
enabled: false
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.canManageUsers
|
||
// onTriggered: Global.openPopup(inviteFriendsToCommunityPopup, {
|
||
// community: root.store.chatsModelInst.communities.activeCommunity
|
||
// })
|
||
}
|
||
}
|
||
|
||
categoryPopupMenu: StatusPopupMenu {
|
||
|
||
property var categoryItem
|
||
|
||
openHandler: function (id) {
|
||
// Not Refactored Yet
|
||
// categoryItem = root.store.chatsModelInst.communities.activeCommunity.getCommunityCategoryItemById(id)
|
||
}
|
||
|
||
StatusMenuItem {
|
||
// Not Refactored Yet
|
||
enabled: true
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
//% "Edit Category"
|
||
text: qsTrId("edit-category")
|
||
icon.name: "edit"
|
||
onTriggered: {
|
||
// Not Refactored Yet
|
||
// Global.openPopup(createCategoryPopup, {
|
||
// communityId: root.store.chatsModelInst.communities.activeCommunity.id,
|
||
// isEdit: true,
|
||
// categoryId: categoryItem.id,
|
||
// categoryName: categoryItem.name
|
||
// })
|
||
}
|
||
}
|
||
|
||
StatusMenuSeparator {
|
||
// Not Refactored Yet
|
||
visible: true
|
||
//visible: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
}
|
||
|
||
StatusMenuItem {
|
||
// Not Refactored Yet
|
||
enabled: true
|
||
//enabled: root.store.chatsModelInst.communities.activeCommunity.admin
|
||
//% "Delete Category"
|
||
text: qsTrId("delete-category")
|
||
icon.name: "delete"
|
||
type: StatusMenuItem.Type.Danger
|
||
onTriggered: {
|
||
Global.openPopup(deleteCategoryConfirmationDialogComponent, {
|
||
//% "Delete %1 category"
|
||
title: qsTrId("delete--1-category").arg(categoryItem.name),
|
||
//% "Are you sure you want to delete %1 category? Channels inside the category won’t be deleted."
|
||
confirmationText: qsTrId("are-you-sure-you-want-to-delete--1-category--channels-inside-the-category-won-t-be-deleted-")
|
||
.arg(categoryItem.name),
|
||
categoryId: categoryItem.id
|
||
})
|
||
}
|
||
}
|
||
}
|
||
|
||
chatListPopupMenu: ChatContextMenuView {
|
||
id: chatContextMenuView
|
||
|
||
openHandler: function (id) {
|
||
let jsonObj = root.communitySectionModule.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
|
||
}
|
||
|
||
isCommunityChat = root.communitySectionModule.isCommunity()
|
||
chatId = obj.itemId
|
||
chatName = obj.name
|
||
chatType = obj.type
|
||
chatMuted = obj.muted
|
||
|
||
// TODO
|
||
//currentFleet
|
||
}
|
||
|
||
onMuteChat: {
|
||
root.communitySectionModule.muteChat(id)
|
||
}
|
||
|
||
onUnmuteChat: {
|
||
root.communitySectionModule.unmuteChat(id)
|
||
}
|
||
|
||
onMarkAllMessagesRead: {
|
||
root.communitySectionModule.markAllMessagesRead(id)
|
||
}
|
||
|
||
onClearChatHistory: {
|
||
root.communitySectionModule.clearChatHistory(id)
|
||
}
|
||
}
|
||
}
|
||
|
||
Loader {
|
||
id: emptyViewAndSuggestionsLoader
|
||
// Not Refactored Yet
|
||
// active: root.store.chatsModelInst.communities.activeCommunity.admin &&
|
||
// (!localAccountSensitiveSettings.hiddenCommunityWelcomeBanners ||
|
||
// !localAccountSensitiveSettings.hiddenCommunityWelcomeBanners.includes(root.store.chatsModelInst.communities.activeCommunity.id))
|
||
width: parent.width
|
||
height: active ? item.height : 0
|
||
anchors.top: communityChatListAndCategories.bottom
|
||
anchors.topMargin: active ? Style.current.padding : 0
|
||
sourceComponent: Component {
|
||
CommunityWelcomeBannerPanel {
|
||
activeCommunity: store.activeCommunity
|
||
store: root.store
|
||
}
|
||
}
|
||
}
|
||
|
||
Loader {
|
||
id: backUpBannerLoader
|
||
// Not Refactored Yet
|
||
// active: root.store.chatsModelInst.communities.activeCommunity.admin &&
|
||
// (!localAccountSensitiveSettings.hiddenCommunityBackUpBanners ||
|
||
// !localAccountSensitiveSettings.hiddenCommunityBackUpBanners.includes(root.store.chatsModelInst.communities.activeCommunity.id))
|
||
width: parent.width
|
||
height: active ? item.height : 0
|
||
anchors.top: emptyViewAndSuggestionsLoader.bottom
|
||
anchors.topMargin: active ? Style.current.padding : 0
|
||
sourceComponent: Component {
|
||
Item {
|
||
width: parent.width
|
||
height: backupBanner.height
|
||
|
||
BackUpCommuntyBannerPanel {
|
||
id: backupBanner
|
||
activeCommunity: store.activeCommunity
|
||
onBackupButtonClicked: {
|
||
Global.openPopup(transferOwnershipPopup, {
|
||
privateKey: root.store.exportCommunity(),
|
||
store: root.store
|
||
})
|
||
}
|
||
}
|
||
MouseArea {
|
||
anchors.fill: backupBanner
|
||
acceptedButtons: Qt.RightButton
|
||
onClicked: {
|
||
/* Prevents sending events to the component beneath
|
||
if Right Mouse Button is clicked. */
|
||
mouse.accepted = false;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
Component {
|
||
id: createChannelPopup
|
||
CreateChannelPopup {
|
||
anchors.centerIn: parent
|
||
store: root.store
|
||
pinnedMessagesPopupComponent: root.pinnedMessagesPopupComponent
|
||
onClosed: {
|
||
destroy()
|
||
}
|
||
}
|
||
}
|
||
|
||
Component {
|
||
id: createCategoryPopup
|
||
CreateCategoryPopup {
|
||
anchors.centerIn: parent
|
||
store: root.store
|
||
onClosed: {
|
||
destroy()
|
||
}
|
||
}
|
||
}
|
||
|
||
Component {
|
||
id: deleteCategoryConfirmationDialogComponent
|
||
ConfirmationDialog {
|
||
property string categoryId
|
||
btnType: "warn"
|
||
showCancelButton: true
|
||
onClosed: {
|
||
destroy()
|
||
}
|
||
onCancelButtonClicked: {
|
||
close();
|
||
}
|
||
onConfirmButtonClicked: function(){
|
||
// Not Refactored Yet
|
||
// const error = root.store.chatsModelInst.communities.deleteCommunityCategory(root.store.chatsModelInst.communities.activeCommunity.id, categoryId)
|
||
// if (error) {
|
||
// creatingError.text = error
|
||
// return creatingError.open()
|
||
// }
|
||
// close();
|
||
}
|
||
}
|
||
}
|
||
|
||
MessageDialog {
|
||
id: deleteError
|
||
//% "Error deleting the category"
|
||
title: qsTrId("error-deleting-the-category")
|
||
icon: StandardIcon.Critical
|
||
standardButtons: StandardButton.Ok
|
||
}
|
||
|
||
Component {
|
||
id: membershipRequestPopup
|
||
MembershipRequestsPopup {
|
||
anchors.centerIn: parent
|
||
store: root.store
|
||
onClosed: {
|
||
destroy()
|
||
}
|
||
}
|
||
}
|
||
|
||
Component {
|
||
id: transferOwnershipPopup
|
||
TransferOwnershipPopup {
|
||
anchors.centerIn: parent
|
||
onClosed: {
|
||
let hiddenBannerIds = localAccountSensitiveSettings.hiddenCommunityBackUpBanners || []
|
||
if (hiddenBannerIds.includes(root.store.activeCommunity.id)) {
|
||
return
|
||
}
|
||
hiddenBannerIds.push(root.store.activeCommunity.id)
|
||
localAccountSensitiveSettings.hiddenCommunityBackUpBanners = hiddenBannerIds
|
||
}
|
||
}
|
||
}
|
||
}
|