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 --- kopete/protocols/oscar/icq/ui/Makefile.am | 17 + kopete/protocols/oscar/icq/ui/icqadd.ui | 122 ++++ .../protocols/oscar/icq/ui/icqaddcontactpage.cpp | 126 +++++ kopete/protocols/oscar/icq/ui/icqaddcontactpage.h | 60 ++ .../protocols/oscar/icq/ui/icqauthreplydialog.cpp | 73 +++ kopete/protocols/oscar/icq/ui/icqauthreplydialog.h | 45 ++ kopete/protocols/oscar/icq/ui/icqauthreplyui.ui | 196 +++++++ kopete/protocols/oscar/icq/ui/icqeditaccountui.ui | 486 ++++++++++++++++ .../oscar/icq/ui/icqeditaccountwidget.cpp | 190 +++++++ .../protocols/oscar/icq/ui/icqeditaccountwidget.h | 52 ++ kopete/protocols/oscar/icq/ui/icqgeneralinfo.ui | 611 +++++++++++++++++++++ .../oscar/icq/ui/icqinterestinfowidget.ui | 116 ++++ .../protocols/oscar/icq/ui/icqotherinfowidget.ui | 68 +++ kopete/protocols/oscar/icq/ui/icqsearchbase.ui | 493 +++++++++++++++++ kopete/protocols/oscar/icq/ui/icqsearchdialog.cpp | 320 +++++++++++ kopete/protocols/oscar/icq/ui/icqsearchdialog.h | 69 +++ .../protocols/oscar/icq/ui/icquserinfowidget.cpp | 190 +++++++ kopete/protocols/oscar/icq/ui/icquserinfowidget.h | 58 ++ kopete/protocols/oscar/icq/ui/icqworkinfowidget.ui | 249 +++++++++ 19 files changed, 3541 insertions(+) create mode 100644 kopete/protocols/oscar/icq/ui/Makefile.am create mode 100644 kopete/protocols/oscar/icq/ui/icqadd.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqaddcontactpage.cpp create mode 100644 kopete/protocols/oscar/icq/ui/icqaddcontactpage.h create mode 100644 kopete/protocols/oscar/icq/ui/icqauthreplydialog.cpp create mode 100644 kopete/protocols/oscar/icq/ui/icqauthreplydialog.h create mode 100644 kopete/protocols/oscar/icq/ui/icqauthreplyui.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqeditaccountui.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqeditaccountwidget.cpp create mode 100644 kopete/protocols/oscar/icq/ui/icqeditaccountwidget.h create mode 100644 kopete/protocols/oscar/icq/ui/icqgeneralinfo.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqinterestinfowidget.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqotherinfowidget.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqsearchbase.ui create mode 100644 kopete/protocols/oscar/icq/ui/icqsearchdialog.cpp create mode 100644 kopete/protocols/oscar/icq/ui/icqsearchdialog.h create mode 100644 kopete/protocols/oscar/icq/ui/icquserinfowidget.cpp create mode 100644 kopete/protocols/oscar/icq/ui/icquserinfowidget.h create mode 100644 kopete/protocols/oscar/icq/ui/icqworkinfowidget.ui (limited to 'kopete/protocols/oscar/icq/ui') diff --git a/kopete/protocols/oscar/icq/ui/Makefile.am b/kopete/protocols/oscar/icq/ui/Makefile.am new file mode 100644 index 00000000..24a726f2 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/Makefile.am @@ -0,0 +1,17 @@ +METASOURCES = AUTO +AM_CPPFLAGS = -I$(srcdir)/../ \ + -I$(srcdir)/../../ \ + -I$(srcdir)/ui/ \ + -I$(srcdir)/../../liboscar \ + -I$(srcdir)/../../../../ \ + $(KOPETE_INCLUDES) $(all_includes) + +noinst_LTLIBRARIES = libkopeteicqui.la + +libkopeteicqui_la_SOURCES = icqadd.ui icqeditaccountui.ui \ + icqeditaccountwidget.cpp icqgeneralinfo.ui icqotherinfowidget.ui icqworkinfowidget.ui icqinterestinfowidget.ui\ + icquserinfowidget.cpp icqauthreplyui.ui icqauthreplydialog.cpp icqaddcontactpage.cpp \ + icqsearchbase.ui icqsearchdialog.cpp icqsearchdialog.h + +libkopeteicqui_la_LIBADD = $(top_builddir)/kopete/libkopete/libkopete.la + diff --git a/kopete/protocols/oscar/icq/ui/icqadd.ui b/kopete/protocols/oscar/icq/ui/icqadd.ui new file mode 100644 index 00000000..ef793fbb --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqadd.ui @@ -0,0 +1,122 @@ + +icqAddUI + + + icqAddUI + + + + 0 + 0 + 452 + 88 + + + + + unnamed + + + 0 + + + 6 + + + + layout3 + + + + unnamed + + + + textLabel1 + + + UIN #: + + + + + uinEdit + + + + + + + layout4 + + + + unnamed + + + + textLabel1_2 + + + Alternatively, you can search the ICQ Whitepages : + + + + + spacer8 + + + Horizontal + + + Expanding + + + + 47 + 26 + + + + + + searchButton + + + &Search + + + image0 + + + + + + + spacer4 + + + Vertical + + + Expanding + + + + 20 + 20 + + + + + + + + 89504e470d0a1a0a0000000d49484452000000100000001008060000001ff3ff61000002a749444154388d7d91cd4b945114c69f73ef3b33ea7ca838a6a32681501194d2975050b4c82f92dc042e5a550b5bf60744bb16b58a8268218144d026da64da228a0a2b52d1c8c8c48f2c54669c19df79df793fefbd2d662469860e1cb870cef3e339cf2500989b5b88e56cb78b0857f2b6d3e67b0e0b0503baf4e57bdbb21eb8b6fadedf7fda4599a2e999f9bdb66b5fb75db79b3164b8c6b3504af8426852885adff3272dc31cb14c313e38d827fe0568593d77225811b8d8d810475555a89e88e0791e0c330f2515cc7c9e6ccb822f8d6f00964a009e6b5f8ed554211a0d235c5501ce1874c30411414a89582cdc0625c3e964e64c3900b35de768301000e70c1ae7608c81738e80a6a1b2b202b16814cd4d8946ced550b90c98e33a158c113ccf47ceccc3cc5b080534282591d94c637d6d1d5bd92c2ccb3af2f0d1e8bd92135cd7370184018088c0350ec639a291086291083ccf432e6740d3822c994cc54a1c5886f5d1755d48a920a584520a4a291000251508844c3a83baf82e1051e90996e5dc5959fe0d21fd4270424208015184e9ba8e0f139350d050460fd6de7ec80e5786313b3307c33021a484effb104222994c61ecc52b380ec1cbfcc281fcd33dd3379af7ec04d0f497c5ae8977afc77b7acf6262620a7a2e0d2505a0181a1a1388d735209f5a41647504bb833fdcad8de4e896c9864edd5edb00006d9bd49468c4c0406f318b420b2121a440eaf324226d3588b79c0f6a536303d6fc2a9e5d4d5c1bb8bfb6cc769829f7cd2010aaf77741f7dbb095d1517bb81b0dadf57dd1907bf3f1a5448b5656b52d2ea6c62b6bf076ad09355f17cc939d84face736185d10bd9d9541dfbbb5c1010018c1158f14d44205600ad878ebdf9f47cfceec6a6e5b0d6e39a1139d8a5b1e2707878e47f660a15aaddfcb9a4df4a3f79d921abf7f52cda1d737f0030624881b39160420000000049454e44ae426082 + + + + + kpushbutton.h + + diff --git a/kopete/protocols/oscar/icq/ui/icqaddcontactpage.cpp b/kopete/protocols/oscar/icq/ui/icqaddcontactpage.cpp new file mode 100644 index 00000000..b1ab2eb4 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqaddcontactpage.cpp @@ -0,0 +1,126 @@ + /* + icqaddcontactpage.cpp - ICQ Protocol Plugin + + Copyright (c) 2002 by Stefan Gehn + Kopete (c) 2002-2003 by the Kopete developers + + ************************************************************************* + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ************************************************************************* +*/ + +#include "icqaddcontactpage.h" + +#include + +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include + +#include "icqadd.h" +#include "icqaccount.h" +#include "icqprotocol.h" +#include "icqsearchdialog.h" + + +ICQAddContactPage::ICQAddContactPage(ICQAccount *owner, QWidget *parent, const char *name) + : AddContactPage(parent,name) +{ + kdDebug(14153) << k_funcinfo << "called" << endl; + mAccount = owner; + m_searchDialog = 0L; + + (new QVBoxLayout(this))->setAutoAdd(true); + addUI = new icqAddUI(this); + connect( addUI->searchButton, SIGNAL( clicked() ), this, SLOT( showSearchDialog() ) ); +} + +ICQAddContactPage::~ICQAddContactPage() +{ +} + +void ICQAddContactPage::setUINFromSearch( const QString& uin ) +{ + addUI->uinEdit->setText( uin ); +} + +void ICQAddContactPage::showEvent(QShowEvent *e) +{ +// slotSelectionChanged(); + AddContactPage::showEvent(e); +} + +bool ICQAddContactPage::apply(Kopete::Account* , Kopete::MetaContact *parentContact ) +{ + kdDebug(14153) << k_funcinfo << "called; adding contact..." << endl; + + QString contactId = addUI->uinEdit->text(); + kdDebug(14153) << k_funcinfo << "uin=" << contactId << endl; + return mAccount->addContact(contactId, parentContact, Kopete::Account::ChangeKABC ); + +} + +bool ICQAddContactPage::validateData() +{ + if(!mAccount->isConnected()) + { + // Account currently offline + addUI->searchButton->setEnabled( false ); + addUI->uinEdit->setEnabled( false ); + KMessageBox::sorry( this, i18n("You must be online to add a contact."), i18n("ICQ Plugin") ); + return false; + } + + Q_ULONG uin = addUI->uinEdit->text().toULong(); + if ( uin < 1000 ) + { + // Invalid (or missing) UIN + KMessageBox::sorry( this, i18n("You must enter a valid UIN."), i18n("ICQ Plugin") ); + return false; + } + else + { + // UIN is valid + return true; + } +} + +void ICQAddContactPage::showSearchDialog() +{ + if ( m_searchDialog ) + m_searchDialog->raise(); + else + { + m_searchDialog = new ICQSearchDialog( mAccount, this, "icqSearchDialog" ); + m_searchDialog->show(); + connect( m_searchDialog, SIGNAL( finished() ), this, SLOT( searchDialogDestroyed() ) ); + } +} + +void ICQAddContactPage::searchDialogDestroyed() +{ + QObject::disconnect( this, 0, m_searchDialog, 0 ); + m_searchDialog->delayedDestruct(); + m_searchDialog = NULL; +} + + +#include "icqaddcontactpage.moc" +// vim: set noet ts=4 sts=4 sw=4: +// kate: indent-mode csands; space-indent off; replace-tabs off; diff --git a/kopete/protocols/oscar/icq/ui/icqaddcontactpage.h b/kopete/protocols/oscar/icq/ui/icqaddcontactpage.h new file mode 100644 index 00000000..e9285b79 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqaddcontactpage.h @@ -0,0 +1,60 @@ + /* + icqaddcontactpage.h - ICQ Protocol Plugin + + Copyright (c) 2002 by Stefan Gehn + Copyright (c) 2004-2005 by Matt Rogers + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ************************************************************************* +*/ + +#ifndef ICQADDCONTACTPAGE_H +#define ICQADDCONTACTPAGE_H + +#include +#include + +/** + *@author Matt Rogers + *@author Stefan Gehn + */ +class icqAddUI; +class ICQAccount; +class ICQSearchDialog; + +class ICQAddContactPage : public AddContactPage +{ +Q_OBJECT + +public: + ICQAddContactPage(ICQAccount *owner, QWidget *parent = 0, const char *name = 0); + ~ICQAddContactPage(); + + virtual bool validateData(); + virtual bool apply(Kopete::Account* , Kopete::MetaContact *parentContact); + + void setUINFromSearch( const QString& ); + +protected: + void showEvent(QShowEvent *e); + +private slots: + void showSearchDialog(); + void searchDialogDestroyed(); +private: + + ICQAccount *mAccount; + icqAddUI *addUI; + ICQSearchDialog* m_searchDialog; +}; + +#endif + +//kate: space-indent off; replace-tabs off; indent-mode csands; diff --git a/kopete/protocols/oscar/icq/ui/icqauthreplydialog.cpp b/kopete/protocols/oscar/icq/ui/icqauthreplydialog.cpp new file mode 100644 index 00000000..76b56fba --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqauthreplydialog.cpp @@ -0,0 +1,73 @@ +/* + Kopete Oscar Protocol + icqauthreplydialog.cpp - ICQ authorization reply dialog + + Copyright (c) 2004 Gustavo Pichorim Boiko + + Kopete (c) 2002-2004 by the Kopete developers + + ************************************************************************* + * * + * 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. * + * * + ************************************************************************* +*/ +#include "icqauthreplydialog.h" +#include "icqauthreplyui.h" + +#include + +#include +#include +#include + +ICQAuthReplyDialog::ICQAuthReplyDialog( QWidget *parent, const char *name, bool wasRequested ) + : KDialogBase( parent, name, true, i18n( "Authorization Reply" ), KDialogBase::Ok | KDialogBase::Cancel ) +{ + m_ui = new ICQAuthReplyUI( this ); + setMainWidget( m_ui ); + m_wasRequested = wasRequested; + + if ( !m_wasRequested ) + { + m_ui->lblReqReason->hide(); + m_ui->lblRequestReason->hide(); + } + else + { + this->setWFlags( this->getWFlags() | Qt::WDestructiveClose ); + } +} + +ICQAuthReplyDialog::~ICQAuthReplyDialog() +{ +} + +void ICQAuthReplyDialog::setUser( const QString & user ) +{ + if ( m_wasRequested ) + m_ui->lblUserReq->setText( + i18n( "%1 requested authorization to add you to his/her contact list." ).arg( user ) ); + else + m_ui->lblUserReq->setText( i18n( "Authorization reply to %1." ).arg( user ) ); +} + +void ICQAuthReplyDialog::setRequestReason( const QString & reason ) +{ + m_ui->lblRequestReason->setText( reason ); +} + +QString ICQAuthReplyDialog::reason() +{ + return m_ui->leReason->text(); +} + +bool ICQAuthReplyDialog::grantAuth() +{ + return m_ui->rbGrant->isChecked(); +} + +#include "icqauthreplydialog.moc" diff --git a/kopete/protocols/oscar/icq/ui/icqauthreplydialog.h b/kopete/protocols/oscar/icq/ui/icqauthreplydialog.h new file mode 100644 index 00000000..da27b241 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqauthreplydialog.h @@ -0,0 +1,45 @@ +/* + Kopete Oscar Protocol + icqauthreplydialog.h - ICQ authorization reply dialog + + Copyright (c) 2004 Gustavo Pichorim Boiko + + Kopete (c) 2002-2004 by the Kopete developers + + ************************************************************************* + * * + * 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 ICQAUTHREPLYDIALOG_H +#define ICQAUTHREPLYDIALOG_H + +#include + +class ICQAuthReplyUI; + +/** + * A dialog to ask user what to do when a contact requests authorization + * @author Gustavo Pichorim Boiko + */ +class ICQAuthReplyDialog : public KDialogBase +{ +Q_OBJECT +public: + ICQAuthReplyDialog(QWidget *parent = 0, const char *name = 0, bool wasRequested = true); + ~ICQAuthReplyDialog(); + + void setUser( const QString& user ); + void setRequestReason( const QString& reason ); + QString reason(); + bool grantAuth(); +private: + bool m_wasRequested; + ICQAuthReplyUI *m_ui; +}; + +#endif diff --git a/kopete/protocols/oscar/icq/ui/icqauthreplyui.ui b/kopete/protocols/oscar/icq/ui/icqauthreplyui.ui new file mode 100644 index 00000000..12607856 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqauthreplyui.ui @@ -0,0 +1,196 @@ + +ICQAuthReplyUI + + + ICQAuthReplyUI + + + + 0 + 0 + 412 + 148 + + + + ICQ Authorization Reply + + + + unnamed + + + + layout22 + + + + unnamed + + + + lblReason + + + + 1 + 5 + 0 + 0 + + + + Reason: + + + + + leReason + + + + + + + layout23 + + + + unnamed + + + + spacer14 + + + Horizontal + + + Expanding + + + + 50 + 20 + + + + + + bgAction + + + + 5 + 0 + 0 + 0 + + + + NoFrame + + + Plain + + + + + + + unnamed + + + + rbGrant + + + &Grant authorization + + + true + + + + + rbDecline + + + &Decline authorization + + + + + + + spacer12 + + + Horizontal + + + Expanding + + + + 220 + 21 + + + + + + + + lblUserReq + + + %1 requested authorization to add you to his/her contact list. + + + + + layout24 + + + + unnamed + + + + lblReqReason + + + + 0 + 5 + 0 + 0 + + + + Request Reason: + + + + + lblRequestReason + + + + 7 + 5 + 0 + 0 + + + + Some reason... + + + + + + + + diff --git a/kopete/protocols/oscar/icq/ui/icqeditaccountui.ui b/kopete/protocols/oscar/icq/ui/icqeditaccountui.ui new file mode 100644 index 00000000..3ecc91cb --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqeditaccountui.ui @@ -0,0 +1,486 @@ + +ICQEditAccountUI + + + ICQEditAccountUI + + + + 0 + 0 + 592 + 404 + + + + Account Preferences - ICQ + + + + unnamed + + + 0 + + + 0 + + + + tabWidget7 + + + + tab + + + &Basic Setup + + + + unnamed + + + + groupBox3 + + + Account Preferences + + + + unnamed + + + + layout5 + + + + unnamed + + + + lblAccountId + + + IC&Q UIN: + + + edtAccountId + + + The user ID of your ICQ account. + + + The user ID of your ICQ account. This should be in the form of a number (no decimals, no spaces). + + + + + edtAccountId + + + The user ID of your ICQ account. + + + The user ID of your ICQ account. This should be in the form of a number (no decimals, no spaces). + + + + + + + mPasswordWidget + + + + + chkAutoLogin + + + true + + + E&xclude from connect all + + + If you check that case, the account will not be connected when you press the "Connect All" button, or at startup even if you selected to automatically connect at startup + + + + + chkGlobalIdentity + + + Exclu&de from Global Identity + + + + + + + groupBox5 + + + + 3 + 1 + 0 + 0 + + + + Registration + + + + unnamed + + + + textLabel6 + + + + 3 + 1 + 0 + 0 + + + + + 0 + 0 + + + + To connect to the ICQ network, you will need an ICQ account.<br><br> +If you do not currently have an ICQ account, please click the button to create one. + + + WordBreak|AlignVCenter + + + + + buttonRegister + + + Re&gister New Account + + + + + + + spacerBasicSetup + + + Vertical + + + Expanding + + + + 20 + 40 + + + + + + + + tab + + + Accou&nt Preferences + + + + unnamed + + + + groupBox2 + + + Connection Preferences + + + + unnamed + + + + edtServerPort + + + false + + + 65534 + + + 1 + + + 5190 + + + The port on the ICQ server that you would like to connect to. + + + The port on the ICQ server that you would like to connect to. Normally this is 5190. + + + + + edtServerAddress + + + false + + + login.icq.com + + + The IP address or hostmask of the ICQ server you wish to connect to. + + + The IP address or hostmask of the ICQ server you wish to connect to. Normally you will want the default (login.icq.com). + + + + + lblServerPort + + + false + + + Po&rt: + + + edtServerPort + + + The port on the ICQ server that you would like to connect to. + + + The port on the ICQ server that you would like to connect to. Normally this is 5190. + + + + + lblServer + + + false + + + Ser&ver / + + + edtServerAddress + + + The IP address or hostmask of the ICQ server you wish to connect to. + + + The IP address or hostmask of the ICQ server you wish to connect to. Normally you will want the default (login.icq.com). + + + + + optionOverrideServer + + + &Override default server information + + + + + + + groupBox65 + + + Privacy Options + + + + unnamed + + + + chkRequireAuth + + + &Require authorization before someone can add you to their contact list + + + Enable authorization requirement, which will not allow users to add you to their contact list without authorization from you. + + + Enable authorization requirement, which will not allow users to add you to their contact list without authorization from you. Check this box, and you will have to confirm any users who add you to their list before they may see your online status. + + + + + chkHideIP + + + Hide &IP address + + + Check this to hide your IP address from people when they view your user info + + + Checking this box will not allow people to see what your IP address if they view your ICQ user details such as name, address, or age. + + + + + chkWebAware + + + Make my status available via &ICQ's unified messaging center + + + false + + + Check this box to enable Web Aware functionality. + + + Check this box to enable ICQ's Web Aware functionality, which allows people to see your online status from ICQ's web page, and send you a message without necessarily having ICQ themselves. + + + + + + + spacerPreferences + + + Vertical + + + Expanding + + + + 20 + 40 + + + + + + encodingCombo + + + true + + + + + textLabel1 + + + true + + + Default to the following &encoding for messages: + + + encodingCombo + + + + + + + + labelStatusMessage + + + + + + AlignCenter + + + + + + + Kopete::UI::PasswordWidget +
kopetepasswordwidget.h
+ + 50 + 50 + + 0 + + 1 + 0 + 0 + 0 + + image0 + changed() +
+
+ + + 89504e470d0a1a0a0000000d4948445200000016000000160806000000c4b46c3b000003b149444154388dad945f4c5b551cc73fe7dc4b7b4bcba0762d45c43114323599ee6192609c51d883892ce083f1718b3ebb185f8dc91e972cf39d2d2a2f1af664b6f1e0fe3863a0718969700eb0c52142da0242a1bd6d696f7bcff101585203ceb8fd9ece39f99dcff9fe7edf939f88c562ec465f5f9fe609442c161362173c3e3eae7b7a7ac8e7f36432196cdbfe4f907c3e4f2291201e8fe338cec3737357e9e8e828aded1e229d650e1f2d51754b082110124c13a4dc5ea341eb9dc284c0558a853f3ce8cb0677ef500fde7d39d2596679e326597b8e9abb85d7a770ab16ab6983ec5a05b487a70e36f0f4e10afe408d6a558310980108478dba4a1e8233990c5d474b64ed39aa3a8fe5f3317fbf81dbd70bccfeb205947632fd74f6589c1c6ea2f70d03a58ba0c1f2c9bdc1b66de3b8256a6e11cbe7e3ee1d181b590124fe2693aeee08d223c82c3a2c24b7b874bec8f26288774f7bd054504aef0dde6e99c0eb83f9fb266323cb80a27fb0958141836044605a2ee5523393371cc646fee2da37195aa35d0c0c5b4859ac03d7e91712dcaac5adab3650a3ff9d08ef7dd8404bb48869e5d958b5b87dadc4c9a1464e9f0d0326df7ebd86bd2e310cb1bf62d384d59441f2d70a070e1c60e09489929b988681bdd9cc97170bcc4c65595f71f8e0e3301337fc24a7732467831875a47f289652b0be5e4151e6d07316c1b0c0340d8ab92023e76d66a6b2840e36d2fb7a13fee632475e6edc367ea98a90fb98b7dd6310ca0328a44761582e1bab41befabcc0ec940d28bc5e93b68e064cab84e1d9beaeb48934eac1f53b01c1b000fca496aa54b61a99fcde61662a4b4b4b23d1680be9d426173e4df3602a48ea411989a4fd590f52a8fd156b05ed9d350e3defe3cfdf4b4c7ce770ea7d3fb9f520afbe1620daeee5c26735d20b9b9cfb6811a754a439e4e5c5639a4caa1e5caf586bfc0197b78702005cb9b4cae4cd3267ce8638fe964bd72b393e39d74928d242617303a756a37f284447770dcdbffc6384a05a85de1306e9a52057c7527c7131c3c42d3f475eb2303c82d4fc3276d6811db37efeb148723082d9b08f79f97c1e5729109a9a28307cc622d2d6cdf52b2b24efe548dedb00142009862cfa879ee1a71f6cec928353511472fbf4389148b0b0e0c108081412458dfe21c9f11351e67e7358595468246d1d1e5e38a6e9e851bc39d84ab502a669331dafec0d8ec7e3e8cb06e1a881d727d1ae40180a434a8c9db129a54126ad48a7358c2b4c5352c8c374bcccdab2bb37d8719cba79fab8211f9df218e0582c261e95f8bfc04f1a1e8bc5c4dfe0a190172af6a9690000000049454e44ae426082 + + + + + optionOverrideServer + toggled(bool) + lblServer + setEnabled(bool) + + + optionOverrideServer + toggled(bool) + lblServerPort + setEnabled(bool) + + + optionOverrideServer + toggled(bool) + edtServerAddress + setEnabled(bool) + + + optionOverrideServer + toggled(bool) + edtServerPort + setEnabled(bool) + + + + tabWidget7 + edtAccountId + chkAutoLogin + buttonRegister + optionOverrideServer + edtServerAddress + edtServerPort + chkRequireAuth + chkHideIP + chkWebAware + + + + kopetepasswordwidget.h + +
diff --git a/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.cpp b/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.cpp new file mode 100644 index 00000000..e4b308be --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.cpp @@ -0,0 +1,190 @@ +/* + icqeditaccountwidget.cpp - ICQ Account Widget + + Copyright (c) 2003 by Chris TenHarmsel + Kopete (c) 2003 by the Kopete developers + + ************************************************************************* + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ************************************************************************* +*/ + +#include "icqeditaccountwidget.h" +#include "icqeditaccountui.h" + +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "kopetepassword.h" +#include "kopetepasswordwidget.h" + +#include "icqprotocol.h" +#include "icqaccount.h" +#include "icqcontact.h" + +ICQEditAccountWidget::ICQEditAccountWidget(ICQProtocol *protocol, + Kopete::Account *account, QWidget *parent, const char *name) + : QWidget(parent, name), KopeteEditAccountWidget(account) +{ + kdDebug(14153) << k_funcinfo << "Called." << endl; + + mAccount=dynamic_cast(account); + mProtocol=protocol; + + (new QVBoxLayout(this))->setAutoAdd(true); + mAccountSettings = new ICQEditAccountUI( this ); + + mProtocol->fillComboFromTable( mAccountSettings->encodingCombo, mProtocol->encodings() ); + + // Read in the settings from the account if it exists + if(mAccount) + { + mAccountSettings->edtAccountId->setText(mAccount->accountId()); + + // TODO: Remove me after we can change Account IDs (Matt) + mAccountSettings->edtAccountId->setDisabled(true); + mAccountSettings->mPasswordWidget->load(&mAccount->password()); + mAccountSettings->chkAutoLogin->setChecked(mAccount->excludeConnect()); + + QString serverEntry = mAccount->configGroup()->readEntry("Server", "login.oscar.aol.com"); + int portEntry = mAccount->configGroup()->readNumEntry("Port", 5190); + if ( serverEntry != "login.oscar.aol.com" || ( portEntry != 5190) ) + mAccountSettings->optionOverrideServer->setChecked( true ); + + mAccountSettings->edtServerAddress->setText( serverEntry ); + mAccountSettings->edtServerPort->setValue( portEntry ); + + bool configValue = mAccount->configGroup()->readBoolEntry( "RequireAuth", false ); + mAccountSettings->chkRequireAuth->setChecked( configValue ); + + configValue = mAccount->configGroup()->readBoolEntry( "HideIP", true ); + mAccountSettings->chkHideIP->setChecked( configValue ); + + configValue = mAccount->configGroup()->readBoolEntry( "WebAware", false ); + mAccountSettings->chkWebAware->setChecked( configValue ); + + int encodingValue = mAccount->configGroup()->readNumEntry( "DefaultEncoding", 4 ); + mProtocol->setComboFromTable( mAccountSettings->encodingCombo, + mProtocol->encodings(), + encodingValue ); + + // Global Identity + mAccountSettings->chkGlobalIdentity->setChecked( mAccount->configGroup()->readBoolEntry("ExcludeGlobalIdentity", false) ); + } + else + { + mProtocol->setComboFromTable( mAccountSettings->encodingCombo, + mProtocol->encodings(), + 4 ); + } + + QObject::connect(mAccountSettings->buttonRegister, SIGNAL(clicked()), this, SLOT(slotOpenRegister())); + + /* Set tab order to password custom widget correctly */ + QWidget::setTabOrder( mAccountSettings->edtAccountId, mAccountSettings->mPasswordWidget->mRemembered ); + QWidget::setTabOrder( mAccountSettings->mPasswordWidget->mRemembered, mAccountSettings->mPasswordWidget->mPassword ); + QWidget::setTabOrder( mAccountSettings->mPasswordWidget->mPassword, mAccountSettings->chkAutoLogin ); + +} + +Kopete::Account *ICQEditAccountWidget::apply() +{ + kdDebug(14153) << k_funcinfo << "Called." << endl; + + // If this is a new account, create it + if (!mAccount) + { + kdDebug(14153) << k_funcinfo << "Creating a new account" << endl; + mAccount = new ICQAccount(mProtocol, mAccountSettings->edtAccountId->text()); + if(!mAccount) + return NULL; + } + + mAccountSettings->mPasswordWidget->save(&mAccount->password()); + mAccount->setExcludeConnect(mAccountSettings->chkAutoLogin->isChecked()); + + bool configValue = mAccountSettings->chkRequireAuth->isChecked(); + mAccount->configGroup()->writeEntry( "RequireAuth", configValue ); + + configValue = mAccountSettings->chkHideIP->isChecked(); + mAccount->configGroup()->writeEntry( "HideIP", configValue ); + + configValue = mAccountSettings->chkWebAware->isChecked(); + mAccount->configGroup()->writeEntry( "WebAware", configValue ); + + int encodingMib = mProtocol->getCodeForCombo( mAccountSettings->encodingCombo, + mProtocol->encodings() ); + mAccount->configGroup()->writeEntry( "DefaultEncoding", encodingMib ); + + if ( mAccountSettings->optionOverrideServer->isChecked() ) + { + mAccount->setServerAddress(mAccountSettings->edtServerAddress->text()); + mAccount->setServerPort(mAccountSettings->edtServerPort->value()); + } + else + { + mAccount->setServerAddress("login.oscar.aol.com"); + mAccount->setServerPort(5190); + } + + // Global Identity + mAccount->configGroup()->writeEntry( "ExcludeGlobalIdentity", mAccountSettings->chkGlobalIdentity->isChecked() ); + + return mAccount; +} + +bool ICQEditAccountWidget::validateData() +{ + kdDebug(14153) << k_funcinfo << "Called." << endl; + + QString userName = mAccountSettings->edtAccountId->text(); + + if (userName.isEmpty()) + return false; + + for (unsigned int i=0; iedtServerAddress->text().isEmpty()) + return false; + + // Seems good to me + kdDebug(14153) << k_funcinfo << + "Account data validated successfully." << endl; + return true; +} + +void ICQEditAccountWidget::slotOpenRegister() +{ + KRun::runURL( "http://go.icq.com/register/", "text/html" ); +} + +#include "icqeditaccountwidget.moc" +// vim: set noet ts=4 sts=4 sw=4: +// kate: indent-mode csands; space-indent off; replace-tabs off; diff --git a/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.h b/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.h new file mode 100644 index 00000000..fc5c6d38 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqeditaccountwidget.h @@ -0,0 +1,52 @@ +/* + icqeditaccountwidget.h - ICQ Account Widget + + Copyright (c) 2003 by Chris TenHarmsel + Copyright (c) 2004-2005 by Matt Rogers + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + ************************************************************************* +*/ + +#ifndef ICQEDITACCOUNTWIDGET_H +#define ICQEDITACCOUNTWIDGET_H + +#include +#include +#include "editaccountwidget.h" + +namespace Kopete { class Account; } + +class ICQAccount; +class ICQProtocol; +class ICQEditAccountUI; + +class ICQEditAccountWidget : public QWidget, public KopeteEditAccountWidget +{ +Q_OBJECT + +public: + ICQEditAccountWidget(ICQProtocol *, Kopete::Account *, + QWidget *parent=0, const char *name=0); + + virtual bool validateData(); + virtual Kopete::Account *apply(); + +private slots: + void slotOpenRegister(); + +protected: + ICQAccount *mAccount; + ICQProtocol *mProtocol; + ICQEditAccountUI *mAccountSettings; +}; +#endif +// vim: set noet ts=4 sts=4 sw=4: +// kate: indent-mode csands; space-indent off; replace-tabs off; diff --git a/kopete/protocols/oscar/icq/ui/icqgeneralinfo.ui b/kopete/protocols/oscar/icq/ui/icqgeneralinfo.ui new file mode 100644 index 00000000..6383bec1 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqgeneralinfo.ui @@ -0,0 +1,611 @@ + +ICQGeneralInfoWidget + + + ICQGeneralInfoWidget + + + + 0 + 0 + 488 + 572 + + + + + unnamed + + + + groupBox2 + + + Location && Contact Information + + + + unnamed + + + + textLabel2 + + + &City: + + + cityEdit + + + + + textLabel1 + + + &Address: + + + addressEdit + + + + + textLabel5 + + + &Phone: + + + phoneEdit + + + + + textLabel4 + + + &State: + + + stateEdit + + + + + cityEdit + + + + 7 + 0 + 1 + 0 + + + + true + + + + + textLabel8 + + + Countr&y: + + + countryEdit + + + + + homepageEdit + + + + 3 + 0 + 0 + 0 + + + + true + + + + + textLabel9 + + + &Email: + + + emailEdit + + + + + emailEdit + + + + 3 + 0 + 0 + 0 + + + + true + + + + + textLabel10_2 + + + &Homepage: + + + homepageEdit + + + + + cellEdit + + + + 7 + 0 + 0 + 0 + + + + true + + + + + countryEdit + + + true + + + + + stateEdit + + + + 7 + 0 + 1 + 0 + + + + true + + + + + textLabel7_2 + + + Fa&x: + + + faxEdit + + + + + faxEdit + + + true + + + + + phoneEdit + + + + + + true + + + + + textLabel6_2 + + + Ce&ll: + + + cellEdit + + + + + addressEdit + + + + 3 + 0 + 0 + 0 + + + + true + + + + + textLabel3 + + + &Zip: + + + zipEdit + + + + + zipEdit + + + + 7 + 0 + 0 + 0 + + + + + + + true + + + + + + + groupBox4 + + + Personal Information + + + + unnamed + + + + uinEdit + + + + 7 + 0 + 1 + 0 + + + + true + + + + + fullNameLabel + + + &Full name: + + + fullNameEdit + + + + + ipEdit + + + + 7 + 0 + 0 + 0 + + + + + 125 + 0 + + + + + + + true + + + + + timezoneEdit + + + true + + + + + nickNameEdit + + + + 7 + 0 + 2 + 0 + + + + true + + + + + nickNameLabel + + + &Nickname: + + + nickNameEdit + + + + + uinLabel + + + &UIN #: + + + uinEdit + + + + + birthdayLabel + + + &Birthday: + + + birthday + + + + + ageSpinBox + + + + + textLabel6 + + + Gen&der: + + + genderEdit + + + + + birthday + + + true + + + + + fullNameEdit + + + true + + + + + genderEdit + + + true + + + + + ipLabel + + + &IP: + + + ipEdit + + + + + textLabel7 + + + &Timezone: + + + timezoneEdit + + + + + maritalLabel + + + Marital status: + + + + + textLabel10 + + + + 0 + 5 + 0 + 0 + + + + A&ge: + + + ageSpinBox + + + + + marital + + + true + + + + + + + groupBox3 + + + Origin + + + + unnamed + + + + oStateEdit + + + true + + + + + oCountryEdit + + + true + + + + + oCityEdit + + + + 7 + 0 + 0 + 0 + + + + true + + + + + textLabel2_2 + + + City: + + + + + textLabel3_2 + + + Country: + + + + + textLabel1_2 + + + State: + + + + + + + spacer4 + + + Vertical + + + Expanding + + + + 21 + 20 + + + + + + + nickNameEdit + fullNameEdit + genderEdit + uinEdit + ipEdit + timezoneEdit + ageSpinBox + addressEdit + cityEdit + stateEdit + zipEdit + countryEdit + phoneEdit + faxEdit + cellEdit + emailEdit + homepageEdit + + + diff --git a/kopete/protocols/oscar/icq/ui/icqinterestinfowidget.ui b/kopete/protocols/oscar/icq/ui/icqinterestinfowidget.ui new file mode 100644 index 00000000..ce4041c9 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqinterestinfowidget.ui @@ -0,0 +1,116 @@ + +ICQInterestInfoWidget + + + ICQInterestInfoWidget + + + + 0 + 0 + 660 + 572 + + + + + unnamed + + + + buttonGroup1 + + + Interests + + + + unnamed + + + + desc1 + + + true + + + + + desc2 + + + true + + + + + desc3 + + + true + + + + + topic2 + + + true + + + + + topic1 + + + true + + + + + topic3 + + + true + + + + + topic4 + + + true + + + + + desc4 + + + true + + + + + + + spacer2 + + + Vertical + + + Expanding + + + + 20 + 220 + + + + + + + diff --git a/kopete/protocols/oscar/icq/ui/icqotherinfowidget.ui b/kopete/protocols/oscar/icq/ui/icqotherinfowidget.ui new file mode 100644 index 00000000..4e5a3a34 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqotherinfowidget.ui @@ -0,0 +1,68 @@ + +ICQOtherInfoWidget + + + ICQOtherInfoWidget + + + + 0 + 0 + 289 + 473 + + + + + unnamed + + + + spacer8 + + + Vertical + + + Expanding + + + + 20 + 30 + + + + + + textLabel12 + + + Email addresses: + + + + + emailListBox + + + + + textLabel13 + + + Contact notes: + + + + + notesEdit + + + true + + + + + + diff --git a/kopete/protocols/oscar/icq/ui/icqsearchbase.ui b/kopete/protocols/oscar/icq/ui/icqsearchbase.ui new file mode 100644 index 00000000..68e59281 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqsearchbase.ui @@ -0,0 +1,493 @@ + +ICQSearchBase + + + ICQSearchBase + + + + 0 + 0 + 603 + 465 + + + + + unnamed + + + + clearButton + + + false + + + C&lear + + + 10 + + + Clear the results + + + + + closeButton + + + &Close + + + 13 + + + Close this dialog + + + + + stopButton + + + false + + + Stop + + + + + + 26 + + + Stops the search + + + + + addButton + + + false + + + Add + + + + + + 27 + + + Add the selected user to your contact list + + + + + userInfoButton + + + false + + + User Info + + + + + + Show information about the selected contact + + + + + spacer6 + + + Vertical + + + Expanding + + + + 41 + 190 + + + + + + tabWidget3 + + + + tab + + + UIN Search + + + + unnamed + + + + textLabel1 + + + &UIN #: + + + uin + + + + + uin + + + + + spacer4 + + + Vertical + + + Expanding + + + + 20 + 105 + + + + + + + + tab + + + ICQ Whitepages Search + + + + unnamed + + + + lastName + + + + + nickName + + + + + textLabel4 + + + &Last name: + + + lastName + + + + + textLabel3 + + + &First name: + + + firstName + + + + + textLabel6 + + + &Email: + + + email + + + + + textLabel2 + + + &Nickname: + + + nickName + + + + + country + + + + + textLabel9 + + + Lan&guage: + + + language + + + + + language + + + + + city + + + + + textLabel10 + + + &City: + + + city + + + + + firstName + + + + + email + + + + + textLabel8 + + + &Gender: + + + gender + + + + + gender + + + + + onlyOnline + + + Only search for online contacts + + + + + textLabel11 + + + C&ountry: + + + country + + + + + spacer5 + + + Vertical + + + Expanding + + + + 20 + 16 + + + + + + spacer3 + + + Horizontal + + + Expanding + + + + 166 + 20 + + + + + + + + + + UIN + + + true + + + true + + + + + Nickname + + + true + + + true + + + + + First Name + + + true + + + true + + + + + Last Name + + + true + + + true + + + + + Email + + + true + + + true + + + + + Requires Authorization? + + + true + + + true + + + + searchResults + + + true + + + This is where the results from your search are displayed. If you double-click a result, the search window will close and pass the UIN of the contact you wish to add back to the Add Contact Wizard. You can only add one contact at a time. + + + + + searchButton + + + &Search + + + Search the ICQ Whitepages with your search criteria + + + + + newSearchButton + + + true + + + New Search + + + Clears both search fields and results + + + + + + tabWidget3 + uin + nickName + firstName + email + lastName + gender + city + language + country + onlyOnline + searchButton + stopButton + clearButton + addButton + userInfoButton + closeButton + searchResults + + + + kpushbutton.h + kpushbutton.h + kpushbutton.h + kpushbutton.h + kpushbutton.h + klistview.h + kpushbutton.h + kpushbutton.h + + diff --git a/kopete/protocols/oscar/icq/ui/icqsearchdialog.cpp b/kopete/protocols/oscar/icq/ui/icqsearchdialog.cpp new file mode 100644 index 00000000..0010166a --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqsearchdialog.cpp @@ -0,0 +1,320 @@ +/* + Kopete Oscar Protocol + icqsearchdialog.cpp - search for people + + Copyright (c) 2005 Matt Rogers + + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * 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. * + * * + ************************************************************************* +*/ + +#include "icqsearchdialog.h" + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "kopeteuiglobal.h" + +#include "icqaccount.h" +#include "icqaddcontactpage.h" +#include "icqprotocol.h" +#include "icqsearchbase.h" +#include "oscartypes.h" +#include "icqcontact.h" +#include "icquserinfowidget.h" + +ICQSearchDialog::ICQSearchDialog( ICQAccount* account, QWidget* parent, const char* name ) +: KDialogBase( parent, name, true, i18n( "ICQ User Search" ), 0, NoDefault ) +{ + m_account = account; + m_searchUI = new ICQSearchBase( this, name ); + setMainWidget( m_searchUI ); + connect( m_searchUI->searchButton, SIGNAL( clicked() ), this, SLOT( startSearch() ) ); + connect( m_searchUI->searchResults, SIGNAL( selectionChanged() ), this, SLOT( resultSelectionChanged() ) ); + connect( m_searchUI->addButton, SIGNAL( clicked() ), this, SLOT( addContact() ) ); + connect( m_searchUI->clearButton, SIGNAL( clicked() ), this, SLOT( clearResults() ) ); + connect( m_searchUI->stopButton, SIGNAL( clicked() ), this, SLOT( stopSearch() ) ); + connect( m_searchUI->closeButton, SIGNAL( clicked() ), this, SLOT( closeDialog() ) ); + connect( m_searchUI->userInfoButton, SIGNAL( clicked() ), this, SLOT( userInfo() ) ); + connect( m_searchUI->newSearchButton, SIGNAL( clicked() ), this, SLOT( newSearch() ) ); + + ICQProtocol *p = ICQProtocol::protocol(); + p->fillComboFromTable( m_searchUI->gender, p->genders() ); + p->fillComboFromTable( m_searchUI->country, p->countries() ); + p->fillComboFromTable( m_searchUI->language, p->languages() ); + + m_contact = NULL; + m_infoWidget = NULL; + + m_contact = NULL; + m_infoWidget = NULL; +} + + +ICQSearchDialog::~ICQSearchDialog() +{ +} + +void ICQSearchDialog::startSearch() +{ + // Doing the search only if the account is online, otherwise warn the user + if(!m_account->isConnected()) + { + // Account currently offline + m_searchUI->searchButton->setEnabled( false ); + KMessageBox::sorry( this, i18n("You must be online to search the ICQ Whitepages."), i18n("ICQ Plugin") ); + } + else + { + // Account is online + clearResults(); + + m_searchUI->stopButton->setEnabled( true ); + m_searchUI->searchButton->setEnabled( false ); + m_searchUI->newSearchButton->setEnabled( false ); + + connect( m_account->engine(), SIGNAL( gotSearchResults( const ICQSearchResult& ) ), + this, SLOT( newResult( const ICQSearchResult& ) ) ); + connect( m_account->engine(), SIGNAL( endOfSearch( int ) ), + this, SLOT( searchFinished( int ) ) ); + + const QWidget* currentPage = m_searchUI->tabWidget3->currentPage(); + + if ( currentPage == m_searchUI->tab ) + { + if( m_searchUI->uin->text().isEmpty() || m_searchUI->uin->text().toULong() == 0 ) + { + // Invalid UIN + stopSearch(); + clearResults(); + KMessageBox::sorry( this, i18n("You must enter a valid UIN."), i18n("ICQ Plugin") ); + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Search aborted: invalid UIN " << m_searchUI->uin->text() << endl; + } + else + { + //doing a uin search + m_account->engine()->uinSearch( m_searchUI->uin->text() ); + } + } + else if ( currentPage == m_searchUI->tab_2 ) + { + //create a ICQWPSearchInfo struct and send it + ICQProtocol* p = ICQProtocol::protocol(); + ICQWPSearchInfo info; + QTextCodec* codec = m_account->defaultCodec(); + info.firstName = codec->fromUnicode( m_searchUI->firstName->text() ); + info.lastName = codec->fromUnicode( m_searchUI->lastName->text() ); + info.nickName = codec->fromUnicode( m_searchUI->nickName->text() ); + info.email = codec->fromUnicode( m_searchUI->email->text() ); + info.city = codec->fromUnicode( m_searchUI->city->text() ); // City + info.gender = p->getCodeForCombo(m_searchUI->gender, p->genders()); // Gender + info.language = p->getCodeForCombo(m_searchUI->language, p->languages()); // Lang + info.country =p->getCodeForCombo(m_searchUI->country, p->countries()); // country code + info.onlineOnly = m_searchUI->onlyOnline->isChecked(); + + // Check if the user has actually entered things to search + if( info.firstName.isEmpty() && + info.lastName.isEmpty() && + info.nickName.isEmpty() && + info.email.isEmpty() && + info.city.isEmpty() && + (info.gender == 0) && + (info.language == 0) && + (info.country == 0) + ) + { + // All fields were blank + stopSearch(); + clearResults(); + KMessageBox::information(this, i18n("You must enter search criteria."), i18n("ICQ Plugin") ); + kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << "Search aborted: all fields were blank" << endl; + } + else + { + // Start the search + m_account->engine()->whitePagesSearch( info ); + kdDebug(OSCAR_RAW_DEBUG) << k_funcinfo << "Starting whitepage search" << endl; + } + } + } +} + +void ICQSearchDialog::stopSearch() +{ + disconnect( m_account->engine(), SIGNAL( gotSearchResults( const ICQSearchResult& ) ), + this, SLOT( newResult( const ICQSearchResult& ) ) ); + disconnect( m_account->engine(), SIGNAL( endOfSearch( int ) ), + this, SLOT( searchFinished( int ) ) ); + + m_searchUI->stopButton->setEnabled( false ); + m_searchUI->searchButton->setEnabled( true ); + m_searchUI->newSearchButton->setEnabled( true ); +} + +void ICQSearchDialog::addContact() +{ + ICQAddContactPage* iacp = dynamic_cast( parent() ); + if ( !iacp ) + { + kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << "The ICQ ACP is not our parent!!" << endl; + } + else + { + QString uin = m_searchUI->searchResults->selectedItem()->text( 0 ); + kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << "Passing " << uin << " back to the ACP" << endl; + iacp->setUINFromSearch( uin ); + + // Closing the dialog + closeDialog(); + } +} + +void ICQSearchDialog::userInfo() +{ + // Lookup user info only if the account is online, otherwise warn the user + if(!m_account->isConnected()) + { + // Account currently offline + KMessageBox::sorry( this, i18n("You must be online to display user info."), i18n("ICQ Plugin") ); + } + else + { + // Account currently online + m_contact = new ICQContact( m_account, + m_searchUI->searchResults->selectedItem()->text( 0 ), + NULL); + + m_infoWidget = new ICQUserInfoWidget( Kopete::UI::Global::mainWidget(), "icq info" ); + QObject::connect( m_infoWidget, SIGNAL( finished() ), this, SLOT( closeUserInfo() ) ); + + m_infoWidget->setContact( m_contact ); + m_infoWidget->setModal(true); + m_infoWidget->show(); + if ( m_contact->account()->isConnected() ) + m_account->engine()->requestFullInfo( m_contact->contactId() ); + kdDebug(OSCAR_ICQ_DEBUG) << k_funcinfo << "Displaying user info" << endl; + } +} + +void ICQSearchDialog::closeUserInfo() +{ + // Free the ICQUserInfoWidget + QObject::disconnect( this, 0, m_infoWidget, 0 ); + m_infoWidget->delayedDestruct(); + m_infoWidget = NULL; + + // Free the ICQContact + delete m_contact; + m_contact = NULL; +} + +void ICQSearchDialog::clearResults() +{ + stopSearch(); + m_searchUI->searchResults->clear(); + m_searchUI->addButton->setEnabled( false ); + m_searchUI->userInfoButton->setEnabled( false ); + m_searchUI->searchButton->setEnabled( true ); +} + +void ICQSearchDialog::closeDialog() +{ + stopSearch(); + clearResults(); + clearFields(); + + slotClose(); +} + +void ICQSearchDialog::resultSelectionChanged() +{ + if ( !m_searchUI->searchResults->selectedItem() ) + { + m_searchUI->addButton->setEnabled( false ); + m_searchUI->userInfoButton->setEnabled( false ); + } + else + { + m_searchUI->addButton->setEnabled( true ); + m_searchUI->userInfoButton->setEnabled( true ); + } +} + +void ICQSearchDialog::newResult( const ICQSearchResult& info ) +{ + if ( info.uin == 1 ) + { + //TODO update progress + return; + } + + QTextCodec* codec = m_account->defaultCodec(); + + QListViewItem *item = new QListViewItem( m_searchUI->searchResults, QString::number( info.uin ), + codec->toUnicode( info.nickName ), + codec->toUnicode( info.firstName ), + codec->toUnicode( info.lastName ), + codec->toUnicode( info.email ), + info.auth ? i18n( "Yes" ) : i18n( "No" ) ); + + if ( !item ) + return; + + if ( info.online ) + item->setPixmap( 0, SmallIcon( "icq_online" ) ); + else + item->setPixmap( 0, SmallIcon( "icq_offline" ) ); + +} + +void ICQSearchDialog::searchFinished( int numLeft ) +{ + kdWarning(OSCAR_ICQ_DEBUG) << k_funcinfo << "There are " << numLeft << "contact left out of this search" << endl; + m_searchUI->stopButton->setEnabled( false ); + m_searchUI->clearButton->setEnabled( true ); + m_searchUI->searchButton->setEnabled( true ); + m_searchUI->newSearchButton->setEnabled( true ); +} + +void ICQSearchDialog::clearFields() +{ + m_searchUI->uin->setText( QString::null ); + + m_searchUI->firstName->setText( QString::null ); + m_searchUI->lastName->setText( QString::null ); + m_searchUI->nickName->setText( QString::null ); + m_searchUI->email->setText( QString::null ); + m_searchUI->city->setText( QString::null ); + m_searchUI->gender->setCurrentItem( 0 ); // Unspecified + m_searchUI->country->setCurrentItem( 0 ); + m_searchUI->language->setCurrentItem( 0 ); + m_searchUI->onlyOnline->setChecked( false ); +} + +void ICQSearchDialog::newSearch() +{ + clearResults(); + clearFields(); +} + +//kate: indent-mode csands; space-indent off; replace-tabs off; tab-width 4; + +#include "icqsearchdialog.moc" diff --git a/kopete/protocols/oscar/icq/ui/icqsearchdialog.h b/kopete/protocols/oscar/icq/ui/icqsearchdialog.h new file mode 100644 index 00000000..b14aa2a1 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqsearchdialog.h @@ -0,0 +1,69 @@ +/* + Kopete Oscar Protocol + icqsearchdialog.h - search for people + + Copyright (c) 2005 Matt Rogers + + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * 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 ICQSEARCHDIALOG_H +#define ICQSEARCHDIALOG_H + +#include +#include "icquserinfo.h" + +class ICQAccount; +class ICQSearchBase; +class ICQContact; +class ICQUserInfoWidget; +/** +@author Kopete Developers +*/ +class ICQSearchDialog : public KDialogBase +{ +Q_OBJECT +public: + ICQSearchDialog( ICQAccount* account, QWidget* parent = 0, const char* name = 0 ); + ~ICQSearchDialog(); + +private slots: + void startSearch(); + void stopSearch(); + void addContact(); + void clearResults(); + void closeDialog(); + void userInfo(); + void closeUserInfo(); + void newSearch(); + + /// Enable/disable buttons when the selection changes + void resultSelectionChanged(); + + /// Add a search result to the listview + void newResult( const ICQSearchResult& info ); + + /// The search is finished + void searchFinished( int numLeft ); + +private: + ICQAccount* m_account; + ICQSearchBase* m_searchUI; + ICQContact* m_contact; + ICQUserInfoWidget* m_infoWidget; + + void clearFields(); +}; + +#endif + +//kate: indent-mode csands; space-indent off; replace-tabs off; tab-width 4; diff --git a/kopete/protocols/oscar/icq/ui/icquserinfowidget.cpp b/kopete/protocols/oscar/icq/ui/icquserinfowidget.cpp new file mode 100644 index 00000000..3830e05f --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icquserinfowidget.cpp @@ -0,0 +1,190 @@ +/* + Kopete Oscar Protocol + icquserinfowidget.cpp - Display ICQ user info + + Copyright (c) 2005 Matt Rogers + + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * 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. * + * * + ************************************************************************* +*/ + +#include "icquserinfowidget.h" + +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include + +#include "icqgeneralinfo.h" +#include "icqcontact.h" +#include "icqprotocol.h" +#include "icqworkinfowidget.h" +#include "icqotherinfowidget.h" +#include "icqinterestinfowidget.h" + + +ICQUserInfoWidget::ICQUserInfoWidget( QWidget * parent, const char * name ) +: KDialogBase( KDialogBase::IconList, 0, parent, name, false, i18n( "ICQ User Information" ), Ok ) +{ + kdDebug(14153) << k_funcinfo << "Creating new icq user info widget" << endl; + + QFrame* genInfo = addPage( i18n( "General Info" ), + i18n( "General ICQ Information" ), + KGlobal::iconLoader()->loadIcon( QString::fromLatin1( "identity" ), KIcon::Desktop ) ); + QVBoxLayout* genLayout = new QVBoxLayout( genInfo ); + m_genInfoWidget = new ICQGeneralInfoWidget( genInfo, "Basic Information" ); + genLayout->addWidget( m_genInfoWidget ); + + QFrame* workInfo = addPage( i18n( "Work Info" ), + i18n( "Work Information" ), + KGlobal::iconLoader()->loadIcon( QString::fromLatin1( "attach" ), KIcon::Desktop ) ); + QVBoxLayout* workLayout = new QVBoxLayout( workInfo ); + m_workInfoWidget = new ICQWorkInfoWidget( workInfo, "Work Information" ); + workLayout->addWidget( m_workInfoWidget ); + + QFrame* otherInfo = addPage( i18n( "Other Info" ), + i18n( "Other ICQ Information" ), + KGlobal::iconLoader()->loadIcon( QString::fromLatin1( "email" ), KIcon::Desktop ) ); + QVBoxLayout* otherLayout = new QVBoxLayout( otherInfo ); + m_otherInfoWidget = new ICQOtherInfoWidget( otherInfo, "Other Information" ); + otherLayout->addWidget( m_otherInfoWidget ); + + QFrame* interestInfo = addPage( i18n( "Interest Info" ), + i18n( "Interest" ), + KGlobal::iconLoader()->loadIcon( QString::fromLatin1( "email" ), KIcon::Desktop ) ); + QVBoxLayout* interestLayout = new QVBoxLayout( interestInfo ); + m_interestInfoWidget = new ICQInterestInfoWidget( interestInfo, "Other Information" ); + interestLayout->addWidget( m_interestInfoWidget ); + +} + +void ICQUserInfoWidget::setContact( ICQContact* contact ) +{ + m_contact = contact; + QObject::connect( contact, SIGNAL( haveBasicInfo( const ICQGeneralUserInfo& ) ), + this, SLOT( fillBasicInfo( const ICQGeneralUserInfo& ) ) ); + QObject::connect( contact, SIGNAL( haveWorkInfo( const ICQWorkUserInfo& ) ), + this, SLOT( fillWorkInfo( const ICQWorkUserInfo& ) ) ); + QObject::connect( contact, SIGNAL( haveEmailInfo( const ICQEmailInfo& ) ), + this, SLOT( fillEmailInfo( const ICQEmailInfo& ) ) ); + QObject::connect( contact, SIGNAL( haveMoreInfo( const ICQMoreUserInfo& ) ), + this, SLOT( fillMoreInfo( const ICQMoreUserInfo& ) ) ); + QObject::connect( contact, SIGNAL( haveInterestInfo( const ICQInterestInfo& ) ), + this, SLOT( fillInterestInfo( const ICQInterestInfo& ) ) ); +} + +void ICQUserInfoWidget::fillBasicInfo( const ICQGeneralUserInfo& ui ) +{ + QTextCodec* codec = m_contact->contactCodec(); + m_genInfoWidget->uinEdit->setText( m_contact->contactId() ); + m_genInfoWidget->nickNameEdit->setText( codec->toUnicode( ui.nickname ) ); + m_genInfoWidget->fullNameEdit->setText( codec->toUnicode( ui.firstName ) + " " + codec->toUnicode( ui.lastName ) ); + m_genInfoWidget->ipEdit->setText( m_contact->property( "ipAddress" ).value().toString() ); + m_genInfoWidget->emailEdit->setText( codec->toUnicode( ui.email ) ); + m_genInfoWidget->cityEdit->setText( codec->toUnicode( ui.city ) ); + m_genInfoWidget->stateEdit->setText( codec->toUnicode( ui.state ) ); + m_genInfoWidget->phoneEdit->setText( codec->toUnicode( ui.phoneNumber ) ); + m_genInfoWidget->faxEdit->setText( codec->toUnicode( ui.faxNumber ) ); + m_genInfoWidget->addressEdit->setText( codec->toUnicode( ui.address ) ); + m_genInfoWidget->cellEdit->setText( codec->toUnicode( ui.cellNumber ) ); + m_genInfoWidget->zipEdit->setText( codec->toUnicode( ui.zip ) ); + + QString country = static_cast( m_contact->protocol() )->countries()[ui.country]; + m_genInfoWidget->countryEdit->setText( country ); +} + +void ICQUserInfoWidget::fillWorkInfo( const ICQWorkUserInfo& ui ) +{ + QTextCodec* codec = m_contact->contactCodec(); + m_workInfoWidget->cityEdit->setText( codec->toUnicode( ui.city ) ); + m_workInfoWidget->stateEdit->setText( codec->toUnicode( ui.state ) ); + m_workInfoWidget->phoneEdit->setText( codec->toUnicode( ui.phone ) ); + m_workInfoWidget->faxEdit->setText( codec->toUnicode( ui.fax ) ); + m_workInfoWidget->addressEdit->setText( codec->toUnicode( ui.address ) ); + m_workInfoWidget->zipEdit->setText( codec->toUnicode( ui.zip ) ); + m_workInfoWidget->companyEdit->setText( codec->toUnicode( ui.company ) ); + m_workInfoWidget->departmentEdit->setText( codec->toUnicode( ui.department ) ); + m_workInfoWidget->positionEdit->setText( codec->toUnicode( ui.position ) ); + m_workInfoWidget->homepageEdit->setText( codec->toUnicode( ui.homepage ) ); + + ICQProtocol* p = static_cast( m_contact->protocol() ); + QString country = p->countries()[ui.country]; + m_workInfoWidget->countryEdit->setText( country ); + + //TODO handle the occupation +} + +void ICQUserInfoWidget::fillEmailInfo( const ICQEmailInfo& ) +{ +} + +void ICQUserInfoWidget::fillInterestInfo( const ICQInterestInfo& info) +{ + QTextCodec* codec = m_contact->contactCodec(); + if (info.count>0) { + QString topic = static_cast( m_contact->protocol() )->interests()[info.topics[0]]; + m_interestInfoWidget->topic1->setText( topic ); + m_interestInfoWidget->desc1->setText( codec->toUnicode( info.descriptions[0] ) ); + } + if (info.count>1) { + QString topic = static_cast( m_contact->protocol() )->interests()[info.topics[1]]; + m_interestInfoWidget->topic2->setText( topic ); + m_interestInfoWidget->desc2->setText( codec->toUnicode( info.descriptions[1] ) ); + } + if (info.count>2) { + QString topic = static_cast( m_contact->protocol() )->interests()[info.topics[2]]; + m_interestInfoWidget->topic3->setText( topic ); + m_interestInfoWidget->desc3->setText( codec->toUnicode( info.descriptions[2] ) ); + } + if (info.count>3) { + QString topic = static_cast( m_contact->protocol() )->interests()[info.topics[3]]; + m_interestInfoWidget->topic4->setText( topic ); + m_interestInfoWidget->desc4->setText( codec->toUnicode( info.descriptions[3] ) ); + } +} + +void ICQUserInfoWidget::fillMoreInfo( const ICQMoreUserInfo& ui ) +{ + QTextCodec* codec = m_contact->contactCodec(); + m_genInfoWidget->ageSpinBox->setValue( ui.age ); + if ( ui.birthday.isValid() ) + m_genInfoWidget->birthday->setText( KGlobal::locale()->formatDate( ui.birthday,true ) ); + + QString gender = static_cast( m_contact->protocol() )->genders()[ui.gender]; + m_genInfoWidget->genderEdit->setText( gender ); + m_genInfoWidget->homepageEdit->setText( codec->toUnicode( ui.homepage ) ); + + QString ms = static_cast( m_contact->protocol() )->maritals()[ui.marital]; + m_genInfoWidget->marital->setText( ms ); + + m_genInfoWidget->oCityEdit->setText( codec->toUnicode( ui.ocity) ); + m_genInfoWidget->oStateEdit->setText( codec->toUnicode( ui.ostate) ); + + QString ocountry = static_cast( m_contact->protocol() )->countries()[ui.ocountry]; + m_genInfoWidget->oCountryEdit->setText( ocountry ); + + //TODO languages +} + + +#include "icquserinfowidget.moc" + +//kate: indent-mode csands; tab-width 4; space-indent off; replace-tabs off; + diff --git a/kopete/protocols/oscar/icq/ui/icquserinfowidget.h b/kopete/protocols/oscar/icq/ui/icquserinfowidget.h new file mode 100644 index 00000000..ef478e59 --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icquserinfowidget.h @@ -0,0 +1,58 @@ +/* + Kopete Oscar Protocol + icquserinfowidget.h - Display ICQ user info + + Copyright (c) 2005 Matt Rogers + + Kopete (c) 2002-2005 by the Kopete developers + + ************************************************************************* + * * + * 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 _ICQUSERINFOWIDGET_H_ +#define _ICQUSERINFOWIDGET_H_ + +#include +#include + +class KJanusWidget; +class ICQGeneralInfoWidget; +class ICQWorkInfoWidget; +class ICQOtherInfoWidget; +class ICQInterestInfoWidget; +class ICQContact; + +class ICQUserInfoWidget : public KDialogBase +{ +Q_OBJECT +public: + ICQUserInfoWidget( QWidget* parent = 0, const char* name = 0 ); + void setContact( ICQContact* contact ); + +public slots: + void fillBasicInfo( const ICQGeneralUserInfo& ); + void fillWorkInfo( const ICQWorkUserInfo& ); + void fillEmailInfo( const ICQEmailInfo& ); + void fillMoreInfo( const ICQMoreUserInfo& ); + void fillInterestInfo( const ICQInterestInfo& ); + +private: + ICQGeneralInfoWidget* m_genInfoWidget; + ICQWorkInfoWidget* m_workInfoWidget; + ICQOtherInfoWidget* m_otherInfoWidget; + ICQInterestInfoWidget * m_interestInfoWidget; + KJanusWidget* m_janusWidget; + ICQContact* m_contact; + +}; + +#endif + +//kate: indent-mode csands; tab-width 4; space-indent off; replace-tabs off; diff --git a/kopete/protocols/oscar/icq/ui/icqworkinfowidget.ui b/kopete/protocols/oscar/icq/ui/icqworkinfowidget.ui new file mode 100644 index 00000000..a31021ba --- /dev/null +++ b/kopete/protocols/oscar/icq/ui/icqworkinfowidget.ui @@ -0,0 +1,249 @@ + +ICQWorkInfoWidget + + + ICQWorkInfoWidget + + + + 0 + 0 + 328 + 480 + + + + + unnamed + + + + groupBox2 + + + Personal Work Information + + + + unnamed + + + + textLabel10 + + + Phone: + + + + + textLabel11 + + + Fax: + + + + + textLabel6 + + + Department: + + + + + departmentEdit + + + true + + + + + textLabel7 + + + Position: + + + + + positionEdit + + + true + + + + + phoneEdit + + + true + + + + + faxEdit + + + true + + + + + + + buttonGroup1 + + + Company Location Information + + + + unnamed + + + + textLabel1 + + + Name: + + + + + textLabel8 + + + Homepage: + + + + + textLabel2 + + + Address: + + + + + textLabel4 + + + Zip: + + + + + textLabel5 + + + State: + + + + + textLabel3 + + + City: + + + + + textLabel9 + + + + 5 + 5 + 0 + 0 + + + + Country: + + + + + companyEdit + + + true + + + + + homepageEdit + + + true + + + + + addressEdit + + + true + + + + + cityEdit + + + true + + + + + stateEdit + + + true + + + + + zipEdit + + + true + + + + + countryEdit + + + true + + + + + + + spacer2 + + + Vertical + + + Expanding + + + + 20 + 70 + + + + + + + -- cgit v1.2.1