mirror of
https://github.com/KDE/latte-dock.git
synced 2025-01-11 13:18:13 +03:00
reject duplicate layout names in settings
This commit is contained in:
parent
880ed9638e
commit
37cac2ca81
@ -39,6 +39,7 @@
|
|||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QHeaderView>
|
#include <QHeaderView>
|
||||||
|
#include <QItemSelection>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <QTemporaryDir>
|
#include <QTemporaryDir>
|
||||||
@ -57,7 +58,7 @@ namespace Controller {
|
|||||||
|
|
||||||
Layouts::Layouts(QDialog *parent, Latte::Corona *corona, QTableView *view)
|
Layouts::Layouts(QDialog *parent, Latte::Corona *corona, QTableView *view)
|
||||||
: QObject(parent),
|
: QObject(parent),
|
||||||
m_parent(parent),
|
m_parentDialog(parent),
|
||||||
m_corona(corona),
|
m_corona(corona),
|
||||||
m_model(new Model::Layouts(this, corona)),
|
m_model(new Model::Layouts(this, corona)),
|
||||||
m_proxyModel(new QSortFilterProxyModel(this)),
|
m_proxyModel(new QSortFilterProxyModel(this)),
|
||||||
@ -72,6 +73,7 @@ Layouts::Layouts(QDialog *parent, Latte::Corona *corona, QTableView *view)
|
|||||||
|
|
||||||
connect(m_model, &QAbstractItemModel::dataChanged, this, &Layouts::dataChanged);
|
connect(m_model, &QAbstractItemModel::dataChanged, this, &Layouts::dataChanged);
|
||||||
connect(m_model, &Model::Layouts::rowsInserted, this, &Layouts::dataChanged);
|
connect(m_model, &Model::Layouts::rowsInserted, this, &Layouts::dataChanged);
|
||||||
|
connect(m_model, &Model::Layouts::nameDuplicated, this, &Layouts::on_nameDuplicatedFrom);
|
||||||
}
|
}
|
||||||
|
|
||||||
Layouts::~Layouts()
|
Layouts::~Layouts()
|
||||||
@ -230,7 +232,7 @@ QString Layouts::uniqueTempDirectory()
|
|||||||
|
|
||||||
QString Layouts::uniqueLayoutName(QString name)
|
QString Layouts::uniqueLayoutName(QString name)
|
||||||
{
|
{
|
||||||
int pos_ = name.lastIndexOf(QRegExp(QString("[-][0-9]+")));
|
int pos_ = name.lastIndexOf(QRegExp(QString(" [-][0-9]+")));
|
||||||
|
|
||||||
if (m_model->containsCurrentName(name) && pos_ > 0) {
|
if (m_model->containsCurrentName(name) && pos_ > 0) {
|
||||||
name = name.left(pos_);
|
name = name.left(pos_);
|
||||||
@ -241,7 +243,7 @@ QString Layouts::uniqueLayoutName(QString name)
|
|||||||
QString namePart = name;
|
QString namePart = name;
|
||||||
|
|
||||||
while (m_model->containsCurrentName(name)) {
|
while (m_model->containsCurrentName(name)) {
|
||||||
name = namePart + "-" + QString::number(i);
|
name = namePart + " - " + QString::number(i);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -289,7 +291,7 @@ void Layouts::toggleSharedForSelected()
|
|||||||
if (selected.isShared()) {
|
if (selected.isShared()) {
|
||||||
m_proxyModel->setData(m_proxyModel->index(m_view->currentIndex().row(), Model::Layouts::SHAREDCOLUMN), QStringList(), Qt::UserRole);
|
m_proxyModel->setData(m_proxyModel->index(m_view->currentIndex().row(), Model::Layouts::SHAREDCOLUMN), QStringList(), Qt::UserRole);
|
||||||
} else {
|
} else {
|
||||||
/* bool assigned{false};
|
/* bool assigned{false};
|
||||||
QStringList assignedList;
|
QStringList assignedList;
|
||||||
|
|
||||||
QStringList availableShares = availableSharesFor(row);
|
QStringList availableShares = availableSharesFor(row);
|
||||||
@ -447,7 +449,7 @@ void Layouts::loadLayouts()
|
|||||||
|
|
||||||
//! there are broken layouts and the user must be informed!
|
//! there are broken layouts and the user must be informed!
|
||||||
if (brokenLayouts.count() > 0) {
|
if (brokenLayouts.count() > 0) {
|
||||||
auto msg = new QMessageBox(m_parent);
|
auto msg = new QMessageBox(m_parentDialog);
|
||||||
msg->setIcon(QMessageBox::Warning);
|
msg->setIcon(QMessageBox::Warning);
|
||||||
msg->setWindowTitle(i18n("Layout Warning"));
|
msg->setWindowTitle(i18n("Layout Warning"));
|
||||||
msg->setText(i18n("The layout(s) <b>%0</b> have <i>broken configuration</i>!!! Please <b>remove them</b> to improve the system stability...").arg(brokenLayouts.join(",")));
|
msg->setText(i18n("The layout(s) <b>%0</b> have <i>broken configuration</i>!!! Please <b>remove them</b> to improve the system stability...").arg(brokenLayouts.join(",")));
|
||||||
@ -502,7 +504,7 @@ void Layouts::addLayoutForFile(QString file, QString layoutName, bool newTempDir
|
|||||||
|
|
||||||
m_model->appendLayout(copied);
|
m_model->appendLayout(copied);
|
||||||
|
|
||||||
// ui->layoutsView->selectRow(row);
|
// ui->layoutsView->selectRow(row);
|
||||||
|
|
||||||
if (showNotification) {
|
if (showNotification) {
|
||||||
//NOTE: The pointer is automatically deleted when the event is closed
|
//NOTE: The pointer is automatically deleted when the event is closed
|
||||||
@ -835,6 +837,39 @@ void Layouts::saveColumnWidths()
|
|||||||
m_corona->universalSettings()->setLayoutsColumnWidths(columnWidths);
|
m_corona->universalSettings()->setLayoutsColumnWidths(columnWidths);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Layouts::on_nameDuplicatedFrom(const QString &provenId, const QString &trialId)
|
||||||
|
{
|
||||||
|
//! duplicated layout name
|
||||||
|
auto msg = new QMessageBox(m_parentDialog);
|
||||||
|
msg->setIcon(QMessageBox::Warning);
|
||||||
|
msg->setWindowTitle(i18n("Layout Warning"));
|
||||||
|
msg->setText(i18n("There are layouts with the same name, that is not permitted!!! Please update these names to re-apply the changes..."));
|
||||||
|
msg->setStandardButtons(QMessageBox::Ok);
|
||||||
|
|
||||||
|
connect(msg, &QMessageBox::finished, this, [ &, provenId, trialId](int result) {
|
||||||
|
int pRow = rowForId(provenId);
|
||||||
|
int tRow = rowForId(trialId);
|
||||||
|
|
||||||
|
if (pRow >= 0) {
|
||||||
|
QItemSelectionModel::SelectionFlags flags = QItemSelectionModel::ClearAndSelect;
|
||||||
|
QItemSelection rowSelection;
|
||||||
|
|
||||||
|
QModelIndex pIndexS = m_proxyModel->index(pRow, Model::Layouts::BACKGROUNDCOLUMN);
|
||||||
|
QModelIndex pIndexE = m_proxyModel->index(pRow, Model::Layouts::SHAREDCOLUMN);
|
||||||
|
|
||||||
|
rowSelection.select(pIndexS, pIndexE);
|
||||||
|
|
||||||
|
m_view->selectionModel()->select(rowSelection, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
QModelIndex tIndex = m_proxyModel->index(tRow, Model::Layouts::NAMECOLUMN);
|
||||||
|
m_view->edit(tIndex);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
msg->open();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -86,6 +86,7 @@ signals:
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void saveColumnWidths();
|
void saveColumnWidths();
|
||||||
|
void on_nameDuplicatedFrom(const QString &provenId, const QString &trialId);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void initView();
|
void initView();
|
||||||
@ -98,7 +99,7 @@ private:
|
|||||||
QString uniqueLayoutName(QString name);
|
QString uniqueLayoutName(QString name);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QDialog *m_parent{nullptr};
|
QDialog *m_parentDialog{nullptr};
|
||||||
Latte::Corona *m_corona{nullptr};
|
Latte::Corona *m_corona{nullptr};
|
||||||
QTableView *m_view{nullptr};
|
QTableView *m_view{nullptr};
|
||||||
|
|
||||||
|
@ -570,9 +570,17 @@ bool Layouts::setData(const QModelIndex &index, const QVariant &value, int role)
|
|||||||
break;
|
break;
|
||||||
case NAMECOLUMN:
|
case NAMECOLUMN:
|
||||||
if (role == Qt::DisplayRole) {
|
if (role == Qt::DisplayRole) {
|
||||||
m_layoutsTable[row].setCurrentName(value.toString());
|
QString provenId = m_layoutsTable.idForCurrentName(value.toString());
|
||||||
emit dataChanged(index, index, roles);
|
|
||||||
return true;
|
if (!provenId.isEmpty() && provenId != m_layoutsTable[row].id /*not the same row*/ ){
|
||||||
|
//! duplicate name should be rejected
|
||||||
|
emit nameDuplicated(provenId, m_layoutsTable[row].id);
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
m_layoutsTable[row].setCurrentName(value.toString());
|
||||||
|
emit dataChanged(index, index, roles);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case MENUCOLUMN:
|
case MENUCOLUMN:
|
||||||
|
@ -101,6 +101,7 @@ public:
|
|||||||
|
|
||||||
signals:
|
signals:
|
||||||
void inMultipleModeChanged();
|
void inMultipleModeChanged();
|
||||||
|
void nameDuplicated(const QString &provenId, const QString &trialId);
|
||||||
void rowsInserted();
|
void rowsInserted();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
Loading…
Reference in New Issue
Block a user