2021-02-10 15:37:17 -05:00
|
|
|
import QtQuick 2.12
|
2021-07-20 11:50:36 +02:00
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2021-02-10 15:37:17 -05:00
|
|
|
|
2021-07-20 11:50:36 +02:00
|
|
|
StatusModal {
|
2021-02-10 15:37:17 -05:00
|
|
|
id: popup
|
2021-10-22 23:49:47 +03:00
|
|
|
property var store
|
2022-01-18 15:54:14 -05:00
|
|
|
property var communitySectionModule
|
2022-06-21 13:44:20 +02:00
|
|
|
property var communityData
|
2021-02-10 15:37:17 -05:00
|
|
|
onOpened: {
|
2021-09-07 15:51:32 +02:00
|
|
|
contentItem.errorText.text = ""
|
2021-02-10 15:37:17 -05:00
|
|
|
}
|
|
|
|
|
2022-04-04 13:26:30 +02:00
|
|
|
header.title: qsTr("Membership requests")
|
2021-09-07 15:51:32 +02:00
|
|
|
header.subTitle: contentItem.membershipRequestList.count
|
2021-02-10 15:37:17 -05:00
|
|
|
|
2021-09-02 17:40:10 +03:00
|
|
|
contentItem: Column {
|
2021-07-20 11:50:36 +02:00
|
|
|
property alias errorText: errorText
|
|
|
|
property alias membershipRequestList: membershipRequestList
|
|
|
|
width: popup.width
|
2021-02-10 15:37:17 -05:00
|
|
|
|
2021-07-20 11:50:36 +02:00
|
|
|
StatusBaseText {
|
2021-02-10 15:37:17 -05:00
|
|
|
id: errorText
|
|
|
|
visible: !!text
|
|
|
|
height: visible ? implicitHeight : 0
|
2021-07-20 11:50:36 +02:00
|
|
|
color: Theme.palette.dangerColor1
|
2021-02-10 15:37:17 -05:00
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
wrapMode: Text.Wrap
|
|
|
|
width: parent.width
|
|
|
|
}
|
|
|
|
|
2021-07-20 11:50:36 +02:00
|
|
|
Item {
|
|
|
|
height: 8
|
|
|
|
width: parent.width
|
|
|
|
}
|
2021-02-10 15:37:17 -05:00
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
StatusScrollView {
|
2021-07-20 11:50:36 +02:00
|
|
|
width: parent.width
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
topPadding: 8
|
|
|
|
bottomPadding: 8
|
|
|
|
height: 300
|
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
StatusListView {
|
2021-07-20 11:50:36 +02:00
|
|
|
id: membershipRequestList
|
2022-08-05 17:22:22 +03:00
|
|
|
width: parent.width
|
|
|
|
height: parent.height
|
2022-06-21 13:44:20 +02:00
|
|
|
model: popup.communityData.pendingRequestsToJoin
|
2021-07-20 11:50:36 +02:00
|
|
|
|
|
|
|
delegate: StatusListItem {
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2022-01-21 14:18:56 -05:00
|
|
|
property var contactDetails: Utils.getContactDetailsAsJson(model.pubKey)
|
2021-07-20 11:50:36 +02:00
|
|
|
|
2022-05-10 19:04:25 +03:00
|
|
|
property string displayName: contactDetails.displayName || popup.store.generateAlias(model.pubKey)
|
2022-03-30 17:30:28 +02:00
|
|
|
image.source: contactDetails.thumbnailImage
|
2021-07-20 11:50:36 +02:00
|
|
|
title: displayName
|
|
|
|
|
|
|
|
components: [
|
|
|
|
StatusRoundIcon {
|
|
|
|
icon.name: "thumbs-up"
|
|
|
|
icon.color: Theme.palette.white
|
|
|
|
icon.background.width: 28
|
|
|
|
icon.background.height: 28
|
|
|
|
icon.background.color: Theme.palette.successColor1
|
|
|
|
MouseArea {
|
|
|
|
id: thumbsUpSensor
|
|
|
|
hoverEnabled: true
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
2022-01-18 15:54:14 -05:00
|
|
|
onClicked: communitySectionModule.acceptRequestToJoinCommunity(id)
|
2021-02-10 15:37:17 -05:00
|
|
|
}
|
2021-07-20 11:50:36 +02:00
|
|
|
},
|
|
|
|
StatusRoundIcon {
|
|
|
|
icon.name: "thumbs-down"
|
|
|
|
icon.color: Theme.palette.white
|
|
|
|
icon.background.width: 28
|
|
|
|
icon.background.height: 28
|
|
|
|
icon.background.color: Theme.palette.dangerColor1
|
|
|
|
MouseArea {
|
|
|
|
id: thumbsDownSensor
|
|
|
|
hoverEnabled: true
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
2022-01-18 15:54:14 -05:00
|
|
|
onClicked: communitySectionModule.declineRequestToJoinCommunity(id)
|
2021-02-10 15:37:17 -05:00
|
|
|
}
|
|
|
|
}
|
2021-07-20 11:50:36 +02:00
|
|
|
]
|
2021-02-10 15:37:17 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-20 11:50:36 +02:00
|
|
|
leftButtons: [
|
2022-08-02 16:48:07 +03:00
|
|
|
StatusBackButton {
|
2021-07-20 11:50:36 +02:00
|
|
|
onClicked: popup.close()
|
|
|
|
}
|
|
|
|
]
|
2021-02-10 15:37:17 -05:00
|
|
|
}
|