-
Notifications
You must be signed in to change notification settings - Fork 0
/
tableeditordialog.cpp
89 lines (82 loc) · 3 KB
/
tableeditordialog.cpp
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
* Copyright (C) 2020 brian DOT l DOT miller DOT ttu AT gmail DOT com
* This file is part of QCovidTracker.
*
* This program comes with ABSOLUTELY NO WARRANTY
* QCovidTracker is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* QCovidTracker 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with QCovidTracker. If not, see <https://www.gnu.org/licenses/.
*/
#include "tableeditordialog.h"
#include "ui_tableeditordialog.h"
#include <QDebug>
#include <QSqlRecord>
#include <QSqlError>
#include <QMessageBox>
TableEditorDialog::TableEditorDialog(QWidget *parent) :
QDialog(parent),
ui(new Ui::TableEditorDialog)
{
ui->setupUi(this);
dbi = new DatabaseInterface("JSONFieldEditor");
mdb = dbi->getDatabase();
tableModel = new QSqlTableModel(this, mdb);
ui->tableViewTable->setModel(tableModel);
connect(ui->pushButtonAddNewRow, &QPushButton::clicked, this, &TableEditorDialog::addNewRow);
connect(ui->pushButtonCommit, &QPushButton::clicked, this, &TableEditorDialog::submitAndRefresh);
ui->comboBoxTable->addItem("--SELECT A TABLE--");
ui->comboBoxTable->addItem("State Info");
ui->comboBoxTable->addItem("Data Source");
connect(ui->comboBoxTable, SIGNAL(currentIndexChanged(int)), this, SLOT(tableSelectionChanged(int)));
}
void TableEditorDialog::tableSelectionChanged(int index) {
if (index == 1) {
tableModel->setTable("state_info");
tableModel->setEditStrategy(QSqlTableModel::OnManualSubmit);
tableModel->select();
ui->tableViewTable->hideColumn(0);
}
else if (index == 2) {
tableModel->setTable("data_source");
tableModel->setEditStrategy(QSqlTableModel::OnManualSubmit);
tableModel->select();
}
}
void TableEditorDialog::submitAndRefresh() {
tableModel->submitAll();
}
void TableEditorDialog::addNewRow() {
tableModel->insertRow(tableModel->rowCount());
}
void TableEditorDialog::reject() {
if (tableModel->isDirty()) {
QMessageBox msgBox;
msgBox.setText("The table has unsaved changes.");
msgBox.setInformativeText("Do you want to save your changes?");
msgBox.setStandardButtons(QMessageBox::Save | QMessageBox::Discard | QMessageBox::Cancel);
msgBox.setDefaultButton(QMessageBox::Save);
int ret = msgBox.exec();
switch(ret) {
case QMessageBox::Save:
tableModel->submitAll();
break;
default:
QDialog::reject();
break;
}
}
QDialog::reject();
}
TableEditorDialog::~TableEditorDialog()
{
delete ui;
}