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
|
#ifndef TABLECONSTRAINTSMODEL_H
#define TABLECONSTRAINTSMODEL_H
#include "parser/ast/sqlitecreatetable.h"
#include "guiSQLiteStudio_global.h"
#include <QAbstractTableModel>
#include <QPointer>
class GUI_API_EXPORT TableConstraintsModel : public QAbstractTableModel
{
Q_OBJECT
public:
explicit TableConstraintsModel(QObject *parent = 0);
int rowCount(const QModelIndex& parent = QModelIndex()) const;
int columnCount(const QModelIndex& parent = QModelIndex()) const;
QVariant data(const QModelIndex& index, int role) const;
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
Qt::DropActions supportedDropActions() const;
Qt::DropActions supportedDragActions() const;
QStringList mimeTypes() const;
QMimeData* mimeData(const QModelIndexList& indexes) const;
bool canDropMimeData(const QMimeData* data, Qt::DropAction action, int row, int column, const QModelIndex& parent) const;
bool dropMimeData(const QMimeData* data, Qt::DropAction action, int row, int column, const QModelIndex& parent);
Qt::ItemFlags flags(const QModelIndex& index) const;
bool isModified() const;
void setCreateTable(SqliteCreateTable* value);
SqliteCreateTable::Constraint* getConstraint(int constrIdx) const;
void replaceConstraint(int constrIdx, SqliteCreateTable::Constraint* constr);
void constraintModified(int constrIdx);
void insertConstraint(int constrIdx, SqliteCreateTable::Constraint* constr);
void appendConstraint(SqliteCreateTable::Constraint* constr);
void delConstraint(int constrIdx);
void moveConstraintUp(int constrIdx);
void moveConstraintDown(int constrIdx);
void moveConstraintColumnTo(int constrIdx, int newIdx);
private:
enum class Columns
{
TYPE,
NAME,
DETAILS
};
Columns getColumn(int idx) const;
QString getTypeLabel(SqliteCreateTable::Constraint::Type type) const;
QIcon getTypeIcon(SqliteCreateTable::Constraint::Type type) const;
QString getDetails(SqliteCreateTable::Constraint* constr) const;
QString getPkDetails(SqliteCreateTable::Constraint* constr) const;
QString getUniqueDetails(SqliteCreateTable::Constraint* constr) const;
QString getCheckDetails(SqliteCreateTable::Constraint* constr) const;
QString getFkDetails(SqliteCreateTable::Constraint* constr) const;
QString getConstrDetails(SqliteCreateTable::Constraint* constr, int tokenOffset) const;
void columnRenamed(SqliteCreateTable::Constraint* constr, const QString& oldColumn, const QString& newColumn);
bool handleColumnDeleted(SqliteCreateTable::Constraint* constr, const QString& column);
static const constexpr char* mimeType = "application/x-sqlitestudio-tablestructureconstraintmodel-row-index";
QPointer<SqliteCreateTable> createTable;
bool modified = false;
public slots:
void columnModified(const QString& oldColumn, SqliteCreateTable::Column* newColumn);
void columnDeleted(const QString& column);
signals:
void modifiyStateChanged();
void constraintOrderChanged();
};
#endif // TABLECONSTRAINTSMODEL_H
|