remove the desktop specific functionality, to be moved to a plugin that

ships with the plasma binary. should make the amarok people happy ;)

svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=720731
This commit is contained in:
Aaron J. Seigo 2007-10-03 15:46:40 +00:00
parent 0cfd584408
commit bd1f639f95
3 changed files with 5 additions and 147 deletions

View File

@ -65,15 +65,6 @@ kde4_add_ui_files (
appletbrowser/kcategorizeditemsviewbase.ui appletbrowser/kcategorizeditemsviewbase.ui
) )
set(krunner_xml ${KDEBASE_WORKSPACE_SOURCE_DIR}/krunner/org.kde.krunner.Interface.xml)
QT4_ADD_DBUS_INTERFACE(plasma_LIB_SRCS ${krunner_xml} krunner_interface)
set(screensaver_xml ${KDEBASE_WORKSPACE_SOURCE_DIR}/krunner/org.freedesktop.ScreenSaver.xml)
QT4_ADD_DBUS_INTERFACE(plasma_LIB_SRCS ${screensaver_xml} screensaver_interface)
set(ksmserver_xml ${KDEBASE_WORKSPACE_SOURCE_DIR}/ksmserver/org.kde.KSMServerInterface.xml)
QT4_ADD_DBUS_INTERFACE(plasma_LIB_SRCS ${ksmserver_xml} ksmserver_interface)
if(QT_QTOPENGL_FOUND AND OPENGL_FOUND) if(QT_QTOPENGL_FOUND AND OPENGL_FOUND)
MESSAGE(STATUS "Adding support for OpenGL applets to libplasma") MESSAGE(STATUS "Adding support for OpenGL applets to libplasma")
set(plasma_LIB_SRCS set(plasma_LIB_SRCS

View File

@ -35,8 +35,6 @@
#include <KRun> #include <KRun>
#include <KServiceTypeTrader> #include <KServiceTypeTrader>
#include "workspace/kworkspace.h"
#include "corona.h" #include "corona.h"
#include "karambamanager.h" #include "karambamanager.h"
#include "phase.h" #include "phase.h"
@ -45,12 +43,6 @@
#include "widgets/freelayout.h" #include "widgets/freelayout.h"
#include "widgets/boxlayout.h" #include "widgets/boxlayout.h"
#include "krunner_interface.h"
#include "ksmserver_interface.h"
#include "screensaver_interface.h"
#include "appletbrowser.h"
namespace Plasma namespace Plasma
{ {
@ -63,14 +55,8 @@ public:
layout(0), layout(0),
background(0), background(0),
bitmapBackground(0), bitmapBackground(0),
engineExplorerAction(0),
appletBrowserAction(0),
runCommandAction(0),
lockAction(0),
logoutAction(0),
screen(-1), screen(-1),
immutable(false), immutable(false)
appletBrowser(0)
{ {
} }
@ -80,7 +66,6 @@ public:
applets.clear(); applets.clear();
delete layout; delete layout;
delete bitmapBackground; delete bitmapBackground;
delete appletBrowser;
} }
FormFactor formFactor; FormFactor formFactor;
@ -90,15 +75,9 @@ public:
Plasma::Svg *background; Plasma::Svg *background;
QPixmap* bitmapBackground; QPixmap* bitmapBackground;
QString wallpaperPath; QString wallpaperPath;
QAction *engineExplorerAction;
QAction *appletBrowserAction;
QAction *runCommandAction;
QAction *lockAction;
QAction *logoutAction;
QSize size; QSize size;
int screen; int screen;
bool immutable; bool immutable;
AppletBrowser *appletBrowser;
}; };
Containment::Containment(QGraphicsItem* parent, Containment::Containment(QGraphicsItem* parent,
@ -191,116 +170,11 @@ void Containment::paintInterface(QPainter *painter,
painter->restore(); painter->restore();
} }
void Containment::launchExplorer()
{
KRun::run("plasmaengineexplorer", KUrl::List(), 0);
}
void Containment::launchAppletBrowser()
{
if (!d->appletBrowser) {
//TODO: should we delete this after some point, so as to conserve memory
// and any possible processing tha tmight end up in AppletBrowser?
d->appletBrowser = new AppletBrowser(this);
}
d->appletBrowser->show();
}
void Containment::runCommand()
{
if (!KAuthorized::authorizeKAction("run_command")) {
return;
}
QString interface("org.kde.krunner");
org::kde::krunner::Interface krunner(interface, "/Interface",
QDBusConnection::sessionBus());
if (krunner.isValid()) {
krunner.display();
}
}
void Containment::lockScreen()
{
if (!KAuthorized::authorizeKAction("lock_screen")) {
return;
}
QString interface("org.freedesktop.ScreenSaver");
org::freedesktop::ScreenSaver screensaver(interface, "/ScreenSaver",
QDBusConnection::sessionBus());
if (screensaver.isValid()) {
screensaver.Lock();
}
}
void Containment::logout()
{
if (!KAuthorized::authorizeKAction("logout")) {
return;
}
QString interface("org.kde.ksmserver");
org::kde::KSMServerInterface smserver(interface, "/KSMServer",
QDBusConnection::sessionBus());
if (smserver.isValid()) {
smserver.logout(KWorkSpace::ShutdownConfirmDefault,
KWorkSpace::ShutdownTypeDefault,
KWorkSpace::ShutdownModeDefault);
}
}
QSizeF Containment::contentSizeHint() const QSizeF Containment::contentSizeHint() const
{ {
return d->size; return d->size;
} }
QList<QAction*> Containment::contextActions()
{
//FIXME: several items here ... probably all junior jobs =)
// - pretty up the menu with separators
// - should we offer "Switch User" here?
if (!d->appletBrowserAction) {
d->engineExplorerAction = new QAction(i18n("Engine Explorer"), this);
connect(d->engineExplorerAction, SIGNAL(triggered(bool)), this, SLOT(launchExplorer()));
d->appletBrowserAction = new QAction(i18n("Add applet"), this);
connect(d->appletBrowserAction, SIGNAL(triggered(bool)), this, SLOT(launchAppletBrowser()));
d->runCommandAction = new QAction(i18n("Run Command..."), this);
connect(d->runCommandAction, SIGNAL(triggered(bool)), this, SLOT(runCommand()));
d->lockAction = new QAction(i18n("Lock Screen"), this);
d->lockAction->setIcon(KIcon("system-lock-screen"));
connect(d->lockAction, SIGNAL(triggered(bool)), this, SLOT(lockScreen()));
d->logoutAction = new QAction(i18n("Logout"), this);
d->logoutAction->setIcon(KIcon("system-log-out"));
connect(d->logoutAction, SIGNAL(triggered(bool)), this, SLOT(logout()));
}
QList<QAction*> actions;
actions.append(d->engineExplorerAction);
actions.append(d->appletBrowserAction);
if (KAuthorized::authorizeKAction("run_command")) {
actions.append(d->runCommandAction);
}
if (KAuthorized::authorizeKAction("lock_screen")) {
actions.append(d->lockAction);
}
if (KAuthorized::authorizeKAction("logout")) {
actions.append(d->logoutAction);
}
return actions;
}
void Containment::contextMenuEvent(QGraphicsSceneContextMenuEvent* event) void Containment::contextMenuEvent(QGraphicsSceneContextMenuEvent* event)
{ {
kDebug() << "let's see if we manage to get a context menu here, huh"; kDebug() << "let's see if we manage to get a context menu here, huh";
@ -615,7 +489,7 @@ void Containment::dropEvent(QGraphicsSceneDragDropEvent *event)
addApplet(plasmoidName, QVariantList(), 0, geom); addApplet(plasmoidName, QVariantList(), 0, geom);
event->acceptProposedAction(); event->acceptProposedAction();
} else if (KUrl::List::canDecode(event->mimeData())) { } else if (KUrl::List::canDecode(event->mimeData())) {
KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); KUrl::List urls = KUrl::List::fromMimeData(event->mimeData());
foreach (const KUrl& url, urls) { foreach (const KUrl& url, urls) {
KMimeType::Ptr mime = KMimeType::findByUrl(url); KMimeType::Ptr mime = KMimeType::findByUrl(url);
QString mimeName = mime->name(); QString mimeName = mime->name();
@ -626,7 +500,7 @@ void Containment::dropEvent(QGraphicsSceneDragDropEvent *event)
KPluginInfo::List appletList = Applet::knownAppletsForMimetype(mimeName); KPluginInfo::List appletList = Applet::knownAppletsForMimetype(mimeName);
if (appletList.isEmpty()) { if (appletList.isEmpty()) {
// no special applet associated with this mimetype, let's // no special applet associated with this mimetype, let's
addApplet("url", args, 0, geom); addApplet("url", args, 0, geom);
} else { } else {
//TODO: should we show a dialog here to choose which plasmoid load if //TODO: should we show a dialog here to choose which plasmoid load if

View File

@ -119,11 +119,11 @@ class PLASMA_EXPORT Containment : public Applet
* *
* @param category Only applets matchin this category will be returned. * @param category Only applets matchin this category will be returned.
* Useful in conjunction with knownCategories. * Useful in conjunction with knownCategories.
* If "Misc" is passed in, then applets without a * If "Misc" is passed in, then applets without a
* Categories= entry are also returned. * Categories= entry are also returned.
* If an empty string is passed in, all applets are * If an empty string is passed in, all applets are
* returned. * returned.
* @param parentApp the application to filter applets on. Uses the * @param parentApp the application to filter applets on. Uses the
* X-KDE-ParentApp entry (if any) in the plugin info. * X-KDE-ParentApp entry (if any) in the plugin info.
* The default value of QString() will result in a * The default value of QString() will result in a
* list containing only applets not specifically * list containing only applets not specifically
@ -196,8 +196,6 @@ class PLASMA_EXPORT Containment : public Applet
*/ */
void initConstraints(KConfigGroup* group); void initConstraints(KConfigGroup* group);
QList<QAction*> contextActions();
/** /**
* Reimplemented from Applet * Reimplemented from Applet
*/ */
@ -228,11 +226,6 @@ class PLASMA_EXPORT Containment : public Applet
* @internal * @internal
*/ */
void appletDestroyed(QObject*); void appletDestroyed(QObject*);
void launchExplorer();
void launchAppletBrowser();
void runCommand();
void lockScreen();
void logout();
void dropEvent(QGraphicsSceneDragDropEvent* event); void dropEvent(QGraphicsSceneDragDropEvent* event);
private: private: