Summary: | Notification if someone reads your away message | ||
---|---|---|---|
Product: | [Unmaintained] kopete | Reporter: | Mathias Soeken <soeken> |
Component: | ICQ and AIM Plugins | Assignee: | Roman Jarosz <kedgedev> |
Status: | RESOLVED FIXED | ||
Severity: | wishlist | ||
Priority: | NOR | ||
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | Ubuntu | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Mathias Soeken
2006-02-22 09:52:42 UTC
This would really be a nice feature in Kopete. :) Licq does the notification by showing a blinking frame around the contact who read my away message. I had a (very short) glimpse at the licq source code, and it's probably hidden somewhere in its monstrous CICQDaemon::ProcessTcpPacket method in icqd-tcp.cpp. Search for "ICQ_CMDxTCP_READxAWAYxMSG". HTH :) ICQ team, can it be done? Possible, sure. Whether or not it'll actually be done is another story Perhaps the question is, how difficult the task is? Are there already events that notifies if somebody reads your away message or is the away message sent to a server after setting it? it has nothing to do with how difficult it is (since it's not really all that difficult) but whether or not somebody actually does it SVN commit 604788 by rjarosz: Add ICQ feature 122468: Notification if someone reads your away message FEATURE: 122468 M +5 -0 kopete/kopete.notifyrc M +19 -0 protocols/oscar/icq/icqaccount.cpp M +2 -0 protocols/oscar/icq/icqaccount.h M +1 -0 protocols/oscar/liboscar/client.cpp M +1 -0 protocols/oscar/liboscar/client.h --- trunk/KDE/kdenetwork/kopete/kopete/kopete.notifyrc #604787:604788 @@ -126,3 +126,8 @@ Name=Message dropped Comment=A message was filtered by the Privacy Plugin Action=PassivePopup + +[Event/icq_user_reads_status_message] +Name=ICQ Reading status +Comment=An ICQ user is reading your status message +Action=PassivePopup --- trunk/KDE/kdenetwork/kopete/protocols/oscar/icq/icqaccount.cpp #604787:604788 @@ -21,6 +21,7 @@ #include <kmenu.h> #include <kmessagebox.h> #include <kicon.h> +#include <knotification.h> #include "kopeteawayaction.h" #include "kopetemessage.h" @@ -99,6 +100,9 @@ mInfoWidget = 0L; mInitialStatusMessage.clear(); + QObject::connect( engine(), SIGNAL(userReadsStatusMessage(const QString&)), + this, SLOT(userReadsStatusMessage(const QString&)) ); + //setIgnoreUnknownContacts(pluginData(protocol(), "IgnoreUnknownContacts").toUInt() == 1); /* FIXME: need to do this when web aware or hide ip change @@ -269,6 +273,21 @@ mInfoWidget = 0L; } +void ICQAccount::userReadsStatusMessage( const QString& contact ) +{ + QString name; + + Kopete::Contact * ct = contacts()[ Oscar::normalize( contact ) ]; + if ( ct ) + name = ct->nickName(); + else + name = contact; + + KNotification* notification = new KNotification( "icq_user_reads_status_message" ); + notification->setText( i18n( "User %1 is reading your status message", name ) ); + notification->sendEvent(); +} + void ICQAccount::setAway( bool away, const QString &awayReason ) { kDebug(14153) << k_funcinfo << "account='" << accountId() << "'" << endl; --- trunk/KDE/kdenetwork/kopete/protocols/oscar/icq/icqaccount.h #604787:604788 @@ -93,6 +93,8 @@ void storeUserInfoDialog(); void closeUserInfoDialog(); + void userReadsStatusMessage( const QString& contact ); + private: bool mWebAware; bool mHideIP; --- trunk/KDE/kdenetwork/kopete/protocols/oscar/liboscar/client.cpp #604787:604788 @@ -543,6 +543,7 @@ { QTextCodec* codec = d->codecProvider->codecForContact( msg.sender() ); response.setText( Oscar::Message::UserDefined, statusMessage(), codec ); + emit userReadsStatusMessage( msg.sender() ); } else { --- trunk/KDE/kdenetwork/kopete/protocols/oscar/liboscar/client.h #604787:604788 @@ -444,6 +444,7 @@ void receivedAwayMessage( const QString& contact, const QString& message ); void receivedAwayMessage( const Oscar::Message& message ); void receivedUserInfo( const QString& contact, const UserDetails& details ); + void userReadsStatusMessage( const QString& contact ); /** We warned a user */ void userWarned( const QString& contact, quint16 increase, quint16 newLevel ); |