blob: 1f9d1f870fc2db49fa790eac420ffa5af97f41d7 (
plain) (
blame)
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 INDEXDIALOG_H
#define INDEXDIALOG_H
#include "db/db.h"
#include "guiSQLiteStudio_global.h"
#include "parser/ast/sqlitecreateindex.h"
#include <QDialog>
#include <QStringListModel>
namespace Ui {
class IndexDialog;
}
class QGridLayout;
class QSignalMapper;
class QCheckBox;
class QComboBox;
class GUI_API_EXPORT IndexDialog : public QDialog
{
Q_OBJECT
public:
IndexDialog(Db* db, QWidget *parent = 0);
IndexDialog(Db* db, const QString& index, QWidget *parent = 0);
~IndexDialog();
void setTable(const QString& value);
protected:
void changeEvent(QEvent *e);
private:
void init();
void readIndex();
void readCollations();
void buildColumn(const QString& name, int row);
void applyColumnValues();
void applyIndex();
SqliteIndexedColumn* addIndexedColumn(const QString& name);
void rebuildCreateIndex();
void queryDuplicates();
bool existingIndex = false;
Db* db = nullptr;
QString table;
QString index;
SqliteCreateIndexPtr createIndex;
SqliteCreateIndexPtr originalCreateIndex;
QStringList tableColumns;
QSignalMapper* columnStateSignalMapping = nullptr;
QStringListModel collations;
QList<QCheckBox*> columnCheckBoxes;
QList<QComboBox*> sortComboBoxes;
QList<QComboBox*> collateComboBoxes;
int totalColumns = 0;
Ui::IndexDialog *ui = nullptr;
private slots:
void updateValidation();
void buildColumns();
void updateTable(const QString& value);
void updateColumnState(int row);
void updatePartialConditionState();
void updateDdl();
void tabChanged(int tab);
public slots:
void accept();
};
#endif // INDEXDIALOG_H
|