395 lines
14 KiB
C++
395 lines
14 KiB
C++
#include "connectionDialog.h"
|
||
#include "./ui_connectionDialog.h"
|
||
#include "maskLayer.h"
|
||
#include "mainwindow.h"
|
||
#include "settings.h"
|
||
#include "tableWidgetHoverDelegate.h"
|
||
#include "customBorderContainer.h"
|
||
#include <QDateTime>
|
||
|
||
#define itemID 1
|
||
|
||
ConnectionDialog::ConnectionDialog(QWidget *parent)
|
||
: QDialog(parent)
|
||
, ui(new Ui::ConnectionDialog)
|
||
, m_pMainWindow(nullptr)
|
||
{
|
||
ui->setupUi(this);
|
||
if(QSysInfo::kernelType() == "linux")
|
||
{
|
||
//Linux下默认的Qt::Dialog即使有父窗口也无法按照子窗口的行为进行展示,并且最大、最小按钮不好关闭,因此需要去掉Dialog属性,随之而来的问题是,模态无法起作用
|
||
setWindowFlags(windowFlags() & ~Qt::Dialog);
|
||
setStyleSheet("QDialog{border: 1px solid rgb(205,205,205);border-radius:5px;background-color:rgb(245,245,245);}");
|
||
|
||
m_customBorderContainer = new CustomBorderContainer(this);
|
||
m_customBorderContainer->setOperationOptions(CustomBorderContainer::Movable | CustomBorderContainer::Resizable);
|
||
}
|
||
else
|
||
{
|
||
//setModal(true);
|
||
}
|
||
|
||
initialize();
|
||
}
|
||
|
||
ConnectionDialog::~ConnectionDialog()
|
||
{
|
||
delete ui;
|
||
}
|
||
|
||
void ConnectionDialog::showEvent(QShowEvent* e)
|
||
{
|
||
if(ui->connectionList->rowCount() > 0)
|
||
{
|
||
ui->connectionList->setCurrentCell(0, 0);
|
||
//刷新信息
|
||
QTableWidgetItem* item = ui->connectionList->item(0, 0);
|
||
QString connID = item->data(Qt::UserRole + itemID).toString();
|
||
loadConnInfo(connID);
|
||
m_curConnListRow = 0;
|
||
}
|
||
|
||
QDialog::showEvent(e);
|
||
}
|
||
|
||
void ConnectionDialog::closeEvent(QCloseEvent* e)
|
||
{
|
||
if(m_isNewStatus)
|
||
{
|
||
if(m_pMainWindow)
|
||
{
|
||
m_pMainWindow->showMessageDialog(type_question, QString::fromWCharArray(L"提示"),
|
||
QString::fromWCharArray(L"当前正在新建连接的编辑中,确定放弃吗"));
|
||
if(g_msgDlgBtn == btn_No)
|
||
{
|
||
e->ignore();
|
||
return;
|
||
}
|
||
}
|
||
|
||
removeConnListItem(m_curConnListRow);
|
||
m_isNewStatus = false;
|
||
}
|
||
|
||
QDialog::closeEvent(e);
|
||
}
|
||
|
||
void ConnectionDialog::initialize()
|
||
{
|
||
m_isNewStatus = false;
|
||
m_curConnListRow = -1;
|
||
|
||
m_pMaskLayer = new MaskLayer(this);
|
||
|
||
QIntValidator* validator = new QIntValidator(0, 9999, this);
|
||
ui->lineEdit_port->setValidator(validator);
|
||
|
||
QTableWidgetHoverDelegate* delegate = new QTableWidgetHoverDelegate(ui->connectionList);
|
||
ui->connectionList->setItemDelegate(delegate);
|
||
ui->connectionList->setSelectionBehavior(QAbstractItemView::SelectRows);
|
||
ui->connectionList->setSelectionMode(QAbstractItemView::SingleSelection);
|
||
ui->connectionList->horizontalHeader()->setSectionResizeMode(1, QHeaderView::Stretch); //备注
|
||
ui->connectionList->setColumnWidth(0, 120); //名称
|
||
//从配置文件初始化列表
|
||
QStringList connList = Settings::instance().getConnectionList();
|
||
for(const QString& connID : connList)
|
||
{
|
||
DatabaseConfig config = Settings::instance().loadDatabaseConfig(connID);
|
||
appendConnListItem(connID, config.strConnectionName, config.strComment);
|
||
}
|
||
if(ui->connectionList->rowCount() > 0) //默认定位到第一个会话链接
|
||
{
|
||
QTableWidgetItem* item = ui->connectionList->item(0, 0);
|
||
ui->connectionList->setCurrentItem(item);
|
||
QString connID = item->data(Qt::UserRole + itemID).toString();
|
||
loadConnInfo(connID);
|
||
m_curConnListRow = 0;
|
||
}
|
||
|
||
ui->splitter->setStretchFactor(0, 2);
|
||
ui->splitter->setStretchFactor(0, 3);
|
||
|
||
connect(ui->connectionList, &QTableWidget::cellClicked, this, &ConnectionDialog::onTableCellClicked_connList);
|
||
connect(ui->comboBox_dbType, &QComboBox::currentTextChanged, this, &ConnectionDialog::onComboxChanged_dbType);
|
||
connect(ui->btnOpen, &QPushButton::clicked, this, &ConnectionDialog::onBtnClicked_open);
|
||
connect(ui->btnCancle, &QPushButton::clicked, this, &ConnectionDialog::onBtnClicked_cancle);
|
||
connect(ui->btnSave, &QPushButton::clicked, this, &ConnectionDialog::onBtnClicked_save);
|
||
connect(ui->btnAdd, &QPushButton::clicked, this, &ConnectionDialog::onBtnClicked_add);
|
||
connect(ui->btnRemove, &QPushButton::clicked, this, &ConnectionDialog::onBtnClicked_remove);
|
||
}
|
||
|
||
void ConnectionDialog::appendConnListItem(const QString& connID, const QString& connName, const QString& connRemark)
|
||
{
|
||
int rowCount = ui->connectionList->rowCount();
|
||
ui->connectionList->insertRow(rowCount);
|
||
ui->connectionList->setItem(rowCount, 0, new QTableWidgetItem(connName)); //名称
|
||
QTableWidgetItem* item = ui->connectionList->item(rowCount, 0);
|
||
item->setData(Qt::UserRole + itemID, connID);
|
||
item->setFlags(item->flags() & (~Qt::ItemIsEditable));
|
||
item->setTextAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
|
||
ui->connectionList->setItem(rowCount, 1, new QTableWidgetItem(connRemark)); //备注
|
||
item = ui->connectionList->item(rowCount, 1);
|
||
item->setFlags(item->flags() & (~Qt::ItemIsEditable));
|
||
item->setTextAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
|
||
}
|
||
|
||
void ConnectionDialog::addNewConnListItem()
|
||
{
|
||
int rowCount = ui->connectionList->rowCount();
|
||
ui->connectionList->insertRow(rowCount);
|
||
ui->connectionList->setItem(rowCount, 0, new QTableWidgetItem(QString::fromWCharArray(L"新建连接"))); //名称
|
||
QTableWidgetItem* item = ui->connectionList->item(rowCount, 0);
|
||
item->setFlags(item->flags() & (~Qt::ItemIsEditable));
|
||
item->setTextAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
|
||
ui->connectionList->setItem(rowCount, 1, new QTableWidgetItem("信息编辑中...")); //备注
|
||
item = ui->connectionList->item(rowCount, 1);
|
||
item->setFlags(item->flags() & (~Qt::ItemIsEditable));
|
||
item->setTextAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
|
||
ui->connectionList->setCurrentItem(item);
|
||
//刷新详细信息
|
||
m_curConnListRow = ui->connectionList->currentRow();
|
||
item = ui->connectionList->item(m_curConnListRow, 0);
|
||
ui->connectionList->setCurrentItem(item);
|
||
QString connID = item->data(Qt::UserRole + itemID).toString();
|
||
loadConnInfo(connID);
|
||
}
|
||
|
||
void ConnectionDialog::removeConnListItem(int row)
|
||
{
|
||
if(row < 0 || row > ui->connectionList->rowCount())
|
||
return;
|
||
|
||
QString connID = ui->connectionList->item(row, 0)->data(Qt::UserRole + itemID).toString();
|
||
|
||
for(int i = 0; i < ui->connectionList->columnCount(); i++)
|
||
delete ui->connectionList->takeItem(row, i);
|
||
ui->connectionList->removeRow(row);
|
||
|
||
//刷新详细信息
|
||
if(ui->connectionList->rowCount() == 0)
|
||
{
|
||
m_curConnListRow = -1;
|
||
ui->lineEdit_connection->setText("");
|
||
ui->lineEdit_hostName->setText("");
|
||
ui->lineEdit_port->setText("5432");
|
||
ui->lineEdit_userName->setText("");
|
||
ui->lineEdit_password->setText("");
|
||
ui->lineEdit_dbName->setText("");
|
||
ui->comboBox_dbType->setCurrentText("PostgreSQL");
|
||
ui->plainTextEdit->setPlainText("");
|
||
}
|
||
else
|
||
{
|
||
m_curConnListRow = ui->connectionList->currentRow();
|
||
QTableWidgetItem* item = ui->connectionList->item(m_curConnListRow, 0);
|
||
ui->connectionList->setCurrentItem(item);
|
||
QString connID = item->data(Qt::UserRole + itemID).toString();
|
||
loadConnInfo(connID);
|
||
}
|
||
|
||
if(!connID.isEmpty()) //从配置文件中删除
|
||
Settings::instance().removeDatabaseConfig(connID);
|
||
}
|
||
|
||
void ConnectionDialog::loadConnInfo(const QString& connID)
|
||
{
|
||
if(connID.isEmpty()) //新建链接
|
||
ui->lineEdit_password->setEchoMode(QLineEdit::Normal);
|
||
else
|
||
ui->lineEdit_password->setEchoMode(QLineEdit::Password);
|
||
|
||
DatabaseConfig config = Settings::instance().loadDatabaseConfig(connID);
|
||
ui->lineEdit_connection->setText(config.strConnectionName);
|
||
ui->lineEdit_hostName->setText(config.strHost);
|
||
ui->lineEdit_port->setText(QString::number(config.nPort));
|
||
ui->lineEdit_userName->setText(config.strUserName);
|
||
ui->lineEdit_password->setText(config.strPassword);
|
||
ui->lineEdit_dbName->setText(config.strDBName);
|
||
if(config.strDBType == "QPSQL")
|
||
ui->comboBox_dbType->setCurrentText("PostgreSQL");
|
||
else if(config.strDBType == "QMYSQL")
|
||
ui->comboBox_dbType->setCurrentText("MySQL");
|
||
ui->plainTextEdit->setPlainText(config.strComment);
|
||
}
|
||
|
||
void ConnectionDialog::setMainWindow(MainWindow* window)
|
||
{
|
||
m_pMainWindow = window;
|
||
}
|
||
|
||
void ConnectionDialog::setErrorInfo(const QString& info)
|
||
{
|
||
if(m_pMainWindow)
|
||
m_pMainWindow->showMessageDialog(type_warning, QString::fromWCharArray(L"错误"),info);
|
||
else
|
||
ui->label_error->setText(info);
|
||
}
|
||
void ConnectionDialog::clearErrorInfo()
|
||
{
|
||
if(m_pMainWindow)
|
||
m_pMainWindow->hideMessageDialog();
|
||
else
|
||
ui->label_error->setText("");
|
||
}
|
||
|
||
void ConnectionDialog::showMask()
|
||
{
|
||
// QRect geometry = this->geometry();
|
||
// QRect frameGeometry = this->geometry();
|
||
// int nY = frameGeometry.height() - geometry.height();
|
||
// m_pMaskLayer->setGeometry(0, nY, frameGeometry.width(), frameGeometry.height());
|
||
m_pMaskLayer->setGeometry(0, 0, this->width(), this->height());
|
||
m_pMaskLayer->show();
|
||
}
|
||
void ConnectionDialog::hideMask()
|
||
{
|
||
m_pMaskLayer->close();
|
||
}
|
||
|
||
void ConnectionDialog::onComboxChanged_dbType(const QString& text)
|
||
{
|
||
if(text == "PostgreSQL")
|
||
ui->lineEdit_port->setText("5432");
|
||
else if(text == "MySQL")
|
||
ui->lineEdit_port->setText("3306");
|
||
}
|
||
|
||
void ConnectionDialog::onTableCellClicked_connList(int row, int column)
|
||
{
|
||
if(m_curConnListRow != row)
|
||
{
|
||
if(m_isNewStatus)
|
||
{
|
||
if(m_pMainWindow)
|
||
{
|
||
m_pMainWindow->showMessageDialog(type_question, QString::fromWCharArray(L"提示"),
|
||
QString::fromWCharArray(L"当前正在新建连接的编辑中,确定放弃吗"));
|
||
if(g_msgDlgBtn == btn_No)
|
||
{
|
||
ui->connectionList->setCurrentCell(m_curConnListRow, 0);
|
||
return;
|
||
}
|
||
}
|
||
m_isNewStatus = false;
|
||
removeConnListItem(m_curConnListRow);
|
||
}
|
||
|
||
//刷新信息
|
||
QTableWidgetItem* item = ui->connectionList->item(row, 0);
|
||
QString connID = item->data(Qt::UserRole + itemID).toString();
|
||
loadConnInfo(connID);
|
||
m_curConnListRow = row;
|
||
}
|
||
}
|
||
|
||
void ConnectionDialog::onBtnClicked_open()
|
||
{
|
||
if(ui->lineEdit_connection->text() == "" || ui->lineEdit_hostName->text() == "" || ui->lineEdit_userName->text() == "" ||
|
||
ui->lineEdit_password->text() == "" || ui->lineEdit_port->text() == "")
|
||
{
|
||
setErrorInfo(QString::fromWCharArray(L"除‘备注’外不能有信息为空"));
|
||
return;
|
||
}
|
||
|
||
DatabaseConfig config;
|
||
config.strConnectionName = ui->lineEdit_connection->text();
|
||
config.strHost = ui->lineEdit_hostName->text();
|
||
config.nPort = ui->lineEdit_port->text().toInt();
|
||
config.strUserName = ui->lineEdit_userName->text();
|
||
config.strPassword = ui->lineEdit_password->text();
|
||
config.strDBName = ui->lineEdit_dbName->text();
|
||
if(ui->comboBox_dbType->currentText() == "PostgreSQL")
|
||
config.strDBType = "QPSQL";
|
||
else if(ui->comboBox_dbType->currentText() == "MySQL")
|
||
config.strDBType = "QMYSQL";
|
||
|
||
emit addConnection(config);
|
||
}
|
||
|
||
void ConnectionDialog::onBtnClicked_cancle()
|
||
{
|
||
if(m_isNewStatus)
|
||
{
|
||
m_isNewStatus = false;
|
||
removeConnListItem(m_curConnListRow);
|
||
clearErrorInfo();
|
||
}
|
||
else
|
||
close();
|
||
}
|
||
|
||
void ConnectionDialog::onBtnClicked_save()
|
||
{
|
||
if(ui->lineEdit_connection->text() == "" || ui->lineEdit_hostName->text() == "" || ui->lineEdit_userName->text() == "" ||
|
||
ui->lineEdit_password->text() == "" || ui->lineEdit_port->text() == "")
|
||
{
|
||
setErrorInfo(QString::fromWCharArray(L"除‘备注’外不能有其它信息为空"));
|
||
return;
|
||
}
|
||
|
||
if(ui->connectionList->rowCount() == 0)
|
||
{
|
||
setErrorInfo(QString::fromWCharArray(L"当前无存储对象,请先创建一个链接"));
|
||
return;
|
||
}
|
||
|
||
DatabaseConfig config;
|
||
config.strConnectionName = ui->lineEdit_connection->text();
|
||
config.strHost = ui->lineEdit_hostName->text();
|
||
config.nPort = ui->lineEdit_port->text().toInt();
|
||
config.strUserName = ui->lineEdit_userName->text();
|
||
config.strPassword = ui->lineEdit_password->text();
|
||
config.strDBName = ui->lineEdit_dbName->text();
|
||
if(ui->comboBox_dbType->currentText() == "PostgreSQL")
|
||
config.strDBType = "QPSQL";
|
||
else if(ui->comboBox_dbType->currentText() == "MySQL")
|
||
config.strDBType = "QMYSQL";
|
||
if(ui->plainTextEdit->toPlainText().isEmpty())
|
||
config.strComment = QString::fromWCharArray(L"无");
|
||
else
|
||
config.strComment = ui->plainTextEdit->toPlainText();
|
||
|
||
QTableWidgetItem* item = ui->connectionList->item(ui->connectionList->currentRow(), 0);
|
||
if(m_isNewStatus)
|
||
{
|
||
config.strID = QDateTime::currentDateTime().toString("yyMMddhhmmssz");
|
||
item->setData(Qt::UserRole + itemID, config.strID);
|
||
m_isNewStatus = false;
|
||
}
|
||
else
|
||
config.strID = item->data(Qt::UserRole + itemID).toString();
|
||
item->setText(ui->lineEdit_connection->text());
|
||
item = ui->connectionList->item(ui->connectionList->currentRow(), 1);
|
||
item->setText(config.strComment);
|
||
|
||
Settings::instance().saveDatabaseConfig(config);
|
||
}
|
||
|
||
void ConnectionDialog::onBtnClicked_add()
|
||
{
|
||
if(m_isNewStatus)
|
||
{
|
||
if(m_pMainWindow)
|
||
m_pMainWindow->showMessageDialog(type_warning, QString::fromWCharArray(L"错误"),
|
||
QString::fromWCharArray(L"当前正在新建链接的编辑中,请先结束操作"));
|
||
return;
|
||
}
|
||
addNewConnListItem();
|
||
m_isNewStatus = true;
|
||
}
|
||
|
||
void ConnectionDialog::onBtnClicked_remove()
|
||
{
|
||
if(m_pMainWindow)
|
||
{
|
||
m_pMainWindow->showMessageDialog(type_question, QString::fromWCharArray(L"提示"),
|
||
QString::fromWCharArray(L"确认删除当前选择吗"));
|
||
if(g_msgDlgBtn == btn_Yes)
|
||
{
|
||
removeConnListItem(m_curConnListRow);
|
||
if(m_isNewStatus)
|
||
m_isNewStatus = false;
|
||
}
|
||
}
|
||
}
|