mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
If we want to include dive computer names in the undo system, there should be visual feedback on undo/redo. This would mean opening the divecomputer dialog, which would appear quite strange. Therefore, add a tab. This is not ideal, but consistent with the dive site tab, which probably shouldn't be there either. In the future, the UI needs some rethinking. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
41 lines
1 KiB
C++
41 lines
1 KiB
C++
// SPDX-License-Identifier: GPL-2.0
|
|
#ifndef DIVECOMPUTERMODEL_H
|
|
#define DIVECOMPUTERMODEL_H
|
|
|
|
#include "qt-models/cleanertablemodel.h"
|
|
#include "core/device.h"
|
|
#include <QSortFilterProxyModel>
|
|
|
|
class DiveComputerModel : public CleanerTableModel {
|
|
Q_OBJECT
|
|
public:
|
|
enum {
|
|
REMOVE,
|
|
MODEL,
|
|
ID,
|
|
NICKNAME
|
|
};
|
|
DiveComputerModel(QObject *parent = 0);
|
|
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
|
int rowCount(const QModelIndex &parent = QModelIndex()) const override;
|
|
Qt::ItemFlags flags(const QModelIndex &index) const override;
|
|
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) override;
|
|
void keepWorkingList();
|
|
|
|
public
|
|
slots:
|
|
void remove(const QModelIndex &index);
|
|
|
|
private:
|
|
std::vector<device> dcs;
|
|
};
|
|
|
|
class DiveComputerSortedModel : public QSortFilterProxyModel {
|
|
public:
|
|
using QSortFilterProxyModel::QSortFilterProxyModel;
|
|
void remove(const QModelIndex &index);
|
|
private:
|
|
bool lessThan(const QModelIndex &i1, const QModelIndex &i2) const;
|
|
};
|
|
|
|
#endif
|