2023-08-07 16:35:14 +03:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
2023-08-08 11:41:59 +03:00
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
|
|
|
|
import Qt.labs.settings 1.0
|
2023-08-07 16:35:14 +03:00
|
|
|
|
|
|
|
import AppLayouts.Communities.panels 1.0
|
|
|
|
|
2023-08-08 11:41:59 +03:00
|
|
|
import utils 1.0
|
|
|
|
|
2023-08-07 16:35:14 +03:00
|
|
|
import Models 1.0
|
|
|
|
import SortFilterProxyModel 0.2
|
2023-08-08 11:41:59 +03:00
|
|
|
import Storybook 1.0
|
2023-08-07 16:35:14 +03:00
|
|
|
|
2023-08-17 10:55:28 +02:00
|
|
|
import StatusQ.Core.Utils 0.1 as SQUtils
|
|
|
|
|
2023-08-07 16:35:14 +03:00
|
|
|
SplitView {
|
|
|
|
id: root
|
|
|
|
|
2023-08-08 11:41:59 +03:00
|
|
|
orientation: Qt.Vertical
|
|
|
|
Logs { id: logs }
|
|
|
|
|
2023-08-17 10:55:28 +02:00
|
|
|
// Utils.globalUtilsInst mock
|
|
|
|
QtObject {
|
|
|
|
function getEmojiHashAsJson(publicKey) {
|
|
|
|
return JSON.stringify(["👨🏻🍼", "🏃🏿♂️", "🌇", "🤶🏿", "🏮","🤷🏻♂️", "🤦🏻", "📣", "🤎", "👷🏽", "😺", "🥞", "🔃", "🧝🏽♂️"])
|
|
|
|
}
|
|
|
|
|
|
|
|
function getColorId(publicKey) {
|
|
|
|
return SQUtils.ModelUtils.getByKey(usersModel, "pubKey", publicKey, "colorId")
|
|
|
|
}
|
|
|
|
|
|
|
|
function getCompressedPk(publicKey) { return "zx3sh" + publicKey }
|
|
|
|
|
|
|
|
function getColorHashAsJson(publicKey) {
|
|
|
|
return JSON.stringify([{colorId: 0, segmentLength: 1},
|
|
|
|
{colorId: 19, segmentLength: 2}])
|
|
|
|
}
|
|
|
|
|
|
|
|
function isCompressedPubKey(publicKey) { return true }
|
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
Utils.globalUtilsInst = this
|
|
|
|
}
|
|
|
|
Component.onDestruction: {
|
|
|
|
Utils.globalUtilsInst = {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Global.userProfile mock
|
|
|
|
QtObject {
|
|
|
|
readonly property string pubKey: "0x043a7ed0e8d1012cf04" // Mike from UsersModel
|
|
|
|
Component.onCompleted: {
|
|
|
|
Global.userProfile = this
|
|
|
|
}
|
|
|
|
Component.onDestruction: {
|
|
|
|
Utils.userProfile = {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-07 16:35:14 +03:00
|
|
|
MembersTabPanel {
|
|
|
|
id: membersTabPanelPage
|
2023-08-08 11:41:59 +03:00
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.fillHeight: true
|
2023-08-17 10:55:28 +02:00
|
|
|
placeholderText: "Search users"
|
2023-08-07 16:35:14 +03:00
|
|
|
model: usersModelWithMembershipState
|
2023-08-08 11:41:59 +03:00
|
|
|
panelType: viewStateSelector.currentValue
|
|
|
|
|
|
|
|
onKickUserClicked: {
|
2023-08-17 10:55:28 +02:00
|
|
|
logs.logEvent("MembersTabPanel::onKickUserClicked", ["id", "name"], arguments)
|
2023-08-08 11:41:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
onBanUserClicked: {
|
2023-08-17 10:55:28 +02:00
|
|
|
logs.logEvent("MembersTabPanel::onBanUserClicked", ["id", "name"], arguments)
|
2023-08-08 11:41:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
onUnbanUserClicked: {
|
2023-08-17 10:55:28 +02:00
|
|
|
logs.logEvent("MembersTabPanel::onUnbanUserClicked", ["id"], arguments)
|
2023-08-08 11:41:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
onAcceptRequestToJoin: {
|
2023-08-17 10:55:28 +02:00
|
|
|
logs.logEvent("MembersTabPanel::onAcceptRequestToJoin", ["id"], arguments)
|
2023-08-08 11:41:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
onDeclineRequestToJoin: {
|
2023-08-17 10:55:28 +02:00
|
|
|
logs.logEvent("MembersTabPanel::onDeclineRequestToJoin", ["id"], arguments)
|
2023-08-08 11:41:59 +03:00
|
|
|
}
|
2023-08-07 16:35:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
UsersModel {
|
|
|
|
id: usersModel
|
|
|
|
}
|
|
|
|
|
|
|
|
SortFilterProxyModel {
|
|
|
|
id: usersModelWithMembershipState
|
2023-08-08 11:41:59 +03:00
|
|
|
readonly property var membershipStatePerView: [
|
|
|
|
[Constants.CommunityMembershipRequestState.Accepted , Constants.CommunityMembershipRequestState.BannedPending, Constants.CommunityMembershipRequestState.KickedPending],
|
|
|
|
[Constants.CommunityMembershipRequestState.Banned],
|
|
|
|
[Constants.CommunityMembershipRequestState.Pending, Constants.CommunityMembershipRequestState.AcceptedPending, Constants.CommunityMembershipRequestState.RejectedPending],
|
|
|
|
[Constants.CommunityMembershipRequestState.Rejected]
|
|
|
|
]
|
|
|
|
|
2023-08-07 16:35:14 +03:00
|
|
|
sourceModel: usersModel
|
2023-08-08 11:41:59 +03:00
|
|
|
sortRole: membersTabPanelPage.panelType
|
2023-08-07 16:35:14 +03:00
|
|
|
|
|
|
|
proxyRoles: [
|
|
|
|
ExpressionRole {
|
|
|
|
name: "membershipRequestState"
|
2023-08-08 11:41:59 +03:00
|
|
|
expression: {
|
|
|
|
var memberStates = usersModelWithMembershipState.membershipStatePerView[membersTabPanelPage.panelType]
|
|
|
|
return memberStates[model.index % (memberStates.length)]
|
|
|
|
}
|
2023-08-07 16:35:14 +03:00
|
|
|
},
|
|
|
|
ExpressionRole {
|
|
|
|
name: "requestToJoinLoading"
|
|
|
|
expression: false
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2023-08-08 11:41:59 +03:00
|
|
|
|
|
|
|
LogsAndControlsPanel {
|
|
|
|
SplitView.minimumHeight: 100
|
|
|
|
SplitView.preferredHeight: 320
|
|
|
|
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
Label {
|
|
|
|
text: "View state"
|
|
|
|
}
|
|
|
|
|
|
|
|
ComboBox {
|
|
|
|
id: viewStateSelector
|
|
|
|
textRole: "text"
|
|
|
|
valueRole: "value"
|
|
|
|
model: ListModel {
|
|
|
|
id: model
|
|
|
|
ListElement { text: "All members"; value: MembersTabPanel.TabType.AllMembers }
|
|
|
|
ListElement { text: "Banned Members"; value: MembersTabPanel.TabType.BannedMembers }
|
|
|
|
ListElement { text: "Pending Members"; value: MembersTabPanel.TabType.PendingRequests }
|
|
|
|
ListElement { text: "Declined Members"; value: MembersTabPanel.TabType.DeclinedRequests }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Settings {
|
|
|
|
property alias membersTabPanelSelection: viewStateSelector.currentIndex
|
|
|
|
}
|
2023-08-07 16:35:14 +03:00
|
|
|
}
|