2020-12-11 15:29:46 -05:00
|
|
|
|
import QtQuick 2.12
|
|
|
|
|
import QtQuick.Dialogs 1.3
|
|
|
|
|
import "../../../../imports"
|
|
|
|
|
import "../../../../shared"
|
|
|
|
|
import "../../../../shared/status"
|
|
|
|
|
import "../ContactsColumn"
|
|
|
|
|
|
|
|
|
|
ModalPopup {
|
2021-02-11 15:37:31 -05:00
|
|
|
|
property QtObject community: chatsModel.communities.observedCommunity
|
2020-12-11 15:29:46 -05:00
|
|
|
|
property string communityId: community.id
|
|
|
|
|
property string name: community.name
|
|
|
|
|
property string description: community.description
|
2020-12-11 15:38:10 -05:00
|
|
|
|
property int access: community.access
|
2021-02-10 15:37:17 -05:00
|
|
|
|
property string source: community.thumbnailImage
|
2020-12-11 15:38:10 -05:00
|
|
|
|
property int nbMembers: community.nbMembers
|
2021-02-10 15:37:17 -05:00
|
|
|
|
property bool ensOnly: community.ensOnly
|
|
|
|
|
property bool canJoin: community.canJoin
|
|
|
|
|
property bool canRequestAccess: community.canRequestAccess
|
2021-03-09 12:50:45 +01:00
|
|
|
|
property bool isMember: community.isMember
|
2021-03-23 15:13:36 -04:00
|
|
|
|
property string communityColor: community.communityColor || Style.current.blue
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
|
|
|
|
id: popup
|
|
|
|
|
|
|
|
|
|
header: Item {
|
|
|
|
|
height: childrenRect.height
|
|
|
|
|
width: parent.width
|
|
|
|
|
|
2021-03-23 15:13:36 -04:00
|
|
|
|
|
|
|
|
|
Loader {
|
2020-12-11 15:29:46 -05:00
|
|
|
|
id: communityImg
|
2021-03-23 15:13:36 -04:00
|
|
|
|
sourceComponent: !!popup.source ? commmunityImgCmp : letterIdenticonCmp
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: commmunityImgCmp
|
|
|
|
|
RoundedImage {
|
|
|
|
|
source: popup.source
|
|
|
|
|
width: 40
|
|
|
|
|
height: 40
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: letterIdenticonCmp
|
|
|
|
|
StatusLetterIdenticon {
|
|
|
|
|
width: 40
|
|
|
|
|
height: 40
|
|
|
|
|
chatName: popup.name
|
|
|
|
|
color: popup.communityColor
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledTextEdit {
|
|
|
|
|
id: communityName
|
|
|
|
|
text: popup.name
|
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
anchors.topMargin: 2
|
|
|
|
|
anchors.left: communityImg.right
|
|
|
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
|
|
|
font.bold: true
|
|
|
|
|
font.pixelSize: 17
|
|
|
|
|
readOnly: true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledText {
|
2021-02-10 15:37:17 -05:00
|
|
|
|
id: accessText
|
2020-12-11 15:38:10 -05:00
|
|
|
|
text: {
|
|
|
|
|
switch(access) {
|
2021-02-18 11:36:05 -05:00
|
|
|
|
//% "Public community"
|
|
|
|
|
case Constants.communityChatPublicAccess: return qsTrId("public-community");
|
|
|
|
|
//% "Invitation only community"
|
|
|
|
|
case Constants.communityChatInvitationOnlyAccess: return qsTrId("invitation-only-community");
|
|
|
|
|
//% "On request community"
|
|
|
|
|
case Constants.communityChatOnRequestAccess: return qsTrId("on-request-community");
|
|
|
|
|
//% "Unknown community"
|
|
|
|
|
default: return qsTrId("unknown-community");
|
2020-12-11 15:38:10 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
anchors.left: communityName.left
|
|
|
|
|
anchors.top: communityName.bottom
|
|
|
|
|
anchors.topMargin: 2
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Thin
|
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
|
}
|
2021-02-10 15:37:17 -05:00
|
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
|
visible: popup.ensOnly
|
|
|
|
|
text: qsTr(" - ENS Only")
|
|
|
|
|
anchors.left: accessText.right
|
|
|
|
|
anchors.verticalCenter: accessText.verticalCenter
|
|
|
|
|
anchors.topMargin: 2
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Thin
|
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
|
id: descriptionText
|
|
|
|
|
text: popup.description
|
2020-12-15 12:04:19 -04:00
|
|
|
|
wrapMode: Text.Wrap
|
2020-12-11 15:29:46 -05:00
|
|
|
|
width: parent.width
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Thin
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Item {
|
|
|
|
|
id: memberContainer
|
|
|
|
|
width: parent.width
|
|
|
|
|
height: memberImage.height
|
|
|
|
|
anchors.top: descriptionText.bottom
|
|
|
|
|
anchors.topMargin: Style.current.padding
|
|
|
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
|
id: memberImage
|
|
|
|
|
source: "../../../img/member.svg"
|
|
|
|
|
width: 16
|
|
|
|
|
height: 16
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
StyledText {
|
2020-12-15 12:04:19 -04:00
|
|
|
|
text: nbMembers === 1 ?
|
2021-02-18 11:36:05 -05:00
|
|
|
|
//% "1 member"
|
|
|
|
|
qsTrId("1-member") :
|
|
|
|
|
//% "%1 members"
|
|
|
|
|
qsTrId("-1-members").arg(popup.nbMembers)
|
2020-12-11 15:29:46 -05:00
|
|
|
|
wrapMode: Text.WrapAnywhere
|
|
|
|
|
width: parent.width
|
|
|
|
|
anchors.left: memberImage.right
|
|
|
|
|
anchors.leftMargin: 4
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Medium
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
|
id: sep1
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
anchors.top: memberContainer.bottom
|
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
|
id: chatsTitle
|
2021-02-18 11:36:05 -05:00
|
|
|
|
//% "Chats"
|
|
|
|
|
text: qsTrId("chats")
|
2020-12-11 15:29:46 -05:00
|
|
|
|
anchors.top: sep1.bottom
|
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Thin
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ListView {
|
|
|
|
|
id: chatsList
|
|
|
|
|
width: parent.width
|
|
|
|
|
anchors.top: chatsTitle.bottom
|
|
|
|
|
anchors.topMargin: 4
|
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
|
clip: true
|
|
|
|
|
model: community.chats
|
2020-12-15 12:04:19 -04:00
|
|
|
|
boundsBehavior: Flickable.StopAtBounds
|
2020-12-11 15:29:46 -05:00
|
|
|
|
delegate: Channel {
|
|
|
|
|
id: channelItem
|
|
|
|
|
unviewedMessagesCount: ""
|
|
|
|
|
width: parent.width
|
|
|
|
|
name: model.name
|
|
|
|
|
lastMessage: model.description
|
|
|
|
|
contentType: Constants.messageType
|
|
|
|
|
color: Style.current.transparent
|
2020-12-15 12:04:19 -04:00
|
|
|
|
enableMouseArea: false
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
|
footer: Item {
|
2021-01-13 14:15:52 -05:00
|
|
|
|
width: parent.width
|
|
|
|
|
height: backButton.height
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
|
|
|
|
StatusIconButton {
|
|
|
|
|
id: backButton
|
|
|
|
|
icon.name: "leave_chat"
|
|
|
|
|
width: 44
|
|
|
|
|
height: 44
|
|
|
|
|
iconColor: Style.current.primary
|
|
|
|
|
highlighted: true
|
|
|
|
|
icon.color: Style.current.primary
|
|
|
|
|
icon.width: 28
|
|
|
|
|
icon.height: 28
|
|
|
|
|
radius: width / 2
|
|
|
|
|
onClicked: {
|
|
|
|
|
openPopup(communitiesPopupComponent)
|
|
|
|
|
popup.close()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StatusButton {
|
2021-02-10 15:37:17 -05:00
|
|
|
|
property bool isPendingRequest: {
|
|
|
|
|
if (access !== Constants.communityChatOnRequestAccess) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
2021-02-11 15:37:31 -05:00
|
|
|
|
return chatsModel.communities.isCommunityRequestPending(communityId)
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
|
|
|
|
text: {
|
|
|
|
|
if (ensOnly && !profileModel.profile.ensVerified) {
|
|
|
|
|
return qsTr("Membership requires an ENS username")
|
|
|
|
|
}
|
|
|
|
|
if (canJoin) {
|
|
|
|
|
return qsTr("Join ‘%1’").arg(popup.name);
|
|
|
|
|
}
|
|
|
|
|
if (isPendingRequest) {
|
|
|
|
|
return qsTr("Pending")
|
|
|
|
|
}
|
|
|
|
|
switch(access) {
|
|
|
|
|
case Constants.communityChatPublicAccess: return qsTr("Join ‘%1’").arg(popup.name);
|
|
|
|
|
case Constants.communityChatInvitationOnlyAccess: return qsTr("You need to be invited");
|
|
|
|
|
case Constants.communityChatOnRequestAccess: return qsTr("Request to join ‘%1’").arg(popup.name);
|
|
|
|
|
default: return qsTr("Unknown community");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
enabled: {
|
|
|
|
|
if (ensOnly && !profileModel.profile.ensVerified) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
if (canJoin) {
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
if (access === Constants.communityChatInvitationOnlyAccess || isPendingRequest) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
onClicked: {
|
2021-02-10 15:37:17 -05:00
|
|
|
|
let error
|
2021-03-09 12:50:45 +01:00
|
|
|
|
if (access === Constants.communityChatOnRequestAccess && !popup.isMember) {
|
2021-02-11 15:37:31 -05:00
|
|
|
|
error = chatsModel.communities.requestToJoinCommunity(popup.communityId,
|
2021-02-10 15:37:17 -05:00
|
|
|
|
profileModel.profile.ensVerified ? profileModel.profile.username : "")
|
|
|
|
|
if (!error) {
|
|
|
|
|
enabled = false
|
|
|
|
|
text = qsTr("Pending")
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2021-03-05 10:05:04 +01:00
|
|
|
|
error = chatsModel.communities.joinCommunity(popup.communityId, true)
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
|
joiningError.text = error
|
|
|
|
|
return joiningError.open()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
popup.close()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MessageDialog {
|
|
|
|
|
id: joiningError
|
2021-02-18 11:36:05 -05:00
|
|
|
|
//% "Error joining the community"
|
|
|
|
|
title: qsTrId("error-joining-the-community")
|
2020-12-11 15:29:46 -05:00
|
|
|
|
icon: StandardIcon.Critical
|
|
|
|
|
standardButtons: StandardButton.Ok
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|