summaryrefslogtreecommitdiffstats
path: root/src/networksettings/qnetworksettingsservicemodel.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/networksettings/qnetworksettingsservicemodel.cpp')
-rw-r--r--src/networksettings/qnetworksettingsservicemodel.cpp37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/networksettings/qnetworksettingsservicemodel.cpp b/src/networksettings/qnetworksettingsservicemodel.cpp
index ce8ea86..f7a8a26 100644
--- a/src/networksettings/qnetworksettingsservicemodel.cpp
+++ b/src/networksettings/qnetworksettingsservicemodel.cpp
@@ -75,11 +75,31 @@ QVariant QNetworkSettingsServiceModel::data(const QModelIndex & index, int role)
return QVariant();
}
+bool QNetworkSettingsServiceModel::replacePlaceholder(QNetworkSettingsService* item)
+{
+ if (item->type() == QNetworkSettingsType::Wired) {
+ for (int i = 0; i < m_items.size(); ++i) {
+ QNetworkSettingsService* existing = m_items.at(i);
+ if (existing->placeholderState()) {
+ m_items.replace(i, item);
+ existing->deleteLater();
+ updated(i);
+ return true;
+ }
+ }
+ }
+ return false;
+}
+
void QNetworkSettingsServiceModel::append(QNetworkSettingsService* item)
{
item->setParent(this);
connectStateChanges(item);
+ if ((item->type() == QNetworkSettingsType::Wired) && replacePlaceholder(item)) {
+ return;
+ }
+
beginResetModel();
m_items.append(item);
endResetModel();
@@ -89,6 +109,11 @@ void QNetworkSettingsServiceModel::insert(int row, QNetworkSettingsService* item
{
item->setParent(this);
connectStateChanges(item);
+
+ if ((item->type() == QNetworkSettingsType::Wired) && replacePlaceholder(item)) {
+ return;
+ }
+
beginInsertRows(QModelIndex(), row, row);
m_items.insert(row, item);
endInsertRows();
@@ -105,6 +130,12 @@ void QNetworkSettingsServiceModel::connectStateChanges(QNetworkSettingsService*
void QNetworkSettingsServiceModel::remove(int row)
{
QNetworkSettingsService* item = m_items.at(row);
+ if (item->type() == QNetworkSettingsType::Wired) {
+ /* Don't remove a wired service so that it doesn't become undefined in the UI.
+ This avoids problems when a cable is disconnected. */
+ item->setPlaceholderState(true);
+ return;
+ }
item->deleteLater();
beginRemoveRows(QModelIndex(), row, row);
m_items.removeAt(row);
@@ -262,3 +293,9 @@ int QNetworkSettingsServiceFilter::activeRow() const
}
return -1;
}
+
+void QNetworkSettingsServiceFilter::setWiredNetworksAvailable(bool wiredNetworksAvailable)
+{
+ m_wiredNetworksAvailable = wiredNetworksAvailable;
+ emit wiredNetworksAvailableChanged();
+}