1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
/*
Copyright (c) 2016 Michael Bohlender <michael.bohlender@kdemail.net>
Copyright (c) 2016 Christian Mollekopf <mollekopf@kolabsys.com>
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 "folderlistmodel.h"
#include <sink/store.h>
#include <settings/settings.h>
using namespace Sink;
using namespace Sink::ApplicationDomain;
FolderListModel::FolderListModel(QObject *parent) : QSortFilterProxyModel()
{
setDynamicSortFilter(true);
sort(0, Qt::AscendingOrder);
Query query;
query.setFlags(Sink::Query::LiveQuery);
query.request<Folder::Name>().request<Folder::Icon>().request<Folder::Parent>();
query.requestTree<Folder::Parent>();
runQuery(query);
}
FolderListModel::~FolderListModel()
{
}
QHash< int, QByteArray > FolderListModel::roleNames() const
{
QHash<int, QByteArray> roles;
roles[Name] = "name";
roles[Icon] = "icon";
roles[Id] = "id";
roles[DomainObject] = "domainObject";
return roles;
}
QVariant FolderListModel::data(const QModelIndex &idx, int role) const
{
auto srcIdx = mapToSource(idx);
switch (role) {
case Name:
return srcIdx.sibling(srcIdx.row(), 0).data(Qt::DisplayRole).toString();
case Icon:
return srcIdx.sibling(srcIdx.row(), 1).data(Qt::DisplayRole).toString();
case Id:
return srcIdx.data(Store::DomainObjectBaseRole).value<ApplicationDomainType::Ptr>()->identifier();
case DomainObject:
return srcIdx.data(Store::DomainObjectRole);
}
return QSortFilterProxyModel::data(idx, role);
}
void FolderListModel::runQuery(const Query &query)
{
mModel = Store::loadModel<Folder>(query);
setSourceModel(mModel.data());
}
void FolderListModel::setAccountId(const QVariant &accountId)
{
const auto account = accountId.toString().toUtf8();
//Get all folders of an account
auto query = Query();
query.resourceFilter<SinkResource::Account>(account);
query.setFlags(Sink::Query::LiveQuery);
query.requestTree<Folder::Parent>();
query.request<Folder::Name>()
.request<Folder::Icon>()
.request<Folder::Parent>();
query.requestTree<Folder::Parent>();
runQuery(query);
}
static int getPriority(const Sink::ApplicationDomain::Folder &folder)
{
auto specialPurpose = folder.getSpecialPurpose();
if (specialPurpose.contains(Sink::ApplicationDomain::SpecialPurpose::Mail::inbox)) {
return 10;
}
if (!specialPurpose.isEmpty()) {
return 9;
}
return 0;
}
bool FolderListModel::lessThan(const QModelIndex &left, const QModelIndex &right) const
{
const auto leftFolder = left.data(Sink::Store::DomainObjectRole).value<Sink::ApplicationDomain::Folder::Ptr>();
const auto rightFolder = right.data(Sink::Store::DomainObjectRole).value<Sink::ApplicationDomain::Folder::Ptr>();
if (getPriority(*leftFolder) < getPriority(*rightFolder)) {
return true;
}
return leftFolder->getName() < rightFolder->getName();
}
QVariant FolderListModel::accountId() const
{
return QVariant();
}
|