summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/mail.pro12
-rw-r--r--noncore/net/mail/mainwindow.cpp24
-rw-r--r--noncore/net/mail/mainwindow.h3
-rw-r--r--noncore/net/mail/opiemail.cpp2
-rw-r--r--noncore/net/mail/viewmail.cpp91
-rw-r--r--noncore/net/mail/viewmail.h5
-rw-r--r--noncore/net/mail/viewmailbase.cpp5
-rw-r--r--noncore/net/mail/viewmailbase.h3
8 files changed, 101 insertions, 44 deletions
diff --git a/noncore/net/mail/mail.pro b/noncore/net/mail/mail.pro
index d058db7..49be889 100644
--- a/noncore/net/mail/mail.pro
+++ b/noncore/net/mail/mail.pro
@@ -1,58 +1,64 @@
1 CONFIG += qt warn_on debug quick-app 1 CONFIG += qt warn_on debug quick-app
2 2
3 HEADERS = defines.h \ 3 HEADERS = defines.h \
4 logindialog.h \ 4 logindialog.h \
5 settings.h \ 5 settings.h \
6 editaccounts.h \ 6 editaccounts.h \
7 mailwrapper.h \ 7 mailwrapper.h \
8 composemail.h \ 8 composemail.h \
9 accountview.h \ 9 accountview.h \
10 mainwindow.h \ 10 mainwindow.h \
11 viewmail.h \ 11 viewmail.h \
12 viewmailbase.h \ 12 viewmailbase.h \
13 opiemail.h \ 13 opiemail.h \
14 imapwrapper.h \ 14 imapwrapper.h \
15 mailtypes.h \ 15 mailtypes.h \
16 mailistviewitem.h \ 16 mailistviewitem.h \
17 pop3wrapper.h \ 17 pop3wrapper.h \
18 abstractmail.h 18 abstractmail.h \
19 settingsdialog.h \
20 statuswidget.h
19 21
20 SOURCES = main.cpp \ 22 SOURCES = main.cpp \
21 opiemail.cpp \ 23 opiemail.cpp \
22 mainwindow.cpp \ 24 mainwindow.cpp \
23 accountview.cpp \ 25 accountview.cpp \
24 composemail.cpp \ 26 composemail.cpp \
25 mailwrapper.cpp \ 27 mailwrapper.cpp \
26 imapwrapper.cpp \ 28 imapwrapper.cpp \
27 addresspicker.cpp \ 29 addresspicker.cpp \
28 editaccounts.cpp \ 30 editaccounts.cpp \
29 logindialog.cpp \ 31 logindialog.cpp \
30 viewmail.cpp \ 32 viewmail.cpp \
31 viewmailbase.cpp \ 33 viewmailbase.cpp \
32 settings.cpp \ 34 settings.cpp \
33 mailtypes.cpp \ 35 mailtypes.cpp \
34 pop3wrapper.cpp \ 36 pop3wrapper.cpp \
35 abstractmail.cpp 37 abstractmail.cpp \
38 settingsdialog.cpp \
39 statuswidget.cpp
36 40
37 INTERFACES = editaccountsui.ui \ 41 INTERFACES = editaccountsui.ui \
38 selectmailtypeui.ui \ 42 selectmailtypeui.ui \
39 imapconfigui.ui \ 43 imapconfigui.ui \
40 pop3configui.ui \ 44 pop3configui.ui \
41 nntpconfigui.ui \ 45 nntpconfigui.ui \
42 smtpconfigui.ui \ 46 smtpconfigui.ui \
43 addresspickerui.ui \ 47 addresspickerui.ui \
44 logindialogui.ui \ 48 logindialogui.ui \
45 composemailui.ui 49 composemailui.ui \
50 settingsdialogui.ui \
51 statuswidgetui.ui
46 52
47INCLUDEPATH += $(OPIEDIR)/include 53INCLUDEPATH += $(OPIEDIR)/include
48 54
49CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX ) 55CONFTEST = $$system( echo $CONFIG_TARGET_MACOSX )
50contains( CONFTEST, y ){ 56contains( CONFTEST, y ){
51 LIBS += -lqpe -letpan -lssl -lcrypto -lopie -liconv 57 LIBS += -lqpe -letpan -lssl -lcrypto -lopie -liconv
52}else{ 58}else{
53 LIBS += -lqpe -letpan -lssl -lcrypto -lopie 59 LIBS += -lqpe -letpan -lssl -lcrypto -lopie
54} 60}
55 61
56TARGET = opiemail 62TARGET = opiemail
57 63
58include ( $(OPIEDIR)/include.pro ) 64include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/net/mail/mainwindow.cpp b/noncore/net/mail/mainwindow.cpp
index 9a37510..d3b9c34 100644
--- a/noncore/net/mail/mainwindow.cpp
+++ b/noncore/net/mail/mainwindow.cpp
@@ -1,246 +1,264 @@
1#include <qlabel.h> 1#include <qlabel.h>
2#include <qvbox.h> 2#include <qvbox.h>
3#include <qheader.h> 3#include <qheader.h>
4#include <qtimer.h> 4#include <qtimer.h>
5#include <qlayout.h> 5#include <qlayout.h>
6#include <qmessagebox.h> 6#include <qmessagebox.h>
7#include <qtextstream.h> 7#include <qtextstream.h>
8 8
9#include <qpe/qpeapplication.h> 9#include <qpe/qpeapplication.h>
10#include <qpe/resource.h> 10#include <qpe/resource.h>
11 11
12#include "defines.h" 12#include "defines.h"
13#include "mainwindow.h" 13#include "mainwindow.h"
14#include "settingsdialog.h"
14#include "viewmail.h" 15#include "viewmail.h"
15#include "mailtypes.h" 16#include "mailtypes.h"
16#include "mailistviewitem.h" 17#include "mailistviewitem.h"
17 18
19
18MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) 20MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags )
19 : QMainWindow( parent, name, flags ) 21 : QMainWindow( parent, name, flags )
20{ 22{
21 setCaption( tr( "Mail" ) ); 23 setCaption( tr( "Mail" ) );
22 setToolBarsMovable( false ); 24 setToolBarsMovable( false );
23 25
24 toolBar = new QToolBar( this ); 26 toolBar = new QToolBar( this );
25 menuBar = new QMenuBar( toolBar ); 27 menuBar = new QMenuBar( toolBar );
26 mailMenu = new QPopupMenu( menuBar ); 28 mailMenu = new QPopupMenu( menuBar );
27 menuBar->insertItem( tr( "Mail" ), mailMenu ); 29 menuBar->insertItem( tr( "Mail" ), mailMenu );
28 settingsMenu = new QPopupMenu( menuBar ); 30 settingsMenu = new QPopupMenu( menuBar );
29 menuBar->insertItem( tr( "Settings" ), settingsMenu ); 31 menuBar->insertItem( tr( "Settings" ), settingsMenu );
30 32
31 addToolBar( toolBar ); 33 addToolBar( toolBar );
32 toolBar->setHorizontalStretchable( true ); 34 toolBar->setHorizontalStretchable( true );
33 35
34 QLabel *spacer = new QLabel( toolBar ); 36 QLabel *spacer = new QLabel( toolBar );
35 spacer->setBackgroundMode( QWidget::PaletteButton ); 37 spacer->setBackgroundMode( QWidget::PaletteButton );
36 toolBar->setStretchableWidget( spacer ); 38 toolBar->setStretchableWidget( spacer );
37 39
38 composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL, 40 composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL,
39 0, 0, this ); 41 0, 0, this );
40 composeMail->addTo( toolBar ); 42 composeMail->addTo( toolBar );
41 composeMail->addTo( mailMenu ); 43 composeMail->addTo( mailMenu );
42 44
43 sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED, 45 sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED,
44 0, 0, this ); 46 0, 0, this );
45 sendQueued->addTo( toolBar ); 47 sendQueued->addTo( toolBar );
46 sendQueued->addTo( mailMenu ); 48 sendQueued->addTo( mailMenu );
47 49
50 /*
48 syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, 51 syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC,
49 0, 0, this ); 52 0, 0, this );
50 syncFolders->addTo( toolBar ); 53 syncFolders->addTo( toolBar );
51 syncFolders->addTo( mailMenu ); 54 syncFolders->addTo( mailMenu );
55 */
52 56
53 showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS, 57 showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS,
54 0, 0, this, 0, true ); 58 0, 0, this, 0, true );
55 showFolders->addTo( toolBar ); 59 showFolders->addTo( toolBar );
56 showFolders->addTo( mailMenu ); 60 showFolders->addTo( mailMenu );
57 showFolders->setOn( true ); 61 showFolders->setOn( true );
58 connect(showFolders, SIGNAL( toggled( bool ) ), 62 connect(showFolders, SIGNAL( toggled( bool ) ),
59 SLOT( slotShowFolders( bool ) ) ); 63 SLOT( slotShowFolders( bool ) ) );
60 64
61 searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS, 65 /*
66 searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS,
62 0, 0, this ); 67 0, 0, this );
63 searchMails->addTo( toolBar ); 68 searchMails->addTo( toolBar );
64 searchMails->addTo( mailMenu ); 69 searchMails->addTo( mailMenu );
70 */
65 71
66 deleteMails = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); 72 deleteMails = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this);
67 deleteMails->addTo( toolBar ); 73 deleteMails->addTo( toolBar );
68 deleteMails->addTo( mailMenu ); 74 deleteMails->addTo( mailMenu );
69 connect( deleteMails, SIGNAL( activated() ), 75 connect( deleteMails, SIGNAL( activated() ),
70 SLOT( slotDeleteMail() ) ); 76 SLOT( slotDeleteMail() ) );
71 77
72 editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS, 78 editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS,
73 0, 0, this ); 79 0, 0, this );
74 editSettings->addTo( settingsMenu ); 80 editSettings->addTo( settingsMenu );
81 connect( editSettings, SIGNAL( activated() ),
82 SLOT( slotEditSettings() ) );
75 83
76 editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS, 84 editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS,
77 0, 0, this ); 85 0, 0, this );
78 editAccounts->addTo( settingsMenu ); 86 editAccounts->addTo( settingsMenu );
79 87
80 QWidget *view = new QWidget( this ); 88 QWidget *view = new QWidget( this );
81 setCentralWidget( view ); 89 setCentralWidget( view );
82 90
83 layout = new QBoxLayout ( view, QBoxLayout::LeftToRight ); 91 layout = new QBoxLayout ( view, QBoxLayout::LeftToRight );
84 92
85 folderView = new AccountView( view ); 93 folderView = new AccountView( view );
86 folderView->header()->hide(); 94 folderView->header()->hide();
87 folderView->setRootIsDecorated( true ); 95 folderView->setRootIsDecorated( true );
88 folderView->addColumn( tr( "Mailbox" ) ); 96 folderView->addColumn( tr( "Mailbox" ) );
89 //folderView->hide(); 97 //folderView->hide();
90 98
91 layout->addWidget( folderView ); 99 layout->addWidget( folderView );
92 100
93 mailView = new QListView( view ); 101 mailView = new QListView( view );
94 mailView->addColumn( tr( "" ) ); 102 mailView->addColumn( tr( "" ) );
95 mailView->addColumn( tr( "Subject" ),QListView::Manual ); 103 mailView->addColumn( tr( "Subject" ),QListView::Manual );
96 mailView->addColumn( tr( "Sender" ),QListView::Manual ); 104 mailView->addColumn( tr( "Sender" ),QListView::Manual );
97 mailView->addColumn( tr( "Size" ),QListView::Manual); 105 mailView->addColumn( tr( "Size" ),QListView::Manual);
98 mailView->addColumn( tr( "Date" )); 106 mailView->addColumn( tr( "Date" ));
99 mailView->setAllColumnsShowFocus(true); 107 mailView->setAllColumnsShowFocus(true);
100 mailView->setSorting(-1); 108 mailView->setSorting(-1);
101 109
110 statusWidget = new StatusWidget( view );
111
102 layout->addWidget( mailView ); 112 layout->addWidget( mailView );
113 layout->addWidget( statusWidget );
103 layout->setStretchFactor( folderView, 1 ); 114 layout->setStretchFactor( folderView, 1 );
104 layout->setStretchFactor( mailView, 2 ); 115 layout->setStretchFactor( mailView, 2 );
105 116
117
106 slotAdjustLayout(); 118 slotAdjustLayout();
107 119
108 connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this, 120 connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this,
109 SLOT( displayMail( QListViewItem * ) ) ); 121 SLOT( displayMail( QListViewItem * ) ) );
110 122
111 connect(folderView, SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*))); 123 connect(folderView, SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*)));
112 124
113 QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); 125 QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) );
114 126
115} 127}
116 128
117 129
118void MainWindow::slotAdjustLayout() { 130void MainWindow::slotAdjustLayout() {
119 131
120 QWidget *d = QApplication::desktop(); 132 QWidget *d = QApplication::desktop();
121 133
122 if ( d->width() < d->height() ) { 134 if ( d->width() < d->height() ) {
123 layout->setDirection( QBoxLayout::TopToBottom ); 135 layout->setDirection( QBoxLayout::TopToBottom );
124 } else { 136 } else {
125 layout->setDirection( QBoxLayout::LeftToRight ); 137 layout->setDirection( QBoxLayout::LeftToRight );
126 } 138 }
127 delete d; 139 delete d;
128} 140}
129 141
130void MainWindow::slotAdjustColumns() 142void MainWindow::slotAdjustColumns()
131{ 143{
132 bool hidden = folderView->isHidden(); 144 bool hidden = folderView->isHidden();
133 if ( hidden ) folderView->show(); 145 if ( hidden ) folderView->show();
134 folderView->setColumnWidth( 0, folderView->visibleWidth() ); 146 folderView->setColumnWidth( 0, folderView->visibleWidth() );
135 if ( hidden ) folderView->hide(); 147 if ( hidden ) folderView->hide();
136 148
137 mailView->setColumnWidth( 0, 10 ); 149 mailView->setColumnWidth( 0, 10 );
138 mailView->setColumnWidth( 1, mailView->visibleWidth() - 130 ); 150 mailView->setColumnWidth( 1, mailView->visibleWidth() - 130 );
139 mailView->setColumnWidth( 2, 80 ); 151 mailView->setColumnWidth( 2, 80 );
140 mailView->setColumnWidth( 3, 50 ); 152 mailView->setColumnWidth( 3, 50 );
141 mailView->setColumnWidth( 4, 50 ); 153 mailView->setColumnWidth( 4, 50 );
142} 154}
143 155
156void MainWindow::slotEditSettings() {
157 SettingsDialog settingsDialog( this, 0, true );
158 settingsDialog.showMaximized();
159 settingsDialog.exec();
160}
161
144void MainWindow::slotShowFolders( bool show ) 162void MainWindow::slotShowFolders( bool show )
145{ 163{
146 qDebug( "Show Folders" ); 164 qDebug( "Show Folders" );
147 if ( show && folderView->isHidden() ) { 165 if ( show && folderView->isHidden() ) {
148 qDebug( "-> showing" ); 166 qDebug( "-> showing" );
149 folderView->show(); 167 folderView->show();
150 } else if ( !show && !folderView->isHidden() ) { 168 } else if ( !show && !folderView->isHidden() ) {
151 qDebug( "-> hiding" ); 169 qDebug( "-> hiding" );
152 folderView->hide(); 170 folderView->hide();
153 } 171 }
154} 172}
155 173
156void MainWindow::refreshMailView(QList<RecMail>*list) 174void MainWindow::refreshMailView(QList<RecMail>*list)
157{ 175{
158 MailListViewItem*item = 0; 176 MailListViewItem*item = 0;
159 mailView->clear(); 177 mailView->clear();
160 for (unsigned int i = 0; i < list->count();++i) { 178 for (unsigned int i = 0; i < list->count();++i) {
161 item = new MailListViewItem(mailView,item); 179 item = new MailListViewItem(mailView,item);
162 item->storeData(*(list->at(i))); 180 item->storeData(*(list->at(i)));
163 item->showEntry(); 181 item->showEntry();
164 } 182 }
165} 183}
166void MainWindow::displayMail(QListViewItem*item) 184void MainWindow::displayMail(QListViewItem*item)
167{ 185{
168 186
169 if (!item) return; 187 if (!item) return;
170 RecMail mail = ((MailListViewItem*)item)->data(); 188 RecMail mail = ((MailListViewItem*)item)->data();
171 RecBody body = folderView->fetchBody(mail); 189 RecBody body = folderView->fetchBody(mail);
172 190
173 ViewMail readMail( this ); 191 ViewMail readMail( this );
174 readMail.setBody( body ); 192 readMail.setBody( body );
175 readMail.setMail( mail ); 193 readMail.setMail( mail );
176 readMail.showMaximized(); 194 readMail.showMaximized();
177 readMail.exec(); 195 readMail.exec();
178 196
179 if ( readMail.deleted ) { 197 if ( readMail.deleted ) {
180 folderView->refreshCurrent(); 198 folderView->refreshCurrent();
181 } else { 199 } else {
182 ( (MailListViewItem*)item )->setPixmap( 0, Resource::loadPixmap( "mail/kmmsgunseen") ); 200 ( (MailListViewItem*)item )->setPixmap( 0, Resource::loadPixmap( "") );
183 } 201 }
184} 202}
185 203
186void MainWindow::slotDeleteMail() 204void MainWindow::slotDeleteMail()
187{ 205{
188 if (!mailView->currentItem()) return; 206 if (!mailView->currentItem()) return;
189 RecMail mail = ((MailListViewItem*)mailView->currentItem() )->data(); 207 RecMail mail = ((MailListViewItem*)mailView->currentItem() )->data();
190 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 ) { 208 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 ) {
191 mail.Wrapper()->deleteMail( mail ); 209 mail.Wrapper()->deleteMail( mail );
192 folderView->refreshCurrent(); 210 folderView->refreshCurrent();
193 } 211 }
194} 212}
195 213
196 214
197 215
198MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) 216MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item )
199 :QListViewItem(parent,item),mail_data() 217 :QListViewItem(parent,item),mail_data()
200{ 218{
201} 219}
202 220
203void MailListViewItem::showEntry() 221void MailListViewItem::showEntry()
204{ 222{
205 if ( mail_data.getFlags().testBit( FLAG_ANSWERED ) == true) { 223 if ( mail_data.getFlags().testBit( FLAG_ANSWERED ) == true) {
206 setPixmap( 0, Resource::loadPixmap( "mail/kmmsgreplied") ); 224 setPixmap( 0, Resource::loadPixmap( "mail/kmmsgreplied") );
207 } else if ( mail_data.getFlags().testBit( FLAG_SEEN ) == true ) { 225 } else if ( mail_data.getFlags().testBit( FLAG_SEEN ) == true ) {
208 /* I think it looks nicer if there are not such a log of icons but only on mails 226 /* I think it looks nicer if there are not such a log of icons but only on mails
209 replied or new - Alwin*/ 227 replied or new - Alwin*/
210 //setPixmap( 0, Resource::loadPixmap( "mail/kmmsgunseen") ); 228 //setPixmap( 0, Resource::loadPixmap( "mail/kmmsgunseen") );
211 } else { 229 } else {
212 setPixmap( 0, Resource::loadPixmap( "mail/kmmsgnew") ); 230 setPixmap( 0, Resource::loadPixmap( "mail/kmmsgnew") );
213 } 231 }
214 double s = mail_data.Msgsize(); 232 double s = mail_data.Msgsize();
215 int w; 233 int w;
216 w=0; 234 w=0;
217 235
218 while (s>1024) { 236 while (s>1024) {
219 s/=1024; 237 s/=1024;
220 ++w; 238 ++w;
221 if (w>=2) break; 239 if (w>=2) break;
222 } 240 }
223 241
224 QString q=""; 242 QString q="";
225 QString fsize=""; 243 QString fsize="";
226 switch(w) { 244 switch(w) {
227 case 1: 245 case 1:
228 q="k"; 246 q="k";
229 break; 247 break;
230 case 2: 248 case 2:
231 q="M"; 249 q="M";
232 break; 250 break;
233 default: 251 default:
234 break; 252 break;
235 } 253 }
236 254
237 { 255 {
238 QTextOStream o(&fsize); 256 QTextOStream o(&fsize);
239 if (w>0) o.precision(2); else o.precision(0); 257 if (w>0) o.precision(2); else o.precision(0);
240 o.setf(QTextStream::fixed); 258 o.setf(QTextStream::fixed);
241 o << s << " " << q << "Byte"; 259 o << s << " " << q << "Byte";
242 } 260 }
243 261
244 setText(1,mail_data.getSubject()); 262 setText(1,mail_data.getSubject());
245 setText(2,mail_data.getFrom()); 263 setText(2,mail_data.getFrom());
246 setText(3,fsize); 264 setText(3,fsize);
diff --git a/noncore/net/mail/mainwindow.h b/noncore/net/mail/mainwindow.h
index 21af190..4e4f4bb 100644
--- a/noncore/net/mail/mainwindow.h
+++ b/noncore/net/mail/mainwindow.h
@@ -1,43 +1,46 @@
1#ifndef MAINWINDOW_H 1#ifndef MAINWINDOW_H
2#define MAINWINDOW_H 2#define MAINWINDOW_H
3 3
4#include <qmainwindow.h> 4#include <qmainwindow.h>
5#include <qlistview.h> 5#include <qlistview.h>
6#include <qaction.h> 6#include <qaction.h>
7 7
8#include <qtoolbar.h> 8#include <qtoolbar.h>
9#include <qmenubar.h> 9#include <qmenubar.h>
10 10
11#include "accountview.h" 11#include "accountview.h"
12#include "statuswidget.h"
12 13
13class RecMail; 14class RecMail;
14 15
15class MainWindow : public QMainWindow 16class MainWindow : public QMainWindow
16{ 17{
17 Q_OBJECT 18 Q_OBJECT
18 19
19public: 20public:
20 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags flags = 0 ); 21 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags flags = 0 );
21 22
22public slots: 23public slots:
23 void slotAdjustColumns(); 24 void slotAdjustColumns();
24 25
25protected slots: 26protected slots:
26 virtual void slotShowFolders( bool show ); 27 virtual void slotShowFolders( bool show );
27 virtual void refreshMailView(QList<RecMail>*); 28 virtual void refreshMailView(QList<RecMail>*);
28 virtual void displayMail(QListViewItem*); 29 virtual void displayMail(QListViewItem*);
29 virtual void slotDeleteMail(); 30 virtual void slotDeleteMail();
30 void slotAdjustLayout(); 31 void slotAdjustLayout();
32 void slotEditSettings();
31 33
32protected: 34protected:
33 QToolBar *toolBar; 35 QToolBar *toolBar;
36 StatusWidget *statusWidget;
34 QMenuBar *menuBar; 37 QMenuBar *menuBar;
35 QPopupMenu *mailMenu, *settingsMenu; 38 QPopupMenu *mailMenu, *settingsMenu;
36 QAction *composeMail, *sendQueued, *showFolders, *searchMails, *deleteMails, 39 QAction *composeMail, *sendQueued, *showFolders, *searchMails, *deleteMails,
37 *editSettings, *editAccounts, *syncFolders; 40 *editSettings, *editAccounts, *syncFolders;
38 AccountView *folderView; 41 AccountView *folderView;
39 QListView *mailView; 42 QListView *mailView;
40 QBoxLayout *layout; 43 QBoxLayout *layout;
41}; 44};
42 45
43#endif 46#endif
diff --git a/noncore/net/mail/opiemail.cpp b/noncore/net/mail/opiemail.cpp
index 740e4cf..7ab4e0d 100644
--- a/noncore/net/mail/opiemail.cpp
+++ b/noncore/net/mail/opiemail.cpp
@@ -1,55 +1,55 @@
1#include "opiemail.h" 1#include "opiemail.h"
2#include "editaccounts.h" 2#include "editaccounts.h"
3#include "composemail.h" 3#include "composemail.h"
4 4
5OpieMail::OpieMail( QWidget *parent, const char *name, WFlags flags ) 5OpieMail::OpieMail( QWidget *parent, const char *name, WFlags flags )
6 : MainWindow( parent, name, flags ) 6 : MainWindow( parent, name, flags )
7{ 7{
8 settings = new Settings(); 8 settings = new Settings();
9 9
10 folderView->populate( settings->getAccounts() ); 10 folderView->populate( settings->getAccounts() );
11 11
12 connect( composeMail, SIGNAL( activated() ), SLOT( slotComposeMail() ) ); 12 connect( composeMail, SIGNAL( activated() ), SLOT( slotComposeMail() ) );
13 connect( sendQueued, SIGNAL( activated() ), SLOT( slotSendQueued() ) ); 13 connect( sendQueued, SIGNAL( activated() ), SLOT( slotSendQueued() ) );
14 connect( searchMails, SIGNAL( activated() ), SLOT( slotSearchMails() ) ); 14// connect( searchMails, SIGNAL( activated() ), SLOT( slotSearchMails() ) );
15 connect( editSettings, SIGNAL( activated() ), SLOT( slotEditSettings() ) ); 15 connect( editSettings, SIGNAL( activated() ), SLOT( slotEditSettings() ) );
16 connect( editAccounts, SIGNAL( activated() ), SLOT( slotEditAccounts() ) ); 16 connect( editAccounts, SIGNAL( activated() ), SLOT( slotEditAccounts() ) );
17} 17}
18 18
19void OpieMail::slotComposeMail() 19void OpieMail::slotComposeMail()
20{ 20{
21 qDebug( "Compose Mail" ); 21 qDebug( "Compose Mail" );
22 ComposeMail compose( settings, this, 0 , true ); 22 ComposeMail compose( settings, this, 0 , true );
23 compose.showMaximized(); 23 compose.showMaximized();
24 compose.slotAdjustColumns(); 24 compose.slotAdjustColumns();
25 compose.exec(); 25 compose.exec();
26} 26}
27 27
28void OpieMail::slotSendQueued() 28void OpieMail::slotSendQueued()
29{ 29{
30 qDebug( "Send Queued" ); 30 qDebug( "Send Queued" );
31} 31}
32 32
33void OpieMail::slotSearchMails() 33void OpieMail::slotSearchMails()
34{ 34{
35 qDebug( "Search Mails" ); 35 qDebug( "Search Mails" );
36} 36}
37 37
38void OpieMail::slotEditSettings() 38void OpieMail::slotEditSettings()
39{ 39{
40 qDebug( "Edit Settings" ); 40 qDebug( "Edit Settings" );
41} 41}
42 42
43void OpieMail::slotEditAccounts() 43void OpieMail::slotEditAccounts()
44{ 44{
45 qDebug( "Edit Accounts" ); 45 qDebug( "Edit Accounts" );
46 EditAccounts eaDialog( settings, this, 0, true ); 46 EditAccounts eaDialog( settings, this, 0, true );
47 eaDialog.showMaximized(); 47 eaDialog.showMaximized();
48 eaDialog.slotAdjustColumns(); 48 eaDialog.slotAdjustColumns();
49 eaDialog.exec(); 49 eaDialog.exec();
50 if ( settings ) delete settings; 50 if ( settings ) delete settings;
51 settings = new Settings(); 51 settings = new Settings();
52 52
53 folderView->populate( settings->getAccounts() ); 53 folderView->populate( settings->getAccounts() );
54} 54}
55 55
diff --git a/noncore/net/mail/viewmail.cpp b/noncore/net/mail/viewmail.cpp
index d86454c..e11fe1f 100644
--- a/noncore/net/mail/viewmail.cpp
+++ b/noncore/net/mail/viewmail.cpp
@@ -1,294 +1,315 @@
1#include <qtextbrowser.h> 1#include <qtextbrowser.h>
2#include <qmessagebox.h> 2#include <qmessagebox.h>
3#include <qtextstream.h> 3#include <qtextstream.h>
4#include <qaction.h> 4#include <qaction.h>
5#include <qpopupmenu.h> 5#include <qpopupmenu.h>
6#include <qfile.h> 6#include <qfile.h>
7#include <qapplication.h> 7#include <qapplication.h>
8 8
9#include <qpe/config.h>
10
9#include <opie/ofiledialog.h> 11#include <opie/ofiledialog.h>
10 12
11#include "settings.h" 13#include "settings.h"
12#include "composemail.h" 14#include "composemail.h"
13#include "viewmail.h" 15#include "viewmail.h"
14#include "abstractmail.h" 16#include "abstractmail.h"
15#include "accountview.h" 17#include "accountview.h"
16#include "mailtypes.h" 18#include "mailtypes.h"
17 19
18AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file, 20AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file,
19 const QString&fsize,int num) 21 const QString&fsize,int num)
20 : QListViewItem(parent,after),_partNum(num) 22 : QListViewItem(parent,after),_partNum(num)
21{ 23{
22 setText(0, mime); 24 setText(0, mime);
23 setText(1, desc); 25 setText(1, desc);
24 setText(2, file); 26 setText(2, file);
25 setText(3, fsize); 27 setText(3, fsize);
26} 28}
27 29
28void ViewMail::setBody( RecBody body ) { 30void ViewMail::setBody( RecBody body ) {
29 31
30m_body = body; 32m_body = body;
31m_mail[2] = body.Bodytext(); 33m_mail[2] = body.Bodytext();
32attachbutton->setEnabled(body.Parts().count()>0); 34attachbutton->setEnabled(body.Parts().count()>0);
33attachments->setEnabled(body.Parts().count()>0); 35attachments->setEnabled(body.Parts().count()>0);
34if (body.Parts().count()==0) { 36if (body.Parts().count()==0) {
35 return; 37 return;
36} 38}
37AttachItem * curItem=0; 39AttachItem * curItem=0;
38QString type=body.Description().Type()+"/"+body.Description().Subtype(); 40QString type=body.Description().Type()+"/"+body.Description().Subtype();
39QString desc,fsize; 41QString desc,fsize;
40double s = body.Description().Size(); 42double s = body.Description().Size();
41int w; 43int w;
42w=0; 44w=0;
43 45
44while (s>1024) { 46while (s>1024) {
45 s/=1024; 47 s/=1024;
46 ++w; 48 ++w;
47 if (w>=2) break; 49 if (w>=2) break;
48} 50}
49 51
50QString q=""; 52QString q="";
51switch(w) { 53switch(w) {
52case 1: 54case 1:
53 q="k"; 55 q="k";
54 break; 56 break;
55case 2: 57case 2:
56 q="M"; 58 q="M";
57 break; 59 break;
58default: 60default:
59 break; 61 break;
60} 62}
61 63
62{ 64{
63 /* I did not found a method to make a CONTENT reset on a QTextStream 65 /* I did not found a method to make a CONTENT reset on a QTextStream
64 so I use this construct that the stream will re-constructed in each 66 so I use this construct that the stream will re-constructed in each
65 loop. To let it work, the textstream is packed into a own area of 67 loop. To let it work, the textstream is packed into a own area of
66 code is it will be destructed after finishing its small job. 68 code is it will be destructed after finishing its small job.
67 */ 69 */
68 QTextOStream o(&fsize); 70 QTextOStream o(&fsize);
69 if (w>0) o.precision(2); else o.precision(0); 71 if (w>0) o.precision(2); else o.precision(0);
70 o.setf(QTextStream::fixed); 72 o.setf(QTextStream::fixed);
71 o << s << " " << q << "Byte"; 73 o << s << " " << q << "Byte";
72} 74}
73 75
74curItem=new AttachItem(attachments,curItem,type,"Mailbody","",fsize,-1); 76curItem=new AttachItem(attachments,curItem,type,"Mailbody","",fsize,-1);
75QString filename = ""; 77QString filename = "";
76for (unsigned int i = 0; i < body.Parts().count();++i) { 78for (unsigned int i = 0; i < body.Parts().count();++i) {
77 type = body.Parts()[i].Type()+"/"+body.Parts()[i].Subtype(); 79 type = body.Parts()[i].Type()+"/"+body.Parts()[i].Subtype();
78 part_plist_t::ConstIterator it = body.Parts()[i].Parameters().begin(); 80 part_plist_t::ConstIterator it = body.Parts()[i].Parameters().begin();
79 for (;it!=body.Parts()[i].Parameters().end();++it) { 81 for (;it!=body.Parts()[i].Parameters().end();++it) {
80 qDebug(it.key()); 82 qDebug(it.key());
81 if (it.key().lower()=="name") { 83 if (it.key().lower()=="name") {
82 filename=it.data(); 84 filename=it.data();
83 } 85 }
84 } 86 }
85 s = body.Parts()[i].Size(); 87 s = body.Parts()[i].Size();
86 w = 0; 88 w = 0;
87 while (s>1024) { 89 while (s>1024) {
88 s/=1024; 90 s/=1024;
89 ++w; 91 ++w;
90 if (w>=2) break; 92 if (w>=2) break;
91 } 93 }
92 switch(w) { 94 switch(w) {
93 case 1: 95 case 1:
94 q="k"; 96 q="k";
95 break; 97 break;
96 case 2: 98 case 2:
97 q="M"; 99 q="M";
98 break; 100 break;
99 default: 101 default:
100 q=""; 102 q="";
101 break; 103 break;
102 } 104 }
103 QTextOStream o(&fsize); 105 QTextOStream o(&fsize);
104 if (w>0) o.precision(2); else o.precision(0); 106 if (w>0) o.precision(2); else o.precision(0);
105 o.setf(QTextStream::fixed); 107 o.setf(QTextStream::fixed);
106 o << s << " " << q << "Byte"; 108 o << s << " " << q << "Byte";
107 desc = body.Parts()[i].Description(); 109 desc = body.Parts()[i].Description();
108 curItem=new AttachItem(attachments,curItem,type,desc,filename,fsize,i); 110 curItem=new AttachItem(attachments,curItem,type,desc,filename,fsize,i);
109} 111}
110} 112}
111 113
114
115void ViewMail::slotShowHtml( bool state ) {
116 m_showHtml = state;
117 setText();
118}
119
112void ViewMail::slotItemClicked( QListViewItem * item , const QPoint & point, int ) { 120void ViewMail::slotItemClicked( QListViewItem * item , const QPoint & point, int ) {
113 if (!item ) 121 if (!item )
114 return; 122 return;
115 123
116 if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { 124 if ( ( ( AttachItem* )item )->Partnumber() == -1 ) {
117 setText(); 125 setText();
118 return; 126 return;
119 } 127 }
120 QPopupMenu *menu = new QPopupMenu(); 128 QPopupMenu *menu = new QPopupMenu();
121 int ret=0; 129 int ret=0;
122 130
123 if ( item->text( 0 ).left( 5 ) == "text/" ) { 131 if ( item->text( 0 ).left( 5 ) == "text/" ) {
124 menu->insertItem( tr( "Show Text" ), 1 ); 132 menu->insertItem( tr( "Show Text" ), 1 );
125 } 133 }
126 menu->insertItem( tr( "Save Attachment" ), 0 ); 134 menu->insertItem( tr( "Save Attachment" ), 0 );
127 menu->insertSeparator(1); 135 menu->insertSeparator(1);
128 136
129 ret = menu->exec( point, 0 ); 137 ret = menu->exec( point, 0 );
130 138
131 switch(ret) { 139 switch(ret) {
132 case 0: 140 case 0:
133 { MimeTypes types; 141 { MimeTypes types;
134 types.insert( "all", "*" ); 142 types.insert( "all", "*" );
135 QString str = OFileDialog::getSaveFileName( 1, 143 QString str = OFileDialog::getSaveFileName( 1,
136 "/", item->text( 2 ) , types, 0 ); 144 "/", item->text( 2 ) , types, 0 );
137 145
138 if( !str.isEmpty() ) { 146 if( !str.isEmpty() ) {
139 encodedString*content = m_recMail.Wrapper()->fetchDecodedPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] ); 147 encodedString*content = m_recMail.Wrapper()->fetchDecodedPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] );
140 if (content) { 148 if (content) {
141 QFile output(str); 149 QFile output(str);
142 output.open(IO_WriteOnly); 150 output.open(IO_WriteOnly);
143 output.writeBlock(content->Content(),content->Length()); 151 output.writeBlock(content->Content(),content->Length());
144 output.close(); 152 output.close();
145 delete content; 153 delete content;
146 } 154 }
147 } 155 }
148 } 156 }
149 break ; 157 break ;
150 158
151 case 1: 159 case 1:
152 if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { 160 if ( ( ( AttachItem* )item )->Partnumber() == -1 ) {
153 setText(); 161 setText();
154 } else { 162 } else {
155 if ( m_recMail.Wrapper() != 0l ) { // make sure that there is a wrapper , even after delete or simular actions 163 if ( m_recMail.Wrapper() != 0l ) { // make sure that there is a wrapper , even after delete or simular actions
156 browser->setText( m_recMail.Wrapper()->fetchTextPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] ) ); 164 browser->setText( m_recMail.Wrapper()->fetchTextPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] ) );
157 } 165 }
158 } 166 }
159 break; 167 break;
160 } 168 }
161 delete menu; 169 delete menu;
162} 170}
163 171
164 172
165void ViewMail::setMail( RecMail mail ) { 173void ViewMail::setMail( RecMail mail ) {
166 174
167m_recMail = mail; 175 m_recMail = mail;
168 176
169m_mail[0] = mail.getFrom(); 177 m_mail[0] = mail.getFrom();
170m_mail[1] = mail.getSubject(); 178 m_mail[1] = mail.getSubject();
171m_mail[3] = mail.getDate(); 179 m_mail[3] = mail.getDate();
172m_mail[4] = mail.Msgid(); 180 m_mail[4] = mail.Msgid();
173 181
174m_mail2[0] = mail.To(); 182 m_mail2[0] = mail.To();
175m_mail2[1] = mail.CC(); 183 m_mail2[1] = mail.CC();
176m_mail2[2] = mail.Bcc(); 184 m_mail2[2] = mail.Bcc();
177 185
178setText(); 186 setText();
179} 187}
180 188
181 189
182 190
183ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) 191ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl)
184 : ViewMailBase(parent, name, fl), _inLoop(false) 192 : ViewMailBase(parent, name, fl), _inLoop(false)
185{ 193{
186 m_gotBody = false; 194 m_gotBody = false;
187 deleted = false; 195 deleted = false;
188 196
189 connect(reply, SIGNAL(activated()), SLOT(slotReply())); 197 connect( reply, SIGNAL(activated()), SLOT(slotReply()));
190 connect(forward, SIGNAL(activated()), SLOT(slotForward())); 198 connect( forward, SIGNAL(activated()), SLOT(slotForward()));
191 connect( deleteMail, SIGNAL( activated() ), SLOT( slotDeleteMail( ) ) ); 199 connect( deleteMail, SIGNAL( activated() ), SLOT( slotDeleteMail( ) ) );
200 connect( showHtml, SIGNAL( toggled( bool ) ), SLOT( slotShowHtml( bool ) ) );
192 201
193 attachments->setEnabled(m_gotBody); 202 attachments->setEnabled(m_gotBody);
194 connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) ); 203 connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) );
195 204
205 readConfig();
196 206
197} 207}
198 208
209void ViewMail::readConfig() {
210 Config cfg( "mail" );
211 cfg.setGroup( "Settings" );
212 m_showHtml = cfg.readBoolEntry( "showHtml", false );
213 showHtml->setOn( m_showHtml );
214}
215
199void ViewMail::setText() 216void ViewMail::setText()
200{ 217{
201 218
202 QString toString; 219 QString toString;
203 QString ccString; 220 QString ccString;
204 QString bccString; 221 QString bccString;
205 222
206 for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) { 223 for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) {
207 toString += (*it); 224 toString += (*it);
208 } 225 }
209 for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) { 226 for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) {
210 ccString += (*it); 227 ccString += (*it);
211 } 228 }
212 for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) { 229 for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) {
213 bccString += (*it); 230 bccString += (*it);
214 } 231 }
215 232
216 setCaption( caption().arg( m_mail[0] ) ); 233 setCaption( caption().arg( m_mail[0] ) );
217 234
218 m_mailHtml = "<html><body>" 235 m_mailHtml = "<html><body>"
219 "<table width=\"100%\" border=\"0\"><tr bgcolor=\"#FFDD76\"><td>" 236 "<table width=\"100%\" border=\"0\"><tr bgcolor=\"#FFDD76\"><td>"
220 "<div align=left><b>" + deHtml( m_mail[1] ) + "</b></div>" 237 "<div align=left><b>" + deHtml( m_mail[1] ) + "</b></div>"
221 "</td></tr><tr bgcolor=\"#EEEEE6\"><td>" 238 "</td></tr><tr bgcolor=\"#EEEEE6\"><td>"
222 "<b>" + tr( "From" ) + ": </b><font color=#6C86C0>" + deHtml( m_mail[0] ) + "</font><br>" 239 "<b>" + tr( "From" ) + ": </b><font color=#6C86C0>" + deHtml( m_mail[0] ) + "</font><br>"
223 "<b>" + tr( "To" ) + ": </b><font color=#6C86C0>" + deHtml( toString ) + "</font><br><b>" + 240 "<b>" + tr( "To" ) + ": </b><font color=#6C86C0>" + deHtml( toString ) + "</font><br><b>" +
224 tr( "Cc" ) + ": </b>" + deHtml( ccString ) + "<br>" 241 tr( "Cc" ) + ": </b>" + deHtml( ccString ) + "<br>"
225 "<b>" + tr( "Date" ) + ": </b> " + m_mail[3] + 242 "<b>" + tr( "Date" ) + ": </b> " + m_mail[3] +
226 "</td></tr></table><font face=fixed>"; 243 "</td></tr></table><font face=fixed>";
227 244
245 if ( !m_showHtml ) {
228 browser->setText( QString( m_mailHtml) + deHtml( m_mail[2] ) + "</font></html>" ); 246 browser->setText( QString( m_mailHtml) + deHtml( m_mail[2] ) + "</font></html>" );
229 // remove later in favor of a real handling 247 } else {
230 m_gotBody = true; 248 browser->setText( QString( m_mailHtml) + m_mail[2] + "</font></html>" );
249 }
250 // remove later in favor of a real handling
251 m_gotBody = true;
231} 252}
232 253
233 254
234ViewMail::~ViewMail() 255ViewMail::~ViewMail()
235{ 256{
236 hide(); 257 hide();
237} 258}
238 259
239void ViewMail::hide() 260void ViewMail::hide()
240{ 261{
241 QWidget::hide(); 262 QWidget::hide();
242 263
243 if (_inLoop) { 264 if (_inLoop) {
244 _inLoop = false; 265 _inLoop = false;
245 qApp->exit_loop(); 266 qApp->exit_loop();
246 267
247 } 268 }
248 269
249} 270}
250 271
251void ViewMail::exec() 272void ViewMail::exec()
252{ 273{
253 show(); 274 show();
254 275
255 if (!_inLoop) { 276 if (!_inLoop) {
256 _inLoop = true; 277 _inLoop = true;
257 qApp->enter_loop(); 278 qApp->enter_loop();
258 } 279 }
259 280
260} 281}
261 282
262QString ViewMail::deHtml(const QString &string) 283QString ViewMail::deHtml(const QString &string)
263{ 284{
264 QString string_ = string; 285 QString string_ = string;
265 string_.replace(QRegExp("&"), "&amp;"); 286 string_.replace(QRegExp("&"), "&amp;");
266 string_.replace(QRegExp("<"), "&lt;"); 287 string_.replace(QRegExp("<"), "&lt;");
267 string_.replace(QRegExp(">"), "&gt;"); 288 string_.replace(QRegExp(">"), "&gt;");
268 string_.replace(QRegExp("\\n"), "<br>"); 289 string_.replace(QRegExp("\\n"), "<br>");
269 return string_; 290 return string_;
270} 291}
271 292
272void ViewMail::slotReply() 293void ViewMail::slotReply()
273{ 294{
274 if (!m_gotBody) { 295 if (!m_gotBody) {
275 QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); 296 QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok"));
276 return; 297 return;
277 } 298 }
278 299
279 QString rtext; 300 QString rtext;
280 rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose 301 rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose
281 .arg( m_mail[0] ) 302 .arg( m_mail[0] )
282 .arg( m_mail[3] ); 303 .arg( m_mail[3] );
283 304
284 QString text = m_mail[2]; 305 QString text = m_mail[2];
285 QStringList lines = QStringList::split(QRegExp("\\n"), text); 306 QStringList lines = QStringList::split(QRegExp("\\n"), text);
286 QStringList::Iterator it; 307 QStringList::Iterator it;
287 for (it = lines.begin(); it != lines.end(); it++) { 308 for (it = lines.begin(); it != lines.end(); it++) {
288 rtext += "> " + *it + "\n"; 309 rtext += "> " + *it + "\n";
289 } 310 }
290 rtext += "\n"; 311 rtext += "\n";
291 312
292 QString prefix; 313 QString prefix;
293 if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = ""; 314 if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = "";
294 else prefix = "Re: "; // no i18n on purpose 315 else prefix = "Re: "; // no i18n on purpose
diff --git a/noncore/net/mail/viewmail.h b/noncore/net/mail/viewmail.h
index dd7f854..bf7a4dd 100644
--- a/noncore/net/mail/viewmail.h
+++ b/noncore/net/mail/viewmail.h
@@ -1,61 +1,64 @@
1#ifndef VIEWMAIL_H 1#ifndef VIEWMAIL_H
2#define VIEWMAIL_H 2#define VIEWMAIL_H
3 3
4#include <qlistview.h> 4#include <qlistview.h>
5#include <qmap.h> 5#include <qmap.h>
6#include <qstringlist.h> 6#include <qstringlist.h>
7 7
8#include "viewmailbase.h" 8#include "viewmailbase.h"
9#include "mailtypes.h" 9#include "mailtypes.h"
10 10
11class AttachItem : public QListViewItem 11class AttachItem : public QListViewItem
12{ 12{
13public: 13public:
14 AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file, 14 AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file,
15 const QString&fsize,int num); 15 const QString&fsize,int num);
16 int Partnumber() { return _partNum; } 16 int Partnumber() { return _partNum; }
17 17
18private: 18private:
19 int _partNum; 19 int _partNum;
20}; 20};
21 21
22class ViewMail : public ViewMailBase 22class ViewMail : public ViewMailBase
23{ 23{
24 Q_OBJECT 24 Q_OBJECT
25 25
26public: 26public:
27 ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal); 27 ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal);
28 ~ViewMail(); 28 ~ViewMail();
29 29
30 void hide(); 30 void hide();
31 void exec(); 31 void exec();
32 void setMail( RecMail mail ); 32 void setMail( RecMail mail );
33 void setBody( RecBody body ); 33 void setBody( RecBody body );
34 bool deleted; 34 bool deleted;
35 35
36protected: 36protected:
37 QString deHtml(const QString &string); 37 QString deHtml(const QString &string);
38 38
39protected slots: 39protected slots:
40 void slotReply(); 40 void slotReply();
41 void slotForward(); 41 void slotForward();
42 void setText(); 42 void setText();
43 void slotItemClicked( QListViewItem * item , const QPoint & point, int c ); 43 void slotItemClicked( QListViewItem * item , const QPoint & point, int c );
44 void slotDeleteMail( ); 44 void slotDeleteMail( );
45 45 void slotShowHtml( bool );
46 46
47private: 47private:
48 void readConfig();
49
48 bool _inLoop; 50 bool _inLoop;
49 QString m_mailHtml; 51 QString m_mailHtml;
50 bool m_gotBody; 52 bool m_gotBody;
51 RecBody m_body; 53 RecBody m_body;
52 RecMail m_recMail; 54 RecMail m_recMail;
55 bool m_showHtml;
53 56
54 // 0 from 1 subject 2 bodytext 3 date 57 // 0 from 1 subject 2 bodytext 3 date
55 QMap <int,QString> m_mail; 58 QMap <int,QString> m_mail;
56 // 0 to 1 cc 2 bcc 59 // 0 to 1 cc 2 bcc
57 QMap <int,QStringList> m_mail2; 60 QMap <int,QStringList> m_mail2;
58 61
59}; 62};
60 63
61#endif 64#endif
diff --git a/noncore/net/mail/viewmailbase.cpp b/noncore/net/mail/viewmailbase.cpp
index 0c7f671..e69617d 100644
--- a/noncore/net/mail/viewmailbase.cpp
+++ b/noncore/net/mail/viewmailbase.cpp
@@ -1,77 +1,82 @@
1#include <qtextbrowser.h> 1#include <qtextbrowser.h>
2#include <qlistview.h> 2#include <qlistview.h>
3#include <qaction.h> 3#include <qaction.h>
4#include <qlabel.h> 4#include <qlabel.h>
5#include <qvbox.h> 5#include <qvbox.h>
6#include <qpopupmenu.h> 6#include <qpopupmenu.h>
7 7
8#include <qpe/qpetoolbar.h> 8#include <qpe/qpetoolbar.h>
9#include <qmenubar.h> 9#include <qmenubar.h>
10#include <qpe/resource.h> 10#include <qpe/resource.h>
11 11
12#include "viewmailbase.h" 12#include "viewmailbase.h"
13//#include "opendiag.h" 13//#include "opendiag.h"
14 14
15ViewMailBase::ViewMailBase(QWidget *parent, const char *name, WFlags fl) 15ViewMailBase::ViewMailBase(QWidget *parent, const char *name, WFlags fl)
16 : QMainWindow(parent, name, fl) 16 : QMainWindow(parent, name, fl)
17{ 17{
18 setCaption(tr("E-Mail by %1")); 18 setCaption(tr("E-Mail by %1"));
19 setToolBarsMovable(false); 19 setToolBarsMovable(false);
20 20
21 toolbar = new QToolBar(this); 21 toolbar = new QToolBar(this);
22 menubar = new QMenuBar( toolbar ); 22 menubar = new QMenuBar( toolbar );
23 mailmenu = new QPopupMenu( menubar ); 23 mailmenu = new QPopupMenu( menubar );
24 menubar->insertItem( tr( "Mail" ), mailmenu ); 24 menubar->insertItem( tr( "Mail" ), mailmenu );
25 25
26 toolbar->setHorizontalStretchable(true); 26 toolbar->setHorizontalStretchable(true);
27 addToolBar(toolbar); 27 addToolBar(toolbar);
28 28
29 QLabel *spacer = new QLabel(toolbar); 29 QLabel *spacer = new QLabel(toolbar);
30 spacer->setBackgroundMode(QWidget::PaletteButton); 30 spacer->setBackgroundMode(QWidget::PaletteButton);
31 toolbar->setStretchableWidget(spacer); 31 toolbar->setStretchableWidget(spacer);
32 32
33 reply = new QAction(tr("Reply"), QIconSet(Resource::loadPixmap("mail/reply")), 0, 0, this); 33 reply = new QAction(tr("Reply"), QIconSet(Resource::loadPixmap("mail/reply")), 0, 0, this);
34 reply->addTo(toolbar); 34 reply->addTo(toolbar);
35 reply->addTo(mailmenu); 35 reply->addTo(mailmenu);
36 36
37 forward = new QAction(tr("Forward"), QIconSet(Resource::loadPixmap("mail/forward")), 0, 0, this); 37 forward = new QAction(tr("Forward"), QIconSet(Resource::loadPixmap("mail/forward")), 0, 0, this);
38 forward->addTo(toolbar); 38 forward->addTo(toolbar);
39 forward->addTo(mailmenu); 39 forward->addTo(mailmenu);
40 40
41 attachbutton = new QAction(tr("Attachments"), QIconSet(Resource::loadPixmap("mail/attach")), 0, 0, this, 0, true); 41 attachbutton = new QAction(tr("Attachments"), QIconSet(Resource::loadPixmap("mail/attach")), 0, 0, this, 0, true);
42 attachbutton->addTo(toolbar); 42 attachbutton->addTo(toolbar);
43 attachbutton->addTo(mailmenu); 43 attachbutton->addTo(mailmenu);
44 connect(attachbutton, SIGNAL(toggled(bool)), SLOT(slotChangeAttachview(bool))); 44 connect(attachbutton, SIGNAL(toggled(bool)), SLOT(slotChangeAttachview(bool)));
45 45
46
47 showHtml = new QAction( tr( "Show Html" ), QIconSet( Resource::loadPixmap( "mail/attach" ) ), 0, 0, this, 0, true );
48 showHtml->addTo( toolbar );
49 showHtml->addTo( mailmenu );
50
46 deleteMail = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); 51 deleteMail = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this);
47 deleteMail->addTo(toolbar); 52 deleteMail->addTo(toolbar);
48 deleteMail->addTo(mailmenu); 53 deleteMail->addTo(mailmenu);
49 54
50 QVBox *view = new QVBox(this); 55 QVBox *view = new QVBox(this);
51 setCentralWidget(view); 56 setCentralWidget(view);
52 57
53 attachments = new QListView(view); 58 attachments = new QListView(view);
54 attachments->setMinimumHeight(90); 59 attachments->setMinimumHeight(90);
55 attachments->setMaximumHeight(90); 60 attachments->setMaximumHeight(90);
56 attachments->setAllColumnsShowFocus(true); 61 attachments->setAllColumnsShowFocus(true);
57 attachments->addColumn("Mime Type", 60); 62 attachments->addColumn("Mime Type", 60);
58 attachments->addColumn(tr("Description"), 100); 63 attachments->addColumn(tr("Description"), 100);
59 attachments->addColumn(tr("Filename"), 80); 64 attachments->addColumn(tr("Filename"), 80);
60 attachments->addColumn(tr("Size"), 80); 65 attachments->addColumn(tr("Size"), 80);
61 attachments->setSorting(-1); 66 attachments->setSorting(-1);
62 attachments->hide(); 67 attachments->hide();
63 68
64 browser = new QTextBrowser(view); 69 browser = new QTextBrowser(view);
65 70
66 //openDiag = new OpenDiag(view); 71 //openDiag = new OpenDiag(view);
67 //openDiag->hide(); 72 //openDiag->hide();
68 73
69} 74}
70 75
71void ViewMailBase::slotChangeAttachview(bool state) 76void ViewMailBase::slotChangeAttachview(bool state)
72{ 77{
73 if (state) attachments->show(); 78 if (state) attachments->show();
74 else attachments->hide(); 79 else attachments->hide();
75} 80}
76 81
77 82
diff --git a/noncore/net/mail/viewmailbase.h b/noncore/net/mail/viewmailbase.h
index 898522e..6d2a5b2 100644
--- a/noncore/net/mail/viewmailbase.h
+++ b/noncore/net/mail/viewmailbase.h
@@ -1,36 +1,37 @@
1#ifndef VIEWMAILBASE_H 1#ifndef VIEWMAILBASE_H
2#define VIEWMAILBASE_H 2#define VIEWMAILBASE_H
3 3
4#include <qmainwindow.h> 4#include <qmainwindow.h>
5 5
6class QAction; 6class QAction;
7class OpenDiag; 7class OpenDiag;
8class QListView; 8class QListView;
9class QToolBar; 9class QToolBar;
10class QTextBrowser; 10class QTextBrowser;
11class QMenuBar; 11class QMenuBar;
12class QPopupMenu; 12class QPopupMenu;
13 13
14class ViewMailBase : public QMainWindow 14class ViewMailBase : public QMainWindow
15{ 15{
16 Q_OBJECT 16 Q_OBJECT
17 17
18public: 18public:
19 ViewMailBase(QWidget *parent = 0, const char *name = 0, WFlags fl = 0); 19 ViewMailBase(QWidget *parent = 0, const char *name = 0, WFlags fl = 0);
20 20
21protected: 21protected:
22 QAction *reply, *forward, *attachbutton, *deleteMail; 22 QAction *reply, *forward, *attachbutton, *deleteMail, *showHtml;
23 QListView *attachments; 23 QListView *attachments;
24 QToolBar *toolbar; 24 QToolBar *toolbar;
25 QTextBrowser *browser; 25 QTextBrowser *browser;
26 OpenDiag *openDiag; 26 OpenDiag *openDiag;
27 QMenuBar *menubar; 27 QMenuBar *menubar;
28 QPopupMenu *mailmenu; 28 QPopupMenu *mailmenu;
29 29
30protected slots: 30protected slots:
31 void slotChangeAttachview(bool state); 31 void slotChangeAttachview(bool state);
32 32
33
33}; 34};
34 35
35#endif 36#endif
36 37