2022-03-23 16:38:23 +01:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
import shared.controls.chat 1.0
|
|
|
|
|
|
|
|
import "../../layouts"
|
|
|
|
|
|
|
|
SettingsPageLayout {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
property bool editable: true
|
|
|
|
|
|
|
|
signal membershipRequestsClicked()
|
|
|
|
signal userProfileClicked(string id)
|
|
|
|
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
|
|
|
|
|
|
|
title: qsTr("Members")
|
|
|
|
|
|
|
|
content: ColumnLayout {
|
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
|
|
|
|
|
|
|
|
CommunityMembersTabPanel {
|
|
|
|
model: root.membersModel
|
|
|
|
placeholderText: {
|
|
|
|
if (root.membersModel.count === 0) {
|
|
|
|
return qsTr("No members to search")
|
|
|
|
} else {
|
2022-09-23 00:18:15 +02:00
|
|
|
return qsTr("Search %1's %n member(s)", "", root.membersModel.count).arg(root.communityName)
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
panelType: CommunityMembersTabPanel.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
|
|
|
onUserProfileClicked: root.userProfileClicked(id)
|
|
|
|
onKickUserClicked: {
|
|
|
|
kickModal.userNameToKick = name
|
|
|
|
kickModal.userIdToKick = id
|
|
|
|
kickModal.open()
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
onBanUserClicked: {
|
|
|
|
banModal.userNameToBan = name
|
|
|
|
banModal.userIdToBan = id
|
|
|
|
banModal.open()
|
|
|
|
}
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-08-04 09:49:41 +02:00
|
|
|
CommunityMembersTabPanel {
|
|
|
|
model: root.pendingMemberRequestsModel
|
|
|
|
placeholderText: {
|
|
|
|
if (root.pendingMemberRequestsModel.count === 0) {
|
|
|
|
return qsTr("No pending requests to search")
|
|
|
|
} else {
|
|
|
|
return qsTr("Search %1's %2 pending request%3").arg(root.communityName)
|
|
|
|
.arg(root.pendingMemberRequestsModel.count)
|
|
|
|
.arg(root.pendingMemberRequestsModel.count > 1 ? "s" : "")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
panelType: CommunityMembersTabPanel.TabType.PendingRequests
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
onAcceptRequestToJoin: root.acceptRequestToJoin(id)
|
|
|
|
onDeclineRequestToJoin: root.declineRequestToJoin(id)
|
|
|
|
}
|
|
|
|
|
|
|
|
CommunityMembersTabPanel {
|
|
|
|
model: root.declinedMemberRequestsModel
|
|
|
|
placeholderText: {
|
|
|
|
if (root.declinedMemberRequestsModel.count === 0) {
|
|
|
|
return qsTr("No rejected members to search")
|
|
|
|
} else {
|
|
|
|
return qsTr("Search %1's %2 rejected member%3").arg(root.communityName)
|
|
|
|
.arg(root.declinedMemberRequestsModel.count)
|
|
|
|
.arg(root.declinedMemberRequestsModel.count > 1 ? "s" : "")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
panelType: CommunityMembersTabPanel.TabType.DeclinedRequests
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
onAcceptRequestToJoin: root.acceptRequestToJoin(id)
|
|
|
|
}
|
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
CommunityMembersTabPanel {
|
|
|
|
model: root.bannedMembersModel
|
|
|
|
placeholderText: {
|
|
|
|
if (root.bannedMembersModel.count === 0) {
|
|
|
|
return qsTr("No banned members to search")
|
|
|
|
} else {
|
|
|
|
return qsTr("Search %1's %2 banned member%3").arg(root.communityName)
|
|
|
|
.arg(root.bannedMembersModel.count)
|
|
|
|
.arg(root.bannedMembersModel.count > 1 ? "s" : "")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
panelType: CommunityMembersTabPanel.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
|
|
|
onUserProfileClicked: root.userProfileClicked(id)
|
|
|
|
onUnbanUserClicked: root.unbanUserClicked(id)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
StatusModal {
|
|
|
|
id: banModal
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
property string userNameToBan: ""
|
|
|
|
property string userIdToBan: ""
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
readonly property string text: qsTr("Are you sure you ban <b>%1</b> from %2?").arg(userNameToBan).arg(root.communityName)
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
anchors.centerIn: parent
|
|
|
|
width: 400
|
|
|
|
header.title: qsTr("Ban %1").arg(userNameToBan)
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
contentItem: StatusBaseText {
|
|
|
|
id: banContentText
|
|
|
|
anchors.centerIn: parent
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
padding: 15
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
text: banModal.text
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
rightButtons: [
|
|
|
|
StatusButton {
|
|
|
|
text: qsTr("Cancel")
|
|
|
|
onClicked: banModal.close()
|
|
|
|
normalColor: "transparent"
|
|
|
|
hoverColor: "transparent"
|
|
|
|
},
|
|
|
|
StatusButton {
|
|
|
|
id: banButton
|
|
|
|
text: qsTr("Ban")
|
|
|
|
type: StatusBaseButton.Type.Danger
|
|
|
|
onClicked: {
|
|
|
|
root.banUserClicked(banModal.userIdToBan)
|
|
|
|
banModal.close()
|
2022-03-23 16:38:23 +01:00
|
|
|
}
|
2022-06-28 17:03:10 +02:00
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
StatusModal {
|
|
|
|
id: kickModal
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
property string userNameToKick: ""
|
|
|
|
property string userIdToKick: ""
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
readonly property string text : qsTr("Are you sure you kick <b>%1</b> from %2?").arg(userNameToKick).arg(communityName)
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
anchors.centerIn: parent
|
|
|
|
width: 400
|
|
|
|
header.title: qsTr("Kick %1").arg(userNameToKick)
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
contentItem: StatusBaseText {
|
|
|
|
id: kickContentText
|
|
|
|
anchors.centerIn: parent
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
padding: 15
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
text: kickModal.text
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
|
2022-06-28 17:03:10 +02:00
|
|
|
rightButtons: [
|
|
|
|
StatusButton {
|
|
|
|
text: qsTr("Cancel")
|
|
|
|
onClicked: kickModal.close()
|
|
|
|
normalColor: "transparent"
|
|
|
|
hoverColor: "transparent"
|
|
|
|
},
|
|
|
|
StatusButton {
|
|
|
|
text: qsTr("Kick")
|
|
|
|
type: StatusBaseButton.Type.Danger
|
|
|
|
onClicked: {
|
|
|
|
root.kickUserClicked(kickModal.userIdToKick)
|
|
|
|
kickModal.close()
|
|
|
|
}
|
2022-03-23 16:38:23 +01:00
|
|
|
}
|
2022-06-28 17:03:10 +02:00
|
|
|
]
|
2022-03-23 16:38:23 +01:00
|
|
|
}
|
|
|
|
}
|