display an icon instead of a button as config overlay in panels, due to

constrained size

svn path=/trunk/KDE/kdelibs/; revision=888026
This commit is contained in:
Marco Martin 2008-11-23 14:09:45 +00:00
parent fd0e2e8fc2
commit e06cb3cda0

View File

@ -58,6 +58,7 @@
#include <kservicetypetrader.h> #include <kservicetypetrader.h>
#include <kshortcut.h> #include <kshortcut.h>
#include <kwindowsystem.h> #include <kwindowsystem.h>
#include <kpushbutton.h>
#include <solid/powermanagement.h> #include <solid/powermanagement.h>
@ -803,10 +804,25 @@ void Applet::setConfigurationRequired(bool needsConfig, const QString &reason)
//configLayout->setAlignment(explanation, Qt::AlignBottom | Qt::AlignCenter); //configLayout->setAlignment(explanation, Qt::AlignBottom | Qt::AlignCenter);
} }
PushButton *configWidget = new PushButton(d->messageOverlay);
//popupapplets in panels just show an icon, otherwise the button is too large
Plasma::FormFactor f = formFactor();
if (f == Plasma::Horizontal || f == Plasma::Vertical) {
IconWidget *configWidget = new IconWidget(d->messageOverlay);
configWidget->setSvg("widgets/configuration-icons", "configure");
configWidget->setDrawBackground(true);
connect(configWidget, SIGNAL(clicked()), this, SLOT(showConfigurationInterface()));
configLayout->addItem(configWidget, row, 1);
//FIXME: this thing seems necessary for some applets, others not
configWidget->setZValue(999);
} else {
PushButton *configWidget = new PushButton(d->messageOverlay); PushButton *configWidget = new PushButton(d->messageOverlay);
configWidget->setText(i18n("Configure...")); configWidget->setText(i18n("Configure..."));
connect(configWidget, SIGNAL(clicked()), this, SLOT(showConfigurationInterface())); connect(configWidget, SIGNAL(clicked()), this, SLOT(showConfigurationInterface()));
configLayout->addItem(configWidget, row, 1); configLayout->addItem(configWidget, row, 1);
}
//configLayout->setAlignment(configWidget, Qt::AlignTop | Qt::AlignCenter); //configLayout->setAlignment(configWidget, Qt::AlignTop | Qt::AlignCenter);
//configLayout->addStretch(); //configLayout->addStretch();