status-desktop/ui/app/AppLayouts/Chat/CommunityComponents/CommunitiesPopup.qml

170 lines
5.3 KiB
QML
Raw Normal View History

2020-12-11 20:29:46 +00:00
import QtQuick 2.12
import QtQuick.Controls 2.3
import QtQuick.Layouts 1.3
import QtQml.Models 2.3
import QtGraphicalEffects 1.13
import "../../../../imports"
import "../../../../shared"
import "../../../../shared/status"
ModalPopup {
id: popup
onOpened: {
searchBox.text = "";
searchBox.forceActiveFocus(Qt.MouseFocusReason)
}
2021-02-18 16:36:05 +00:00
//% "Communities"
title: qsTrId("communities")
2020-12-11 20:29:46 +00:00
SearchBox {
id: searchBox
2021-02-18 16:36:05 +00:00
//% "Search for communities or topics"
placeholderText: qsTrId("search-for-communities-or-topics")
2020-12-11 20:29:46 +00:00
iconWidth: 17
iconHeight: 17
customHeight: 36
fontPixelSize: 15
}
ScrollView {
id: scrollView
width: parent.width
anchors.topMargin: Style.current.padding
anchors.top: searchBox.bottom
anchors.bottom: parent.bottom
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
ScrollBar.vertical.policy: communitiesList.contentHeight > communitiesList.height ? ScrollBar.AlwaysOn : ScrollBar.AlwaysOff
ListView {
anchors.fill: parent
model: communitiesDelegateModel
2020-12-11 20:29:46 +00:00
spacing: 4
clip: true
id: communitiesList
2020-12-15 16:04:19 +00:00
section.property: "name"
section.criteria: ViewSection.FirstCharacter
section.delegate: Column {
width: parent.width
height: childrenRect.height + Style.current.halfPadding
StyledText {
text: section.toUpperCase()
2020-12-15 16:04:19 +00:00
}
Separator {
anchors.left: popup.left
anchors.right: popup.right
}
}
}
DelegateModelGeneralized {
id: communitiesDelegateModel
lessThan: [
function(left, right) {
return left.name.toLowerCase() < right.name.toLowerCase()
}
]
model: chatsModel.communities.list
2020-12-11 20:29:46 +00:00
delegate: Item {
// TODO add the search for the name and category once they exist
2020-12-11 20:38:10 +00:00
visible: {
if (!searchBox.text) {
return true
}
const lowerCaseSearchStr = searchBox.text.toLowerCase()
return name.toLowerCase().includes(lowerCaseSearchStr) || description.toLowerCase().includes(lowerCaseSearchStr)
}
2020-12-15 16:04:19 +00:00
height: visible ? communityImage.height + Style.current.padding : 0
2020-12-11 20:29:46 +00:00
width: parent.width
RoundedImage {
id: communityImage
width: 40
height: 40
source: thumbnailImage
2020-12-11 20:29:46 +00:00
}
StyledText {
id: communityName
text: name
anchors.left: communityImage.right
anchors.leftMargin: Style.current.padding
font.pixelSize: 17
font.weight: Font.Bold
}
StyledText {
id: communityDesc
text: description
anchors.left: communityName.left
anchors.right: parent.right
anchors.top: communityName.bottom
font.pixelSize: 15
font.weight: Font.Thin
elide: Text.ElideRight
}
2020-12-15 16:04:19 +00:00
StyledText {
id: communityMembers
text: nbMembers === 1 ?
qsTr("1 member") :
qsTr("%1 members").arg(nbMembers)
2020-12-15 16:04:19 +00:00
anchors.left: communityDesc.left
anchors.right: parent.right
anchors.top: communityDesc.bottom
font.pixelSize: 13
color: Style.current.secondaryText
font.weight: Font.Thin
}
2020-12-11 20:29:46 +00:00
MouseArea {
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
onClicked: {
if (joined && isMember) {
chatsModel.communities.setActiveCommunity(id)
2020-12-11 20:29:46 +00:00
} else {
chatsModel.communities.setObservedCommunity(id)
2020-12-11 20:29:46 +00:00
openPopup(communityDetailPopup)
}
popup.close()
}
}
}
}
}
2020-12-11 20:38:10 +00:00
2020-12-18 20:55:33 +00:00
footer: Item {
width: parent.width
height: importBtn.height
2020-12-18 20:55:33 +00:00
StatusButton {
id: importBtn
2021-02-18 16:36:05 +00:00
//% "Import a community"
text: qsTrId("import-community")
2020-12-18 20:55:33 +00:00
anchors.right: createBtn.left
anchors.rightMargin: Style.current.smallPadding
onClicked: {
openPopup(importCommunitiesPopupComponent)
popup.close()
}
}
StatusButton {
id: createBtn
2021-02-18 16:36:05 +00:00
//% "Create a community"
text: qsTrId("create-community")
2020-12-18 20:55:33 +00:00
anchors.right: parent.right
onClicked: {
openPopup(createCommunitiesPopupComponent)
popup.close()
}
2020-12-11 20:29:46 +00:00
}
}
}