2020-12-11 15:29:46 -05:00
|
|
|
|
import QtQuick 2.12
|
2021-07-19 14:25:52 +02:00
|
|
|
|
import QtQuick.Controls 2.3
|
2020-12-11 15:29:46 -05:00
|
|
|
|
import QtQuick.Dialogs 1.3
|
2021-07-19 14:25:52 +02:00
|
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
|
import utils 1.0
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
StatusModal {
|
2021-10-22 23:49:47 +03:00
|
|
|
|
id: root
|
|
|
|
|
|
|
|
|
|
property var store
|
2021-12-16 10:24:25 -05:00
|
|
|
|
property QtObject community: root.store.communitiesModuleInst.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-12-16 10:24:25 -05:00
|
|
|
|
property string source: community.image
|
2022-01-11 16:53:18 -05:00
|
|
|
|
property int nbMembers: community.members.count
|
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-12-16 10:24:25 -05:00
|
|
|
|
property string communityColor: community.color || Style.current.blue
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
header.title: name
|
|
|
|
|
header.subTitle: {
|
|
|
|
|
let subTitle = ""
|
|
|
|
|
switch(access) {
|
|
|
|
|
case Constants.communityChatPublicAccess:
|
2022-04-04 13:26:30 +02:00
|
|
|
|
subTitle = qsTr("Public community");
|
2021-07-19 14:25:52 +02:00
|
|
|
|
break;
|
2022-02-09 10:43:23 +01:00
|
|
|
|
case Constants.communityChatInvitationOnlyAccess:
|
2022-04-04 13:26:30 +02:00
|
|
|
|
subTitle = qsTr("Invitation only community");
|
2021-07-19 14:25:52 +02:00
|
|
|
|
break;
|
2022-02-09 10:43:23 +01:00
|
|
|
|
case Constants.communityChatOnRequestAccess:
|
2022-04-04 13:26:30 +02:00
|
|
|
|
subTitle = qsTr("On request community");
|
2021-07-19 14:25:52 +02:00
|
|
|
|
break;
|
2021-12-16 10:24:25 -05:00
|
|
|
|
default:
|
|
|
|
|
subTitle = qsTr("Unknown community");
|
2021-07-19 14:25:52 +02:00
|
|
|
|
break;
|
2021-03-23 15:13:36 -04:00
|
|
|
|
}
|
2021-07-19 14:25:52 +02:00
|
|
|
|
if (ensOnly) {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
subTitle += qsTr(" - ENS only")
|
2021-03-23 15:13:36 -04:00
|
|
|
|
}
|
2021-07-19 14:25:52 +02:00
|
|
|
|
return subTitle
|
|
|
|
|
}
|
2021-03-23 15:13:36 -04:00
|
|
|
|
|
2021-09-02 17:40:10 +03:00
|
|
|
|
contentItem: Column {
|
2021-10-22 23:49:47 +03:00
|
|
|
|
width: root.width
|
2021-07-19 14:25:52 +02:00
|
|
|
|
|
|
|
|
|
Item {
|
|
|
|
|
height: childrenRect.height + 8
|
|
|
|
|
width: parent.width - 32
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
|
id: description
|
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
anchors.topMargin: 16
|
2021-10-22 23:49:47 +03:00
|
|
|
|
text: root.description
|
2021-07-19 14:25:52 +02:00
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
|
wrapMode: Text.WordWrap
|
2021-07-26 15:53:39 +02:00
|
|
|
|
width: parent.width
|
2022-03-28 15:53:50 +03:00
|
|
|
|
textFormat: Text.PlainText
|
2021-03-23 15:13:36 -04:00
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
StatusIcon {
|
|
|
|
|
id: statusIcon
|
|
|
|
|
anchors.top: description.bottom
|
|
|
|
|
anchors.topMargin: 16
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
|
icon: "tiny/contact"
|
|
|
|
|
width: 16
|
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
StatusBaseText {
|
2022-09-27 23:26:26 +02:00
|
|
|
|
text: qsTr("%n member(s)", "", nbMembers)
|
2021-07-19 14:25:52 +02:00
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Medium
|
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
|
anchors.left: statusIcon.right
|
|
|
|
|
anchors.leftMargin: 2
|
|
|
|
|
anchors.verticalCenter: statusIcon.verticalCenter
|
2020-12-11 15:38:10 -05:00
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
2021-02-10 15:37:17 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
StatusModalDivider {
|
|
|
|
|
topPadding: 8
|
|
|
|
|
bottomPadding: 8
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
Item {
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
width: parent.width - 32
|
|
|
|
|
height: 34
|
|
|
|
|
StatusBaseText {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
text: qsTr("Channels")
|
2021-07-19 14:25:52 +02:00
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
|
anchors.bottomMargin: 4
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
|
StatusScrollView {
|
2021-10-22 23:49:47 +03:00
|
|
|
|
width: root.width
|
2021-07-19 14:25:52 +02:00
|
|
|
|
height: 300
|
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
2022-07-13 15:29:38 +03:00
|
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
|
StatusListView {
|
2021-07-19 14:25:52 +02:00
|
|
|
|
id: chatList
|
|
|
|
|
anchors.fill: parent
|
|
|
|
|
model: community.chats
|
|
|
|
|
delegate: StatusListItem {
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
title: "#" + model.name
|
|
|
|
|
subTitle: model.description
|
2022-08-11 14:55:08 +03:00
|
|
|
|
asset.isLetterIdenticon: true
|
|
|
|
|
asset.bgColor: root.communityColor
|
2021-07-19 14:25:52 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
leftButtons: [
|
2022-08-02 16:48:07 +03:00
|
|
|
|
StatusBackButton {
|
2020-12-11 15:29:46 -05:00
|
|
|
|
id: backButton
|
|
|
|
|
onClicked: {
|
2021-10-22 23:49:47 +03:00
|
|
|
|
root.close()
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-19 14:25:52 +02:00
|
|
|
|
]
|
2020-12-11 15:29:46 -05:00
|
|
|
|
|
2021-07-19 14:25:52 +02:00
|
|
|
|
rightButtons: [
|
2020-12-11 15:29:46 -05:00
|
|
|
|
StatusButton {
|
2021-02-10 15:37:17 -05:00
|
|
|
|
property bool isPendingRequest: {
|
|
|
|
|
if (access !== Constants.communityChatOnRequestAccess) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
2022-01-28 15:44:52 -05:00
|
|
|
|
return false
|
2021-12-13 15:24:21 +01:00
|
|
|
|
// Not Refactored Yet
|
|
|
|
|
// return root.store.chatsModelInst.communities.isCommunityRequestPending(root.communityId)
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
|
|
|
|
text: {
|
2021-12-13 15:24:21 +01:00
|
|
|
|
// Not Refactored Yet
|
|
|
|
|
// if (root.ensOnly && !root.store.profileModelInst.profile.ensVerified) {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
// return qsTr("Membership requires an ENS username")
|
2021-12-13 15:24:21 +01:00
|
|
|
|
// }
|
2021-10-22 23:49:47 +03:00
|
|
|
|
if (root.canJoin) {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
return qsTr("Join ‘%1’").arg(root.name);
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
|
|
|
|
if (isPendingRequest) {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
return qsTr("Pending")
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
2021-10-22 23:49:47 +03:00
|
|
|
|
switch(root.access) {
|
2022-04-04 13:26:30 +02:00
|
|
|
|
case Constants.communityChatPublicAccess: return qsTr("Join ‘%1’").arg(root.name);
|
|
|
|
|
case Constants.communityChatInvitationOnlyAccess: return qsTr("You need to be invited");
|
|
|
|
|
case Constants.communityChatOnRequestAccess: return qsTr("Request to join ‘%1’").arg(root.name);
|
|
|
|
|
default: return qsTr("Unknown community");
|
2021-02-10 15:37:17 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
enabled: {
|
2021-12-13 15:24:21 +01:00
|
|
|
|
// Not Refactored Yet
|
|
|
|
|
// if (root.ensOnly && !root.store.profileModelInst.profile.ensVerified) {
|
|
|
|
|
// return false
|
|
|
|
|
// }
|
2021-10-22 23:49:47 +03:00
|
|
|
|
if (root.access === Constants.communityChatInvitationOnlyAccess || isPendingRequest) {
|
2021-02-10 15:37:17 -05:00
|
|
|
|
return false
|
|
|
|
|
}
|
2021-04-29 15:54:09 -04:00
|
|
|
|
if (canJoin) {
|
|
|
|
|
return true
|
|
|
|
|
}
|
2021-02-10 15:37:17 -05:00
|
|
|
|
return true
|
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
onClicked: {
|
2021-12-13 15:24:21 +01:00
|
|
|
|
// Not Refactored Yet
|
2021-12-16 10:24:25 -05:00
|
|
|
|
let error
|
2022-01-28 15:44:52 -05:00
|
|
|
|
if (access === Constants.communityChatOnRequestAccess &&
|
|
|
|
|
!root.community.amISectionAdmin
|
|
|
|
|
&& !root.isMember) {
|
2021-12-16 10:24:25 -05:00
|
|
|
|
// TODO refactor
|
|
|
|
|
return
|
|
|
|
|
// error = root.store.chatsModelInst.communities.requestToJoinCommunity(root.communityId, userProfile.name)
|
|
|
|
|
// if (!error) {
|
|
|
|
|
// enabled = false
|
2022-04-04 13:26:30 +02:00
|
|
|
|
// text = qsTr("Pending")
|
2021-12-16 10:24:25 -05:00
|
|
|
|
// }
|
|
|
|
|
} else {
|
2022-12-13 12:37:27 +03:00
|
|
|
|
error = root.store.communitiesModuleInst.requestToJoinCommunity(root.communityId, root.store.userProfileInst.preferredName)
|
2021-12-16 10:24:25 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (error) {
|
|
|
|
|
joiningError.text = error
|
|
|
|
|
return joiningError.open()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
root.close()
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-07-19 14:25:52 +02:00
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
MessageDialog {
|
|
|
|
|
id: joiningError
|
2022-04-04 13:26:30 +02:00
|
|
|
|
title: qsTr("Error joining the community")
|
2021-07-19 14:25:52 +02:00
|
|
|
|
icon: StandardIcon.Critical
|
|
|
|
|
standardButtons: StandardButton.Ok
|
2020-12-11 15:29:46 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|