2024-10-15 21:26:12 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import QtGraphicalEffects 1.15
|
2023-10-31 18:55:41 +01:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
|
|
import AppLayouts.Communities.panels 1.0
|
|
|
|
import AppLayouts.Chat.views 1.0
|
|
|
|
|
|
|
|
import StatusQ.Layout 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
|
|
|
|
StatusSectionLayout {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
// General properties:
|
|
|
|
property string name
|
|
|
|
property string communityDesc
|
|
|
|
property color color
|
|
|
|
property string channelName
|
|
|
|
property string channelDesc
|
|
|
|
|
|
|
|
// Blur view properties:
|
|
|
|
property int membersCount
|
|
|
|
property url image
|
|
|
|
property var communityItemsModel
|
|
|
|
property string chatDateTimeText
|
|
|
|
property string listUsersText
|
|
|
|
property var messagesModel
|
|
|
|
|
|
|
|
signal adHocChatButtonClicked
|
|
|
|
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
readonly property int blurryRadius: 32
|
|
|
|
}
|
|
|
|
|
|
|
|
headerContent: JoinCommunityHeaderPanel {
|
|
|
|
color: root.color
|
|
|
|
name: root.name
|
|
|
|
channelName: root.channelName
|
|
|
|
communityDesc: root.communityDesc
|
|
|
|
channelDesc: root.channelDesc
|
|
|
|
}
|
|
|
|
|
|
|
|
// Blur background:
|
|
|
|
leftPanel: ColumnLayout {
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
ColumnHeaderPanel {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
name: root.name
|
|
|
|
membersCount: root.membersCount
|
|
|
|
image: root.image
|
|
|
|
color: root.color
|
|
|
|
amISectionAdmin: false
|
|
|
|
openCreateChat: false
|
|
|
|
onAdHocChatButtonClicked: root.adHocChatButtonClicked()
|
|
|
|
}
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Layout.fillWidth: true
|
2024-10-15 21:26:12 +02:00
|
|
|
Layout.margins: Theme.halfPadding
|
2023-10-31 18:55:41 +01:00
|
|
|
layer.enabled: true
|
|
|
|
layer.effect: fastBlur
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
model: root.communityItemsModel
|
|
|
|
delegate: StatusChatListItem {
|
|
|
|
enabled: false
|
|
|
|
name: model.name
|
|
|
|
asset.color: root.color
|
|
|
|
selected: model.selected
|
|
|
|
type: StatusChatListItem.Type.CommunityChat
|
|
|
|
notificationsCount: model.notificationsCount
|
|
|
|
hasUnreadMessages: model.hasUnreadMessages
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Item {
|
|
|
|
// filler
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Blur background + Control node offline information content:
|
|
|
|
centerPanel: ControlNodeOfflineCenterPanel {
|
|
|
|
id: joinCommunityCenterPanel
|
|
|
|
|
|
|
|
anchors.fill: parent
|
|
|
|
name: root.name
|
|
|
|
chatDateTimeText: root.chatDateTimeText
|
|
|
|
listUsersText: root.listUsersText
|
|
|
|
messagesModel: root.messagesModel
|
|
|
|
}
|
|
|
|
|
|
|
|
showRightPanel: false
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: fastBlur
|
|
|
|
|
|
|
|
FastBlur {
|
|
|
|
radius: d.blurryRadius
|
|
|
|
transparentBorder: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|