mirror of
https://github.com/Qortal/Brooklyn.git
synced 2025-02-14 11:15:54 +00:00
195 lines
4.8 KiB
C++
195 lines
4.8 KiB
C++
/*
|
|
SPDX-FileCopyrightText: 2012 Marco Martin <mart@kde.org>
|
|
|
|
SPDX-License-Identifier: LGPL-2.0-or-later
|
|
*/
|
|
|
|
#include "dirmodel.h"
|
|
|
|
#include <QDebug>
|
|
#include <QImage>
|
|
#include <QMimeDatabase>
|
|
#include <QPixmap>
|
|
#include <QProcess>
|
|
#include <QTimer>
|
|
|
|
#include <KDirLister>
|
|
#include <KIO/EmptyTrashJob>
|
|
#include <kio/previewjob.h>
|
|
|
|
DirModel::DirModel(QObject *parent)
|
|
: KDirModel(parent)
|
|
, m_screenshotSize(180, 120)
|
|
{
|
|
#if 0 // unused here in trash
|
|
QMimeDatabase db;
|
|
const QList<QMimeType> mimeList = db.allMimeTypes();
|
|
|
|
m_mimeTypes << "inode/directory";
|
|
for (const QMimeType &mime : mimeList) {
|
|
if (mime.name().startsWith(QLatin1String("image/"))) {
|
|
m_mimeTypes << mime.name();
|
|
}
|
|
}
|
|
|
|
//TODO: configurable mime filter
|
|
//dirLister()->setMimeFilter(m_mimeTypes);
|
|
#endif
|
|
|
|
m_previewTimer = new QTimer(this);
|
|
m_previewTimer->setSingleShot(true);
|
|
connect(m_previewTimer, &QTimer::timeout, this, &DirModel::delayedPreview);
|
|
|
|
// using the same cache of the engine, they index both by url
|
|
m_imageCache = new KImageCache(QStringLiteral("org.kde.dirmodel-qml"), 10485760);
|
|
|
|
connect(this, &QAbstractItemModel::rowsInserted, this, &DirModel::countChanged);
|
|
connect(this, &QAbstractItemModel::rowsRemoved, this, &DirModel::countChanged);
|
|
connect(this, &QAbstractItemModel::modelReset, this, &DirModel::countChanged);
|
|
}
|
|
|
|
DirModel::~DirModel()
|
|
{
|
|
delete m_imageCache;
|
|
}
|
|
|
|
QHash<int, QByteArray> DirModel::roleNames() const
|
|
{
|
|
return {
|
|
{Qt::DisplayRole, "display"},
|
|
{Qt::DecorationRole, "decoration"},
|
|
{UrlRole, "url"},
|
|
{MimeTypeRole, "mimeType"},
|
|
{Thumbnail, "thumbnail"},
|
|
};
|
|
}
|
|
|
|
QString DirModel::url() const
|
|
{
|
|
return dirLister()->url().toString();
|
|
}
|
|
|
|
void DirModel::setUrl(const QString &url)
|
|
{
|
|
if (url.isEmpty()) {
|
|
return;
|
|
}
|
|
if (dirLister()->url().path() == url) {
|
|
dirLister()->updateDirectory(QUrl(url));
|
|
return;
|
|
}
|
|
|
|
beginResetModel();
|
|
dirLister()->openUrl(QUrl(url));
|
|
endResetModel();
|
|
Q_EMIT urlChanged();
|
|
}
|
|
|
|
int DirModel::indexForUrl(const QString &url) const
|
|
{
|
|
QModelIndex index = KDirModel::indexForUrl(QUrl(url));
|
|
return index.row();
|
|
}
|
|
|
|
QVariantMap DirModel::get(int i) const
|
|
{
|
|
QModelIndex modelIndex = index(i, 0);
|
|
|
|
KFileItem item = itemForIndex(modelIndex);
|
|
QString url = item.url().toString();
|
|
QString mimeType = item.mimetype();
|
|
|
|
QVariantMap ret;
|
|
ret.insert(QStringLiteral("url"), QVariant(url));
|
|
ret.insert(QStringLiteral("mimeType"), QVariant(mimeType));
|
|
|
|
return ret;
|
|
}
|
|
|
|
void DirModel::emptyTrash()
|
|
{
|
|
KIO::emptyTrash();
|
|
}
|
|
|
|
QVariant DirModel::data(const QModelIndex &index, int role) const
|
|
{
|
|
if (!index.isValid()) {
|
|
return QVariant();
|
|
}
|
|
|
|
switch (role) {
|
|
case UrlRole: {
|
|
KFileItem item = itemForIndex(index);
|
|
return item.url().toString();
|
|
}
|
|
case MimeTypeRole: {
|
|
KFileItem item = itemForIndex(index);
|
|
return item.mimetype();
|
|
}
|
|
case Thumbnail: {
|
|
KFileItem item = itemForIndex(index);
|
|
QImage preview = QImage(m_screenshotSize, QImage::Format_ARGB32_Premultiplied);
|
|
|
|
if (m_imageCache->findImage(item.url().toString(), &preview)) {
|
|
return preview;
|
|
}
|
|
|
|
m_previewTimer->start(100);
|
|
const_cast<DirModel *>(this)->m_filesToPreview[item.url()] = QPersistentModelIndex(index);
|
|
Q_FALLTHROUGH();
|
|
}
|
|
default:
|
|
return KDirModel::data(index, role);
|
|
}
|
|
}
|
|
|
|
void DirModel::delayedPreview()
|
|
{
|
|
QHash<QUrl, QPersistentModelIndex>::const_iterator i = m_filesToPreview.constBegin();
|
|
|
|
KFileItemList list;
|
|
|
|
while (i != m_filesToPreview.constEnd()) {
|
|
QUrl file = i.key();
|
|
QPersistentModelIndex index = i.value();
|
|
|
|
if (!m_previewJobs.contains(file) && file.isValid()) {
|
|
list.append(KFileItem(file, QString(), 0));
|
|
m_previewJobs.insert(file, QPersistentModelIndex(index));
|
|
}
|
|
|
|
++i;
|
|
}
|
|
|
|
if (!list.isEmpty()) {
|
|
KIO::PreviewJob *job = KIO::filePreview(list, m_screenshotSize);
|
|
job->setIgnoreMaximumSize(true);
|
|
// qDebug() << "Created job" << job;
|
|
connect(job, &KIO::PreviewJob::gotPreview, this, &DirModel::showPreview);
|
|
connect(job, &KIO::PreviewJob::failed, this, &DirModel::previewFailed);
|
|
}
|
|
|
|
m_filesToPreview.clear();
|
|
}
|
|
|
|
void DirModel::showPreview(const KFileItem &item, const QPixmap &preview)
|
|
{
|
|
QPersistentModelIndex index = m_previewJobs.value(item.url());
|
|
m_previewJobs.remove(item.url());
|
|
|
|
if (!index.isValid()) {
|
|
return;
|
|
}
|
|
|
|
m_imageCache->insertImage(item.url().toString(), preview.toImage());
|
|
// qDebug() << "preview size:" << preview.size();
|
|
Q_EMIT dataChanged(index, index);
|
|
}
|
|
|
|
void DirModel::previewFailed(const KFileItem &item)
|
|
{
|
|
m_previewJobs.remove(item.url());
|
|
}
|
|
|
|
#include "moc_dirmodel.cpp"
|