2020-06-17 19:18:31 +00:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2020-05-27 21:59:34 +00:00
|
|
|
import "../../../../shared"
|
2020-09-22 14:45:09 +00:00
|
|
|
import "../../../../shared/status"
|
2020-05-27 21:59:34 +00:00
|
|
|
import "../../../../imports"
|
2020-06-02 09:54:46 +00:00
|
|
|
import "../components"
|
2020-05-27 21:59:34 +00:00
|
|
|
|
2021-04-28 15:30:41 +00:00
|
|
|
Item {
|
2020-08-14 12:08:09 +00:00
|
|
|
property int iconSize: 16
|
2020-05-27 21:59:34 +00:00
|
|
|
id: chatTopBarContent
|
|
|
|
height: 56
|
|
|
|
|
2020-09-22 14:50:14 +00:00
|
|
|
Loader {
|
|
|
|
property bool isGroupChatOrOneToOne: (chatsModel.activeChannel.chatType === Constants.chatTypePrivateGroupChat ||
|
|
|
|
chatsModel.activeChannel.chatType === Constants.chatTypeOneToOne)
|
2020-07-15 16:09:20 +00:00
|
|
|
anchors.left: parent.left
|
2020-09-22 14:50:14 +00:00
|
|
|
anchors.leftMargin: this.isGroupChatOrOneToOne ? Style.current.padding : Style.current.padding + 4
|
2020-07-15 16:09:20 +00:00
|
|
|
anchors.top: parent.top
|
2020-09-22 14:50:14 +00:00
|
|
|
anchors.topMargin: 4
|
2021-05-28 02:55:50 +00:00
|
|
|
anchors.right: moreActionsBtn.left
|
|
|
|
anchors.rightMargin: Style.current.padding + moreActionsBtn.width
|
2020-09-22 14:50:14 +00:00
|
|
|
sourceComponent: this.isGroupChatOrOneToOne ? chatInfoButton : chatInfo
|
2020-05-27 21:59:34 +00:00
|
|
|
}
|
|
|
|
|
2020-09-22 14:50:14 +00:00
|
|
|
Component {
|
|
|
|
id: chatInfoButton
|
|
|
|
StatusChatInfoButton {
|
2020-10-02 19:25:33 +00:00
|
|
|
chatId: chatsModel.activeChannel.id
|
2021-02-17 20:48:12 +00:00
|
|
|
chatName: {
|
|
|
|
if (chatsModel.activeChannel.chatType === Constants.chatTypePrivateGroupChat) {
|
|
|
|
return chatsModel.activeChannel.name
|
|
|
|
}
|
|
|
|
chatsModel.userNameOrAlias(chatsModel.activeChannel.id)
|
|
|
|
}
|
2020-09-22 14:50:14 +00:00
|
|
|
chatType: chatsModel.activeChannel.chatType
|
|
|
|
identicon: chatsModel.activeChannel.identicon
|
2021-01-15 18:36:42 +00:00
|
|
|
muted: chatsModel.activeChannel.muted
|
2020-09-22 14:50:14 +00:00
|
|
|
identiconSize: 36
|
|
|
|
|
|
|
|
onClicked: {
|
|
|
|
switch (chatsModel.activeChannel.chatType) {
|
2021-02-17 20:36:10 +00:00
|
|
|
case Constants.chatTypePrivateGroupChat:
|
|
|
|
openPopup(groupInfoPopupComponent, {channel: chatsModel.activeChannel})
|
2020-09-22 14:50:14 +00:00
|
|
|
break;
|
|
|
|
case Constants.chatTypeOneToOne:
|
2020-12-21 12:08:44 +00:00
|
|
|
const profileImage = appMain.getProfileImage(chatsModel.activeChannel.id)
|
2021-02-11 15:43:49 +00:00
|
|
|
openProfilePopup(chatsModel.userNameOrAlias(chatsModel.activeChannel.id),
|
|
|
|
chatsModel.activeChannel.id, profileImage || chatsModel.activeChannel.identicon,
|
|
|
|
"", chatsModel.activeChannel.nickname)
|
2020-09-22 14:50:14 +00:00
|
|
|
break;
|
|
|
|
}
|
2020-08-07 19:26:51 +00:00
|
|
|
}
|
|
|
|
}
|
2020-05-27 21:59:34 +00:00
|
|
|
}
|
|
|
|
|
2020-09-22 14:50:14 +00:00
|
|
|
Component {
|
|
|
|
id: chatInfo
|
|
|
|
StatusChatInfo {
|
|
|
|
identiconSize: 36
|
2021-03-02 20:43:32 +00:00
|
|
|
chatId: chatsModel.activeChannel.id
|
2020-09-22 14:50:14 +00:00
|
|
|
chatName: chatsModel.activeChannel.name
|
|
|
|
chatType: chatsModel.activeChannel.chatType
|
|
|
|
identicon: chatsModel.activeChannel.identicon
|
2021-01-15 18:36:42 +00:00
|
|
|
muted: chatsModel.activeChannel.muted
|
2020-06-09 15:48:17 +00:00
|
|
|
}
|
2020-05-27 21:59:34 +00:00
|
|
|
}
|
|
|
|
|
2021-05-28 02:55:50 +00:00
|
|
|
StatusContextMenuButton {
|
|
|
|
id: moreActionsBtn
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2020-05-27 21:59:34 +00:00
|
|
|
anchors.right: parent.right
|
2020-07-09 17:56:31 +00:00
|
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
|
|
|
2021-05-28 02:55:50 +00:00
|
|
|
onClicked: {
|
|
|
|
var menu = chatContextMenu;
|
|
|
|
var isPrivateGroupChat = chatsModel.activeChannel.chatType === Constants.chatTypePrivateGroupChat
|
|
|
|
if(isPrivateGroupChat){
|
|
|
|
menu = groupContextMenu
|
|
|
|
}
|
2021-05-28 17:35:21 +00:00
|
|
|
|
2021-05-28 02:55:50 +00:00
|
|
|
if (menu.opened) {
|
|
|
|
return menu.close()
|
2020-07-09 17:56:31 +00:00
|
|
|
}
|
2020-06-10 19:41:03 +00:00
|
|
|
|
2021-05-28 02:55:50 +00:00
|
|
|
if (isPrivateGroupChat) {
|
|
|
|
menu.popup(moreActionsBtn.x, moreActionsBtn.height)
|
|
|
|
} else {
|
|
|
|
menu.openMenu(chatsModel.activeChannel, chatsModel.getActiveChannelIdx(),
|
|
|
|
moreActionsBtn.x - chatContextMenu.width + moreActionsBtn.width + 4,
|
|
|
|
moreActionsBtn.height - 4)
|
2021-03-17 09:22:35 +00:00
|
|
|
}
|
2021-05-28 02:55:50 +00:00
|
|
|
}
|
2021-01-11 20:08:35 +00:00
|
|
|
|
2021-05-28 02:55:50 +00:00
|
|
|
ChannelContextMenu {
|
|
|
|
id: chatContextMenu
|
|
|
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
|
|
|
}
|
|
|
|
|
|
|
|
PopupMenu {
|
|
|
|
id: groupContextMenu
|
|
|
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
|
|
|
Action {
|
|
|
|
icon.source: "../../../img/group_chat.svg"
|
|
|
|
icon.width: chatTopBarContent.iconSize
|
|
|
|
icon.height: chatTopBarContent.iconSize
|
|
|
|
//% "Group Information"
|
|
|
|
text: qsTrId("group-information")
|
|
|
|
onTriggered: openPopup(groupInfoPopupComponent, {channel: chatsModel.activeChannel})
|
|
|
|
}
|
|
|
|
Action {
|
|
|
|
icon.source: "../../../img/close.svg"
|
|
|
|
icon.width: chatTopBarContent.iconSize
|
|
|
|
icon.height: chatTopBarContent.iconSize
|
|
|
|
//% "Clear History"
|
|
|
|
text: qsTrId("clear-history")
|
|
|
|
onTriggered: chatsModel.clearChatHistory(chatsModel.activeChannel.id)
|
|
|
|
}
|
|
|
|
Action {
|
|
|
|
icon.source: "../../../img/leave_chat.svg"
|
|
|
|
icon.width: chatTopBarContent.iconSize
|
|
|
|
icon.height: chatTopBarContent.iconSize
|
|
|
|
//% "Leave group"
|
|
|
|
text: qsTrId("leave-group")
|
|
|
|
onTriggered: {
|
|
|
|
//% "Leave group"
|
|
|
|
deleteChatConfirmationDialog.title = qsTrId("leave-group")
|
2021-05-28 17:35:21 +00:00
|
|
|
//% "Leave group"
|
2021-05-28 02:55:50 +00:00
|
|
|
deleteChatConfirmationDialog.confirmButtonLabel = qsTrId("leave-group")
|
|
|
|
//% "Are you sure you want to leave this chat?"
|
|
|
|
deleteChatConfirmationDialog.confirmationText = qsTrId("are-you-sure-you-want-to-leave-this-chat-")
|
|
|
|
deleteChatConfirmationDialog.open()
|
2021-05-28 17:35:21 +00:00
|
|
|
}
|
2020-05-27 21:59:34 +00:00
|
|
|
}
|
2021-03-17 09:22:35 +00:00
|
|
|
}
|
2021-05-28 02:55:50 +00:00
|
|
|
}
|
2020-05-27 21:59:34 +00:00
|
|
|
|
2021-06-02 15:52:30 +00:00
|
|
|
// Rectangle {
|
|
|
|
// id: separator
|
|
|
|
// width: 1
|
|
|
|
// height: 24
|
|
|
|
// color: Style.current.separator
|
|
|
|
// anchors.verticalCenter: parent.verticalCenter
|
|
|
|
// }
|
|
|
|
|
|
|
|
// StatusIconButton {
|
|
|
|
// id: activityCenterBtn
|
|
|
|
// icon.name: "bell"
|
|
|
|
// iconColor: Style.current.contextMenuButtonForegroundColor
|
|
|
|
// hoveredIconColor: Style.current.contextMenuButtonForegroundColor
|
|
|
|
// highlightedBackgroundColor: Style.current.contextMenuButtonBackgroundHoverColor
|
|
|
|
// anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
|
|
|
// onClicked: activityCenter.open()
|
|
|
|
|
|
|
|
// Rectangle {
|
|
|
|
// // TODO unhardcode this
|
|
|
|
// property int nbUnseenNotifs: 3
|
|
|
|
|
|
|
|
// id: badge
|
|
|
|
// visible: nbUnseenNotifs > 0
|
|
|
|
// anchors.top: parent.top
|
|
|
|
// anchors.topMargin: -2
|
|
|
|
// anchors.left: parent.right
|
|
|
|
// anchors.leftMargin: -17
|
|
|
|
// radius: height / 2
|
|
|
|
// color: Style.current.blue
|
|
|
|
// border.color: activityCenterBtn.hovered ? Style.current.secondaryBackground : Style.current.background
|
|
|
|
// border.width: 2
|
|
|
|
// width: badge.nbUnseenNotifs < 10 ? 18 : badge.width + 14
|
|
|
|
// height: 18
|
|
|
|
|
|
|
|
// Text {
|
|
|
|
// font.pixelSize: 12
|
|
|
|
// color: Style.current.white
|
|
|
|
// anchors.centerIn: parent
|
|
|
|
// text: badge.nbUnseenNotifs
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
2021-05-28 02:55:50 +00:00
|
|
|
// }
|
2020-08-10 13:06:46 +00:00
|
|
|
|
2021-05-28 17:35:21 +00:00
|
|
|
ActivityCenter {
|
|
|
|
id: activityCenter
|
|
|
|
}
|
|
|
|
|
2020-08-10 13:06:46 +00:00
|
|
|
ConfirmationDialog {
|
|
|
|
id: deleteChatConfirmationDialog
|
2021-01-13 20:26:30 +00:00
|
|
|
btnType: "warn"
|
2020-08-10 13:06:46 +00:00
|
|
|
onConfirmButtonClicked: {
|
|
|
|
chatsModel.leaveActiveChat()
|
|
|
|
deleteChatConfirmationDialog.close()
|
|
|
|
}
|
|
|
|
}
|
2020-06-02 09:54:46 +00:00
|
|
|
}
|