summaryrefslogtreecommitdiffstats
path: root/kmail/kmlineeditspell.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch)
tree67208f7c145782a7e90b123b982ca78d88cc2c87 /kmail/kmlineeditspell.cpp
downloadtdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz
tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.zip
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/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kmail/kmlineeditspell.cpp')
-rw-r--r--kmail/kmlineeditspell.cpp216
1 files changed, 216 insertions, 0 deletions
diff --git a/kmail/kmlineeditspell.cpp b/kmail/kmlineeditspell.cpp
new file mode 100644
index 000000000..ca315dea1
--- /dev/null
+++ b/kmail/kmlineeditspell.cpp
@@ -0,0 +1,216 @@
+// -*- mode: C++; c-file-style: "gnu" -*-
+// kmcomposewin.cpp
+// Author: Markus Wuebben <markus.wuebben@kde.org>
+// This code is published under the GPL.
+
+#include "kmlineeditspell.h"
+
+#include "recentaddresses.h"
+#include "kmkernel.h"
+#include "globalsettings.h"
+
+#include <libkdepim/kvcarddrag.h>
+#include <libemailfunctions/email.h>
+
+#include <kabc/vcardconverter.h>
+#include <kio/netaccess.h>
+
+#include <kpopupmenu.h>
+#include <kurl.h>
+#include <kurldrag.h>
+#include <kmessagebox.h>
+#include <kcompletionbox.h>
+#include <klocale.h>
+
+#include <qevent.h>
+#include <qfile.h>
+#include <qcstring.h>
+#include <qcursor.h>
+
+
+KMLineEdit::KMLineEdit(bool useCompletion,
+ QWidget *parent, const char *name)
+ : KPIM::AddresseeLineEdit(parent,useCompletion,name)
+{
+ allowSemiColonAsSeparator( GlobalSettings::allowSemicolonAsAddressSeparator() );
+}
+
+
+//-----------------------------------------------------------------------------
+void KMLineEdit::keyPressEvent(QKeyEvent *e)
+{
+ if ((e->key() == Key_Enter || e->key() == Key_Return) &&
+ !completionBox()->isVisible())
+ {
+ emit focusDown();
+ AddresseeLineEdit::keyPressEvent(e);
+ return;
+ }
+ if (e->key() == Key_Up)
+ {
+ emit focusUp();
+ return;
+ }
+ if (e->key() == Key_Down)
+ {
+ emit focusDown();
+ return;
+ }
+ AddresseeLineEdit::keyPressEvent(e);
+}
+
+
+void KMLineEdit::insertEmails( const QStringList & emails )
+{
+ if ( emails.empty() )
+ return;
+
+ QString contents = text();
+ if ( !contents.isEmpty() )
+ contents += ',';
+ // only one address, don't need kpopup to choose
+ if ( emails.size() == 1 ) {
+ setText( contents + emails.front() );
+ return;
+ }
+ //multiple emails, let the user choose one
+ KPopupMenu menu( this, "Addresschooser" );
+ for ( QStringList::const_iterator it = emails.begin(), end = emails.end() ; it != end; ++it )
+ menu.insertItem( *it );
+ const int result = menu.exec( QCursor::pos() );
+ if ( result < 0 )
+ return;
+ setText( contents + menu.text( result ) );
+}
+
+void KMLineEdit::dropEvent(QDropEvent *event)
+{
+ QString vcards;
+ KVCardDrag::decode( event, vcards );
+ if ( !vcards.isEmpty() ) {
+ KABC::VCardConverter converter;
+ KABC::Addressee::List list = converter.parseVCards( vcards );
+ KABC::Addressee::List::Iterator ait;
+ for ( ait = list.begin(); ait != list.end(); ++ait ){
+ insertEmails( (*ait).emails() );
+ }
+ } else {
+ KURL::List urls;
+ if ( KURLDrag::decode( event, urls) ) {
+ //kdDebug(5006) << "urlList" << endl;
+ KURL::List::Iterator it = urls.begin();
+ KABC::VCardConverter converter;
+ KABC::Addressee::List list;
+ QString fileName;
+ QString caption( i18n( "vCard Import Failed" ) );
+ for ( it = urls.begin(); it != urls.end(); ++it ) {
+ if ( KIO::NetAccess::download( *it, fileName, parentWidget() ) ) {
+ QFile file( fileName );
+ file.open( IO_ReadOnly );
+ QByteArray rawData = file.readAll();
+ file.close();
+ QString data = QString::fromUtf8( rawData.data(), rawData.size() + 1 );
+ list += converter.parseVCards( data );
+ KIO::NetAccess::removeTempFile( fileName );
+ } else {
+ QString text = i18n( "<qt>Unable to access <b>%1</b>.</qt>" );
+ KMessageBox::error( parentWidget(), text.arg( (*it).url() ), caption );
+ }
+ KABC::Addressee::List::Iterator ait;
+ for ( ait = list.begin(); ait != list.end(); ++ait )
+ insertEmails((*ait).emails());
+ }
+ } else {
+ KPIM::AddresseeLineEdit::dropEvent( event );
+ }
+ }
+}
+
+QPopupMenu *KMLineEdit::createPopupMenu()
+{
+ QPopupMenu *menu = KPIM::AddresseeLineEdit::createPopupMenu();
+ if ( !menu )
+ return 0;
+
+ menu->insertSeparator();
+ menu->insertItem( i18n( "Edit Recent Addresses..." ),
+ this, SLOT( editRecentAddresses() ) );
+
+ return menu;
+}
+
+void KMLineEdit::editRecentAddresses()
+{
+ KRecentAddress::RecentAddressDialog dlg( this );
+ dlg.setAddresses( KRecentAddress::RecentAddresses::self( KMKernel::config() )->addresses() );
+ if ( !dlg.exec() )
+ return;
+ KRecentAddress::RecentAddresses::self( KMKernel::config() )->clear();
+ const QStringList addrList = dlg.addresses();
+ for ( QStringList::const_iterator it = addrList.begin(), end = addrList.end() ; it != end ; ++it )
+ KRecentAddress::RecentAddresses::self( KMKernel::config() )->add( *it );
+ loadContacts();
+}
+
+
+//-----------------------------------------------------------------------------
+void KMLineEdit::loadContacts()
+{
+ // was: KABC::AddressLineEdit::loadAddresses()
+ AddresseeLineEdit::loadContacts();
+
+ if ( GlobalSettings::self()->showRecentAddressesInComposer() ){
+ if ( KMKernel::self() ) {
+ QStringList recent =
+ KRecentAddress::RecentAddresses::self( KMKernel::config() )->addresses();
+ QStringList::Iterator it = recent.begin();
+ QString name, email;
+ int idx = addCompletionSource( i18n( "Recent Addresses" ) );
+ for ( ; it != recent.end(); ++it ) {
+ KABC::Addressee addr;
+ KPIM::getNameAndMail(*it, name, email);
+ addr.setNameFromString( KPIM::quoteNameIfNecessary( name ));
+ addr.insertEmail( email, true );
+ addContact( addr, 120, idx ); // more weight than kabc entries and more than ldap results
+ }
+ }
+ }
+}
+
+
+KMLineEditSpell::KMLineEditSpell(bool useCompletion,
+ QWidget *parent, const char *name)
+ : KMLineEdit(useCompletion,parent,name)
+{
+}
+
+
+void KMLineEditSpell::highLightWord( unsigned int length, unsigned int pos )
+{
+ setSelection ( pos, length );
+}
+
+void KMLineEditSpell::spellCheckDone( const QString &s )
+{
+ if( s != text() )
+ setText( s );
+}
+
+void KMLineEditSpell::spellCheckerMisspelling( const QString &_text, const QStringList&, unsigned int pos)
+{
+ highLightWord( _text.length(),pos );
+}
+
+void KMLineEditSpell::spellCheckerCorrected( const QString &old, const QString &corr, unsigned int pos)
+{
+ if( old!= corr )
+ {
+ setSelection ( pos, old.length() );
+ insert( corr );
+ setSelection ( pos, corr.length() );
+ emit subjectTextSpellChecked();
+ }
+}
+
+
+#include "kmlineeditspell.moc"