-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsearchdialog.cpp
96 lines (84 loc) · 3.09 KB
/
searchdialog.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
90
91
92
93
94
95
96
#include "searchdialog.h"
#include "ui_searchdialog.h"
#include <QSqlQueryModel>
#include <QTextStream>
#include <QSqlError>
#include <QMessageBox>
#include <QDate>
SearchDialog::SearchDialog(QWidget *parent, QSqlDatabase *dbConn) :
QDialog(parent),
ui(new Ui::SearchDialog)
{
ui->setupUi(this);
this->dbConn = dbConn;
// Set table view
model = new QSqlQueryModel(this);
model->setQuery("select date, getup, anniversary, birth, fate, meet, specialDate, "
"field1, field2, field3, field4, field5, field6, "
"field7, field8 from diary", dbConn->database());
model->setHeaderData(0, Qt::Horizontal, "日期");
model->setHeaderData(1, Qt::Horizontal, "起床");
model->setHeaderData(2, Qt::Horizontal, "紀念日");
model->setHeaderData(3, Qt::Horizontal, "生日");
model->setHeaderData(4, Qt::Horizontal, "命運之日");
model->setHeaderData(5, Qt::Horizontal, "邂逅");
model->setHeaderData(6, Qt::Horizontal, "什麼日子");
model->setHeaderData(7, Qt::Horizontal, "成功日記");
model->setHeaderData(8, Qt::Horizontal, "人生的夢/興趣");
model->setHeaderData(9, Qt::Horizontal, "家庭");
model->setHeaderData(10, Qt::Horizontal, "金錢");
model->setHeaderData(11, Qt::Horizontal, "健康");
model->setHeaderData(12, Qt::Horizontal, "人際");
model->setHeaderData(13, Qt::Horizontal, "感情");
model->setHeaderData(14, Qt::Horizontal, "工作/學習");
ui->tableView->setModel(model);
ui->tableView->show();
}
void SearchDialog::setDate(QDate *date)
{
this->selectedDate = date;
}
SearchDialog::~SearchDialog()
{
delete ui;
}
void SearchDialog::on_tableView_doubleClicked(const QModelIndex &index)
{
QString str = model->data( model->index(index.row(), 0 ) ).toString();
int y = str.mid(0,4).toInt();
int m = str.mid(4,2).toInt();
int d = str.mid(6,2).toInt();
this->selectedDate = new QDate(y,m,d);
emit done(y,m,d);
this->close();
}
void SearchDialog::on_lineEdit_editingFinished()
{
search();
ui->lineEdit->selectAll();
}
void SearchDialog::search()
{
QString tok(ui->lineEdit->text());
tok.replace("\'", "\'\'");
QString select = "select date, getup, anniversary, birth, fate, meet, specialDate, "
"field1, field2, field3, field4, field5, field6, field7, field8 from diary ";
QString query = "where anniversary like '%" + tok + "%' "
"or birth like '%" + tok + "%' "
"or fate like '%" + tok + "%' "
"or meet like '%" + tok + "%' "
"or specialDate like '%" + tok + "%' "
"or field1 like '%" + tok + "%' "
"or field2 like '%" + tok + "%' "
"or field3 like '%" + tok + "%' "
"or field4 like '%" + tok + "%' "
"or field5 like '%" + tok + "%' "
"or field6 like '%" + tok + "%' "
"or field7 like '%" + tok + "%' "
"or field8 like '%" + tok + "%' ";
this->model->setQuery(select + query);
}
void SearchDialog::on_lineEdit_textChanged(const QString &arg1)
{
search();
}