2023-06-29 12:03:15 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
2022-03-23 16:38:23 +01:00
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import utils 1.0
|
|
|
|
|
2023-06-23 08:17:04 +02:00
|
|
|
import AppLayouts.Communities.layouts 1.0
|
2023-09-01 00:26:24 +02:00
|
|
|
import AppLayouts.Communities.popups 1.0
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-06-29 12:03:15 +02:00
|
|
|
SettingsPage {
|
2022-03-23 16:38:23 +01:00
|
|
|
id: root
|
|
|
|
|
2023-06-20 10:14:25 +03:00
|
|
|
property var rootStore
|
2022-03-23 16:38:23 +01:00
|
|
|
property var membersModel
|
2022-06-28 17:03:10 +02:00
|
|
|
property var bannedMembersModel
|
2022-08-04 09:49:41 +02:00
|
|
|
property var pendingMemberRequestsModel
|
|
|
|
property var declinedMemberRequestsModel
|
2022-06-28 17:03:10 +02:00
|
|
|
property string communityName
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-08-21 15:07:40 -04:00
|
|
|
property int memberRole
|
2022-03-23 16:38:23 +01:00
|
|
|
property bool editable: true
|
|
|
|
|
|
|
|
signal membershipRequestsClicked()
|
|
|
|
signal kickUserClicked(string id)
|
|
|
|
signal banUserClicked(string id)
|
2022-06-28 17:03:10 +02:00
|
|
|
signal unbanUserClicked(string id)
|
2022-08-04 09:49:41 +02:00
|
|
|
signal acceptRequestToJoin(string id)
|
|
|
|
signal declineRequestToJoin(string id)
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-04-06 14:11:57 +03:00
|
|
|
function goTo(tab: int) {
|
|
|
|
if(root.contentItem) {
|
|
|
|
root.contentItem.goTo(tab)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-30 16:36:46 +02:00
|
|
|
title: qsTr("Members")
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-06-29 12:03:15 +02:00
|
|
|
contentItem: ColumnLayout {
|
2023-04-06 14:11:57 +03:00
|
|
|
|
|
|
|
function goTo(tab: int) {
|
|
|
|
let tabButton = membersTabBar.currentItem
|
|
|
|
switch (tab) {
|
|
|
|
case Constants.CommunityMembershipSubSections.Members:
|
|
|
|
tabButton = allMembersBtn
|
|
|
|
break
|
|
|
|
case Constants.CommunityMembershipSubSections.MembershipRequests:
|
|
|
|
tabButton = pendingRequestsBtn
|
|
|
|
break
|
|
|
|
case Constants.CommunityMembershipSubSections.RejectedMembers:
|
|
|
|
tabButton = declinedRequestsBtn
|
|
|
|
break
|
|
|
|
case Constants.CommunityMembershipSubSections.BannedMembers:
|
|
|
|
tabButton = bannedBtn
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
if(tabButton.enabled)
|
|
|
|
membersTabBar.currentIndex = tabButton.TabBar.index
|
|
|
|
}
|
|
|
|
|
2022-08-08 18:56:57 +03:00
|
|
|
spacing: 19
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
StatusTabBar {
|
|
|
|
id: membersTabBar
|
2022-03-23 16:38:23 +01:00
|
|
|
Layout.fillWidth: true
|
2022-08-08 18:56:57 +03:00
|
|
|
Layout.topMargin: 5
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
StatusTabButton {
|
|
|
|
id: allMembersBtn
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("All Members")
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-08-04 09:49:41 +02:00
|
|
|
StatusTabButton {
|
|
|
|
id: pendingRequestsBtn
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Pending Requests")
|
|
|
|
enabled: pendingMemberRequestsModel.count > 0
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusTabButton {
|
|
|
|
id: declinedRequestsBtn
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Rejected")
|
|
|
|
enabled: declinedMemberRequestsModel.count > 0
|
|
|
|
}
|
2022-06-28 17:03:10 +02:00
|
|
|
|
|
|
|
StatusTabButton {
|
|
|
|
id: bannedBtn
|
|
|
|
width: implicitWidth
|
|
|
|
enabled: bannedMembersModel.count > 0
|
|
|
|
text: qsTr("Banned")
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
}
|
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
StackLayout {
|
|
|
|
id: stackLayout
|
2022-03-23 16:38:23 +01:00
|
|
|
Layout.fillWidth: true
|
2022-06-28 17:03:10 +02:00
|
|
|
Layout.fillHeight: true
|
|
|
|
currentIndex: membersTabBar.currentIndex
|
|
|
|
|
2023-06-26 13:48:45 +02:00
|
|
|
MembersTabPanel {
|
2022-06-28 17:03:10 +02:00
|
|
|
model: root.membersModel
|
2023-06-20 10:14:25 +03:00
|
|
|
rootStore: root.rootStore
|
2023-08-21 15:07:40 -04:00
|
|
|
memberRole: root.memberRole
|
2022-06-28 17:03:10 +02:00
|
|
|
placeholderText: {
|
2023-06-21 22:37:51 +02:00
|
|
|
if (root.membersModel.count === 0)
|
2022-06-28 17:03:10 +02:00
|
|
|
return qsTr("No members to search")
|
2023-06-21 22:37:51 +02:00
|
|
|
|
|
|
|
return qsTr("Search %1's %n member(s)", "", root.membersModel ? root.membersModel.count : 0).arg(root.communityName)
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
2023-06-26 13:48:45 +02:00
|
|
|
panelType: MembersTabPanel.TabType.AllMembers
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
onKickUserClicked: {
|
2023-09-01 00:26:24 +02:00
|
|
|
kickBanPopup.mode = KickBanPopup.Mode.Kick
|
|
|
|
kickBanPopup.username = name
|
|
|
|
kickBanPopup.userId = id
|
|
|
|
kickBanPopup.open()
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
onBanUserClicked: {
|
2023-09-01 00:26:24 +02:00
|
|
|
kickBanPopup.mode = KickBanPopup.Mode.Ban
|
|
|
|
kickBanPopup.username = name
|
|
|
|
kickBanPopup.userId = id
|
|
|
|
kickBanPopup.open()
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-06-26 13:48:45 +02:00
|
|
|
MembersTabPanel {
|
2022-08-04 09:49:41 +02:00
|
|
|
model: root.pendingMemberRequestsModel
|
2023-06-20 10:14:25 +03:00
|
|
|
rootStore: root.rootStore
|
2023-08-21 15:07:40 -04:00
|
|
|
memberRole: root.memberRole
|
2022-08-04 09:49:41 +02:00
|
|
|
placeholderText: {
|
2023-06-21 22:37:51 +02:00
|
|
|
if (root.pendingMemberRequestsModel.count === 0)
|
2022-08-04 09:49:41 +02:00
|
|
|
return qsTr("No pending requests to search")
|
2023-06-21 22:37:51 +02:00
|
|
|
|
|
|
|
return qsTr("Search %1's %n pending request(s)", "", root.pendingMemberRequestsModel.count).arg(root.communityName)
|
2022-08-04 09:49:41 +02:00
|
|
|
}
|
2023-06-26 13:48:45 +02:00
|
|
|
panelType: MembersTabPanel.TabType.PendingRequests
|
2022-08-04 09:49:41 +02:00
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
onAcceptRequestToJoin: root.acceptRequestToJoin(id)
|
|
|
|
onDeclineRequestToJoin: root.declineRequestToJoin(id)
|
|
|
|
}
|
|
|
|
|
2023-06-26 13:48:45 +02:00
|
|
|
MembersTabPanel {
|
2022-08-04 09:49:41 +02:00
|
|
|
model: root.declinedMemberRequestsModel
|
2023-06-20 10:14:25 +03:00
|
|
|
rootStore: root.rootStore
|
2023-08-21 15:07:40 -04:00
|
|
|
memberRole: root.memberRole
|
2022-08-04 09:49:41 +02:00
|
|
|
placeholderText: {
|
2023-06-21 22:37:51 +02:00
|
|
|
if (root.declinedMemberRequestsModel.count === 0)
|
2022-08-04 09:49:41 +02:00
|
|
|
return qsTr("No rejected members to search")
|
2023-06-21 22:37:51 +02:00
|
|
|
|
|
|
|
return qsTr("Search %1's %n rejected member(s)", "", root.declinedMemberRequestsModel.count).arg(root.communityName)
|
2022-08-04 09:49:41 +02:00
|
|
|
}
|
2023-06-26 13:48:45 +02:00
|
|
|
panelType: MembersTabPanel.TabType.DeclinedRequests
|
2022-08-04 09:49:41 +02:00
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
onAcceptRequestToJoin: root.acceptRequestToJoin(id)
|
|
|
|
}
|
|
|
|
|
2023-06-26 13:48:45 +02:00
|
|
|
MembersTabPanel {
|
2022-06-28 17:03:10 +02:00
|
|
|
model: root.bannedMembersModel
|
2023-06-20 10:14:25 +03:00
|
|
|
rootStore: root.rootStore
|
2023-08-21 15:07:40 -04:00
|
|
|
memberRole: root.memberRole
|
2022-06-28 17:03:10 +02:00
|
|
|
placeholderText: {
|
2023-06-21 22:37:51 +02:00
|
|
|
if (root.bannedMembersModel.count === 0)
|
2022-06-28 17:03:10 +02:00
|
|
|
return qsTr("No banned members to search")
|
2023-06-21 22:37:51 +02:00
|
|
|
|
|
|
|
return qsTr("Search %1's %n banned member(s)", "", root.bannedMembersModel.count).arg(root.communityName)
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
2023-06-26 13:48:45 +02:00
|
|
|
panelType: MembersTabPanel.TabType.BannedMembers
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
onUnbanUserClicked: root.unbanUserClicked(id)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-09-01 00:26:24 +02:00
|
|
|
KickBanPopup {
|
|
|
|
id: kickBanPopup
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-09-01 00:26:24 +02:00
|
|
|
property string userId
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-09-01 00:26:24 +02:00
|
|
|
communityName: root.communityName
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2023-09-01 00:26:24 +02:00
|
|
|
onAccepted: {
|
|
|
|
if (mode === KickBanPopup.Mode.Kick)
|
|
|
|
root.kickUserClicked(userId)
|
|
|
|
else
|
|
|
|
root.banUserClicked(userId)
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
}
|
|
|
|
}
|