author | harlekin <harlekin> | 2003-12-10 01:24:21 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2003-12-10 01:24:21 (UTC) |
commit | a908d0ffdb5cee72b7823fc411119b8e1e3faad8 (patch) (unidiff) | |
tree | a5c25c3d49373c705fd541a28f25436dc206be4f | |
parent | c244afea4a03d7ae948152b5abac2f059fb1e789 (diff) | |
download | opie-a908d0ffdb5cee72b7823fc411119b8e1e3faad8.zip opie-a908d0ffdb5cee72b7823fc411119b8e1e3faad8.tar.gz opie-a908d0ffdb5cee72b7823fc411119b8e1e3faad8.tar.bz2 |
basis message id handling
-rw-r--r-- | noncore/net/mail/mainwindow.cpp | 2 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.cpp | 4 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.h | 2 |
3 files changed, 4 insertions, 4 deletions
diff --git a/noncore/net/mail/mainwindow.cpp b/noncore/net/mail/mainwindow.cpp index f19f93d..3edfff1 100644 --- a/noncore/net/mail/mainwindow.cpp +++ b/noncore/net/mail/mainwindow.cpp | |||
@@ -1,185 +1,185 @@ | |||
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 | 6 | ||
7 | #include <qpe/qpeapplication.h> | 7 | #include <qpe/qpeapplication.h> |
8 | 8 | ||
9 | #include "defines.h" | 9 | #include "defines.h" |
10 | #include "mainwindow.h" | 10 | #include "mainwindow.h" |
11 | #include "viewmail.h" | 11 | #include "viewmail.h" |
12 | #include "mailtypes.h" | 12 | #include "mailtypes.h" |
13 | #include "mailistviewitem.h" | 13 | #include "mailistviewitem.h" |
14 | 14 | ||
15 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) | 15 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) |
16 | : QMainWindow( parent, name, flags ) | 16 | : QMainWindow( parent, name, flags ) |
17 | { | 17 | { |
18 | setCaption( tr( "Opie-Mail" ) ); | 18 | setCaption( tr( "Opie-Mail" ) ); |
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 | settingsMenu = new QPopupMenu( menuBar ); | 25 | settingsMenu = new QPopupMenu( menuBar ); |
26 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); | 26 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); |
27 | 27 | ||
28 | addToolBar( toolBar ); | 28 | addToolBar( toolBar ); |
29 | toolBar->setHorizontalStretchable( true ); | 29 | toolBar->setHorizontalStretchable( true ); |
30 | 30 | ||
31 | QLabel *spacer = new QLabel( toolBar ); | 31 | QLabel *spacer = new QLabel( toolBar ); |
32 | spacer->setBackgroundMode( QWidget::PaletteButton ); | 32 | spacer->setBackgroundMode( QWidget::PaletteButton ); |
33 | toolBar->setStretchableWidget( spacer ); | 33 | toolBar->setStretchableWidget( spacer ); |
34 | 34 | ||
35 | composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL, | 35 | composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL, |
36 | 0, 0, this ); | 36 | 0, 0, this ); |
37 | composeMail->addTo( toolBar ); | 37 | composeMail->addTo( toolBar ); |
38 | composeMail->addTo( mailMenu ); | 38 | composeMail->addTo( mailMenu ); |
39 | 39 | ||
40 | sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED, | 40 | sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED, |
41 | 0, 0, this ); | 41 | 0, 0, this ); |
42 | sendQueued->addTo( toolBar ); | 42 | sendQueued->addTo( toolBar ); |
43 | sendQueued->addTo( mailMenu ); | 43 | sendQueued->addTo( mailMenu ); |
44 | 44 | ||
45 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, | 45 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, |
46 | 0, 0, this ); | 46 | 0, 0, this ); |
47 | syncFolders->addTo( toolBar ); | 47 | syncFolders->addTo( toolBar ); |
48 | syncFolders->addTo( mailMenu ); | 48 | syncFolders->addTo( mailMenu ); |
49 | 49 | ||
50 | showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS, | 50 | showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS, |
51 | 0, 0, this, 0, true ); | 51 | 0, 0, this, 0, true ); |
52 | showFolders->addTo( toolBar ); | 52 | showFolders->addTo( toolBar ); |
53 | showFolders->addTo( mailMenu ); | 53 | showFolders->addTo( mailMenu ); |
54 | connect(showFolders, SIGNAL( toggled( bool ) ), | 54 | connect(showFolders, SIGNAL( toggled( bool ) ), |
55 | SLOT( slotShowFolders( bool ) ) ); | 55 | SLOT( slotShowFolders( bool ) ) ); |
56 | 56 | ||
57 | searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS, | 57 | searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS, |
58 | 0, 0, this ); | 58 | 0, 0, this ); |
59 | searchMails->addTo( toolBar ); | 59 | searchMails->addTo( toolBar ); |
60 | searchMails->addTo( mailMenu ); | 60 | searchMails->addTo( mailMenu ); |
61 | 61 | ||
62 | 62 | ||
63 | editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS, | 63 | editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS, |
64 | 0, 0, this ); | 64 | 0, 0, this ); |
65 | editSettings->addTo( settingsMenu ); | 65 | editSettings->addTo( settingsMenu ); |
66 | 66 | ||
67 | editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS, | 67 | editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS, |
68 | 0, 0, this ); | 68 | 0, 0, this ); |
69 | editAccounts->addTo( settingsMenu ); | 69 | editAccounts->addTo( settingsMenu ); |
70 | 70 | ||
71 | QWidget *view = new QWidget( this ); | 71 | QWidget *view = new QWidget( this ); |
72 | setCentralWidget( view ); | 72 | setCentralWidget( view ); |
73 | 73 | ||
74 | layout = new QBoxLayout ( view, QBoxLayout::LeftToRight ); | 74 | layout = new QBoxLayout ( view, QBoxLayout::LeftToRight ); |
75 | 75 | ||
76 | folderView = new AccountView( view ); | 76 | folderView = new AccountView( view ); |
77 | folderView->header()->hide(); | 77 | folderView->header()->hide(); |
78 | folderView->addColumn( tr( "Mailbox" ) ); | 78 | folderView->addColumn( tr( "Mailbox" ) ); |
79 | folderView->hide(); | 79 | folderView->hide(); |
80 | 80 | ||
81 | layout->addWidget( folderView ); | 81 | layout->addWidget( folderView ); |
82 | 82 | ||
83 | mailView = new QListView( view ); | 83 | mailView = new QListView( view ); |
84 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); | 84 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); |
85 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); | 85 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); |
86 | mailView->addColumn( tr( "Date" )); | 86 | mailView->addColumn( tr( "Date" )); |
87 | mailView->setAllColumnsShowFocus(true); | 87 | mailView->setAllColumnsShowFocus(true); |
88 | mailView->setSorting(-1); | 88 | mailView->setSorting(-1); |
89 | 89 | ||
90 | layout->addWidget( mailView ); | 90 | layout->addWidget( mailView ); |
91 | layout->setStretchFactor( folderView, 1 ); | 91 | layout->setStretchFactor( folderView, 1 ); |
92 | layout->setStretchFactor( mailView, 2 ); | 92 | layout->setStretchFactor( mailView, 2 ); |
93 | 93 | ||
94 | slotAdjustLayout(); | 94 | slotAdjustLayout(); |
95 | 95 | ||
96 | connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this, | 96 | connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this, |
97 | SLOT( displayMail( QListViewItem * ) ) ); | 97 | SLOT( displayMail( QListViewItem * ) ) ); |
98 | 98 | ||
99 | connect(folderView,SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*))); | 99 | connect(folderView,SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*))); |
100 | 100 | ||
101 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); | 101 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); |
102 | } | 102 | } |
103 | 103 | ||
104 | 104 | ||
105 | void MainWindow::slotAdjustLayout() { | 105 | void MainWindow::slotAdjustLayout() { |
106 | 106 | ||
107 | QWidget *d = QApplication::desktop(); | 107 | QWidget *d = QApplication::desktop(); |
108 | 108 | ||
109 | if ( d->width() < d->height() ) { | 109 | if ( d->width() < d->height() ) { |
110 | layout->setDirection( QBoxLayout::TopToBottom ); | 110 | layout->setDirection( QBoxLayout::TopToBottom ); |
111 | } else { | 111 | } else { |
112 | layout->setDirection( QBoxLayout::LeftToRight ); | 112 | layout->setDirection( QBoxLayout::LeftToRight ); |
113 | } | 113 | } |
114 | delete d; | 114 | delete d; |
115 | } | 115 | } |
116 | 116 | ||
117 | void MainWindow::slotAdjustColumns() | 117 | void MainWindow::slotAdjustColumns() |
118 | { | 118 | { |
119 | bool hidden = folderView->isHidden(); | 119 | bool hidden = folderView->isHidden(); |
120 | if ( hidden ) folderView->show(); | 120 | if ( hidden ) folderView->show(); |
121 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); | 121 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); |
122 | if ( hidden ) folderView->hide(); | 122 | if ( hidden ) folderView->hide(); |
123 | 123 | ||
124 | mailView->setColumnWidth( 0, mailView->visibleWidth() - 130 ); | 124 | mailView->setColumnWidth( 0, mailView->visibleWidth() - 130 ); |
125 | mailView->setColumnWidth( 1, 80 ); | 125 | mailView->setColumnWidth( 1, 80 ); |
126 | mailView->setColumnWidth( 2, 50 ); | 126 | mailView->setColumnWidth( 2, 50 ); |
127 | } | 127 | } |
128 | 128 | ||
129 | void MainWindow::slotShowFolders( bool show ) | 129 | void MainWindow::slotShowFolders( bool show ) |
130 | { | 130 | { |
131 | qDebug( "Show Folders" ); | 131 | qDebug( "Show Folders" ); |
132 | if ( show && folderView->isHidden() ) { | 132 | if ( show && folderView->isHidden() ) { |
133 | qDebug( "-> showing" ); | 133 | qDebug( "-> showing" ); |
134 | folderView->show(); | 134 | folderView->show(); |
135 | } else if ( !show && !folderView->isHidden() ) { | 135 | } else if ( !show && !folderView->isHidden() ) { |
136 | qDebug( "-> hiding" ); | 136 | qDebug( "-> hiding" ); |
137 | folderView->hide(); | 137 | folderView->hide(); |
138 | } | 138 | } |
139 | } | 139 | } |
140 | 140 | ||
141 | void MainWindow::refreshMailView(QList<RecMail>*list) | 141 | void MainWindow::refreshMailView(QList<RecMail>*list) |
142 | { | 142 | { |
143 | MailListViewItem*item = 0; | 143 | MailListViewItem*item = 0; |
144 | mailView->clear(); | 144 | mailView->clear(); |
145 | for (unsigned int i = 0; i < list->count();++i) { | 145 | for (unsigned int i = 0; i < list->count();++i) { |
146 | item = new MailListViewItem(mailView,item); | 146 | item = new MailListViewItem(mailView,item); |
147 | item->storeData(*(list->at(i))); | 147 | item->storeData(*(list->at(i))); |
148 | item->showEntry(); | 148 | item->showEntry(); |
149 | } | 149 | } |
150 | } | 150 | } |
151 | void MainWindow::displayMail(QListViewItem*item) | 151 | void MainWindow::displayMail(QListViewItem*item) |
152 | { | 152 | { |
153 | if (!item) return; | 153 | if (!item) return; |
154 | qDebug("View mail"); | 154 | qDebug("View mail"); |
155 | RecMail mail = ((MailListViewItem*)item)->data(); | 155 | RecMail mail = ((MailListViewItem*)item)->data(); |
156 | RecBody body = folderView->fetchBody(mail); | 156 | RecBody body = folderView->fetchBody(mail); |
157 | 157 | ||
158 | ViewMail readMail( this ); | 158 | ViewMail readMail( this ); |
159 | 159 | ||
160 | readMail.setMailInfo( mail.getFrom(), mail.To(), mail.getSubject(), mail.CC(), mail.Bcc(), mail.getDate(), body.Bodytext() ); | 160 | readMail.setMailInfo( mail.getFrom(), mail.To(), mail.getSubject(), mail.CC(), mail.Bcc(), mail.getDate(), body.Bodytext(), mail.Msgid() ); |
161 | readMail.showMaximized(); | 161 | readMail.showMaximized(); |
162 | readMail.exec(); | 162 | readMail.exec(); |
163 | } | 163 | } |
164 | 164 | ||
165 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * after ) | 165 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * after ) |
166 | :QListViewItem(parent,after),mail_data() | 166 | :QListViewItem(parent,after),mail_data() |
167 | { | 167 | { |
168 | } | 168 | } |
169 | 169 | ||
170 | void MailListViewItem::showEntry() | 170 | void MailListViewItem::showEntry() |
171 | { | 171 | { |
172 | setText(0,mail_data.getSubject()); | 172 | setText(0,mail_data.getSubject()); |
173 | setText(1,mail_data.getFrom()); | 173 | setText(1,mail_data.getFrom()); |
174 | setText(2,mail_data.getDate()); | 174 | setText(2,mail_data.getDate()); |
175 | } | 175 | } |
176 | 176 | ||
177 | void MailListViewItem::storeData(const RecMail&data) | 177 | void MailListViewItem::storeData(const RecMail&data) |
178 | { | 178 | { |
179 | mail_data = data; | 179 | mail_data = data; |
180 | } | 180 | } |
181 | 181 | ||
182 | const RecMail& MailListViewItem::data()const | 182 | const RecMail& MailListViewItem::data()const |
183 | { | 183 | { |
184 | return mail_data; | 184 | return mail_data; |
185 | } | 185 | } |
diff --git a/noncore/net/mail/viewmail.cpp b/noncore/net/mail/viewmail.cpp index 8f9ea07..7969235 100644 --- a/noncore/net/mail/viewmail.cpp +++ b/noncore/net/mail/viewmail.cpp | |||
@@ -1,225 +1,225 @@ | |||
1 | #include <qtextbrowser.h> | 1 | #include <qtextbrowser.h> |
2 | #include <qmessagebox.h> | 2 | #include <qmessagebox.h> |
3 | #include <qaction.h> | 3 | #include <qaction.h> |
4 | #include <qapplication.h> | 4 | #include <qapplication.h> |
5 | 5 | ||
6 | #include "settings.h" | 6 | #include "settings.h" |
7 | #include "composemail.h" | 7 | #include "composemail.h" |
8 | #include "viewmail.h" | 8 | #include "viewmail.h" |
9 | 9 | ||
10 | AttachItem::AttachItem(QListView *parent, AttachItemStore &attachItemStore) | 10 | AttachItem::AttachItem(QListView *parent, AttachItemStore &attachItemStore) |
11 | : QListViewItem(parent), _attachItemStore(attachItemStore) | 11 | : QListViewItem(parent), _attachItemStore(attachItemStore) |
12 | { | 12 | { |
13 | setText(0, _attachItemStore.mimeType()); | 13 | setText(0, _attachItemStore.mimeType()); |
14 | setText(1, _attachItemStore.fileName()); | 14 | setText(1, _attachItemStore.fileName()); |
15 | setText(2, _attachItemStore.description()); | 15 | setText(2, _attachItemStore.description()); |
16 | } | 16 | } |
17 | 17 | ||
18 | AttachItem::AttachItem(QListViewItem *parent, AttachItemStore &attachItemStore) | 18 | AttachItem::AttachItem(QListViewItem *parent, AttachItemStore &attachItemStore) |
19 | : QListViewItem(parent), _attachItemStore(attachItemStore) | 19 | : QListViewItem(parent), _attachItemStore(attachItemStore) |
20 | { | 20 | { |
21 | setText(0, _attachItemStore.mimeType()); | 21 | setText(0, _attachItemStore.mimeType()); |
22 | setText(1, _attachItemStore.fileName()); | 22 | setText(1, _attachItemStore.fileName()); |
23 | setText(2, _attachItemStore.description()); | 23 | setText(2, _attachItemStore.description()); |
24 | } | 24 | } |
25 | 25 | ||
26 | void ViewMail::setMailInfo( const QString & from, const QStringList & to, const QString & subject, const QStringList & cc, const QStringList & bcc, const QString & date, const QString & bodytext ) { | 26 | void ViewMail::setMailInfo( const QString & from, const QStringList & to, const QString & subject, const QStringList & cc, const QStringList & bcc, const QString & date, const QString & bodytext, const QString & messageID ) { |
27 | 27 | ||
28 | m_mail[0] = from; | 28 | m_mail[0] = from; |
29 | m_mail2[0] = to; | 29 | m_mail2[0] = to; |
30 | m_mail[1] = subject; | 30 | m_mail[1] = subject; |
31 | m_mail2[1] = cc; | 31 | m_mail2[1] = cc; |
32 | m_mail2[2] = bcc; | 32 | m_mail2[2] = bcc; |
33 | m_mail[2] = bodytext; | 33 | m_mail[2] = bodytext; |
34 | m_mail[3] = date; | 34 | m_mail[3] = date; |
35 | m_mail[4] = messageID; | ||
35 | 36 | ||
36 | setText(); | 37 | setText(); |
37 | |||
38 | } | 38 | } |
39 | 39 | ||
40 | 40 | ||
41 | ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) | 41 | ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) |
42 | : ViewMailBase(parent, name, fl), _inLoop(false) | 42 | : ViewMailBase(parent, name, fl), _inLoop(false) |
43 | { | 43 | { |
44 | _gotBody = false; | 44 | _gotBody = false; |
45 | 45 | ||
46 | connect(reply, SIGNAL(activated()), SLOT(slotReply())); | 46 | connect(reply, SIGNAL(activated()), SLOT(slotReply())); |
47 | connect(forward, SIGNAL(activated()), SLOT(slotForward())); | 47 | connect(forward, SIGNAL(activated()), SLOT(slotForward())); |
48 | 48 | ||
49 | attachments->setEnabled(_gotBody); | 49 | attachments->setEnabled(_gotBody); |
50 | 50 | ||
51 | //_handler->iUid("FETCH", QString("%1 (BODY[1])").arg(mail.uid())); | 51 | //_handler->iUid("FETCH", QString("%1 (BODY[1])").arg(mail.uid())); |
52 | //connect(_handler, SIGNAL(gotResponse(IMAPResponse &)), SLOT(slotIMAPUid(IMAPResponse &))); | 52 | //connect(_handler, SIGNAL(gotResponse(IMAPResponse &)), SLOT(slotIMAPUid(IMAPResponse &))); |
53 | } | 53 | } |
54 | 54 | ||
55 | void ViewMail::setText() | 55 | void ViewMail::setText() |
56 | { | 56 | { |
57 | 57 | ||
58 | QString toString; | 58 | QString toString; |
59 | QString ccString; | 59 | QString ccString; |
60 | QString bccString; | 60 | QString bccString; |
61 | 61 | ||
62 | for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) { | 62 | for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) { |
63 | toString += (*it); | 63 | toString += (*it); |
64 | } | 64 | } |
65 | for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) { | 65 | for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) { |
66 | ccString += (*it); | 66 | ccString += (*it); |
67 | } | 67 | } |
68 | for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) { | 68 | for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) { |
69 | bccString += (*it); | 69 | bccString += (*it); |
70 | } | 70 | } |
71 | 71 | ||
72 | setCaption( caption().arg( m_mail[0] ) ); | 72 | setCaption( caption().arg( m_mail[0] ) ); |
73 | 73 | ||
74 | _mailHtml = tr( | 74 | _mailHtml = tr( |
75 | "<html><body>" | 75 | "<html><body>" |
76 | "<div align=center><b><font color=#0000FF>%1</b></font></div>" | 76 | "<div align=center><b><font color=#0000FF>%1</b></font></div>" |
77 | "<b>From:</b><font color=#6C86C0> %2</font><br>" | 77 | "<b>From:</b><font color=#6C86C0> %2</font><br>" |
78 | "<b>To:</b><font color=#6C86C0> %3</font><br>" | 78 | "<b>To:</b><font color=#6C86C0> %3</font><br>" |
79 | "%4" | 79 | "%4" |
80 | "<b>Date:</b> %5<hr>" | 80 | "<b>Date:</b> %5<hr>" |
81 | "<font face=fixed>") | 81 | "<font face=fixed>") |
82 | .arg( deHtml( m_mail[1] ) ) | 82 | .arg( deHtml( m_mail[1] ) ) |
83 | .arg( deHtml( m_mail[0] ) ) | 83 | .arg( deHtml( m_mail[0] ) ) |
84 | .arg( deHtml( toString ) ) | 84 | .arg( deHtml( toString ) ) |
85 | .arg( tr("<b>Cc:</b> %1<br>").arg( deHtml( ccString ) ) ) | 85 | .arg( tr("<b>Cc:</b> %1<br>").arg( deHtml( ccString ) ) ) |
86 | .arg( m_mail[3] ); | 86 | .arg( m_mail[3] ); |
87 | browser->setText( QString(_mailHtml) + deHtml( m_mail[2] ) + "</font>" ); | 87 | browser->setText( QString(_mailHtml) + deHtml( m_mail[2] ) + "</font>" ); |
88 | // remove later in favor of a real handling | 88 | // remove later in favor of a real handling |
89 | _gotBody = true; | 89 | _gotBody = true; |
90 | } | 90 | } |
91 | 91 | ||
92 | 92 | ||
93 | 93 | ||
94 | ViewMail::~ViewMail() | 94 | ViewMail::~ViewMail() |
95 | { | 95 | { |
96 | hide(); | 96 | hide(); |
97 | } | 97 | } |
98 | 98 | ||
99 | void ViewMail::hide() | 99 | void ViewMail::hide() |
100 | { | 100 | { |
101 | QWidget::hide(); | 101 | QWidget::hide(); |
102 | 102 | ||
103 | if (_inLoop) { | 103 | if (_inLoop) { |
104 | _inLoop = false; | 104 | _inLoop = false; |
105 | qApp->exit_loop(); | 105 | qApp->exit_loop(); |
106 | } | 106 | } |
107 | } | 107 | } |
108 | 108 | ||
109 | void ViewMail::exec() | 109 | void ViewMail::exec() |
110 | { | 110 | { |
111 | show(); | 111 | show(); |
112 | 112 | ||
113 | if (!_inLoop) { | 113 | if (!_inLoop) { |
114 | _inLoop = true; | 114 | _inLoop = true; |
115 | qApp->enter_loop(); | 115 | qApp->enter_loop(); |
116 | } | 116 | } |
117 | } | 117 | } |
118 | 118 | ||
119 | QString ViewMail::deHtml(const QString &string) | 119 | QString ViewMail::deHtml(const QString &string) |
120 | { | 120 | { |
121 | QString string_ = string; | 121 | QString string_ = string; |
122 | string_.replace(QRegExp("&"), "&"); | 122 | string_.replace(QRegExp("&"), "&"); |
123 | string_.replace(QRegExp("<"), "<"); | 123 | string_.replace(QRegExp("<"), "<"); |
124 | string_.replace(QRegExp(">"), ">"); | 124 | string_.replace(QRegExp(">"), ">"); |
125 | string_.replace(QRegExp("\\n"), "<br>"); | 125 | string_.replace(QRegExp("\\n"), "<br>"); |
126 | return string_; | 126 | return string_; |
127 | } | 127 | } |
128 | 128 | ||
129 | void ViewMail::slotReply() | 129 | void ViewMail::slotReply() |
130 | { | 130 | { |
131 | if (!_gotBody) { | 131 | if (!_gotBody) { |
132 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); | 132 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); |
133 | return; | 133 | return; |
134 | } | 134 | } |
135 | 135 | ||
136 | QString rtext; | 136 | QString rtext; |
137 | rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose | 137 | rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose |
138 | .arg( m_mail[1] ) | 138 | .arg( m_mail[1] ) |
139 | .arg( m_mail[3] ); | 139 | .arg( m_mail[3] ); |
140 | 140 | ||
141 | QString text = m_mail[2]; | 141 | QString text = m_mail[2]; |
142 | QStringList lines = QStringList::split(QRegExp("\\n"), text); | 142 | QStringList lines = QStringList::split(QRegExp("\\n"), text); |
143 | QStringList::Iterator it; | 143 | QStringList::Iterator it; |
144 | for (it = lines.begin(); it != lines.end(); it++) { | 144 | for (it = lines.begin(); it != lines.end(); it++) { |
145 | rtext += "> " + *it + "\n"; | 145 | rtext += "> " + *it + "\n"; |
146 | } | 146 | } |
147 | rtext += "\n"; | 147 | rtext += "\n"; |
148 | 148 | ||
149 | QString prefix; | 149 | QString prefix; |
150 | if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = ""; | 150 | if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = ""; |
151 | else prefix = "Re: "; // no i18n on purpose | 151 | else prefix = "Re: "; // no i18n on purpose |
152 | 152 | ||
153 | Settings *settings = new Settings(); | 153 | Settings *settings = new Settings(); |
154 | ComposeMail composer( settings ,this, 0, true); | 154 | ComposeMail composer( settings ,this, 0, true); |
155 | composer.setTo( m_mail[0] ); | 155 | composer.setTo( m_mail[0] ); |
156 | composer.setSubject( "Re: " + m_mail[1] ); | 156 | composer.setSubject( "Re: " + m_mail[1] ); |
157 | composer.setMessage( rtext ); | 157 | composer.setMessage( rtext ); |
158 | composer.showMaximized(); | 158 | composer.showMaximized(); |
159 | composer.exec(); | 159 | composer.exec(); |
160 | 160 | ||
161 | qDebug ( rtext ); | 161 | qDebug ( rtext ); |
162 | } | 162 | } |
163 | 163 | ||
164 | void ViewMail::slotForward() | 164 | void ViewMail::slotForward() |
165 | { | 165 | { |
166 | if (!_gotBody) { | 166 | if (!_gotBody) { |
167 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot forward yet."), tr("Ok")); | 167 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot forward yet."), tr("Ok")); |
168 | return; | 168 | return; |
169 | } | 169 | } |
170 | 170 | ||
171 | QString ftext; | 171 | QString ftext; |
172 | ftext += QString("\n----- Forwarded message from %1 -----\n\n") | 172 | ftext += QString("\n----- Forwarded message from %1 -----\n\n") |
173 | .arg( m_mail[0] ); | 173 | .arg( m_mail[0] ); |
174 | if (!m_mail[3].isNull()) | 174 | if (!m_mail[3].isNull()) |
175 | ftext += QString("Date: %1\n") | 175 | ftext += QString("Date: %1\n") |
176 | .arg( m_mail[3] ); | 176 | .arg( m_mail[3] ); |
177 | if (!m_mail[0].isNull()) | 177 | if (!m_mail[0].isNull()) |
178 | ftext += QString("From: %1\n") | 178 | ftext += QString("From: %1\n") |
179 | .arg( m_mail[0] ); | 179 | .arg( m_mail[0] ); |
180 | //if (!_mail.envelope().to().toString().isNull()) | 180 | //if (!_mail.envelope().to().toString().isNull()) |
181 | //ftext += QString("To: %1\n") | 181 | //ftext += QString("To: %1\n") |
182 | // .arg(_mail.envelope().to().toString()); | 182 | // .arg(_mail.envelope().to().toString()); |
183 | //if (!_mail.envelope().cc().toString().isNull()) | 183 | //if (!_mail.envelope().cc().toString().isNull()) |
184 | //ftext += QString("Cc: %1\n") | 184 | //ftext += QString("Cc: %1\n") |
185 | // .arg(_mail.envelope().cc().toString()); | 185 | // .arg(_mail.envelope().cc().toString()); |
186 | if (!m_mail[1].isNull()) | 186 | if (!m_mail[1].isNull()) |
187 | ftext += QString("Subject: %1\n") | 187 | ftext += QString("Subject: %1\n") |
188 | .arg( m_mail[1] ); | 188 | .arg( m_mail[1] ); |
189 | 189 | ||
190 | ftext += QString("\n%1\n") | 190 | ftext += QString("\n%1\n") |
191 | .arg( m_mail[2]); | 191 | .arg( m_mail[2]); |
192 | 192 | ||
193 | ftext += QString("----- End forwarded message -----\n"); | 193 | ftext += QString("----- End forwarded message -----\n"); |
194 | 194 | ||
195 | qDebug( ftext ); | 195 | qDebug( ftext ); |
196 | 196 | ||
197 | 197 | ||
198 | Settings *settings = new Settings(); | 198 | Settings *settings = new Settings(); |
199 | ComposeMail composer( settings ,this, 0, true); | 199 | ComposeMail composer( settings ,this, 0, true); |
200 | composer.setSubject( "Fwd: " + m_mail[1] ); | 200 | composer.setSubject( "Fwd: " + m_mail[1] ); |
201 | composer.setMessage( ftext ); | 201 | composer.setMessage( ftext ); |
202 | composer.showMaximized(); | 202 | composer.showMaximized(); |
203 | composer.exec(); | 203 | composer.exec(); |
204 | } | 204 | } |
205 | 205 | ||
206 | /* | 206 | /* |
207 | void ViewMail::slotIMAPUid(IMAPResponse &response) | 207 | void ViewMail::slotIMAPUid(IMAPResponse &response) |
208 | { | 208 | { |
209 | disconnect(_handler, SIGNAL(gotResponse(IMAPResponse &)), this, SLOT(slotIMAPUid(IMAPResponse &))); | 209 | disconnect(_handler, SIGNAL(gotResponse(IMAPResponse &)), this, SLOT(slotIMAPUid(IMAPResponse &))); |
210 | 210 | ||
211 | if (response.statusResponse().status() == IMAPResponseEnums::OK) { | 211 | if (response.statusResponse().status() == IMAPResponseEnums::OK) { |
212 | QValueList<IMAPResponseBodyPart> bodyParts; | 212 | QValueList<IMAPResponseBodyPart> bodyParts; |
213 | bodyParts.append(response.FETCH()[0].bodyPart(0)); | 213 | bodyParts.append(response.FETCH()[0].bodyPart(0)); |
214 | _mail.setBodyParts(bodyParts); | 214 | _mail.setBodyParts(bodyParts); |
215 | 215 | ||
216 | browser->setText(QString(_mailHtml).arg(deHtml(response.FETCH()[0].bodyPart(0).data()))); | 216 | browser->setText(QString(_mailHtml).arg(deHtml(response.FETCH()[0].bodyPart(0).data()))); |
217 | 217 | ||
218 | // fillList(response.FETCH()[0].bodyStructure()); | 218 | // fillList(response.FETCH()[0].bodyStructure()); |
219 | 219 | ||
220 | _gotBody = true; | 220 | _gotBody = true; |
221 | } else { | 221 | } else { |
222 | 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")); | 222 | 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")); |
223 | } | 223 | } |
224 | } | 224 | } |
225 | */ | 225 | */ |
diff --git a/noncore/net/mail/viewmail.h b/noncore/net/mail/viewmail.h index 615939a..258c09b 100644 --- a/noncore/net/mail/viewmail.h +++ b/noncore/net/mail/viewmail.h | |||
@@ -1,85 +1,85 @@ | |||
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 "imapresponse.h" | 9 | //#include "imapresponse.h" |
10 | //#include "mailtable.h" | 10 | //#include "mailtable.h" |
11 | 11 | ||
12 | class AttachItemStore | 12 | class AttachItemStore |
13 | { | 13 | { |
14 | public: | 14 | public: |
15 | void setMimeType(QString mimeType) { _mimeType = mimeType; } | 15 | void setMimeType(QString mimeType) { _mimeType = mimeType; } |
16 | QString mimeType() { return _mimeType; } | 16 | QString mimeType() { return _mimeType; } |
17 | void setFileName(QString fileName) { _fileName = fileName; } | 17 | void setFileName(QString fileName) { _fileName = fileName; } |
18 | QString fileName() { return _fileName; } | 18 | QString fileName() { return _fileName; } |
19 | void setDescription(QString description) { _description = description; } | 19 | void setDescription(QString description) { _description = description; } |
20 | QString description() { return _description; } | 20 | QString description() { return _description; } |
21 | void setPartNum(QString partNum) { _partNum = partNum; } | 21 | void setPartNum(QString partNum) { _partNum = partNum; } |
22 | QString partNum() { return _partNum; } | 22 | QString partNum() { return _partNum; } |
23 | 23 | ||
24 | private: | 24 | private: |
25 | QString _mimeType, _fileName, _description, _partNum; | 25 | QString _mimeType, _fileName, _description, _partNum; |
26 | 26 | ||
27 | }; | 27 | }; |
28 | 28 | ||
29 | class AttachItem : public QListViewItem | 29 | class AttachItem : public QListViewItem |
30 | { | 30 | { |
31 | public: | 31 | public: |
32 | AttachItem(QListView *parent, AttachItemStore &attachment); | 32 | AttachItem(QListView *parent, AttachItemStore &attachment); |
33 | AttachItem(QListViewItem *parent, AttachItemStore &attachment); | 33 | AttachItem(QListViewItem *parent, AttachItemStore &attachment); |
34 | 34 | ||
35 | AttachItemStore attachItemStore() { return _attachItemStore; } | 35 | AttachItemStore attachItemStore() { return _attachItemStore; } |
36 | 36 | ||
37 | private: | 37 | private: |
38 | AttachItemStore _attachItemStore; | 38 | AttachItemStore _attachItemStore; |
39 | 39 | ||
40 | }; | 40 | }; |
41 | 41 | ||
42 | class ViewMail : public ViewMailBase | 42 | class ViewMail : public ViewMailBase |
43 | { | 43 | { |
44 | Q_OBJECT | 44 | Q_OBJECT |
45 | 45 | ||
46 | public: | 46 | public: |
47 | ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal); | 47 | ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal); |
48 | ~ViewMail(); | 48 | ~ViewMail(); |
49 | 49 | ||
50 | void hide(); | 50 | void hide(); |
51 | void exec(); | 51 | void exec(); |
52 | static QString appName() { return QString::fromLatin1("mail"); } | 52 | static QString appName() { return QString::fromLatin1("mail"); } |
53 | void setMailInfo( const QString & from, const QStringList & to, const QString & subject, const QStringList & cc, const QStringList & bcc,const QString & date, const QString & bodytext ); | 53 | void setMailInfo( const QString & from, const QStringList & to, const QString & subject, const QStringList & cc, const QStringList & bcc,const QString & date, const QString & bodytext, const QString & messageID ); |
54 | 54 | ||
55 | protected: | 55 | protected: |
56 | //void fillList(IMAPResponseBODYSTRUCTURE &structure); | 56 | //void fillList(IMAPResponseBODYSTRUCTURE &structure); |
57 | QString deHtml(const QString &string); | 57 | QString deHtml(const QString &string); |
58 | 58 | ||
59 | protected slots: | 59 | protected slots: |
60 | void slotReply(); | 60 | void slotReply(); |
61 | void slotForward(); | 61 | void slotForward(); |
62 | void setText(); | 62 | void setText(); |
63 | 63 | ||
64 | //void slotIMAPUid(IMAPResponse &response); | 64 | //void slotIMAPUid(IMAPResponse &response); |
65 | 65 | ||
66 | private: | 66 | private: |
67 | bool _inLoop; | 67 | bool _inLoop; |
68 | //IMAPResponseFETCH _mail; | 68 | //IMAPResponseFETCH _mail; |
69 | //IMAPHandler *_handler; | 69 | //IMAPHandler *_handler; |
70 | QString _mailHtml; | 70 | QString _mailHtml; |
71 | bool _gotBody; | 71 | bool _gotBody; |
72 | 72 | ||
73 | // 0 from | 73 | // 0 from |
74 | // 1 subject | 74 | // 1 subject |
75 | // 2 bodytext | 75 | // 2 bodytext |
76 | // 3 date | 76 | // 3 date |
77 | QMap <int,QString> m_mail; | 77 | QMap <int,QString> m_mail; |
78 | // 0 to | 78 | // 0 to |
79 | // 1 cc | 79 | // 1 cc |
80 | // 2 bcc | 80 | // 2 bcc |
81 | QMap <int,QStringList> m_mail2; | 81 | QMap <int,QStringList> m_mail2; |
82 | 82 | ||
83 | }; | 83 | }; |
84 | 84 | ||
85 | #endif | 85 | #endif |