kwin/kcmkwin/kwinscreenedges/kwinscreenedgeconfigform.cpp
Cyril Rossi 99bed106bf KCM KWin Manage default Highlight indicator for settings not handled by KCModule
For the following KCM :
* KWin Options
* KWin Screen Edges
* KWin Tabbox

KCModule introduce an indicator to show which settings have changed from
default value. Unfortunately some KCM have settings' states which are not managed
automatically by the KCModule thus we have to handle it manually.

see https://invent.kde.org/frameworks/kconfigwidgets/-/merge_requests/9
2020-09-30 09:10:23 +02:00

119 lines
3.6 KiB
C++

/*
KWin - the KDE window manager
This file is part of the KDE project.
SPDX-FileCopyrightText: 2009 Lucas Murray <lmurray@undefinedfire.com>
SPDX-FileCopyrightText: 2020 Cyril Rossi <cyril.rossi@enioka.com>
SPDX-License-Identifier: GPL-2.0-or-later
*/
#include "kwinscreenedgeconfigform.h"
#include "ui_main.h"
namespace KWin
{
KWinScreenEdgesConfigForm::KWinScreenEdgesConfigForm(QWidget *parent)
: KWinScreenEdge(parent)
, ui(new Ui::KWinScreenEdgesConfigUI)
{
ui->setupUi(this);
connect(ui->kcfg_ElectricBorderDelay, qOverload<int>(&QSpinBox::valueChanged), this, &KWinScreenEdgesConfigForm::sanitizeCooldown);
// Visual feedback of action group conflicts
connect(ui->kcfg_ElectricBorders, qOverload<int>(&QComboBox::currentIndexChanged), this, &KWinScreenEdgesConfigForm::groupChanged);
connect(ui->kcfg_ElectricBorderMaximize, &QCheckBox::stateChanged, this, &KWinScreenEdgesConfigForm::groupChanged);
connect(ui->kcfg_ElectricBorderTiling, &QCheckBox::stateChanged, this, &KWinScreenEdgesConfigForm::groupChanged);
connect(ui->electricBorderCornerRatioSpin, qOverload<int>(&QSpinBox::valueChanged), this, &KWinScreenEdgesConfigForm::onChanged);
connect(ui->electricBorderCornerRatioSpin, qOverload<int>(&QSpinBox::valueChanged), this, &KWinScreenEdgesConfigForm::updateDefaultIndicators);
}
KWinScreenEdgesConfigForm::~KWinScreenEdgesConfigForm()
{
delete ui;
}
void KWinScreenEdgesConfigForm::setElectricBorderCornerRatio(double value)
{
m_referenceCornerRatio = value;
ui->electricBorderCornerRatioSpin->setValue(m_referenceCornerRatio * 100.);
}
void KWinScreenEdgesConfigForm::setDefaultElectricBorderCornerRatio(double value)
{
m_defaultCornerRatio = value;
}
double KWinScreenEdgesConfigForm::electricBorderCornerRatio() const
{
return ui->electricBorderCornerRatioSpin->value() / 100.;
}
void KWinScreenEdgesConfigForm::setElectricBorderCornerRatioEnabled(bool enable)
{
ui->electricBorderCornerRatioSpin->setEnabled(enable);
}
void KWinScreenEdgesConfigForm::reload()
{
ui->electricBorderCornerRatioSpin->setValue(m_referenceCornerRatio * 100.);
KWinScreenEdge::reload();
}
void KWinScreenEdgesConfigForm::setDefaults()
{
ui->electricBorderCornerRatioSpin->setValue(m_defaultCornerRatio * 100.);
KWinScreenEdge::setDefaults();
}
void KWinScreenEdgesConfigForm::setDefaultsIndicatorsVisible(bool visible)
{
if (m_defaultIndicatorVisible != visible) {
m_defaultIndicatorVisible = visible;
updateDefaultIndicators();
}
}
Monitor *KWinScreenEdgesConfigForm::monitor() const
{
return ui->monitor;
}
bool KWinScreenEdgesConfigForm::isSaveNeeded() const
{
return m_referenceCornerRatio != electricBorderCornerRatio();
}
bool KWinScreenEdgesConfigForm::isDefault() const
{
return m_defaultCornerRatio == electricBorderCornerRatio();
}
void KWinScreenEdgesConfigForm::sanitizeCooldown()
{
ui->kcfg_ElectricBorderCooldown->setMinimum(ui->kcfg_ElectricBorderDelay->value() + 50);
}
void KWinScreenEdgesConfigForm::groupChanged()
{
// Monitor conflicts
bool hide = false;
if (ui->kcfg_ElectricBorders->currentIndex() == 2) {
hide = true;
}
monitorHideEdge(ElectricTop, hide);
monitorHideEdge(ElectricRight, hide);
monitorHideEdge(ElectricBottom, hide);
monitorHideEdge(ElectricLeft, hide);
}
void KWinScreenEdgesConfigForm::updateDefaultIndicators()
{
ui->electricBorderCornerRatioSpin->setProperty("_kde_highlight_neutral", m_defaultIndicatorVisible && (electricBorderCornerRatio() != m_defaultCornerRatio));
ui->electricBorderCornerRatioSpin->update();
}
} // namespace