2005-12-29 21:55:22 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2005 by Aaron Seigo <aseigo@kde.org>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc.,
|
2006-01-23 11:37:31 +00:00
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2005-12-29 21:55:22 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PLASMA_APPLET_H
|
|
|
|
#define PLASMA_APPLET_H
|
|
|
|
|
2007-06-20 06:45:08 +00:00
|
|
|
#include <QtGui/QGraphicsItem>
|
2007-04-22 09:35:04 +00:00
|
|
|
#include <QtGui/QWidget>
|
2005-12-29 21:55:22 +00:00
|
|
|
|
2007-06-16 23:38:56 +00:00
|
|
|
#include <kplugininfo.h>
|
|
|
|
#include <ksharedconfig.h>
|
|
|
|
#include <kgenericfactory.h>
|
2005-12-29 21:55:22 +00:00
|
|
|
|
2007-06-02 17:29:39 +00:00
|
|
|
#include <plasma/plasma.h>
|
2007-07-12 18:34:53 +00:00
|
|
|
#include <plasma/widgets/widget.h>
|
2005-12-29 21:55:22 +00:00
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
2007-06-02 17:29:39 +00:00
|
|
|
|
|
|
|
class DataEngine;
|
|
|
|
|
2007-05-22 18:29:12 +00:00
|
|
|
/**
|
2007-05-23 22:45:21 +00:00
|
|
|
* @short The base Applet (Plasmoid) class
|
2007-05-22 18:29:12 +00:00
|
|
|
*
|
2007-05-23 15:47:27 +00:00
|
|
|
*
|
2007-05-22 18:29:12 +00:00
|
|
|
*/
|
2007-07-12 18:34:53 +00:00
|
|
|
class PLASMA_EXPORT Applet : public QObject, public Widget
|
2005-12-29 21:55:22 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
typedef QList<Applet*> List;
|
2007-05-24 20:01:12 +00:00
|
|
|
typedef QHash<QString, Applet*> Dict;
|
2005-12-29 21:55:22 +00:00
|
|
|
|
2007-05-22 18:29:12 +00:00
|
|
|
/**
|
|
|
|
* @arg parent the QGraphicsItem this applet is parented to
|
|
|
|
* @arg servideId the name of the .desktop file containing the
|
|
|
|
* information about the widget
|
|
|
|
* @arg appletId a unique id used to differentiate between multiple
|
|
|
|
* instances of the same Applet type
|
|
|
|
*/
|
2007-07-12 18:34:53 +00:00
|
|
|
explicit Applet(QGraphicsItem* parent = 0,
|
|
|
|
const QString& serviceId = QString(),
|
|
|
|
uint appletId = 0);
|
2007-05-25 02:36:22 +00:00
|
|
|
|
2007-05-24 20:01:12 +00:00
|
|
|
/**
|
|
|
|
* This constructor is to be used with the plugin loading systems
|
|
|
|
* found in KPluginInfo and KService. The argument list is expected
|
|
|
|
* to have two elements: the KService service ID for the desktop entry
|
|
|
|
* and an applet ID which must be a base 10 number.
|
|
|
|
*
|
|
|
|
* @arg parent a QObject parent; you probably want to pass in 0
|
|
|
|
* @arg args a list of strings containing two entries: the service id
|
|
|
|
* and the applet id
|
|
|
|
*/
|
|
|
|
Applet(QObject* parent, const QStringList& args);
|
|
|
|
|
2005-12-29 21:55:22 +00:00
|
|
|
~Applet();
|
|
|
|
|
|
|
|
/**
|
2007-05-25 02:36:22 +00:00
|
|
|
* Returns the KConfigGroup to access the applets configuration.
|
2005-12-29 21:55:22 +00:00
|
|
|
*
|
2007-05-25 02:36:22 +00:00
|
|
|
* This config object will write to an instance
|
2006-04-13 00:11:16 +00:00
|
|
|
* specific config file named \<appletname\>\<instanceid\>rc
|
2007-05-25 02:36:22 +00:00
|
|
|
* in the Plasma appdata directory.
|
2005-12-29 21:55:22 +00:00
|
|
|
**/
|
2007-07-12 19:14:23 +00:00
|
|
|
KConfigGroup config() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a config group with the name provided. This ensures
|
|
|
|
* that the group name is properly namespaced to avoid collision
|
|
|
|
* with other applets that may be sharing this config file
|
|
|
|
*
|
|
|
|
* @param group the name of the group to access
|
|
|
|
**/
|
|
|
|
KConfigGroup config(const QString& group) const;
|
2005-12-29 21:55:22 +00:00
|
|
|
|
2006-04-13 00:11:16 +00:00
|
|
|
/**
|
2007-05-25 02:36:22 +00:00
|
|
|
* Returns a KConfigGroup object to be shared by all applets of this
|
|
|
|
* type.
|
|
|
|
*
|
|
|
|
* This config object will write to an applet-specific config object
|
|
|
|
* named plasma_\<appletname\>rc in the local config directory.
|
2006-04-13 00:11:16 +00:00
|
|
|
*/
|
2007-07-12 19:14:23 +00:00
|
|
|
KConfigGroup globalConfig() const;
|
2006-04-13 00:11:16 +00:00
|
|
|
|
|
|
|
/**
|
2007-07-11 01:24:43 +00:00
|
|
|
* Loads the given DataEngine
|
2006-04-13 00:11:16 +00:00
|
|
|
*
|
2007-07-11 01:24:43 +00:00
|
|
|
* Tries to load the data engine given by @p name. Each engine is
|
|
|
|
* only loaded once, and that instance is re-used on all subsequent
|
|
|
|
* requests.
|
|
|
|
*
|
|
|
|
* If the data engine was not found, an invalid data engine is returned
|
|
|
|
* (see DataEngine::isValid()).
|
|
|
|
*
|
|
|
|
* Note that you should <em>not</em> delete the returned engine.
|
|
|
|
*
|
|
|
|
* @param name Name of the data engine to load
|
|
|
|
* @return pointer to the data engine if it was loaded,
|
|
|
|
* or an invalid data engine if the requested engine
|
|
|
|
* could not be loaded
|
2006-04-13 00:11:16 +00:00
|
|
|
*/
|
2007-06-02 17:29:39 +00:00
|
|
|
DataEngine* dataEngine(const QString& name);
|
2006-04-13 00:11:16 +00:00
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Called when any of the geometry constraints have been updated.
|
|
|
|
*
|
|
|
|
* This is always called prior to painting and should be used as an
|
2005-12-29 21:55:22 +00:00
|
|
|
* opportunity to layout the widget, calculate sizings, etc.
|
2007-05-31 22:40:38 +00:00
|
|
|
*
|
|
|
|
* Do not call update() from this method; an update() will be triggered
|
|
|
|
* at the appropriate time for the applet.
|
|
|
|
*
|
2005-12-29 21:55:22 +00:00
|
|
|
* @property constraint
|
|
|
|
*/
|
|
|
|
virtual void constraintsUpdated();
|
|
|
|
|
2007-05-31 22:40:38 +00:00
|
|
|
/**
|
|
|
|
* Returns the current form factor the applet is being displayed in.
|
2007-07-06 22:20:57 +00:00
|
|
|
*
|
2007-05-31 22:40:38 +00:00
|
|
|
* @see Plasma::FormFactor
|
|
|
|
*/
|
|
|
|
FormFactor formFactor() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the location of the scene which is displaying applet.
|
2007-07-06 22:20:57 +00:00
|
|
|
*
|
2007-05-31 22:40:38 +00:00
|
|
|
* @see Plasma::Location
|
|
|
|
*/
|
|
|
|
Location location() const;
|
|
|
|
|
2007-06-02 04:47:09 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Returns a maximum size hint based on the Corona's space availability.
|
|
|
|
*
|
2007-06-02 04:47:09 +00:00
|
|
|
* An applet may choose to violate this size hint, but should try and
|
|
|
|
* respect it as much as possible.
|
|
|
|
*/
|
|
|
|
QRectF maxSizeHint() const;
|
|
|
|
|
2007-05-24 20:01:12 +00:00
|
|
|
/**
|
|
|
|
* Returns a list of all known applets in a hash keyed by a unique
|
2007-07-06 22:20:57 +00:00
|
|
|
* identifier for each applet.
|
2007-05-24 20:01:12 +00:00
|
|
|
*
|
|
|
|
* @return list of applets
|
|
|
|
**/
|
|
|
|
static KPluginInfo::List knownApplets();
|
2007-05-31 22:40:38 +00:00
|
|
|
|
2007-07-12 13:24:35 +00:00
|
|
|
/**
|
|
|
|
* Returns a list of all the categories used by
|
|
|
|
* installed applets.
|
|
|
|
*/
|
|
|
|
static QStringList knownCategories();
|
|
|
|
|
2007-07-02 10:47:34 +00:00
|
|
|
/**
|
|
|
|
* @return true if this plasmoid provides a GUI configuration
|
|
|
|
**/
|
|
|
|
bool hasConfigurationInterface();
|
|
|
|
|
2007-05-26 19:01:32 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Reimplement this slot to show a configuration dialog.
|
|
|
|
*
|
|
|
|
* Let the user play with the plasmoid options.
|
|
|
|
* Called when the user selects the configure entry
|
2007-07-02 10:47:34 +00:00
|
|
|
* from the context menu.
|
2007-05-26 19:01:32 +00:00
|
|
|
*/
|
2007-07-02 10:58:03 +00:00
|
|
|
virtual void showConfigurationInterface();
|
2007-05-24 20:01:12 +00:00
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Attempts to load an applet
|
|
|
|
*
|
|
|
|
* Returns a pointer to the applet if successful.
|
|
|
|
* The caller takes responsibility for the applet, including
|
2007-05-24 20:01:12 +00:00
|
|
|
* deleting it when no longer needed.
|
|
|
|
*
|
|
|
|
* @param name the plugin name, as returned by KPluginInfo::pluginName()
|
|
|
|
* @param applet unique ID to assign the applet, or zero to have one
|
|
|
|
* assigned automatically.
|
2007-06-20 08:11:59 +00:00
|
|
|
* @param args to send the applet extra arguments
|
2007-05-24 20:01:12 +00:00
|
|
|
* @return a pointer to the loaded applet, or 0 on load failure
|
|
|
|
**/
|
2007-06-20 08:11:59 +00:00
|
|
|
static Applet* loadApplet(const QString &name, uint appletId = 0,
|
|
|
|
const QStringList& args = QStringList());
|
2007-05-23 15:47:27 +00:00
|
|
|
|
2007-05-24 20:51:59 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Attempts to load an applet
|
|
|
|
*
|
|
|
|
* Returns a pointer to the applet if successful.
|
|
|
|
* The caller takes responsibility for the applet, including
|
2007-05-24 20:51:59 +00:00
|
|
|
* deleting it when no longer needed.
|
|
|
|
*
|
|
|
|
* @param info KPluginInfo object for the desired applet
|
|
|
|
* @param applet unique ID to assign the applet, or zero to have one
|
|
|
|
* assigned automatically.
|
|
|
|
* @return a pointer to the loaded applet, or 0 on load failure
|
|
|
|
**/
|
2007-06-20 08:11:59 +00:00
|
|
|
static Applet* loadApplet(const KPluginInfo* info, uint appletId = 0,
|
|
|
|
const QStringList& args = QStringList());
|
2007-05-24 20:51:59 +00:00
|
|
|
|
2007-06-22 20:28:42 +00:00
|
|
|
/**
|
|
|
|
* This method is called when the interface should be painted.
|
2007-07-06 22:20:57 +00:00
|
|
|
*
|
2007-06-22 20:28:42 +00:00
|
|
|
* @see QGraphicsItem::paint
|
|
|
|
**/
|
|
|
|
virtual void paintInterface(QPainter *painter,
|
|
|
|
const QStyleOptionGraphicsItem *option,
|
|
|
|
QWidget *widget = 0);
|
|
|
|
|
2007-06-05 19:31:48 +00:00
|
|
|
/**
|
|
|
|
* Returns the user-visible name for the applet, as specified in the
|
|
|
|
* .desktop file.
|
2007-07-06 22:20:57 +00:00
|
|
|
*
|
2007-06-05 19:31:48 +00:00
|
|
|
* @return the user-visible name for the applet.
|
|
|
|
**/
|
2007-06-21 18:24:05 +00:00
|
|
|
QString name() const;
|
|
|
|
|
2007-07-12 13:24:35 +00:00
|
|
|
/**
|
|
|
|
* Returns the category the applet is in, as specified in the
|
|
|
|
* .desktop file.
|
|
|
|
*/
|
|
|
|
QString category() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the category of the given applet
|
|
|
|
*
|
|
|
|
* @param a KPluginInfo object for the applet
|
|
|
|
*/
|
|
|
|
static QString category(const KPluginInfo* applet);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the category of the given applet
|
|
|
|
*
|
|
|
|
* @param the name of the applet
|
|
|
|
*/
|
|
|
|
static QString category(const QString& appletName);
|
|
|
|
|
2007-06-21 18:24:05 +00:00
|
|
|
/**
|
|
|
|
* @return true if this applet is immutable
|
|
|
|
**/
|
|
|
|
bool immutable() const;
|
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Sets whether or not this applet is immutable or not.
|
2007-06-21 18:24:05 +00:00
|
|
|
*
|
|
|
|
* @arg immutable true if this applet should not be changable
|
|
|
|
**/
|
|
|
|
void setImmutable(bool immutable);
|
2007-06-05 19:31:48 +00:00
|
|
|
|
2007-06-20 06:45:08 +00:00
|
|
|
/**
|
2007-06-22 20:28:42 +00:00
|
|
|
* @return returns whether or not the applet is using the standard
|
|
|
|
* background
|
2007-06-20 06:45:08 +00:00
|
|
|
**/
|
2007-06-22 20:28:42 +00:00
|
|
|
bool drawStandardBackground();
|
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Sets whether the applet should automatically draw the standard
|
|
|
|
* background.
|
|
|
|
*
|
|
|
|
* Defaults to false
|
2007-06-22 20:28:42 +00:00
|
|
|
**/
|
|
|
|
void setDrawStandardBackground(bool drawBackground);
|
2007-06-20 06:45:08 +00:00
|
|
|
|
2007-07-12 18:34:53 +00:00
|
|
|
/**
|
|
|
|
* If for some reason, the applet fails to get up on its feet (the
|
|
|
|
* library couldn't be loaded, necessary hardware support wasn't found,
|
|
|
|
* etc..) this method returns true
|
|
|
|
**/
|
|
|
|
bool failedToLaunch() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Call this method when the applet fails to launch properly. An
|
|
|
|
* optional reason can be provided.
|
|
|
|
*
|
|
|
|
* Not that all children items will be deleted when this method is
|
|
|
|
* called. If you have pointers to these items, you will need to
|
|
|
|
* reset them after calling this method.
|
|
|
|
*
|
|
|
|
* @param failed true when the applet failed, false when it succeeded
|
|
|
|
* @param reason an optional reason to show the user why the applet
|
|
|
|
* failed to launch
|
|
|
|
**/
|
|
|
|
void setFailedToLaunch(bool failed, const QString& reason = QString());
|
|
|
|
|
2007-07-06 22:20:57 +00:00
|
|
|
// Reimplemented from QGraphicsItem
|
2007-06-21 18:07:39 +00:00
|
|
|
enum { Type = Plasma::AppletType };
|
|
|
|
int type() const { return Type; }
|
2007-07-12 18:34:53 +00:00
|
|
|
QRectF boundingRect () const;
|
2007-06-21 18:07:39 +00:00
|
|
|
|
2006-01-20 11:09:06 +00:00
|
|
|
Q_SIGNALS:
|
2007-05-27 08:01:31 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Emitted when the applet needs to take (or lose) keyboard focus.
|
|
|
|
*
|
|
|
|
* An applet should emit this signal to ensure that autohiding
|
|
|
|
* elements stay unhidden and other bits of bookkeeping are
|
|
|
|
* performed to ensure proper function.
|
2007-05-27 08:01:31 +00:00
|
|
|
*
|
|
|
|
* If you call watchForFocus on your applet, then this is handled for
|
|
|
|
* the applet and it is not necessary to emit the signal directly.
|
|
|
|
*
|
|
|
|
* @param focus true if the applet is taking keyboard focus, false if
|
|
|
|
* it is giving it up
|
|
|
|
**/
|
2007-03-03 01:41:27 +00:00
|
|
|
void requestFocus( bool focus );
|
2005-12-29 21:55:22 +00:00
|
|
|
|
|
|
|
protected:
|
2007-05-27 08:01:31 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Returns the name of the applet.
|
|
|
|
*
|
|
|
|
* This will be the same for all instances of this applet.
|
2007-05-27 08:01:31 +00:00
|
|
|
**/
|
2005-12-29 21:55:22 +00:00
|
|
|
QString globalName() const;
|
2007-05-27 08:01:31 +00:00
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Returns a name unique to the instance of this applet.
|
|
|
|
*
|
|
|
|
* Useful for being able to refer directly to a particular
|
|
|
|
* applet. Combines the global name with the applet id
|
2007-05-27 08:01:31 +00:00
|
|
|
**/
|
2005-12-29 21:55:22 +00:00
|
|
|
QString instanceName() const;
|
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Register widgets that can receive keyboard focus.
|
|
|
|
*
|
|
|
|
* Calling this results in an eventFilter being places on the widget.
|
|
|
|
*
|
2005-12-29 21:55:22 +00:00
|
|
|
* @param widget the widget to watch for keyboard focus
|
|
|
|
* @param watch whether to start watching the widget, or to stop doing so
|
|
|
|
*/
|
2007-03-03 01:41:27 +00:00
|
|
|
void watchForFocus( QObject *widget, bool watch = true );
|
2005-12-29 21:55:22 +00:00
|
|
|
|
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Call this whenever focus is needed or not needed.
|
|
|
|
*
|
|
|
|
* You do not have to call this method for widgets that have
|
|
|
|
* been registered with watchForFocus
|
|
|
|
*
|
2005-12-29 21:55:22 +00:00
|
|
|
* @see watchForFocus
|
|
|
|
* @param focus whether to or not to request focus
|
|
|
|
*/
|
2007-06-21 18:24:05 +00:00
|
|
|
void needsFocus(bool focus);
|
2005-12-29 21:55:22 +00:00
|
|
|
|
2007-07-02 10:47:34 +00:00
|
|
|
/**
|
2007-07-06 22:20:57 +00:00
|
|
|
* Sets whether or not this applet provides a user interface for
|
|
|
|
* configuring the applet.
|
|
|
|
*
|
|
|
|
* It defaults to false, and if true is passed in you should
|
2007-07-02 10:58:03 +00:00
|
|
|
* also reimplement showConfigurationInterface()
|
2007-07-02 10:47:34 +00:00
|
|
|
*
|
|
|
|
* @arg hasInterface whether or not there is a user interface available
|
|
|
|
**/
|
|
|
|
void setHasConfigurationInterface(bool hasInterface);
|
|
|
|
|
2007-05-27 08:01:31 +00:00
|
|
|
/**
|
|
|
|
* @internal event filter; used for focus watching
|
|
|
|
**/
|
2007-03-03 01:41:27 +00:00
|
|
|
bool eventFilter( QObject *o, QEvent *e );
|
2005-12-29 21:55:22 +00:00
|
|
|
|
|
|
|
private:
|
2007-07-06 22:20:57 +00:00
|
|
|
// Reimplemented from QGraphicsItem
|
2007-06-22 20:28:42 +00:00
|
|
|
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0);
|
|
|
|
|
2007-06-21 18:24:05 +00:00
|
|
|
void init();
|
|
|
|
|
2005-12-29 21:55:22 +00:00
|
|
|
class Private;
|
2007-05-21 14:28:03 +00:00
|
|
|
Private* const d;
|
2005-12-29 21:55:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // Plasma namespace
|
|
|
|
|
2007-07-06 22:20:57 +00:00
|
|
|
/**
|
|
|
|
* Register an applet when it is contained in a loadable module
|
|
|
|
*/
|
2007-05-24 20:01:12 +00:00
|
|
|
#define K_EXPORT_PLASMA_APPLET(libname, classname) \
|
|
|
|
K_EXPORT_COMPONENT_FACTORY( \
|
|
|
|
plasma_applet_##libname, \
|
|
|
|
KGenericFactory<classname>("plasma_applet_" #libname))
|
|
|
|
|
2005-12-29 21:55:22 +00:00
|
|
|
#endif // multiple inclusion guard
|
2007-05-24 20:01:12 +00:00
|
|
|
|