aboutsummaryrefslogtreecommitdiff
path: root/qml
diff options
context:
space:
mode:
authorlink2xt <link2xt@testrun.org>2021-07-28 10:41:54 +0300
committerlink2xt <link2xt@testrun.org>2021-08-01 16:53:15 +0300
commit9b2ce7538d28529f3c47e713779e4b0ae7b6aaf1 (patch)
tree8613a74ee1ee5b5074e91ecb9b12a8081d34ade2 /qml
parent4103ae47823671eaaf52d18b10cb6aaac0ea2d0d (diff)
downloadkdeltachat-9b2ce7538d28529f3c47e713779e4b0ae7b6aaf1.tar.gz
kdeltachat-9b2ce7538d28529f3c47e713779e4b0ae7b6aaf1.zip
Add New Chat page
Diffstat (limited to 'qml')
-rw-r--r--qml/ChatlistPage.qml14
-rw-r--r--qml/NewChatPage.qml68
2 files changed, 82 insertions, 0 deletions
diff --git a/qml/ChatlistPage.qml b/qml/ChatlistPage.qml
index 8348091..a0d171a 100644
--- a/qml/ChatlistPage.qml
+++ b/qml/ChatlistPage.qml
@@ -36,6 +36,20 @@ Kirigami.ScrollablePage {
updateChatlist()
}
+ mainAction: Kirigami.Action {
+ text: "New chat"
+ iconName: "list-add"
+ onTriggered: {
+ let newChatPageComponent = Qt.createComponent("qrc:/qml/NewChatPage.qml")
+ if (newChatPageComponent.status == Component.Ready) {
+ let newChatPage = newChatPageComponent.createObject(pageStack, {context: chatlistPage.context})
+ pageStack.layers.push(newChatPage)
+ } else if (newChatPageComponent.status == Component.Error) {
+ console.log("Error loading new chat page: " + newChatPageComponent.errorString())
+ }
+ }
+ }
+
contextualActions: [
Kirigami.Action {
text: "Settings"
diff --git a/qml/NewChatPage.qml b/qml/NewChatPage.qml
new file mode 100644
index 0000000..cc14185
--- /dev/null
+++ b/qml/NewChatPage.qml
@@ -0,0 +1,68 @@
+import QtQuick 2.12
+import QtQuick.Controls 2.12
+import QtQuick.Layouts 1.12
+import org.kde.kirigami 2.12 as Kirigami
+
+import DeltaChat 1.0
+
+Kirigami.ScrollablePage {
+ id: newChatPageRoot
+
+ title: "New chat"
+
+ required property DcContext context
+
+ function updateContacts() {
+ let contacts = context.getContacts(0, "");
+
+ for (let i = 0; i < contacts.length; i++) {
+ let contactId = contacts[i]
+
+ const item = {
+ contactId: contactId
+ }
+ contactsModel.insert(i, item)
+ }
+ }
+
+ Component.onCompleted: {
+ newChatPageRoot.updateContacts()
+ }
+
+ ListModel {
+ id: contactsModel
+ }
+
+ ListView {
+ id: contactsList
+
+ anchors.fill: parent
+ model: contactsModel
+ currentIndex: -1
+
+ delegate: Kirigami.BasicListItem {
+ property DcContact contact: context.getContact(model.contactId)
+
+ label: contact.displayName
+ subtitle: contact.addr
+ }
+
+ Kirigami.PlaceholderMessage {
+ anchors.centerIn: parent
+ visible: contactsList.count == 0
+ text: "You have no contacts in addressbook yet"
+ }
+
+ onCurrentItemChanged: {
+ if (currentIndex == -1) {
+ return;
+ }
+
+ let contactId = contactsModel.get(contactsList.currentIndex).contactId;
+
+ console.log("Creating chat with " + contactId);
+ context.createChatByContactId(contactId);
+ pageStack.layers.pop();
+ }
+ }
+}