kdeconnect-kde/indicator/systray_actions/connectivity_action.cpp
Alexander Lohnau 02d97aabf4 Add explicit moc includes to cpp files
The rationale is explained in https://planet.kde.org/friedrich-kossebau-2023-06-28-include-also-moc-files-of-headers/

In case of KDEConnect, it impressively speeds up compilation. Before it
took 390 seconds on a clean build and with this change it took 330 seconds.
This is due to the mocs_compilation having to include the header files
and thus all their headers. Due to the lots of small plugins we have,
this means that the same headers must be compiled plenty of times.
When we include the moc files directly in the C++ file, they are already
available.
2023-07-28 16:07:34 +02:00

85 lines
2.6 KiB
C++

/*
* SPDX-FileCopyrightText: 2016 Aleix Pol Gonzalez <aleixpol@kde.org>
* SPDX-FileCopyrightText: 2020 Piyush Aggarwal <piyushaggarwal002@gmail.com>
*
* SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
*/
#include "connectivity_action.h"
ConnectivityAction::ConnectivityAction(DeviceDbusInterface *device)
: QAction(nullptr)
, m_connectivityiface(device->id())
{
setCellularNetworkStrength(m_connectivityiface.cellularNetworkStrength());
setCellularNetworkType(m_connectivityiface.cellularNetworkType());
connect(&m_connectivityiface, &ConnectivityReportDbusInterface::refreshedProxy, this, [this] {
setCellularNetworkStrength(m_connectivityiface.cellularNetworkStrength());
setCellularNetworkType(m_connectivityiface.cellularNetworkType());
});
setIcon(QIcon::fromTheme(QStringLiteral("network-wireless")));
ConnectivityAction::update();
}
void ConnectivityAction::update()
{
if (m_cellularNetworkStrength < 0) {
setText(i18nc("The fallback text to display in case the remote device does not have a cellular connection", "No Cellular Connectivity"));
} else {
setText(i18nc("Display the cellular connection type and an approximate percentage of signal strength",
"%1 | ~%2%",
m_cellularNetworkType,
m_cellularNetworkStrength * 25));
}
// set icon name
QString iconName = QStringLiteral("network-mobile");
if (m_cellularNetworkStrength < 0) {
iconName += QStringLiteral("-off");
} else {
int signalStrength;
switch (m_cellularNetworkStrength) {
case 0:
signalStrength = 0;
break;
case 1:
signalStrength = 20;
break;
case 2:
signalStrength = 60;
break;
case 3:
signalStrength = 80;
break;
default:
signalStrength = 100;
break;
}
iconName += QStringLiteral("-") + QString::number(signalStrength);
}
if (connectivity_action::networkTypesWithIcons.contains(m_cellularNetworkType)) {
iconName += QStringLiteral("-") + m_cellularNetworkType.toLower();
}
setIcon(QIcon::fromTheme(iconName));
}
void ConnectivityAction::setCellularNetworkStrength(int cellularNetworkStrength)
{
m_cellularNetworkStrength = cellularNetworkStrength;
update();
}
void ConnectivityAction::setCellularNetworkType(QString cellularNetworkType)
{
m_cellularNetworkType = cellularNetworkType;
update();
}
#include "moc_connectivity_action.cpp"