From 9f89215be2612dbf54ad50c42565c310e3f4099c Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Mon, 10 Oct 2016 15:50:37 +0200 Subject: Query for threads --- framework/domain/maillistmodel.cpp | 18 +++++++++--------- framework/domain/maillistmodel.h | 5 +++-- 2 files changed, 12 insertions(+), 11 deletions(-) (limited to 'framework') diff --git a/framework/domain/maillistmodel.cpp b/framework/domain/maillistmodel.cpp index 9afb6408..746f3523 100644 --- a/framework/domain/maillistmodel.cpp +++ b/framework/domain/maillistmodel.cpp @@ -23,6 +23,7 @@ #include #include +#include MailListModel::MailListModel(QObject *parent) : QSortFilterProxyModel() @@ -50,6 +51,7 @@ QHash< int, QByteArray > MailListModel::roleNames() const roles[Id] = "id"; roles[MimeMessage] = "mimeMessage"; roles[DomainObject] = "domainObject"; + roles[ThreadSize] = "threadSize"; return roles; } @@ -68,18 +70,19 @@ QVariant MailListModel::data(const QModelIndex &idx, int role) const case Date: return mail->getDate(); case Unread: - return mail->getUnread(); + return mail->getProperty("unreadCollected").toList().contains(true); case Important: - return mail->getImportant(); + return mail->getProperty("importantCollected").toList().contains(true); case Draft: return mail->getDraft(); case Id: return mail->identifier(); case DomainObject: return QVariant::fromValue(mail); - case MimeMessage: { + case MimeMessage: return mail->getMimeMessage(); - } + case ThreadSize: + return mail->getProperty("count").toInt(); } return QSortFilterProxyModel::data(idx, role); } @@ -105,10 +108,8 @@ void MailListModel::setParentFolder(const QVariant &parentFolder) qWarning() << "No folder: " << parentFolder; return; } - Sink::Query query; + Sink::Query query = Sink::StandardQueries::threadLeaders(*folder); query.liveQuery = true; - query.resourceFilter(folder->resourceInstanceIdentifier()); - query.sort(); query.limit = 100; query.request(); query.request(); @@ -118,7 +119,6 @@ void MailListModel::setParentFolder(const QVariant &parentFolder) query.request(); query.request(); query.request(); - query.filter(*folder); qWarning() << "Running folder query: " << folder->resourceInstanceIdentifier() << folder->identifier(); runQuery(query); } @@ -136,7 +136,7 @@ void MailListModel::setMail(const QVariant &variant) qWarning() << "No mail: " << mail; return; } - Sink::Query query(*mail); + Sink::Query query = Sink::StandardQueries::completeThread(*mail); query.liveQuery = false; query.request(); query.request(); diff --git a/framework/domain/maillistmodel.h b/framework/domain/maillistmodel.h index 13662a17..a7cb5d84 100644 --- a/framework/domain/maillistmodel.h +++ b/framework/domain/maillistmodel.h @@ -50,10 +50,11 @@ public: Draft, Id, MimeMessage, - DomainObject + DomainObject, + ThreadSize }; - QHash roleNames() const; + QHash roleNames() const Q_DECL_OVERRIDE; void runQuery(const Sink::Query &query); -- cgit v1.2.3 From 91f00fe588c9f00ac92f2d095c6ee9dd74c007a0 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Mon, 10 Oct 2016 16:34:48 +0200 Subject: An outbox model --- framework/domain/CMakeLists.txt | 1 + framework/domain/mailplugin.cpp | 2 + framework/domain/outboxmodel.cpp | 114 +++++++++++++++++++++++++++++++++++++++ framework/domain/outboxmodel.h | 60 +++++++++++++++++++++ 4 files changed, 177 insertions(+) create mode 100644 framework/domain/outboxmodel.cpp create mode 100644 framework/domain/outboxmodel.h (limited to 'framework') diff --git a/framework/domain/CMakeLists.txt b/framework/domain/CMakeLists.txt index ea293655..804b3ccb 100644 --- a/framework/domain/CMakeLists.txt +++ b/framework/domain/CMakeLists.txt @@ -12,6 +12,7 @@ set(mailplugin_SRCS accountfactory.cpp accountscontroller.cpp accountsmodel.cpp + outboxmodel.cpp identitiesmodel.cpp settings/accountsettings.cpp ) diff --git a/framework/domain/mailplugin.cpp b/framework/domain/mailplugin.cpp index 9f06fd5f..c7023bde 100644 --- a/framework/domain/mailplugin.cpp +++ b/framework/domain/mailplugin.cpp @@ -28,6 +28,7 @@ #include "accountfactory.h" #include "accountscontroller.h" #include "accountsmodel.h" +#include "outboxmodel.h" #include @@ -43,4 +44,5 @@ void MailPlugin::registerTypes (const char *uri) qmlRegisterType(uri, 1, 0, "AccountFactory"); qmlRegisterType(uri, 1, 0, "AccountsController"); qmlRegisterType(uri, 1, 0, "AccountsModel"); + qmlRegisterType(uri, 1, 0, "OutboxModel"); } diff --git a/framework/domain/outboxmodel.cpp b/framework/domain/outboxmodel.cpp new file mode 100644 index 00000000..b3533976 --- /dev/null +++ b/framework/domain/outboxmodel.cpp @@ -0,0 +1,114 @@ +/* + Copyright (c) 2016 Michael Bohlender + Copyright (c) 2016 Christian Mollekopf + + This library is free software; you can redistribute it and/or modify it + under the terms of the GNU Library General Public License as published by + the Free Software Foundation; either version 2 of the License, or (at your + option) any later version. + + This library 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 Library General Public + License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to the + Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301, USA. +*/ + +#include "outboxmodel.h" + +#include +#include + +#include + + +OutboxModel::OutboxModel(QObject *parent) + : QSortFilterProxyModel() +{ + setDynamicSortFilter(true); + sort(0, Qt::DescendingOrder); + + using namespace Sink::ApplicationDomain; + auto query = Sink::StandardQueries::outboxMails(); + query.liveQuery = true; + query.request(); + query.request(); + query.request(); + query.request(); + query.request(); + query.request(); + query.request(); + query.request(); + runQuery(query); +} + +OutboxModel::~OutboxModel() +{ + +} + +QHash< int, QByteArray > OutboxModel::roleNames() const +{ + QHash roles; + + roles[Subject] = "subject"; + roles[Sender] = "sender"; + roles[SenderName] = "senderName"; + roles[Date] = "date"; + roles[Unread] = "unread"; + roles[Important] = "important"; + roles[Draft] = "draft"; + roles[Id] = "id"; + roles[MimeMessage] = "mimeMessage"; + roles[DomainObject] = "domainObject"; + + return roles; +} + +QVariant OutboxModel::data(const QModelIndex &idx, int role) const +{ + auto srcIdx = mapToSource(idx); + auto mail = srcIdx.data(Sink::Store::DomainObjectRole).value(); + switch (role) { + case Subject: + return mail->getSubject(); + case Sender: + return mail->getSender(); + case SenderName: + return mail->getSenderName(); + case Date: + return mail->getDate(); + case Unread: + return mail->getUnread(); + case Important: + return mail->getImportant(); + case Draft: + return mail->getDraft(); + case Id: + return mail->identifier(); + case DomainObject: + return QVariant::fromValue(mail); + case MimeMessage: { + return mail->getMimeMessage(); + } + } + return QSortFilterProxyModel::data(idx, role); +} + +bool OutboxModel::lessThan(const QModelIndex &left, const QModelIndex &right) const +{ + const auto leftDate = left.data(Sink::Store::DomainObjectRole).value()->getDate(); + const auto rightDate = right.data(Sink::Store::DomainObjectRole).value()->getDate(); + return leftDate < rightDate; +} + +void OutboxModel::runQuery(const Sink::Query &query) +{ + m_model = Sink::Store::loadModel(query); + setSourceModel(m_model.data()); +} + diff --git a/framework/domain/outboxmodel.h b/framework/domain/outboxmodel.h new file mode 100644 index 00000000..d2fa17ac --- /dev/null +++ b/framework/domain/outboxmodel.h @@ -0,0 +1,60 @@ +/* + Copyright (c) 2016 Michael Bohlender + Copyright (c) 2016 Christian Mollekopf + + This library is free software; you can redistribute it and/or modify it + under the terms of the GNU Library General Public License as published by + the Free Software Foundation; either version 2 of the License, or (at your + option) any later version. + + This library 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 Library General Public + License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to the + Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301, USA. +*/ + +#pragma once + +#include + +#include +#include +#include + +class OutboxModel : public QSortFilterProxyModel +{ + Q_OBJECT + +public: + OutboxModel(QObject *parent = Q_NULLPTR); + ~OutboxModel(); + + QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const Q_DECL_OVERRIDE; + + bool lessThan(const QModelIndex &left, const QModelIndex &right) const Q_DECL_OVERRIDE; + + enum Roles { + Subject = Qt::UserRole + 1, + Sender, + SenderName, + Date, + Unread, + Important, + Draft, + Id, + MimeMessage, + DomainObject + }; + + QHash roleNames() const Q_DECL_OVERRIDE; + + void runQuery(const Sink::Query &query); + +private: + QSharedPointer m_model; +}; -- cgit v1.2.3