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
|
/*
* Copyright (c) 2010-2016 Isode Limited.
* All rights reserved.
* See the COPYING file for more information.
*/
#include <Swift/QtUI/MUCSearch/MUCSearchModel.h>
#include <memory>
#include <Swift/QtUI/MUCSearch/MUCSearchEmptyItem.h>
namespace Swift {
MUCSearchModel::MUCSearchModel() {
}
void MUCSearchModel::clear() {
// We need to reset the model, so that model indices containing raw pointers
// to MUCSearchServiceItems are invalaidated before we delete the
// MUCSearchServiceItems.
emit beginResetModel();
services_.clear();
emit endResetModel();
}
void MUCSearchModel::addService(std::shared_ptr<MUCSearchServiceItem> service) {
emit layoutAboutToBeChanged();
if (sortOrder_) {
service->setSorting(*sortOrder_);
}
services_.push_back(service);
emit layoutChanged();
}
int MUCSearchModel::columnCount(const QModelIndex& /*parent*/) const {
return 1;
}
QVariant MUCSearchModel::data(const QModelIndex& index, int role) const {
return index.isValid() ? static_cast<MUCSearchItem*>(index.internalPointer())->data(role) : QVariant();
}
QModelIndex MUCSearchModel::index(int row, int column, const QModelIndex & parent) const {
if (!hasIndex(row, column, parent)) {
return QModelIndex();
}
if (parent.isValid()) {
MUCSearchServiceItem* parentItem = static_cast<MUCSearchServiceItem*>(parent.internalPointer());
return row < parentItem->rowCount() ? createIndex(row, column, parentItem->getItem(row)) : QModelIndex();
} else {
return row < services_.size() ? createIndex(row, column, services_[row].get()) : QModelIndex();
}
}
QModelIndex MUCSearchModel::parent(const QModelIndex& index) const {
if (!index.isValid()) {
return QModelIndex();
}
MUCSearchItem* item = static_cast<MUCSearchItem*>(index.internalPointer());
if (!item) {
return QModelIndex();
}
else if (dynamic_cast<MUCSearchServiceItem*>(item)) {
return QModelIndex();
}
std::shared_ptr<MUCSearchServiceItem> parent;
if (MUCSearchRoomItem* roomItem = dynamic_cast<MUCSearchRoomItem*>(item)) {
parent = roomItem->getParent();
}
else if (MUCSearchEmptyItem* emptyItem = dynamic_cast<MUCSearchEmptyItem*>(item)) {
parent = emptyItem->getParent();
}
if (parent) {
int row = services_.indexOf(parent);
return createIndex(row, 1, parent.get());
}
else {
return QModelIndex();
}
}
int MUCSearchModel::rowCount(const QModelIndex& parentIndex) const {
if (!parentIndex.isValid()) {
return services_.size();
}
if (dynamic_cast<MUCSearchServiceItem*>(static_cast<MUCSearchItem*>(parentIndex.internalPointer()))) {
return services_[parentIndex.row()]->rowCount();
}
else {
return 0;
}
}
void MUCSearchModel::sort(int column, Qt::SortOrder order) {
sortOrder_ = order;
if (column == 0) {
for (auto&& serviceItem : services_) {
serviceItem->setSorting(*sortOrder_);
}
}
}
}
|