summaryrefslogtreecommitdiffabout
path: root/kmicromail/opiemail.cpp
authorzautrix <zautrix>2004-07-03 16:33:12 (UTC)
committer zautrix <zautrix>2004-07-03 16:33:12 (UTC)
commite3b89230f065c48c84b48c88edb6eb088374c487 (patch) (side-by-side diff)
tree162ea2ef909a6f82ccfcedf45d80d6c821174912 /kmicromail/opiemail.cpp
parent2dd6ac0b2d24c91d35ce674a6c26351352df2b15 (diff)
downloadkdepimpi-e3b89230f065c48c84b48c88edb6eb088374c487.zip
kdepimpi-e3b89230f065c48c84b48c88edb6eb088374c487.tar.gz
kdepimpi-e3b89230f065c48c84b48c88edb6eb088374c487.tar.bz2
Initial revision
Diffstat (limited to 'kmicromail/opiemail.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--kmicromail/opiemail.cpp363
1 files changed, 363 insertions, 0 deletions
diff --git a/kmicromail/opiemail.cpp b/kmicromail/opiemail.cpp
new file mode 100644
index 0000000..b1992ec
--- a/dev/null
+++ b/kmicromail/opiemail.cpp
@@ -0,0 +1,363 @@
+
+#include "settingsdialog.h"
+#include "opiemail.h"
+#include "editaccounts.h"
+#include "composemail.h"
+#include "mailistviewitem.h"
+#include "viewmail.h"
+#include "selectstore.h"
+#include "selectsmtp.h"
+
+#include <qmessagebox.h>
+
+#include <qpe/qpeapplication.h>
+#include <libmailwrapper/smtpwrapper.h>
+#include <libmailwrapper/mailtypes.h>
+#include <libmailwrapper/abstractmail.h>
+/* OPIE */
+//#include <qpe/resource.h>
+#include <qpe/qpeapplication.h>
+
+/* QT */
+
+using namespace Opie::Core;
+
+OpieMail::OpieMail( QWidget *parent, const char *name, WFlags flags )
+ : MainWindow( parent, name, WStyle_ContextHelp )
+{
+ settings = new Settings();
+
+ folderView->populate( settings->getAccounts() );
+
+}
+
+OpieMail::~OpieMail()
+{
+ if (settings) delete settings;
+}
+
+void OpieMail::appMessage(const QCString &msg, const QByteArray &data)
+{
+
+}
+#include <stdlib.h>
+void OpieMail::message(const QCString &msg, const QByteArray &data)
+{
+ // copied from old mail2
+ static int ii = 0;
+
+ // block second call
+ if ( ii < 2 ) {
+ ++ii;
+ if ( ii > 1 ) {
+ qDebug("qcop call blocked ");
+ return;
+ }
+ }
+ //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this);
+ if (msg == "writeMail(QString,QString)")
+ {
+ QDataStream stream(data,IO_ReadOnly);
+ QString name, email;
+ stream >> name >> email;
+ // removing the whitespaces at beginning and end is needed!
+ slotwriteMail(name.stripWhiteSpace(),email.stripWhiteSpace());
+ }
+ else if (msg == "newMail()")
+ {
+ slotComposeMail();
+ }
+ else if (msg == "newMail(QString)")
+ {
+ QDataStream stream(data,IO_ReadOnly);
+ QString nameemail;
+ stream >> nameemail;
+ // the format is
+ // NAME <EMAIL>:SUBJECT
+ //qDebug("message %s ", nameemail.latin1());
+
+ slotwriteMail2( nameemail );
+ }
+}
+void OpieMail::slotwriteMail2(const QString& namemail )
+{
+ // qDebug("OpieMail::slotwriteMail2 ");
+ qApp->processEvents();
+ ComposeMail compose( settings, this, 0, true );
+ if ( !namemail.isEmpty() ) {
+ QString to = namemail;
+ if ( namemail.find( " <") > 1 ) {
+ to = "\"" +to.replace( QRegExp( " <"), "\" <") ;
+ } else
+ if ( namemail.find( "<") > 1 ) {
+ to = "\"" +to.replace( QRegExp( "<"), "\" <") ;
+ }
+ int sub = to.find( ">:");
+ if ( sub > 0 ) {
+ compose.setTo( to.left(sub+1) );
+ compose.setSubject( to.mid(sub+2) );
+ } else
+ compose.setTo( to );
+ }
+ compose.slotAdjustColumns();
+ compose.showMaximized();
+ compose.exec();
+ //qDebug("retttich ");
+}
+void OpieMail::slotwriteMail(const QString&name,const QString&email)
+{
+ // qDebug("OpieMail::slotwriteMail ");
+ ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp );
+ if (!email.isEmpty())
+ {
+ if (!name.isEmpty())
+ {
+ compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">");
+ }
+ else
+ {
+ compose.setTo(email);
+ }
+ }
+ compose.slotAdjustColumns();
+ compose.showMaximized();
+ compose.exec();
+}
+
+void OpieMail::slotComposeMail()
+{
+ slotwriteMail2( QString () );
+ //slotwriteMail(0l,0l);
+}
+
+void OpieMail::slotSendQueued()
+{
+ SMTPaccount *smtp = 0;
+
+ QList<Account> list = settings->getAccounts();
+ QList<SMTPaccount> smtpList;
+ smtpList.setAutoDelete(false);
+ Account *it;
+ for ( it = list.first(); it; it = list.next() )
+ {
+ if ( it->getType() == MAILLIB::A_SMTP )
+ {
+ smtp = static_cast<SMTPaccount *>(it);
+ smtpList.append(smtp);
+ }
+ }
+ if (smtpList.count()==0)
+ {
+ QMessageBox::information(0,tr("Info"),tr("Define a smtp account first"));
+ return;
+ }
+ if (smtpList.count()==1)
+ {
+ smtp = smtpList.at(0);
+ }
+ else
+ {
+ smtp = 0;
+ selectsmtp selsmtp;
+ selsmtp.setSelectionlist(&smtpList);
+ selsmtp.showMaximized();
+ if ( selsmtp.exec() == QDialog::Accepted )
+ {
+ smtp = selsmtp.selected_smtp();
+ }
+ }
+ if (smtp)
+ {
+ SMTPwrapper * wrap = new SMTPwrapper(smtp);
+ if ( wrap->flushOutbox() )
+ {
+ QMessageBox::information(0,tr("Info"),tr("Mail queue flushed"));
+ }
+ delete wrap;
+ }
+}
+
+void OpieMail::slotSearchMails()
+{
+ qDebug("OpieMail::slotSearchMails():not implemented ");
+}
+
+void OpieMail::slotEditSettings()
+{
+ SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp );
+ settingsDialog.showMaximized();
+ settingsDialog.exec();
+}
+
+void OpieMail::slotEditAccounts()
+{
+ EditAccounts eaDialog( settings, this, 0, true, WStyle_ContextHelp );
+ eaDialog.slotAdjustColumns();
+ eaDialog.showMaximized();
+ eaDialog.exec();
+ if ( settings ) delete settings;
+ settings = new Settings();
+
+ folderView->populate( settings->getAccounts() );
+}
+
+void OpieMail::displayMail()
+{
+ QListViewItem*item = mailView->currentItem();
+ if (!item) return;
+ RecMailP mail = ((MailListViewItem*)item)->data();
+ RecBodyP body = folderView->fetchBody(mail);
+ ViewMail readMail( this,"", Qt::WType_Modal | WStyle_ContextHelp );
+ readMail.setBody( body );
+ readMail.setMail( mail );
+ readMail.showMaximized();
+ readMail.exec();
+
+ if ( readMail.deleted )
+ {
+ folderView->refreshCurrent();
+ }
+ else
+ {
+ ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() );
+ }
+}
+
+void OpieMail::slotDeleteMail()
+{
+ if (!mailView->currentItem()) return;
+ RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data();
+ if ( QMessageBox::warning(this, tr("Delete Mail"), QString( tr("<p>Do you really want to delete this mail? <br><br>" ) + mail->getFrom() + " - " + mail->getSubject() ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes )
+ {
+ mail->Wrapper()->deleteMail( mail );
+ folderView->refreshCurrent();
+ }
+}
+void OpieMail::slotDeleteAllMail()
+{
+ if (!mailView->currentItem()) return;
+ RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data();
+ if ( QMessageBox::warning(this, tr("Delete All Mails"), tr("Do you really want to delete\nall selected mails?" ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes )
+ {
+ MailListViewItem* item = (MailListViewItem*)mailView->firstChild ();
+ while ( item ) {
+ if ( item->isSelected() ) {
+ RecMailP mail = item->data();
+ mail->Wrapper()->deleteMail( mail );
+ }
+ item = (MailListViewItem*)item->nextSibling();
+ }
+ folderView->refreshCurrent();
+ }
+}
+void OpieMail::clearSelection()
+{
+ mailView->clearSelection();
+
+}
+
+void OpieMail::mailHold(int button, QListViewItem *item,const QPoint&,int )
+{
+ if (!mailView->currentItem()) return;
+ MAILLIB::ATYPE mailtype = ((MailListViewItem*)mailView->currentItem() )->wrapperType();
+ /* just the RIGHT button - or hold on pda */
+ if (button!=2) {return;}
+ if (!item) return;
+ QPopupMenu *m = new QPopupMenu(0);
+ if (m)
+ {
+ if (mailtype==MAILLIB::A_NNTP) {
+ m->insertItem(tr("Read this posting"),this,SLOT(displayMail()));
+// m->insertItem(tr("Copy this posting"),this,SLOT(slotMoveCopyMail()));
+ } else {
+ if (folderView->currentisDraft()) {
+ m->insertItem(tr("Edit this mail"),this,SLOT(reEditMail()));
+ }
+ m->insertItem(tr("Read this mail"),this,SLOT(displayMail()));
+ m->insertItem(tr("Copy/Move this mail"),this,SLOT(slotMoveCopyMail()));
+ m->insertItem(tr("Delete this mail"),this,SLOT(slotDeleteMail()));
+ m->insertSeparator();
+ m->insertItem(tr("Delete all selected mails"),this,SLOT(slotDeleteAllMail()));
+ m->insertItem(tr("Clear selection"),this,SLOT(clearSelection()));
+ }
+ m->setFocus();
+ m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) );
+ delete m;
+ }
+}
+
+void OpieMail::slotShowFolders( bool show )
+{
+ if ( show && folderView->isHidden() )
+ {
+ folderView->show();
+ }
+ else if ( !show && !folderView->isHidden() )
+ {
+ folderView->hide();
+ }
+}
+
+void OpieMail::refreshMailView(const QValueList<RecMailP>&list)
+{
+ MailListViewItem*item = 0;
+ mailView->clear();
+
+ QValueList<RecMailP>::ConstIterator it;
+ for (it = list.begin(); it != list.end();++it)
+ {
+ item = new MailListViewItem(mailView,item);
+ item->storeData((*it));
+ item->showEntry();
+ }
+}
+
+void OpieMail::mailLeftClicked( QListViewItem *item )
+{
+ mailView->clearSelection();
+ /* just LEFT button - or tap with stylus on pda */
+ //if (button!=1) return;
+ if (!item) return;
+ if (folderView->currentisDraft()) {
+ reEditMail();
+ } else {
+ displayMail();
+ }
+}
+
+void OpieMail::slotMoveCopyMail()
+{
+ if (!mailView->currentItem()) return;
+ RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data();
+ AbstractMail*targetMail = 0;
+ QString targetFolder = "";
+ Selectstore sels;
+ folderView->setupFolderselect(&sels);
+ if (!sels.exec()) return;
+ targetMail = sels.currentMail();
+ targetFolder = sels.currentFolder();
+ if ( (mail->Wrapper()==targetMail && mail->getMbox()==targetFolder) ||
+ targetFolder.isEmpty())
+ {
+ return;
+ }
+ if (sels.newFolder() && !targetMail->createMbox(targetFolder))
+ {
+ QMessageBox::critical(0,tr("Error creating new Folder"),
+ tr("<center>Error while creating<br>new folder - breaking.</center>"));
+ return;
+ }
+ mail->Wrapper()->mvcpMail(mail,targetFolder,targetMail,sels.moveMails());
+ folderView->refreshCurrent();
+}
+
+void OpieMail::reEditMail()
+{
+ if (!mailView->currentItem()) return;
+
+ ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp );
+ compose.reEditMail(((MailListViewItem*)mailView->currentItem() )->data());
+ compose.slotAdjustColumns();
+ compose.showMaximized();
+ compose.exec();
+}