mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Still trying to make it easier for the Mobile Port: This patch is a bit bigger than I hopped, but it was the smallest that I could get. A lot of TODO items where added where I broke the code because the current implementation would break the QML implementtion on the designer. I'll most probably fix those myself when I finish the transition to the models to the new folder. I only moved both models at once because there's an interdependency between them (seems inevitable, tough, but I'll take a better look at it later). Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
36 lines
1.2 KiB
C++
36 lines
1.2 KiB
C++
#ifndef CLEANERTABLEMODEL_H
|
|
#define CLEANERTABLEMODEL_H
|
|
|
|
#include <QAbstractTableModel>
|
|
#include <QStringList>
|
|
|
|
/* When using a QAbstractTableModel, consider using this instead
|
|
* of the default implementation, as it's easyer to setup the columns
|
|
* and headers.
|
|
* Most subsurface classes uses this one to save loads of lines
|
|
* of code and share a consistent layout. */
|
|
|
|
class CleanerTableModel : public QAbstractTableModel {
|
|
Q_OBJECT
|
|
public:
|
|
explicit CleanerTableModel(QObject *parent = 0);
|
|
virtual int columnCount(const QModelIndex &parent = QModelIndex()) const;
|
|
virtual QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const;
|
|
|
|
protected:
|
|
void setHeaderDataStrings(const QStringList &headers);
|
|
signals:
|
|
|
|
/* instead of using QMessageBox directly, wire a QWidget to this signal and display the result.
|
|
* This is because the QModels will be used from the Mobile version and the desktop version. */
|
|
void warningMessage(const QString& title, const QString& message);
|
|
|
|
private:
|
|
QStringList headers;
|
|
};
|
|
|
|
/* Has the string value changed */
|
|
#define CHANGED() \
|
|
(vString = value.toString()) != data(index, role).toString()
|
|
|
|
#endif
|