harbour-fernschreiber/qml/pages/ChatSelectionPage.qml

148 lines
6.1 KiB
QML
Raw Permalink Normal View History

2020-11-15 01:50:12 +03:00
/*
Copyright (C) 2020 Sebastian J. Wolf and other contributors
This file is part of Fernschreiber.
Fernschreiber is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Fernschreiber is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Fernschreiber. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.6
import Sailfish.Silica 1.0
import "../components"
import "../js/twemoji.js" as Emoji
import "../js/functions.js" as Functions
Dialog {
id: chatSelectionPage
allowedOrientations: Orientation.All
canAccept: false
acceptDestinationAction: PageStackAction.Replace
acceptDestinationReplaceTarget: pageStack.find( function(page){ return(page._depth === 0)} )
2020-11-18 13:13:05 +03:00
property int myUserId: tdLibWrapper.getUserInformation().id
2020-11-15 01:50:12 +03:00
property alias headerTitle: pageHeader.title
property alias headerDescription: pageHeader.description
/*
payload dependent on chatSelectionPage.state
- forwardMessages: {fromChatId, messageIds, neededPermissions}
*/
2020-11-15 01:50:12 +03:00
property var payload: ({})
onAccepted: {
switch(chatSelectionPage.state) {
case "forwardMessages":
acceptDestinationInstance.forwardMessages(payload.fromChatId, payload.messageIds)
break;
// future uses of chat selection can be processed here
2020-11-15 01:50:12 +03:00
}
}
PageHeader {
id: pageHeader
title: qsTr("Select Chat")
width: parent.width
}
SilicaListView {
id: chatListView
anchors {
top: pageHeader.bottom
bottom: parent.bottom
left: parent.left
right: parent.right
}
clip: true
model: chatListModel
delegate: ChatListViewItem {
ownUserId: chatSelectionPage.myUserId
Loader { // checking permissions takes a while, so we defer those calculations
id: visibleLoader
asynchronous: true
sourceComponent: Component {
QtObject {
property bool visible: false
Component.onCompleted: {
if(chatSelectionPage.state === "forwardMessages") {
2020-11-18 13:13:05 +03:00
var chatType = display.type['@type']
var chatGroupInformation
if(chatType === "chatTypePrivate" || chatType === "chatTypeSecret") {
visible = true
return;
}
else if (chatType === "chatTypeBasicGroup" ) {
2020-11-18 13:13:05 +03:00
chatGroupInformation = tdLibWrapper.getBasicGroup(display.type.basic_group_id)
}
else if (chatType === "chatTypeSupergroup" ) {
2020-11-18 13:13:05 +03:00
chatGroupInformation = tdLibWrapper.getSuperGroup(display.type.supergroup_id)
}
2020-11-18 13:13:05 +03:00
var groupStatus = chatGroupInformation.status
var groupStatusType = groupStatus["@type"]
var groupStatusPermissions = groupStatus.permissions
var groupPermissions = display.permissions
2020-11-17 13:14:36 +03:00
visible = (groupStatusType === "chatMemberStatusCreator"
|| groupStatusType === "chatMemberStatusAdministrator"
|| (groupStatusType === "chatMemberStatusMember"
&& chatSelectionPage.payload.neededPermissions.every(function(neededPermission){
2020-11-18 13:13:05 +03:00
return groupPermissions[neededPermission]
})
)
2020-11-17 13:14:36 +03:00
|| (groupStatusType === "chatMemberStatusRestricted"
&& chatSelectionPage.payload.neededPermissions.every(function(neededPermission){
2020-11-18 13:13:05 +03:00
return groupStatusPermissions[neededPermission]
2020-11-17 13:14:36 +03:00
})
)
2020-11-18 13:13:05 +03:00
)
} else { // future uses of chat selection can be processed here
2020-11-18 13:13:05 +03:00
visible = true
}
}
}
}
}
property bool valid: visibleLoader && visibleLoader.item && visibleLoader.item.visible
opacity: valid ? 1.0 : 0
Behavior on opacity { FadeAnimation {}}
Behavior on height { NumberAnimation {}}
2020-11-15 01:50:12 +03:00
// normal height while calculating, otherwise all elements get displayed at once
height: !visibleLoader.item || valid ? contentHeight : 0
enabled: valid
2020-11-15 01:50:12 +03:00
onClicked: {
var chat = tdLibWrapper.getChat(display.id);
switch(chatSelectionPage.state) {
case "forwardMessages":
chatSelectionPage.acceptDestinationProperties = { "chatInformation" : chat};
chatSelectionPage.acceptDestination = Qt.resolvedUrl("../pages/ChatPage.qml");
break;
}
chatSelectionPage.canAccept = true;
chatSelectionPage.accept();
}
}
ViewPlaceholder {
enabled: chatListView.count === 0
text: qsTr("You don't have any chats yet.")
}
VerticalScrollDecorator {}
}
}