You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
559 lines
17 KiB
559 lines
17 KiB
/*
|
|
kopetecontact.h - Kopete Contact
|
|
|
|
Copyright (c) 2002-2004 by Duncan Mac-Vicar Prett <duncan@kde.org>
|
|
Copyright (c) 2002-2003 by Martijn Klingens <klingens@kde.org>
|
|
Copyright (c) 2002-2004 by Olivier Goffart <ogoffart @ tiscalinet.be>
|
|
|
|
Kopete (c) 2002-2004 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 __KOPETECONTACT_H__
|
|
#define __KOPETECONTACT_H__
|
|
|
|
#include <tqobject.h>
|
|
#include <kurl.h>
|
|
#include <kdemacros.h>
|
|
#include "kopeteglobal.h"
|
|
|
|
#include "kopete_export.h"
|
|
|
|
class TQImage;
|
|
class KPopupMenu;
|
|
class KAction;
|
|
|
|
namespace Kopete
|
|
{
|
|
|
|
class Group;
|
|
class MetaContact;
|
|
class ChatSession;
|
|
class OnlineStatus;
|
|
class Plugin;
|
|
class Protocol;
|
|
class Account;
|
|
typedef TQPtrList<Group> GroupList;
|
|
|
|
/**
|
|
* @author Duncan Mac-Vicar P. <duncan@kde.org>
|
|
* @author Martijn Klingens <klingens@kde.org>
|
|
* @author Olivier Goffart <ogoffart@ tiscalinet.be>
|
|
*
|
|
* This class abstracts a generic contact
|
|
* Use it for inserting contacts in the contact list for example.
|
|
*/
|
|
class KOPETE_EXPORT Contact : public TQObject
|
|
{
|
|
Q_OBJECT
|
|
|
|
|
|
Q_ENUMS( CanCreateFlags )
|
|
TQ_PROPERTY( TQString formattedName READ formattedName )
|
|
TQ_PROPERTY( TQString formattedIdleTime READ formattedIdleTime )
|
|
TQ_PROPERTY( bool isOnline READ isOnline )
|
|
TQ_PROPERTY( bool fileCapable READ isFileCapable WRITE setFileCapable )
|
|
TQ_PROPERTY( bool canAcceptFiles READ canAcceptFiles )
|
|
//TQ_PROPERTY( bool isReachable READ isReachable )
|
|
TQ_PROPERTY( TQString contactId READ contactId )
|
|
TQ_PROPERTY( TQString icon READ icon WRITE setIcon )
|
|
TQ_PROPERTY( TQString toolTip READ toolTip )
|
|
TQ_PROPERTY( TQString nickName READ nickName WRITE setNickName )
|
|
//TQ_PROPERTY( unsigned long idleTime READ idleTime WRITE setIdleTime )
|
|
|
|
public:
|
|
/**
|
|
* \brief Create new contact.
|
|
*
|
|
* <b>The parent MetaContact must not be NULL</b>
|
|
*
|
|
* \note id is required to be unique per protocol and per account.
|
|
* Across those boundaries ids may occur multiple times.
|
|
* The id is solely for comparing items safely (using pointers is
|
|
* more crash-prone). DO NOT assume anything regarding the id's
|
|
* value! Even if it may look like an ICQ UIN or an MSN passport,
|
|
* this is undefined and may change at any time!
|
|
*
|
|
* @param account is the parent account. this constructor automatically register the contact to the account
|
|
* @param id is the Contact's unique Id (mostly the user's login)
|
|
* @param parent is the parent @ref MetaContact this Contact is part of
|
|
* @param icon is an optional icon
|
|
*/
|
|
Contact( Account *account, const TQString &id, MetaContact *parent,
|
|
const TQString &icon = TQString() );
|
|
|
|
~Contact();
|
|
|
|
/**
|
|
* \brief Get the metacontact for this contact
|
|
* @return The MetaContact object for this contact
|
|
*/
|
|
MetaContact *metaContact() const;
|
|
|
|
|
|
/**
|
|
* \brief Get the unique id that identifies a contact.
|
|
*
|
|
* \note Id is required to be unique per protocol and per account.
|
|
* Across those boundaries ids may occur multiple times.
|
|
* The id is solely for comparing items safely (using pointers is
|
|
* more crash-prone). DO NOT assume anything regarding the id's
|
|
* value! Even if it may look like an ICQ UIN or an MSN passport,
|
|
* this is undefined and may change at any time!
|
|
*
|
|
* @return The unique id of the contact
|
|
*/
|
|
TQString contactId() const;
|
|
|
|
/**
|
|
* \brief Get the protocol that the contact belongs to.
|
|
*
|
|
* simply return account()->protocol()
|
|
*
|
|
* @return the contact's protocol
|
|
*/
|
|
Protocol* protocol() const;
|
|
|
|
/**
|
|
* \brief Get the account that this contact belongs to
|
|
*
|
|
* @return the Account object for this contact
|
|
*/
|
|
Account* account() const;
|
|
|
|
/**
|
|
* \brief Move this contact to a new MetaContact.
|
|
* This basically reparents the contact and updates the internal
|
|
* data structures.
|
|
* If the old contact is going to be empty, a question may ask to the user if it wants to delete the old contact.
|
|
*
|
|
* @param m The new MetaContact to move this contact to
|
|
*/
|
|
void setMetaContact(MetaContact *m);
|
|
|
|
|
|
/**
|
|
* @brief Get whether this contact is online.
|
|
* @return @c true if the contact is online, @c false otherwise.
|
|
*/
|
|
bool isOnline() const;
|
|
|
|
/**
|
|
* \brief Get whether this contact can receive messages
|
|
*
|
|
* Used in determining if the contact is able to
|
|
* receive messages. This function must be defined by child classes
|
|
*
|
|
* @return true if the contact can be reached
|
|
* @return false if the contact can not be reached
|
|
*/
|
|
// FIXME: After KDE 3.2 we should split this into a public, NON-virtual
|
|
// isReachable() accessor that checks for account->isConnected()
|
|
// and then calls a new virtual method that does the
|
|
// protocol-specific work, like 'doIsUnreachable' or so - Martijn
|
|
//
|
|
//FIXME: Can this be made const please? - JK
|
|
virtual bool isReachable();
|
|
|
|
/**
|
|
* @brief Serialize the contact for storage in the contact list.
|
|
*
|
|
* The provided serializedData contain the contact id in the field
|
|
* "contactId". If you don't like this, or don't want to
|
|
* store these fields at all,
|
|
* you are free to remove them from the list.
|
|
*
|
|
* Most plugins don't need more than these fields, so they only need
|
|
* to set the address book fields themselves. If you have nothing to
|
|
* save at all you can clear the TQMap, an empty map is treated as
|
|
* 'nothing to save'.
|
|
*
|
|
* The provided addressBookFields TQMap contains the index field as
|
|
* marked with @ref Plugin::addAddressBookField() with the
|
|
* contact id as value. If no index field is available the TQMap is
|
|
* simply passed as an empty map.
|
|
*
|
|
* @sa Protocol::deserializeContact
|
|
*/
|
|
virtual void serialize( TQMap<TQString, TQString> &serializedData, TQMap<TQString, TQString> &addressBookData );
|
|
|
|
/**
|
|
* @brief Serialize the contacts persistent properties for storage in the contact list.
|
|
*
|
|
* Does the same as @ref serialize() does but for KopeteContactProperties
|
|
* set in this contact with their persistency flag turned on.
|
|
* In contrary to @ref serialize() this does not need to be reimplemented.
|
|
*
|
|
*/
|
|
void serializeProperties(TQMap<TQString, TQString> &serializedData);
|
|
|
|
/**
|
|
* @brief Deserialize the contacts persistent properties
|
|
*/
|
|
void deserializeProperties(TQMap<TQString, TQString> &serializedData);
|
|
|
|
/**
|
|
* @brief Get the online status of the contact
|
|
* @return the online status of the contact
|
|
*/
|
|
OnlineStatus onlineStatus() const;
|
|
|
|
/**
|
|
* \brief Set the contact's online status
|
|
*/
|
|
void setOnlineStatus(const OnlineStatus &status);
|
|
|
|
/**
|
|
* \brief Get the set of custom menu items for this contact
|
|
*
|
|
* Returns a set of custom menu items for the context menu
|
|
* which is displayed in showContextMenu (private). Protocols
|
|
* should use this to add protocol-specific actions to the
|
|
* popup menu. Kopete take care of the deletion of the action collection.
|
|
* Actions should have the collection as parent.
|
|
*
|
|
* @return Collection of menu items to be show on the context menu
|
|
* @todo if possible, try to use KXMLGUI
|
|
*/
|
|
virtual TQPtrList<KAction> *customContextMenuActions();
|
|
|
|
/**
|
|
* @todo What is this function for ?
|
|
*/
|
|
virtual TQPtrList<KAction> *customContextMenuActions( ChatSession *manager );
|
|
|
|
/**
|
|
* @brief Get the Context Menu for this contact
|
|
*
|
|
* This menu includes generic actions common to each protocol, and action defined in
|
|
* @ref customContextMenuActions()
|
|
*/
|
|
KPopupMenu *popupMenu( ChatSession *manager = 0L );
|
|
|
|
/**
|
|
* \brief Get whether or not this contact is capable of file transfers
|
|
*
|
|
*
|
|
* \see setFileCapable()
|
|
* \return true if the protocol for this contact is capable of file transfers
|
|
* \return false if the protocol for this contact is not capable of file transfers
|
|
*
|
|
* @todo have a capabilioties. or move to protocol capabilities
|
|
*/
|
|
bool isFileCapable() const;
|
|
|
|
/**
|
|
* \brief Set the file transfer capability of this contact
|
|
*
|
|
* \param filecap The new file transfer capability setting
|
|
* @todo have a capabilioties. or move to protocol capabilities
|
|
*/
|
|
void setFileCapable( bool filecap );
|
|
|
|
/**
|
|
* \brief Get whether or not this contact can accept file transfers
|
|
*
|
|
* This function checks to make sure that the contact is online as well as
|
|
* capable of sending files.
|
|
* \see isReachable()
|
|
* @return true if this contact is online and is capable of receiving files
|
|
* @todo have a capabilioties. or move to protocol capabilities
|
|
*/
|
|
bool canAcceptFiles() const;
|
|
|
|
enum CanCreateFlags { CannotCreate=false , CanCreate=true };
|
|
|
|
/**
|
|
* Returns the primary message manager affiliated with this contact
|
|
* Although a contact can have more than one active message manager
|
|
* (as is the case with MSN at least), only one message manager will
|
|
* ever be the contacts "primary" message manager.. aka the 1 on 1 chat.
|
|
* This function should always return that instance.
|
|
*
|
|
* @param canCreate If a new message manager can be created in addition
|
|
* to any existing managers. Currently, this is only set to true when
|
|
* a chat is initiated by the user by clicking the contact list.
|
|
*/
|
|
virtual ChatSession * manager( CanCreateFlags canCreate = CannotCreate ) =0;
|
|
|
|
/**
|
|
* Returns the name of the icon to use for this contact
|
|
* If null, the protocol icon need to be used.
|
|
* The icon is not colored, nor has the status icon overloaded
|
|
*/
|
|
TQString& icon() const;
|
|
|
|
/**
|
|
* @brief Change the icon to use for this contact
|
|
* If you don't want to have the protocol icon as icon for this contact, you may set
|
|
* another icon. The icon doesn't need to be colored with the account icon as this operation
|
|
* will be performed later.
|
|
*
|
|
* if you want to go back to the protocol icon, set a null string.
|
|
*/
|
|
void setIcon( const TQString& icon );
|
|
|
|
/**
|
|
* \brief Get the time (in seconds) this contact has been idle
|
|
* It will return the time set in @ref setIdleTime() with an addition of the time
|
|
* since you set this last time
|
|
* @return time this contact has been idle for, in seconds
|
|
//
|
|
// FIXME: Can we make this just 'unsigned long' ? QT Properties can't handle
|
|
// 'unsigned long int'
|
|
*/
|
|
virtual unsigned long int idleTime() const;
|
|
|
|
/**
|
|
* \brief Set the current idle time in seconds.
|
|
* Kopete will automatically calculate the time in @ref idleTime
|
|
* except if you set 0.
|
|
//
|
|
// FIXME: Can we make this just 'unsigned long' ? QT Properties can't handle
|
|
// 'unsigned long int'
|
|
*/
|
|
void setIdleTime(unsigned long int);
|
|
|
|
/**
|
|
* @return A TQStringList containing all property keys
|
|
**/
|
|
TQStringList properties() const;
|
|
|
|
/**
|
|
* Check for existance of a certain property stored
|
|
* using "key".
|
|
* \param key the property to check for
|
|
**/
|
|
bool hasProperty(const TQString &key) const;
|
|
|
|
/**
|
|
* \brief Get the value of a property with key "key".
|
|
*
|
|
* If you don't know the type of the returned TQVariant, you will need
|
|
* to check for it.
|
|
* \return the value of the property
|
|
**/
|
|
const Kopete::ContactProperty &property(const TQString &key) const;
|
|
const Kopete::ContactProperty &property(const Kopete::ContactPropertyTmpl &tmpl) const;
|
|
|
|
/**
|
|
* \brief Add or Set a property for this contact.
|
|
*
|
|
* @param tmpl The template this property is based on, key, label etc. are
|
|
* taken from this one
|
|
* @param value The value to store
|
|
*
|
|
* \note Setting a NULL value or an empty TQString castable value
|
|
* removes the property if it already existed.
|
|
* <b>Don't</b> abuse this for property-removal, instead use
|
|
* @ref removeProperty() if you want to remove on purpose.
|
|
* The Removal is done to clean up the list of properties and to purge them
|
|
* from UI.
|
|
**/
|
|
void setProperty(const Kopete::ContactPropertyTmpl &tmpl, const TQVariant &value);
|
|
|
|
/**
|
|
* \brief Convenience method to set the nickName property to the specified value
|
|
* @param name The nickname to set
|
|
*/
|
|
void setNickName( const TQString &name );
|
|
|
|
/**
|
|
* \brief Convenience method to retrieve the nickName property.
|
|
*
|
|
* This method will return the contactId if there has been no nickName property set
|
|
*/
|
|
TQString nickName() const;
|
|
|
|
/**
|
|
* \brief Remove a property if it exists
|
|
*
|
|
* @param tmpl the template this property is based on
|
|
**/
|
|
void removeProperty(const Kopete::ContactPropertyTmpl &tmpl);
|
|
|
|
/**
|
|
* \brief Get the tooltip for this contact
|
|
* Makes use of formattedName() and formattedIdleTime().
|
|
* \return an RTF tooltip depending on KopetePrefs settings
|
|
**/
|
|
TQString toolTip() const;
|
|
|
|
/**
|
|
* Returns a formatted string of "firstName" and/or "lastName" properties
|
|
* if present.
|
|
* Suitable for GUI display
|
|
**/
|
|
TQString formattedName() const;
|
|
|
|
/**
|
|
* Returns a formatted string of idleTime().
|
|
* Suitable for GUI display
|
|
**/
|
|
TQString formattedIdleTime() const;
|
|
|
|
/**
|
|
* used in @ref sync()
|
|
*/
|
|
enum Changed{ MovedBetweenGroup = 0x01, ///< the contact has been moved between groups
|
|
DisplayNameChanged = 0x02 ///< the displayname of the contact changed
|
|
};
|
|
|
|
|
|
public slots:
|
|
/**
|
|
* This should typically pop up a KopeteChatWindow
|
|
*/
|
|
void startChat();
|
|
|
|
/**
|
|
* Pops up an email type window
|
|
*/
|
|
void sendMessage();
|
|
|
|
/**
|
|
* The user clicked on the contact, do the default action
|
|
*/
|
|
void execute();
|
|
|
|
/**
|
|
* Changes the MetaContact that this contact is a part of. This function
|
|
* is called by the KAction changeMetaContact that is part of the context
|
|
* menu.
|
|
*/
|
|
void changeMetaContact();
|
|
|
|
/**
|
|
* Method to retrieve user information. Should be implemented by
|
|
* the protocols, and popup some sort of dialog box
|
|
*
|
|
* reimplement it to show the informlation
|
|
* @todo rename and make it pure virtual
|
|
*/
|
|
virtual void slotUserInfo() {};
|
|
|
|
/**
|
|
* @brief Syncronise the server and the metacontact.
|
|
* Protocols with server-side contact lists can implement this to
|
|
* sync the server groups with the metaContact groups. Or the server alias if any.
|
|
*
|
|
* This method is called every time the metacontact has been moved or renamed.
|
|
*
|
|
* default implementation does nothing
|
|
*
|
|
* @param changed is a bitmask of the @ref Changed enum which say why the call to this funtion is done.
|
|
*/
|
|
virtual void sync(unsigned int changed = 0xFF);
|
|
|
|
/**
|
|
* Method to delete a contact from the contact list,
|
|
* should be implemented by protocol plugin to handle
|
|
* protocol-specific actions required to delete a contact
|
|
* (ie. messages to the server, etc)
|
|
* the default implementation simply call deleteLater()
|
|
*/
|
|
virtual void deleteContact();
|
|
|
|
/**
|
|
* This is the Contact level slot for sending files. It should be
|
|
* implemented by all contacts which have the setFileCapable() flag set to
|
|
* true. If the function is called through the GUI, no parameters are sent
|
|
* and they take on default values (the file is chosen with a file open dialog)
|
|
*
|
|
* @param sourceURL The actual KURL of the file you are sending
|
|
* @param fileName (Optional) An alternate name for the file - what the
|
|
* receiver will see
|
|
* @param fileSize (Optional) Size of the file being sent. Used when sending
|
|
* a nondeterminate
|
|
* file size (such as over asocket
|
|
*/
|
|
virtual void sendFile( const KURL &sourceURL = KURL(),
|
|
const TQString &fileName = TQString(), uint fileSize = 0L );
|
|
|
|
private slots:
|
|
|
|
/**
|
|
* This add the contact totally in the list if it was a temporary contact
|
|
*/
|
|
void slotAddContact();
|
|
|
|
/**
|
|
* slot called when the action "delete" is called.
|
|
*/
|
|
void slotDelete();
|
|
|
|
/**
|
|
* slot called when the action "block" is called.
|
|
*/
|
|
void slotBlock();
|
|
|
|
/**
|
|
* slot called when the action "unblock" is called.
|
|
*/
|
|
void slotUnblock();
|
|
|
|
/**
|
|
* The account's isConnected has changed.
|
|
*/
|
|
void slotAccountIsConnectedChanged();
|
|
|
|
signals:
|
|
/**
|
|
* The contact's online status changed
|
|
*/
|
|
void onlineStatusChanged( Kopete::Contact *contact,
|
|
const Kopete::OnlineStatus &status, const Kopete::OnlineStatus &oldStatus );
|
|
|
|
/**
|
|
* The contact is about to be destroyed.
|
|
* Called when entering the destructor. Useful for cleanup, since
|
|
* metaContact() is still accessible at this point.
|
|
*
|
|
* @warning this signal is emit in the Contact destructor, so all
|
|
* virtual method are not available
|
|
*/
|
|
void contactDestroyed( Kopete::Contact *contact );
|
|
|
|
/**
|
|
* The contact's idle state changed.
|
|
* You need to emit this signal to update the view.
|
|
* That mean when activity has been noticed
|
|
*/
|
|
void idleStateChanged( Kopete::Contact *contact );
|
|
|
|
/**
|
|
* One of the contact's properties has changed.
|
|
* @param contact this contact, useful for listening to signals from more than one contact
|
|
* @param key the key whose value has changed
|
|
* @param oldValue the value before the change, or an invalid TQVariant if the property is new
|
|
* @param newValue the value after the change, or an invalid TQVariant if the property was removed
|
|
*/
|
|
void propertyChanged( Kopete::Contact *contact, const TQString &key,
|
|
const TQVariant &oldValue, const TQVariant &newValue );
|
|
|
|
protected:
|
|
virtual void virtual_hook(uint id, void *data);
|
|
|
|
private:
|
|
class Private;
|
|
Private *d;
|
|
|
|
|
|
};
|
|
|
|
|
|
} //END namespace Kopete
|
|
|
|
#endif
|
|
|
|
// vim: set noet ts=4 sts=4 sw=4:
|
|
|