kdelibs/kfile/kfileplacesmodel.h
Ivailo Monev 9e554f60fa generic: add new signal to solid device manager
its use case is shown in KFilePlacesModel, basically when a CD-ROM is
ejected it will be removed from the items in the model and when disc is
inserted item for it will be added to the model. Dolphin and Plasma require
changes of their own for this behaviour to be consistent across
applications

naming the method after OpticalDisc::availableContent(), have in mind it
should work when a disc is erased and written to for example or when a
device is formatted and no longer has filesystem which has not been tested
but in theory should work. may need additional checks for encrypted device
but that can be done in the future

Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2021-06-10 02:15:42 +03:00

152 lines
5.5 KiB
C++

/* This file is part of the KDE project
Copyright (C) 2007 Kevin Ottens <ervin@kde.org>
Copyright (C) 2007 David Faure <faure@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License version 2 as published by the Free Software Foundation.
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.
*/
#ifndef KFILEPLACESMODEL_H
#define KFILEPLACESMODEL_H
#include <kfile_export.h>
#include <QtCore/QAbstractItemModel>
#include <kurl.h>
#include <kbookmark.h>
#include <kicon.h>
#include <solid/device.h>
#include <QMimeData>
#include <QAction>
/**
* This class is a list view model. Each entry represents a "place"
* where user can access files. Only revelant when
* used with QListView or QTableView.
*/
class KFILE_EXPORT KFilePlacesModel : public QAbstractItemModel
{
Q_OBJECT
public:
enum AdditionalRoles {
UrlRole = 0x069CD12B,
HiddenRole = 0x0741CAAC,
SetupNeededRole = 0x059A935D,
FixedDeviceRole = 0x332896C1,
CapacityBarRecommendedRole = 0x1548C5C4
};
KFilePlacesModel(QObject *parent=0);
~KFilePlacesModel();
KUrl url(const QModelIndex &index) const;
bool setupNeeded(const QModelIndex &index) const;
KIcon icon(const QModelIndex &index) const;
QString text(const QModelIndex &index) const;
bool isHidden(const QModelIndex &index) const;
bool isDevice(const QModelIndex &index) const;
Solid::Device deviceForIndex(const QModelIndex &index) const;
KBookmark bookmarkForIndex(const QModelIndex &index) const;
QAction *teardownActionForIndex(const QModelIndex &index) const;
QAction *ejectActionForIndex(const QModelIndex &index) const;
void requestTeardown(const QModelIndex &index);
void requestEject(const QModelIndex &index);
void requestSetup(const QModelIndex &index);
void addPlace(const QString &text, const KUrl &url, const QString &iconName = QString(), const QString &appName = QString());
void addPlace(const QString &text, const KUrl &url, const QString &iconName, const QString &appName, const QModelIndex &after);
void editPlace(const QModelIndex &index, const QString &text, const KUrl &url, const QString &iconName = QString(), const QString &appName = QString());
void removePlace(const QModelIndex &index) const;
void setPlaceHidden(const QModelIndex &index, bool hidden);
int hiddenCount() const;
/**
* @brief Get a visible data based on Qt role for the given index.
* Return the device information for the give index.
*
* @param index The QModelIndex which contains the row, column to fetch the data.
* @param role The Interview data role(ex: Qt::DisplayRole).
*
* @return the data for the given index and role.
*/
QVariant data(const QModelIndex &index, int role) const;
/**
* @brief Get the children model index for the given row and column.
*/
QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const;
/**
* @brief Get the parent QModelIndex for the given model child.
*/
QModelIndex parent(const QModelIndex &child) const;
/**
* @brief Get the number of rows for a model index.
*/
int rowCount(const QModelIndex &parent = QModelIndex()) const;
/**
* @brief Get the number of columns for a model index.
*/
int columnCount(const QModelIndex &parent = QModelIndex()) const;
/**
* Returns the closest item for the URL \a url.
* The closest item is defined as item which is equal to
* the URL or at least is a parent URL. If there are more than
* one possible parent URL candidates, the item which covers
* the bigger range of the URL is returned.
*
* Example: the url is '/home/peter/Documents/Music'.
* Available items are:
* - /home/peter
* - /home/peter/Documents
*
* The returned item will the one for '/home/peter/Documents'.
*/
QModelIndex closestItem(const KUrl &url) const;
Qt::DropActions supportedDropActions() const;
Qt::ItemFlags flags(const QModelIndex &index) const;
QStringList mimeTypes() const;
QMimeData *mimeData(const QModelIndexList &indexes) const;
bool dropMimeData(const QMimeData *data, Qt::DropAction action,
int row, int column, const QModelIndex &parent);
Q_SIGNALS:
void errorMessage(const QString &message);
void setupDone(const QModelIndex &index, bool success);
private:
Q_PRIVATE_SLOT(d, void _k_initDeviceList())
Q_PRIVATE_SLOT(d, void _k_deviceAdded(const QString&))
Q_PRIVATE_SLOT(d, void _k_deviceRemoved(const QString&))
Q_PRIVATE_SLOT(d, void _k_contentChanged(const QString&, const bool))
Q_PRIVATE_SLOT(d, void _k_itemChanged(const QString&))
Q_PRIVATE_SLOT(d, void _k_reloadBookmarks())
Q_PRIVATE_SLOT(d, void _k_storageSetupDone(Solid::ErrorType, QVariant))
Q_PRIVATE_SLOT(d, void _k_storageTeardownDone(Solid::ErrorType, QVariant))
class Private;
Private * const d;
friend class Private;
};
#endif