PowerModeler/source/connectionDialog.cpp

349 lines
12 KiB
C++
Raw Normal View History

2025-03-14 16:06:20 +08:00
#include "connectionDialog.h"
#include "./ui_connectionDialog.h"
#include "mainwindow.h"
#include "settings.h"
#include "tableWidgetHoverDelegate.h"
#include <QDateTime>
#define itemID 1
ConnectionDialog::ConnectionDialog(QWidget *parent)
: QDialog(parent)
, ui(new Ui::ConnectionDialog)
, m_pMainWindow(nullptr)
{
ui->setupUi(this);
initialize();
}
ConnectionDialog::~ConnectionDialog()
{
delete ui;
}
void ConnectionDialog::showEvent(QShowEvent* e)
{
if(ui->connectionList->rowCount() > 0)
ui->connectionList->setCurrentCell(0, 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;
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(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->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);
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::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)
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();
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();
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;
}
}
}