/* kopeteawaydialog.h - Kopete Away Dialog Copyright (c) 2002 by Hendrik vom Lehn <hvl@linux-4-ever.de> Copyright (c) 2003 by Martijn Klingens <klingens@kde.org> Kopete (c) 2002-2003 by the Kopete developers <kopete-devel@kde.org> ************************************************************************* * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Lesser General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * ************************************************************************* */ #ifndef KOPETEAWAYDIALOG_H #define KOPETEAWAYDIALOG_H #include <kdialogbase.h> #include "kopete_export.h" namespace Kopete { class Away; } class KopeteAwayDialogPrivate; /** * KopeteAwayDialog is a base class used for implementing * Away Message selection dialogs in Kopete. It presents * the user with a list of pre-written away messages and * a line edit for them to type a "single shot" away message, * one that is not saved and will be lost the next time * they restart the application. * * Individual protocols should subclass this class for protocol * specific Away Message choosers (in the case that the user * wants to set only one protocol away). There are methods for * getting the message that the user selected, as well as a * virtual method that should be implemented that is called * when the user selects "OK", and should be used to do * protocol specific actions needed to set the user as * "Away" (or whatever the protocol calls it). * * @author Hendrik vom Lehn <hvl@linux-4-ever.de> * @author Christopher TenHarmsel <tenharmsel@users.sourceforge.net> */ class KOPETE_EXPORT KopeteAwayDialog : public KDialogBase { TQ_OBJECT public: /** * Constructor for the Away Dialog * @param parent The object that owns this * @param name Name for this object */ KopeteAwayDialog( TQWidget *parent = 0, const char *name = 0 ); /** * Destructor */ virtual ~KopeteAwayDialog(); protected: /** * Do not delete this, this instance will * deleted when the application closes */ Kopete::Away *awayInstance; /** * \brief Gets the last selected away message * @return An away message */ TQString getSelectedAwayMessage(); /** * \brief Sets the user away * * This method is called when the user clicks * OK in the GUI, signalling that they wish * to set the away message that they have chosen. * Please reimplement this method to do protocol * specific things, and use getSelectedAwayMessage() * to get the text of the message that the user * selected. * * @param awayType This is the away type specified * if show was called with a parameter. If show() was called * instead, this parameter will be the empty string. You * will need to compare it to an enum that you declare * in your subclass. */ virtual void setAway( int awayType ) = 0; /** * \brief Called when "Cancel" is clicked * * This method is called when the user clicks * Cancel in the GUI, signalling that they * canceled their request to mark themselves as * away. If your implementation finds this * information useful, implement this method * to handle this info. By default it does nothing * * @param awayType This is the away type specified * if show was called with a parameter, if show() was called * instead, this parameter will be the empty string. */ virtual void cancelAway( int awayType ); public slots: /** * \brief Shows the dialog */ virtual void show(); /** * \brief Shows the dialog * * Shows the away dialog, but maintains a "state" * so you can specify if you're setting away, * do not disturb, gone, etc for protocols that * support this like ICQ and MSN. * * This string does not have any special internal * meaning, but rather will get passed to setAway() * when it is called so that you can decide what * kind of "away" you really want to do. * * @param awayType The type of "away" you want to set. */ void show( int awayType ); protected slots: /** * This slot is called when the user click on "OK" * it will call setAway(), which is pure virtual and * should be implemented for specific needs */ virtual void slotOk(); /** * This slot is called when the user clicks on * "Cancel". It calls cancelAway(), which is * pure virtual and should be implemented to * fit your specific needs if the user selects * "Cancel". This method will close the * dialog, but if you require any specific actions * please implement them in cancelAway(). */ virtual void slotCancel(); private slots: /** * \brief An entry was selected from the combo box */ void slotComboBoxSelection( int index ); private: /** * Initializes the GUI elements every time the * dialog is show. Basically used for remembering * the singleshot message that the user may have * typed in. */ void init(); /** * The last user-entered away text * or the title of the last selected * saved away message, whichever was * last chosen */ TQString mLastUserAwayMessage; /** * The last message that the user typed in the * line edit */ TQString mLastUserTypedMessage; /** * This is used to store the type of away that we're * going to go. */ int mExtendedAwayType; KopeteAwayDialogPrivate *d; }; #endif