PowerModeler/source/connectionDialog.cpp

395 lines
14 KiB
C++
Raw Normal View History

2025-03-14 16:06:20 +08:00
#include "connectionDialog.h"
#include "./ui_connectionDialog.h"
2025-04-21 14:29:20 +08:00
#include "maskLayer.h"
2025-03-14 16:06:20 +08:00
#include "mainwindow.h"
#include "settings.h"
#include "tableWidgetHoverDelegate.h"
#include "customBorderContainer.h"
2025-03-14 16:06:20 +08:00
#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")
{
2025-04-03 18:01:23 +08:00
//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);
}
2025-03-14 16:06:20 +08:00
initialize();
}
ConnectionDialog::~ConnectionDialog()
{
delete ui;
}
void ConnectionDialog::showEvent(QShowEvent* e)
{
if(ui->connectionList->rowCount() > 0)
{
2025-03-14 16:06:20 +08:00
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;
}
2025-03-14 16:06:20 +08:00
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;
2025-04-21 14:29:20 +08:00
m_pMaskLayer = new MaskLayer(this);
2025-03-14 16:06:20 +08:00
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)
2025-03-14 16:06:20 +08:00
{
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("");
2025-04-02 18:09:48 +08:00
ui->lineEdit_dbName->setText("");
2025-03-14 16:06:20 +08:00
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);
2025-04-02 18:09:48 +08:00
ui->lineEdit_dbName->setText(config.strDBName);
2025-03-14 16:06:20 +08:00
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("");
}
2025-04-21 14:29:20 +08:00
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());
2025-04-21 14:29:20 +08:00
m_pMaskLayer->setGeometry(0, 0, this->width(), this->height());
m_pMaskLayer->show();
}
void ConnectionDialog::hideMask()
{
m_pMaskLayer->close();
}
2025-03-14 16:06:20 +08:00
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);
2025-03-14 16:06:20 +08:00
return;
}
2025-03-14 16:06:20 +08:00
}
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();
2025-04-02 18:09:48 +08:00
config.strDBName = ui->lineEdit_dbName->text();
2025-03-14 16:06:20 +08:00
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();
2025-04-02 18:09:48 +08:00
config.strDBName = ui->lineEdit_dbName->text();
2025-03-14 16:06:20 +08:00
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;
}
}
}