2020-12-11 15:29:46 -05:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
import QtQuick.Layouts 1.3
|
2021-07-19 13:21:05 +02:00
|
|
|
|
|
|
|
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
|
2020-12-11 15:29:46 -05:00
|
|
|
|
2021-07-19 13:21:05 +02:00
|
|
|
StatusModal {
|
2020-12-11 15:29:46 -05:00
|
|
|
id: popup
|
|
|
|
|
2021-10-22 23:49:47 +03:00
|
|
|
property var communitiesList
|
|
|
|
signal setActiveCommunity(string id)
|
|
|
|
signal setObservedCommunity(string id)
|
|
|
|
|
2020-12-11 15:29:46 -05:00
|
|
|
onOpened: {
|
2021-09-07 15:42:50 +02:00
|
|
|
contentItem.searchBox.input.text = "";
|
|
|
|
contentItem.searchBox.input.forceActiveFocus(Qt.MouseFocusReason)
|
2020-12-11 15:29:46 -05:00
|
|
|
}
|
|
|
|
|
2021-07-22 17:03:59 +02:00
|
|
|
//% "Communities"
|
|
|
|
header.title: qsTrId("communities")
|
2021-07-19 13:21:05 +02:00
|
|
|
headerActionButton: StatusFlatRoundButton {
|
|
|
|
type: StatusFlatRoundButton.Type.Secondary
|
|
|
|
width: 32
|
|
|
|
height: 32
|
|
|
|
icon.name: "more"
|
|
|
|
|
|
|
|
onClicked: contextMenu.popup(-contextMenu.width+width, height + 4)
|
|
|
|
|
|
|
|
StatusPopupMenu {
|
|
|
|
id: contextMenu
|
|
|
|
StatusMenuItem {
|
|
|
|
icon.name: "download"
|
2021-07-22 17:03:59 +02:00
|
|
|
//% "Access existing community"
|
|
|
|
text: qsTrId("access-existing-community")
|
2021-12-07 22:33:12 +02:00
|
|
|
onTriggered: Global.openPopup(importCommunitiesPopupComponent)
|
2021-07-19 13:21:05 +02:00
|
|
|
}
|
2021-02-12 13:19:31 -05:00
|
|
|
}
|
2021-07-19 13:21:05 +02:00
|
|
|
}
|
2021-02-12 13:19:31 -05:00
|
|
|
|
2021-09-02 17:40:10 +03:00
|
|
|
contentItem: Column {
|
2021-07-19 13:21:05 +02:00
|
|
|
width: popup.width
|
2021-07-26 15:34:19 +02:00
|
|
|
property alias searchBox: searchBox
|
2021-02-12 13:19:31 -05:00
|
|
|
|
2021-08-17 12:00:02 +02:00
|
|
|
Item {
|
|
|
|
height: 8
|
|
|
|
width: parent.width
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusInput {
|
|
|
|
id: searchBox
|
|
|
|
input.placeholderText: qsTr("Search for communities or topics")
|
|
|
|
input.icon.name: "search"
|
|
|
|
input.height: 36
|
|
|
|
input.topPadding: 9
|
2021-02-12 13:19:31 -05:00
|
|
|
}
|
|
|
|
|
2021-08-17 12:00:02 +02:00
|
|
|
StatusModalDivider { topPadding: 8 }
|
2020-12-11 15:29:46 -05:00
|
|
|
|
2021-07-19 13:21:05 +02:00
|
|
|
ScrollView {
|
|
|
|
width: parent.width
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
topPadding: 8
|
|
|
|
bottomPadding: 8
|
|
|
|
height: 400
|
2020-12-11 15:29:46 -05:00
|
|
|
clip: true
|
2021-06-22 14:30:51 -04:00
|
|
|
|
2021-07-19 13:21:05 +02:00
|
|
|
ListView {
|
|
|
|
anchors.fill: parent
|
|
|
|
model: communitiesDelegateModel
|
|
|
|
spacing: 4
|
|
|
|
clip: true
|
|
|
|
id: communitiesList
|
|
|
|
|
|
|
|
section.property: "name"
|
|
|
|
section.criteria: ViewSection.FirstCharacter
|
|
|
|
section.delegate: Column {
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: 16
|
|
|
|
text: section.toUpperCase()
|
|
|
|
font.pixelSize: 15
|
|
|
|
font.weight: Font.Medium
|
|
|
|
color: Theme.palette.directColor1
|
2021-06-22 14:30:51 -04:00
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
|
2021-07-23 11:01:09 +02:00
|
|
|
StatusModalDivider {
|
|
|
|
bottomPadding: 8
|
|
|
|
}
|
2021-03-23 15:13:36 -04:00
|
|
|
}
|
2021-07-19 13:21:05 +02:00
|
|
|
}
|
2021-03-23 15:13:36 -04:00
|
|
|
|
2021-07-19 13:21:05 +02:00
|
|
|
DelegateModelGeneralized {
|
|
|
|
id: communitiesDelegateModel
|
|
|
|
lessThan: [
|
|
|
|
function(left, right) {
|
|
|
|
return left.name.toLowerCase() < right.name.toLowerCase()
|
2021-03-23 15:13:36 -04:00
|
|
|
}
|
2021-07-19 13:21:05 +02:00
|
|
|
]
|
2021-03-23 15:13:36 -04:00
|
|
|
|
2021-10-22 23:49:47 +03:00
|
|
|
model: popup.communitiesList
|
2021-07-19 13:21:05 +02:00
|
|
|
delegate: StatusListItem {
|
|
|
|
visible: {
|
2021-08-17 12:00:02 +02:00
|
|
|
if (!searchBox.input.text) {
|
2021-07-19 13:21:05 +02:00
|
|
|
return true
|
|
|
|
}
|
2021-08-17 12:00:02 +02:00
|
|
|
const lowerCaseSearchStr = searchBox.input.text.toLowerCase()
|
2022-01-25 15:07:03 -05:00
|
|
|
return model.name.toLowerCase().includes(lowerCaseSearchStr) || model.description.toLowerCase().includes(lowerCaseSearchStr)
|
2021-03-23 15:13:36 -04:00
|
|
|
}
|
2021-07-19 13:21:05 +02:00
|
|
|
height: visible ? implicitHeight : 0
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2022-01-25 15:07:03 -05:00
|
|
|
title: model.name
|
|
|
|
subTitle: model.description
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "%1 members"
|
2022-01-25 15:07:03 -05:00
|
|
|
tertiaryTitle: qsTrId("-1-members").arg(model.members.count)
|
2021-07-23 11:01:09 +02:00
|
|
|
statusListItemTitle.font.weight: Font.Bold
|
|
|
|
statusListItemTitle.font.pixelSize: 17
|
2021-12-14 14:21:50 -05:00
|
|
|
image.source: model.image
|
2022-01-25 15:07:03 -05:00
|
|
|
icon.isLetterIdenticon: !model.image
|
|
|
|
icon.background.color: model.color || Theme.palette.primaryColor1
|
2021-07-19 13:21:05 +02:00
|
|
|
|
|
|
|
sensor.onClicked: {
|
2022-01-25 15:07:03 -05:00
|
|
|
if (model.joined && model.isMember) {
|
|
|
|
popup.setActiveCommunity(model.id);
|
2020-12-11 15:29:46 -05:00
|
|
|
} else {
|
2022-01-25 15:07:03 -05:00
|
|
|
popup.setObservedCommunity(model.id);
|
2021-12-07 22:33:12 +02:00
|
|
|
Global.openPopup(communityDetailPopup)
|
2020-12-11 15:29:46 -05:00
|
|
|
}
|
|
|
|
popup.close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-12-11 15:38:10 -05:00
|
|
|
|
2021-07-19 13:21:05 +02:00
|
|
|
rightButtons: [
|
|
|
|
StatusButton {
|
2021-07-22 17:03:59 +02:00
|
|
|
//% "Create a community"
|
|
|
|
text: qsTrId("create-community")
|
2021-07-19 13:21:05 +02:00
|
|
|
onClicked: {
|
2021-12-07 22:33:12 +02:00
|
|
|
Global.openPopup(createCommunitiesPopupComponent)
|
2021-07-19 13:21:05 +02:00
|
|
|
popup.close()
|
|
|
|
}
|
2020-12-11 15:29:46 -05:00
|
|
|
}
|
2021-07-19 13:21:05 +02:00
|
|
|
]
|
2020-12-11 15:29:46 -05:00
|
|
|
}
|
|
|
|
|