218 lines
7.6 KiB
QML
218 lines
7.6 KiB
QML
import QtQuick 2.13
|
|
import QtGraphicalEffects 1.13
|
|
|
|
import utils 1.0
|
|
import shared.controls 1.0
|
|
import shared 1.0
|
|
import shared.panels 1.0
|
|
|
|
import StatusQ.Components 0.1 as StatusQ
|
|
import StatusQ.Core 0.1
|
|
|
|
Item {
|
|
id: wrapper
|
|
|
|
property color textColor: Style.current.textColor
|
|
property string chatId: ""
|
|
property string name: "channelName"
|
|
property string identicon
|
|
property string communityId
|
|
property bool hideSecondIcon: false
|
|
property int chatType: chatsModel.channelView.chats.getChannelType(chatId)
|
|
property int realChatType: {
|
|
if (chatType === Constants.chatTypeCommunity) {
|
|
// TODO add a check for private community chats once it is created
|
|
return Constants.chatTypePubliccommunityComponent
|
|
}
|
|
return chatType
|
|
}
|
|
|
|
property string profileImage: realChatType === Constants.chatTypeOneToOne ? appMain.getProfileImage(chatId) || "" : ""
|
|
|
|
height: 24
|
|
width: childrenRect.width
|
|
|
|
Loader {
|
|
active: true
|
|
height: parent.height
|
|
sourceComponent: wrapper.communityId ? communityComponent : channelComponent
|
|
}
|
|
|
|
Component {
|
|
id: communityComponent
|
|
|
|
Item {
|
|
property int communityIndex: chatsModel.communities.joinedCommunities.getCommunityIndex(wrapper.communityId)
|
|
|
|
property string image: communityIndex > -1 ? chatsModel.communities.joinedCommunities.rowData(communityIndex, "thumbnailImage") : ""
|
|
property string iconColor: !image && communityIndex > -1 ? chatsModel.communities.joinedCommunities.rowData(communityIndex, "communityColor"): ""
|
|
property bool useLetterIdenticon: !image
|
|
property string communityName: communityIndex > -1 ? chatsModel.communities.joinedCommunities.rowData(communityIndex, "name") : ""
|
|
property string channelName: chatsModel.getChannelNameById(wrapper.chatId)
|
|
|
|
id: communityBadge
|
|
width: childrenRect.width
|
|
height: parent.height
|
|
SVGImage {
|
|
id: communityIcon
|
|
visible: !hideSecondIcon
|
|
width: 16
|
|
height: 16
|
|
source: Style.svg("communities")
|
|
anchors.left: parent.left
|
|
anchors.verticalCenter:parent.verticalCenter
|
|
|
|
ColorOverlay {
|
|
anchors.fill: parent
|
|
source: parent
|
|
color: wrapper.textColor
|
|
}
|
|
}
|
|
|
|
Loader {
|
|
id: communityImageLoader
|
|
active: true
|
|
anchors.left: communityIcon.visible ? communityIcon.right : parent.left
|
|
anchors.leftMargin: 2
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
sourceComponent: communityBadge.useLetterIdenticon ? letterIdenticon :imageIcon
|
|
}
|
|
|
|
Component {
|
|
id: imageIcon
|
|
RoundedImage {
|
|
source: communityBadge.image
|
|
noMouseArea: true
|
|
noHover: true
|
|
width: 16
|
|
height: 16
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: letterIdenticon
|
|
StatusQ.StatusLetterIdenticon {
|
|
width: 16
|
|
height: 16
|
|
letterSize: 12
|
|
name: communityBadge.communityName
|
|
color: communityBadge.iconColor
|
|
}
|
|
}
|
|
|
|
StyledTextEdit {
|
|
id: communityName
|
|
text: Utils.getLinkStyle(communityBadge.communityName, hoveredLink, wrapper.textColor)
|
|
height: 18
|
|
readOnly: true
|
|
textFormat: Text.RichText
|
|
width: implicitWidth > 300 ? 300 : implicitWidth
|
|
clip: true
|
|
anchors.left: communityImageLoader.right
|
|
anchors.leftMargin: 4
|
|
color: wrapper.textColor
|
|
font.pixelSize: 13
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
onLinkActivated: function () {
|
|
chatsModel.communities.setActiveCommunity(wrapper.communityId)
|
|
}
|
|
}
|
|
|
|
SVGImage {
|
|
id: caretImage
|
|
source: Style.svg("show-category")
|
|
width: 16
|
|
height: 16
|
|
anchors.left: communityName.right
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
ColorOverlay {
|
|
anchors.fill: parent
|
|
source: parent
|
|
color: wrapper.textColor
|
|
}
|
|
}
|
|
|
|
StyledTextEdit {
|
|
id: channelName
|
|
text: communityBadge.getLinkStyle(communityBadge.channelName || wrapper.name, hoveredLink, wrapper.textColor)
|
|
height: 18
|
|
readOnly: true
|
|
textFormat: Text.RichText
|
|
width: implicitWidth > 300 ? 300 : implicitWidth
|
|
clip: true
|
|
anchors.left: caretImage.right
|
|
color: wrapper.textColor
|
|
font.pixelSize: 13
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
onLinkActivated: function () {
|
|
chatsModel.communities.setActiveCommunity(wrapper.communityId)
|
|
chatsModel.setActiveChannel(model.message.chatId)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: channelComponent
|
|
|
|
Item {
|
|
width: childrenRect.width
|
|
height: parent.height
|
|
|
|
Connections {
|
|
enabled: realChatType === Constants.chatTypeOneToOne
|
|
// TODO use a store once it is available
|
|
target: contactsModule.model.list
|
|
onContactChanged: {
|
|
if (pubkey === wrapper.chatId) {
|
|
wrapper.profileImage = appMain.getProfileImage(wrapper.chatId)
|
|
}
|
|
}
|
|
}
|
|
|
|
SVGImage {
|
|
id: channelIcon
|
|
width: 16
|
|
height: 16
|
|
fillMode: Image.PreserveAspectFit
|
|
source: Style.svg("channel-icon-" + (wrapper.realChatType === Constants.chatTypePublic ? "public-chat" : "group"))
|
|
anchors.left: parent.left
|
|
anchors.verticalCenter:parent.verticalCenter
|
|
}
|
|
|
|
StatusQ.StatusSmartIdenticon {
|
|
id: contactImage
|
|
anchors.left: channelIcon.right
|
|
anchors.leftMargin: 4
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
image: StatusImageSettings {
|
|
width: 16
|
|
height: 16
|
|
source: wrapper.profileImage || wrapper.identicon
|
|
isIdenticon: true
|
|
}
|
|
icon: StatusIconSettings {
|
|
width: 16
|
|
height: 16
|
|
letterSize: 11
|
|
}
|
|
name: wrapper.name
|
|
}
|
|
|
|
StyledText {
|
|
id: contactInfo
|
|
text: wrapper.realChatType !== Constants.chatTypePublic ?
|
|
Emoji.parse(Utils.removeStatusEns(Utils.filterXSS(wrapper.name))) :
|
|
"#" + Utils.filterXSS(wrapper.name)
|
|
anchors.left: contactImage.right
|
|
anchors.leftMargin: 4
|
|
color: wrapper.textColor
|
|
font.weight: Font.Medium
|
|
font.pixelSize: 13
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
}
|
|
}
|
|
}
|