From bcb704366cb5e333a626c18c308c7e0448a8e69f Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kpf/src/AppletItem.h | 167 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 167 insertions(+) create mode 100644 kpf/src/AppletItem.h (limited to 'kpf/src/AppletItem.h') diff --git a/kpf/src/AppletItem.h b/kpf/src/AppletItem.h new file mode 100644 index 00000000..013a6b0a --- /dev/null +++ b/kpf/src/AppletItem.h @@ -0,0 +1,167 @@ +/* + KPF - Public fileserver for KDE + + Copyright 2001 Rik Hemsley (rikkus) + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to + deal in the Software without restriction, including without limitation the + rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +*/ + +#ifndef KPF_APPLET_ITEM_H +#define KPF_APPLET_ITEM_H + +#include +#include + +class KPopupMenu; + +namespace KPF +{ + class ConfigDialog; + class BandwidthGraph; + class ActiveMonitorWindow; + class SingleServerConfigDialog; + class WebServer; + + /** + * Provides control of, and coarse-grained activity display for, a WebServer + * object. Contains a BandwidthGraph widget and provides a context menu + * which allows WebServer object control, plus creation of a new WebServer, + * for user convenience. + */ + class AppletItem : public QWidget + { + Q_OBJECT + + public: + + /** + * @param server The WebServer object which will be monitored and + * controlled by this object. + */ + AppletItem(WebServer * server, QWidget * parent); + + ~AppletItem(); + + /** + * @return the WebServer object given on construction. + */ + WebServer * server(); + + void setBackground(); + + protected slots: + + /** + * Called when an ActiveMonitorWindow (created by this object) is + * about to close. + */ + void slotActiveMonitorWindowDying(ActiveMonitorWindow *); + + /** + * Called when a SingleServerConfigDialog (created by this object) is + * about to close. + */ + void slotConfigDialogDying(SingleServerConfigDialog *); + + /** + * Called when the user requests a new WebServer via the context menu. + */ + void slotNewServer(); + + /** + * Called by a timer after removeServer has been called and the event + * loop has been processed once. + */ + void slotSuicide(); + + signals: + + /** + * Emitted when a new WebServer is requested from the context menu. + */ + void newServer(); + + /** + * Emitted when an URL pointing to a local directory has been dropped. + */ + void newServerAtLocation(const QString &); + + protected: + + /** + * Overridden to provide a context menu plus DnD capabilities. + */ + bool eventFilter(QObject *, QEvent *); + + /** + * Called when the appropriate item is selected from the context menu. + * Creates an ActiveMonitorWindow. + */ + void monitorServer (); + + /** + * Called when the appropriate item is selected from the context menu. + * Asks the WebServerManager instance to remove the associated + * WebServer. + */ + void removeServer (); + + /** + * Called when the appropriate item is selected from the context menu. + * Creates a configuration dialog for the associated WebServer. + */ + void configureServer (); + + /** + * Called when the appropriate item is selected from the context menu. + * Restarts the associated WebServer. + */ + void restartServer (); + + /** + * Called when the appropriate item is selected from the context menu. + * Pauses the associated WebServer. + */ + void pauseServer (); + + private: + + enum + { + Title, + NewServer, + Separator, + Monitor, + Configure, + Remove, + Restart, + Pause + }; + + + WebServer * server_; + SingleServerConfigDialog * configDialog_; + ActiveMonitorWindow * monitorWindow_; + BandwidthGraph * graph_; + KPopupMenu * popup_; + }; +} + +#endif // KPF_APPLET_H + +// vim:ts=2:sw=2:tw=78:et -- cgit v1.2.1