Diffstat (limited to 'noncore/unsupported/mail2/viewmail.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r-- | noncore/unsupported/mail2/viewmail.cpp | 172 |
1 files changed, 172 insertions, 0 deletions
diff --git a/noncore/unsupported/mail2/viewmail.cpp b/noncore/unsupported/mail2/viewmail.cpp new file mode 100644 index 0000000..ae1f5f3 --- a/dev/null +++ b/noncore/unsupported/mail2/viewmail.cpp @@ -0,0 +1,172 @@ +#include <qtextbrowser.h> +#include <qmessagebox.h> +#include <qaction.h> + +#include "mailfactory.h" +#include "composer.h" +#include "viewmail.h" + +AttachItem::AttachItem(QListView *parent, AttachItemStore &attachItemStore) + : QListViewItem(parent), _attachItemStore(attachItemStore) +{ + setText(0, _attachItemStore.mimeType()); + setText(1, _attachItemStore.fileName()); + setText(2, _attachItemStore.description()); +} + +AttachItem::AttachItem(QListViewItem *parent, AttachItemStore &attachItemStore) + : QListViewItem(parent), _attachItemStore(attachItemStore) +{ + setText(0, _attachItemStore.mimeType()); + setText(1, _attachItemStore.fileName()); + setText(2, _attachItemStore.description()); +} + +ViewMail::ViewMail(IMAPResponseFETCH &mail, IMAPHandler *handler, QWidget *parent, const char *name, WFlags fl) + : ViewMailBase(parent, name, fl), _mail(mail), _handler(handler) +{ + setCaption(caption().arg(mail.envelope().from()[0].name())); + + _gotBody = false; + _mailHtml = tr( + "<html><body>" + "<div align=center><b>%1</b></div>" + "<b>From:</b> %2<br>" + "<b>To:</b> %3<br>" + "%4" + "%5" + "<b>Date:</b> %6<hr>" + "<font face=fixed>%7</font>") + .arg(deHtml(mail.envelope().subject().isNull() ? tr("(no subject)") + : deHtml(mail.envelope().subject()))) + .arg(deHtml(mail.envelope().from().toString().isNull() ? tr("(no from)") + : mail.envelope().from().toString())) + .arg(deHtml(mail.envelope().to().toString().isNull() ? tr("(no recipient)") + : mail.envelope().to().toString())) + .arg(mail.envelope().cc().toString().isNull() ? QString(0) + : tr("<b>Cc:</b> %1<br>").arg(deHtml(mail.envelope().cc().toString()))) + .arg(mail.envelope().bcc().toString().isNull() ? QString(0) + : tr("<b>Bcc:</b> %1<br>").arg(deHtml(mail.envelope().bcc().toString()))) + .arg(mail.envelope().mailDate().isNull() ? tr("(no date)") + : mail.envelope().mailDate()) + .arg("%1"); + + connect(reply, SIGNAL(activated()), SLOT(slotReply())); + connect(forward, SIGNAL(activated()), SLOT(slotForward())); + + attachments->setEnabled(_gotBody); + browser->setText(QString(_mailHtml).arg(tr("Getting mail body from server. Please wait..."))); + + _handler->iUid("FETCH", QString("%1 (BODY[1])").arg(mail.uid())); + connect(_handler, SIGNAL(gotResponse(IMAPResponse &)), SLOT(slotIMAPUid(IMAPResponse &))); +} + +QString ViewMail::deHtml(const QString &string) +{ + QString string_ = string; + string_.replace(QRegExp("&"), "&"); + string_.replace(QRegExp("<"), "<"); + string_.replace(QRegExp(">"), ">"); + string_.replace(QRegExp("\\n"), "<br>"); + return string_; +} + +void ViewMail::slotReply() +{ + if (!_gotBody) { + QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); + return; + } + + QString rtext; + rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose + .arg(_mail.envelope().from()[0].toString()) + .arg(_mail.envelope().mailDate()); + + QString text = _mail.bodyPart(1).data(); + QStringList lines = QStringList::split(QRegExp("\\n"), text); + QStringList::Iterator it; + for (it = lines.begin(); it != lines.end(); it++) { + rtext += "> " + *it + "\n"; + } + rtext += "\n"; + + QString prefix; + if (_mail.envelope().subject().find(QRegExp("^Re: *$")) != -1) prefix = ""; + else prefix = "Re: "; // no i18n on purpose + + SendMail sendMail; + sendMail.setTo(_mail.envelope().from()[0].toString()); + sendMail.setSubject(prefix + _mail.envelope().subject()); + sendMail.setInReplyTo(_mail.envelope().messageId()); + sendMail.setMessage(rtext); + + Composer *composer = new Composer(0, 0, Qt::WType_Modal); + composer->setSendMail(sendMail); + composer->showMaximized(); + composer->show(); +} + +void ViewMail::slotForward() +{ + if (!_gotBody) { + QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot forward yet."), tr("Ok")); + return; + } + + QString ftext; + ftext += QString("\n----- Forwarded message from %1 -----\n\n") + .arg(_mail.envelope().from()[0].toString()); + if (!_mail.envelope().mailDate().isNull()) + ftext += QString("Date: %1\n") + .arg(_mail.envelope().mailDate()); + if (!_mail.envelope().from()[0].toString().isNull()) + ftext += QString("From: %1\n") + .arg(_mail.envelope().from()[0].toString()); + if (!_mail.envelope().to().toString().isNull()) + ftext += QString("To: %1\n") + .arg(_mail.envelope().to().toString()); + if (!_mail.envelope().cc().toString().isNull()) + ftext += QString("Cc: %1\n") + .arg(_mail.envelope().cc().toString()); + if (!_mail.envelope().bcc().toString().isNull()) + ftext += QString("Bcc: %1\n") + .arg(_mail.envelope().bcc().toString()); + if (!_mail.envelope().subject().isNull()) + ftext += QString("Subject: %1\n") + .arg(_mail.envelope().subject()); + + ftext += QString("\n%1\n") + .arg(_mail.bodyPart(1).data()); + + ftext += QString("----- End forwarded message -----\n"); + + SendMail sendMail; + sendMail.setSubject("Fwd: " + _mail.envelope().subject()); + sendMail.setMessage(ftext); + + Composer *composer = new Composer(0, 0, Qt::WType_Modal); + composer->setSendMail(sendMail); + composer->showMaximized(); + composer->show(); +} + +void ViewMail::slotIMAPUid(IMAPResponse &response) +{ + disconnect(_handler, SIGNAL(gotResponse(IMAPResponse &)), this, SLOT(slotIMAPUid(IMAPResponse &))); + + if (response.statusResponse().status() == IMAPResponseEnums::OK) { + QValueList<IMAPResponseBodyPart> bodyParts; + bodyParts.append(response.FETCH()[0].bodyPart(1)); + _mail.setBodyParts(bodyParts); + + browser->setText(QString(_mailHtml).arg(deHtml(response.FETCH()[0].bodyPart(1).data()))); + +// fillList(response.FETCH()[0].bodyStructure()); + + _gotBody = true; + } else { + QMessageBox::warning(this, tr("Error"), tr("<p>I was unable to retrieve the mail from the server. You can try again later or give up.</p>"), tr("Ok")); + } +} + |