2021-07-06 13:58:19 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
2022-07-14 14:03:36 +03:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2022-05-20 15:53:40 +03:00
|
|
|
import StatusQ.Components 0.1
|
2022-07-14 14:03:36 +03:00
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.status 1.0
|
2022-02-23 12:08:01 -05:00
|
|
|
import utils 1.0
|
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
import "../controls"
|
|
|
|
|
2022-07-21 11:03:51 +02:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
2021-07-22 17:53:19 +03:00
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
anchors.fill: parent
|
2021-11-30 15:49:45 +01:00
|
|
|
|
|
|
|
// Important:
|
2021-12-09 13:53:40 +01:00
|
|
|
// Each chat/channel has its own ChatContentModule and each ChatContentModule has a single usersModule
|
2021-11-30 15:49:45 +01:00
|
|
|
// usersModule on the backend contains everything needed for this component
|
|
|
|
property var usersModule
|
2021-09-01 19:38:39 +02:00
|
|
|
property var messageContextMenu
|
2022-02-23 12:08:01 -05:00
|
|
|
property string label
|
2021-07-06 13:58:19 -04:00
|
|
|
|
2022-03-09 11:27:32 +01:00
|
|
|
property var rootStore
|
|
|
|
|
2022-02-23 12:08:01 -05:00
|
|
|
StatusBaseText {
|
2021-07-22 17:53:19 +03:00
|
|
|
id: titleText
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: Style.current.padding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.padding
|
2021-08-26 15:04:47 +03:00
|
|
|
opacity: (root.width > 58) ? 1.0 : 0.0
|
2021-07-22 17:53:19 +03:00
|
|
|
visible: (opacity > 0.1)
|
|
|
|
font.pixelSize: Style.current.primaryTextFontSize
|
2022-02-23 12:08:01 -05:00
|
|
|
font.weight: Font.Medium
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
text: root.label
|
2021-07-22 17:53:19 +03:00
|
|
|
}
|
2021-07-06 18:41:26 -04:00
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
StatusListView {
|
2021-07-06 18:41:26 -04:00
|
|
|
id: userListView
|
2022-07-20 14:14:50 +02:00
|
|
|
objectName: "userListPanel"
|
|
|
|
clip: true
|
|
|
|
ScrollBar.vertical: ScrollBar {
|
|
|
|
policy: ScrollBar.AsNeeded
|
|
|
|
}
|
2021-07-22 17:53:19 +03:00
|
|
|
anchors {
|
|
|
|
top: titleText.bottom
|
|
|
|
topMargin: Style.current.padding
|
2021-11-30 13:27:08 +01:00
|
|
|
left: parent.left
|
2021-07-22 17:53:19 +03:00
|
|
|
right: parent.right
|
|
|
|
bottom: parent.bottom
|
|
|
|
bottomMargin: Style.current.bigPadding
|
|
|
|
}
|
2022-07-14 14:03:36 +03:00
|
|
|
|
2022-07-21 11:03:51 +02:00
|
|
|
model: SortFilterProxyModel {
|
|
|
|
sourceModel: usersModule.model
|
2022-07-21 12:30:56 +02:00
|
|
|
sorters: [
|
|
|
|
RoleSorter {
|
|
|
|
roleName: "onlineStatus"
|
|
|
|
sortOrder: Qt.DescendingOrder
|
|
|
|
},
|
|
|
|
StringSorter {
|
|
|
|
roleName: "displayName"
|
|
|
|
caseSensitivity: Qt.CaseInsensitive
|
|
|
|
}
|
|
|
|
]
|
2022-07-21 11:03:51 +02:00
|
|
|
}
|
2022-02-23 12:08:01 -05:00
|
|
|
section.property: "onlineStatus"
|
|
|
|
section.delegate: (root.width > 58) ? sectionDelegateComponent : null
|
2022-05-20 15:53:40 +03:00
|
|
|
delegate: StatusMemberListItem {
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: 8
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 8
|
|
|
|
nickName: model.localNickname
|
2022-06-03 15:24:49 +02:00
|
|
|
userName: model.displayName
|
2022-06-10 12:34:46 +02:00
|
|
|
pubKey: Utils.getCompressedPk(model.pubKey)
|
2022-06-03 15:24:49 +02:00
|
|
|
isContact: model.isContact
|
|
|
|
isVerified: model.isVerified
|
|
|
|
isUntrustworthy: model.isUntrustworthy
|
2022-05-30 13:00:53 +03:00
|
|
|
isAdmin: model.isAdmin
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: {
|
2022-06-03 15:24:49 +02:00
|
|
|
if ((!model.isContact &&
|
2022-05-20 15:53:40 +03:00
|
|
|
Global.privacyModuleInst.profilePicturesVisibility !==
|
|
|
|
Constants.profilePicturesVisibility.everyone)) {
|
|
|
|
return "";
|
|
|
|
}
|
2022-08-11 14:55:08 +03:00
|
|
|
//TODO check if icon is rendered correctly
|
2022-05-20 15:53:40 +03:00
|
|
|
return model.icon;
|
|
|
|
}
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.isImage: (asset.name !== "")
|
|
|
|
asset.isLetterIdenticon: (asset.name === "")
|
2022-09-06 17:06:33 +02:00
|
|
|
asset.color: Utils.colorForColorId(model.colorId)
|
2022-06-03 15:24:49 +02:00
|
|
|
status: model.onlineStatus
|
|
|
|
ringSettings.ringSpecModel: Utils.getColorHashAsJson(model.pubKey) // FIXME: use model.colorHash
|
2022-05-20 15:53:40 +03:00
|
|
|
onClicked: {
|
|
|
|
if (mouse.button === Qt.RightButton) {
|
|
|
|
// Set parent, X & Y positions for the messageContextMenu
|
|
|
|
messageContextMenu.parent = this
|
|
|
|
messageContextMenu.isProfile = true
|
|
|
|
messageContextMenu.myPublicKey = userProfile.pubKey
|
2022-06-03 15:24:49 +02:00
|
|
|
messageContextMenu.selectedUserPublicKey = model.pubKey
|
|
|
|
messageContextMenu.selectedUserDisplayName = model.displayName
|
2022-05-20 15:53:40 +03:00
|
|
|
messageContextMenu.selectedUserIcon = image.source
|
2022-07-05 14:12:27 +04:00
|
|
|
messageContextMenu.popup(4, 4)
|
2022-05-20 15:53:40 +03:00
|
|
|
} else if (mouse.button === Qt.LeftButton && !!messageContextMenu) {
|
2022-06-03 15:24:49 +02:00
|
|
|
Global.openProfilePopup(model.pubKey);
|
2022-05-20 15:53:40 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-02-23 12:08:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: sectionDelegateComponent
|
|
|
|
Item {
|
|
|
|
width: parent.width
|
|
|
|
height: 24
|
|
|
|
StyledText {
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
font.pixelSize: Style.current.additionalTextSize
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
text: {
|
|
|
|
switch(parseInt(section)) {
|
2022-06-10 11:01:31 +02:00
|
|
|
case Constants.onlineStatus.online:
|
|
|
|
return qsTr("Online")
|
|
|
|
default:
|
|
|
|
return qsTr("Inactive")
|
2022-02-23 12:08:01 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-07-06 18:41:26 -04:00
|
|
|
}
|
2021-07-22 17:53:19 +03:00
|
|
|
}
|