author | harlekin <harlekin> | 2003-12-13 13:45:40 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2003-12-13 13:45:40 (UTC) |
commit | e1dc235a829398482dddc66b931d6eec840382ec (patch) (side-by-side diff) | |
tree | b4a93390a382eb9ce2f9c9a3703e4f03c3e475e0 | |
parent | 865b023c57f657c8eff26baa670fc76bbcd548e4 (diff) | |
download | opie-e1dc235a829398482dddc66b931d6eec840382ec.zip opie-e1dc235a829398482dddc66b931d6eec840382ec.tar.gz opie-e1dc235a829398482dddc66b931d6eec840382ec.tar.bz2 |
beginning of attachment handling ( user side )
-rw-r--r-- | noncore/net/mail/mainwindow.cpp | 6 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.cpp | 52 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.h | 2 |
3 files changed, 57 insertions, 3 deletions
diff --git a/noncore/net/mail/mainwindow.cpp b/noncore/net/mail/mainwindow.cpp index f0a915d..560715c 100644 --- a/noncore/net/mail/mainwindow.cpp +++ b/noncore/net/mail/mainwindow.cpp @@ -164,10 +164,10 @@ void MainWindow::displayMail(QListViewItem*item) readMail.exec(); ( (MailListViewItem*)item )->setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgunseen") ); } -MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * after ) - :QListViewItem(parent,after),mail_data() +MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) + :QListViewItem(parent,item),mail_data() { } void MailListViewItem::showEntry() @@ -190,4 +190,6 @@ void MailListViewItem::storeData(const RecMail&data) const RecMail& MailListViewItem::data()const { return mail_data; } + + diff --git a/noncore/net/mail/viewmail.cpp b/noncore/net/mail/viewmail.cpp index 39c9820..c24d5d3 100644 --- a/noncore/net/mail/viewmail.cpp +++ b/noncore/net/mail/viewmail.cpp @@ -1,10 +1,13 @@ #include <qtextbrowser.h> #include <qmessagebox.h> #include <qtextstream.h> #include <qaction.h> +#include <qpopupmenu.h> #include <qapplication.h> +#include <opie/ofiledialog.h> + #include "settings.h" #include "composemail.h" #include "viewmail.h" @@ -15,11 +18,11 @@ AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mi setText(1, file); setText(2, desc); } - void ViewMail::setBody( RecBody body ) { +m_body = body; m_mail[2] = body.Bodytext(); attachbutton->setEnabled(body.Parts().count()>0); attachments->setEnabled(body.Parts().count()>0); if (body.Parts().count()==0) { @@ -97,8 +100,50 @@ for (unsigned int i = 0; i < body.Parts().count();++i) { curItem=new AttachItem(attachments,curItem,type,filename,desc,i); } } +void ViewMail::slotItemClicked( QListViewItem * item , const QPoint & point, int c ) { + if (!item ) + return; + + QPopupMenu *menu = new QPopupMenu(); + int ret=0; + + if ( item->text( 0 ).left( 4 ) == "text" ) { + menu->insertItem( tr( "Show Text" ), 1 ); + } + menu->insertItem( tr( "Save Attachemt" ), 0 ); + menu->insertSeparator(1); + + ret = menu->exec( point, 0 ); + + switch(ret) { + case 0: + { MimeTypes types; + types.insert( "all", "*" ); + QString str = OFileDialog::getSaveFileName( 1, + "/", item->text( 1 ) , types, 0 ); + + if( !str.isEmpty() ) { + qDebug( " first we will need a MIME wrapper" ); + } + } + break ; + + case 1: + + qDebug( QString( "Test selected" ).arg( ( ( AttachItem* )item )->Partnumber() ) ); + if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { + setText(); + } else { + browser->setText( ( m_body.Parts()[( ( AttachItem* )item )->Partnumber() ] ).Identifier() ); + } + break; + } + delete menu; +} + + void ViewMail::setMail( RecMail mail ) { m_mail[0] = mail.getFrom(); m_mail[1] = mail.getSubject(); @@ -122,8 +167,10 @@ ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) connect(reply, SIGNAL(activated()), SLOT(slotReply())); connect(forward, SIGNAL(activated()), SLOT(slotForward())); attachments->setEnabled(m_gotBody); + connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) ); + } void ViewMail::setText() { @@ -171,9 +218,11 @@ void ViewMail::hide() if (_inLoop) { _inLoop = false; qApp->exit_loop(); + } + } void ViewMail::exec() { @@ -182,8 +231,9 @@ void ViewMail::exec() if (!_inLoop) { _inLoop = true; qApp->enter_loop(); } + } QString ViewMail::deHtml(const QString &string) { diff --git a/noncore/net/mail/viewmail.h b/noncore/net/mail/viewmail.h index b497434..0e85839 100644 --- a/noncore/net/mail/viewmail.h +++ b/noncore/net/mail/viewmail.h @@ -37,13 +37,15 @@ protected: protected slots: void slotReply(); void slotForward(); void setText(); + void slotItemClicked( QListViewItem * item , const QPoint & point, int c ); private: bool _inLoop; QString m_mailHtml; bool m_gotBody; + RecBody m_body; // 0 from 1 subject 2 bodytext 3 date QMap <int,QString> m_mail; // 0 to 1 cc 2 bcc |