160 lines
5.0 KiB
QML
160 lines
5.0 KiB
QML
import QtQuick 2.13
|
|
import QtQuick.Controls 2.13
|
|
import QtQuick.Layouts 1.13
|
|
import "../../../../shared"
|
|
import "../../../../imports"
|
|
import "../components"
|
|
|
|
ScrollView {
|
|
property alias channelListCount: chatGroupsListView.count
|
|
property string searchStr: ""
|
|
id: chatGroupsContainer
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
ListView {
|
|
id: chatGroupsListView
|
|
anchors.top: parent.top
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
anchors.left: parent.left
|
|
anchors.rightMargin: Style.current.padding
|
|
anchors.leftMargin: Style.current.padding
|
|
clip: true
|
|
model: chatsModel.chats
|
|
delegate: Channel {
|
|
name: model.name
|
|
lastMessage: model.lastMessage
|
|
timestamp: model.timestamp
|
|
chatType: model.chatType
|
|
identicon: model.identicon
|
|
unviewedMessagesCount: model.unviewedMessagesCount
|
|
hasMentions: model.hasMentions
|
|
contentType: model.contentType
|
|
searchStr: chatGroupsContainer.searchStr
|
|
}
|
|
onCountChanged: {
|
|
if (count > 0 && chatsModel.activeChannelIndex > -1) {
|
|
// If a chat is added or removed, we set the current index to the first value
|
|
chatsModel.activeChannelIndex = 0;
|
|
currentIndex = 0;
|
|
} else {
|
|
if(chatsModel.activeChannelIndex > -1){
|
|
chatGroupsListView.currentIndex = 0;
|
|
} else {
|
|
// Initial state. No chat has been selected yet
|
|
chatGroupsListView.currentIndex = -1;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
PopupMenu {
|
|
property int channelIndex
|
|
|
|
id: channelContextMenu
|
|
width: 175
|
|
subMenuIcons: [
|
|
{
|
|
source: Qt.resolvedUrl("../../../img/bell.svg"),
|
|
width: 16,
|
|
height: 16
|
|
},
|
|
{
|
|
source: Qt.resolvedUrl("../../../img/fetch.svg"),
|
|
width: 16,
|
|
height: 16
|
|
}
|
|
]
|
|
|
|
function openMenu(channelIndex) {
|
|
channelContextMenu.channelIndex = channelIndex
|
|
channelContextMenu.popup()
|
|
}
|
|
|
|
Action {
|
|
text: qsTr("View Group")
|
|
icon.source: "../../../img/group.svg"
|
|
icon.width: 16
|
|
icon.height: 16
|
|
onTriggered: console.log('TODO View group')
|
|
}
|
|
|
|
Separator {}
|
|
|
|
PopupMenu {
|
|
hasArrow: false
|
|
title: qsTr("Mute Chat")
|
|
|
|
// TODO implement mute chat in Model and call it here
|
|
Action { text: qsTr("15 minutes"); icon.width: 0; }
|
|
Action { text: qsTr("1 hour"); icon.width: 0; }
|
|
Action { text: qsTr("8 hours"); icon.width: 0; }
|
|
Action { text: qsTr("24 hours"); icon.width: 0; }
|
|
Action { text: qsTr("Until I turn it back on"); icon.width: 0; }
|
|
}
|
|
Action {
|
|
text: qsTr("Mark as Read")
|
|
icon.source: "../../../img/check-circle.svg"
|
|
icon.width: 16
|
|
icon.height: 16
|
|
onTriggered: {
|
|
chatsModel.markAllChannelMessagesReadByIndex(channelContextMenu.channelIndex)
|
|
}
|
|
}
|
|
PopupMenu {
|
|
hasArrow: false
|
|
title: qsTr("Fetch Messages")
|
|
|
|
// TODO call fetch for the wanted duration
|
|
Action { text: qsTr("Last 24 hours"); icon.width: 0; }
|
|
Action { text: qsTr("Last 2 days"); icon.width: 0; }
|
|
Action { text: qsTr("Last 3 days"); icon.width: 0; }
|
|
Action { text: qsTr("Last 7 days"); icon.width: 0; }
|
|
}
|
|
Action {
|
|
text: qsTr("Clear History")
|
|
icon.source: "../../../img/close.svg"
|
|
icon.width: 16
|
|
icon.height: 16
|
|
onTriggered: chatsModel.clearChatHistoryByIndex(channelContextMenu.channelIndex)
|
|
}
|
|
|
|
Separator {}
|
|
|
|
Action {
|
|
text: qsTr("Leave Group")
|
|
icon.source: "../../../img/leave_chat.svg"
|
|
icon.width: 16
|
|
icon.height: 16
|
|
onTriggered: chatsModel.leaveChatByIndex(channelContextMenu.channelIndex)
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: chatsModel.chats
|
|
onDataChanged: {
|
|
// If the current active channel receives messages and changes its position,
|
|
// refresh the currentIndex accordingly
|
|
if(chatsModel.activeChannelIndex !== chatGroupsListView.currentIndex){
|
|
chatGroupsListView.currentIndex = chatsModel.activeChannelIndex
|
|
}
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: chatsModel
|
|
onActiveChannelChanged: {
|
|
chatGroupsListView.currentIndex = chatsModel.activeChannelIndex
|
|
SelectedMessage.reset();
|
|
chatColumn.isReply = false;
|
|
}
|
|
}
|
|
}
|
|
/*##^##
|
|
Designer {
|
|
D{i:0;autoSize:true;height:480;width:640}
|
|
}
|
|
##^##*/
|