-rw-r--r-- | noncore/net/mail/mainwindow.cpp | 6 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.cpp | 56 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.h | 2 |
3 files changed, 59 insertions, 5 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 @@ -166,6 +166,6 @@ void MainWindow::displayMail(QListViewItem*item) } -MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * after ) - :QListViewItem(parent,after),mail_data() +MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) + :QListViewItem(parent,item),mail_data() { } @@ -192,2 +192,4 @@ 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 @@ -3,6 +3,9 @@ #include <qtextstream.h> #include <qaction.h> +#include <qpopupmenu.h> #include <qapplication.h> +#include <opie/ofiledialog.h> + #include "settings.h" #include "composemail.h" @@ -17,7 +20,7 @@ AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mi } - void ViewMail::setBody( RecBody body ) { +m_body = body; m_mail[2] = body.Bodytext(); attachbutton->setEnabled(body.Parts().count()>0); @@ -53,5 +56,5 @@ default: { /* I did not found a method to make a CONTENT reset on a QTextStream - so I use this construct that the stream will re-constructed in each + so I use this construct that the stream will re-constructed in each loop. To let it work, the textstream is packed into a own area of code is it will be destructed after finishing its small job. @@ -99,4 +102,46 @@ for (unsigned int i = 0; i < body.Parts().count();++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 ) { @@ -124,4 +169,6 @@ ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) attachments->setEnabled(m_gotBody); + connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) ); + } @@ -173,5 +220,7 @@ void ViewMail::hide() _inLoop = false; qApp->exit_loop(); - } + + } + } @@ -184,4 +233,5 @@ void ViewMail::exec() qApp->enter_loop(); } + } 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 @@ -39,4 +39,5 @@ protected slots: void slotForward(); void setText(); + void slotItemClicked( QListViewItem * item , const QPoint & point, int c ); private: @@ -44,4 +45,5 @@ private: QString m_mailHtml; bool m_gotBody; + RecBody m_body; // 0 from 1 subject 2 bodytext 3 date |