a little more paranoia around action access

svn path=/trunk/KDE/kdelibs/; revision=1004683
This commit is contained in:
Aaron J. Seigo 2009-07-30 18:13:01 +00:00
parent ae09154da3
commit a4b980b37b

View File

@ -1069,14 +1069,13 @@ void Applet::flushPendingConstraintsEvents()
QAction *configAction = d->actions->action("configure"); QAction *configAction = d->actions->action("configure");
if (configAction) { if (configAction) {
//XXX assumption: isContainment won't change after this
if (d->isContainment) { if (d->isContainment) {
connect(configAction, SIGNAL(triggered()), this, SLOT(requestConfiguration())); connect(configAction, SIGNAL(triggered()), this, SLOT(requestConfiguration()));
} else { } else {
connect(configAction, SIGNAL(triggered(bool)), this, SLOT(showConfigurationInterface())); connect(configAction, SIGNAL(triggered(bool)), this, SLOT(showConfigurationInterface()));
} }
bool canConfig = unlocked || KAuthorized::authorize("PlasmaAllowConfigureWhenLocked"); bool canConfig = unlocked || KAuthorized::authorize("PlasmaAllowConfigureWhenLocked");
canConfig = canConfig && (d->hasConfigurationInterface || d->isContainment);
configAction->setVisible(canConfig); configAction->setVisible(canConfig);
configAction->setEnabled(canConfig); configAction->setEnabled(canConfig);
} }
@ -1096,10 +1095,9 @@ void Applet::flushPendingConstraintsEvents()
action->setEnabled(unlocked); action->setEnabled(unlocked);
} }
bool canConfig = unlocked || KAuthorized::authorize("PlasmaAllowConfigureWhenLocked");
canConfig = canConfig && (d->hasConfigurationInterface || d->isContainment);
action = d->actions->action("configure"); action = d->actions->action("configure");
if (action) { if (action) {
bool canConfig = unlocked || KAuthorized::authorize("PlasmaAllowConfigureWhenLocked");
action->setVisible(canConfig); action->setVisible(canConfig);
action->setEnabled(canConfig); action->setEnabled(canConfig);
} }
@ -1422,8 +1420,6 @@ bool Applet::hasConfigurationInterface() const
return d->hasConfigurationInterface; return d->hasConfigurationInterface;
} }
//it bugs me that this can get turned on and off at will. I don't see it being useful and it just
//makes more work for me and more code duplication.
void Applet::setHasConfigurationInterface(bool hasInterface) void Applet::setHasConfigurationInterface(bool hasInterface)
{ {
if (d->hasConfigurationInterface == hasInterface) { if (d->hasConfigurationInterface == hasInterface) {
@ -1431,23 +1427,6 @@ void Applet::setHasConfigurationInterface(bool hasInterface)
} }
d->hasConfigurationInterface = hasInterface; d->hasConfigurationInterface = hasInterface;
//FIXME I'm pretty sure this line has issues but I'm preserving current behaviour for now
if (!hasInterface && (d->isContainment || qobject_cast<Plasma::Containment*>(this))) {
return;
}
//config action
KAction *configAction = qobject_cast<KAction*>(d->actions->action("configure"));
if (configAction) {
bool canConfig = false;
if (hasInterface) {
bool unlocked = immutability() == Mutable;
canConfig = unlocked || KAuthorized::authorize("PlasmaAllowConfigureWhenLocked");
}
configAction->setVisible(canConfig);
configAction->setEnabled(canConfig);
}
} }
KActionCollection* AppletPrivate::defaultActions(QObject *parent) KActionCollection* AppletPrivate::defaultActions(QObject *parent)
@ -1718,7 +1697,7 @@ void AppletPrivate::updateShortcuts()
actions->readSettings(); actions->readSettings();
for (int i=0; i<names.size(); ++i) { for (int i = 0; i < names.size(); ++i) {
QAction *a = qactions.at(i); QAction *a = qactions.at(i);
if (a) { if (a) {
actions->addAction(names.at(i), a); actions->addAction(names.at(i), a);
@ -2330,9 +2309,14 @@ void AppletPrivate::init(const QString &packagePath)
q->setHasConfigurationInterface(true); //FIXME why not default it to true in the constructor? q->setHasConfigurationInterface(true); //FIXME why not default it to true in the constructor?
QAction *closeApplet = actions->action("remove"); QAction *closeApplet = actions->action("remove");
closeApplet->setText(i18nc("%1 is the name of the applet", "Remove this %1", q->name())); if (closeApplet) {
closeApplet->setText(i18nc("%1 is the name of the applet", "Remove this %1", q->name()));
}
QAction *configAction = actions->action("configure"); QAction *configAction = actions->action("configure");
configAction->setText(i18nc("%1 is the name of the applet", "%1 Settings", q->name())); if (configAction) {
configAction->setText(i18nc("%1 is the name of the applet", "%1 Settings", q->name()));
}
QObject::connect(Plasma::Theme::defaultTheme(), SIGNAL(themeChanged()), q, SLOT(themeChanged())); QObject::connect(Plasma::Theme::defaultTheme(), SIGNAL(themeChanged()), q, SLOT(themeChanged()));
QObject::connect(q, SIGNAL(activate()), q, SLOT(setFocus())); QObject::connect(q, SIGNAL(activate()), q, SLOT(setFocus()));