-rw-r--r-- | kmicromail/composemail.cpp | 24 | ||||
-rw-r--r-- | kmicromail/mailistviewitem.cpp | 77 | ||||
-rw-r--r-- | kmicromail/mailistviewitem.h | 7 | ||||
-rw-r--r-- | kmicromail/mainwindow.cpp | 10 | ||||
-rw-r--r-- | kmicromail/opiemail.cpp | 2 |
5 files changed, 75 insertions, 45 deletions
diff --git a/kmicromail/composemail.cpp b/kmicromail/composemail.cpp index ca4f247..c1b58a4 100644 --- a/kmicromail/composemail.cpp +++ b/kmicromail/composemail.cpp | |||
@@ -1,363 +1,363 @@ | |||
1 | 1 | ||
2 | #include "composemail.h" | 2 | #include "composemail.h" |
3 | 3 | ||
4 | #include <libmailwrapper/smtpwrapper.h> | 4 | #include <libmailwrapper/smtpwrapper.h> |
5 | #include <libmailwrapper/storemail.h> | 5 | #include <libmailwrapper/storemail.h> |
6 | #include <libmailwrapper/abstractmail.h> | 6 | #include <libmailwrapper/abstractmail.h> |
7 | #include <libmailwrapper/mailtypes.h> | 7 | #include <libmailwrapper/mailtypes.h> |
8 | 8 | ||
9 | /* OPIE */ | 9 | /* OPIE */ |
10 | //#include <opie2/ofiledialog.h> | 10 | //#include <opie2/ofiledialog.h> |
11 | //#include <opie2/odebug.h> | 11 | //#include <opie2/odebug.h> |
12 | #include <kfiledialog.h> | 12 | #include <kfiledialog.h> |
13 | //#include <qpe/resource.h> | 13 | //#include <qpe/resource.h> |
14 | #include <qpe/config.h> | 14 | #include <qpe/config.h> |
15 | #include <qpe/global.h> | 15 | #include <qpe/global.h> |
16 | //#include <qpe/contact.h> | 16 | //#include <qpe/contact.h> |
17 | 17 | ||
18 | 18 | ||
19 | #include <qcombobox.h> | 19 | #include <qcombobox.h> |
20 | #include <qcheckbox.h> | 20 | #include <qcheckbox.h> |
21 | #include <qtimer.h> | 21 | #include <qtimer.h> |
22 | #include <qmessagebox.h> | 22 | #include <qmessagebox.h> |
23 | #include <qpushbutton.h> | 23 | #include <qpushbutton.h> |
24 | #include <qmultilineedit.h> | 24 | #include <qmultilineedit.h> |
25 | #include <qlabel.h> | 25 | #include <qlabel.h> |
26 | #include <qtabwidget.h> | 26 | #include <qtabwidget.h> |
27 | #include <qlistview.h> | 27 | #include <qlistview.h> |
28 | #include <kabc/addresseedialog.h> | 28 | #include <kabc/addresseedialog.h> |
29 | #include <kabc/stdaddressbook.h> | 29 | #include <kabc/stdaddressbook.h> |
30 | #include <kabc/addressee.h> | 30 | #include <kabc/addressee.h> |
31 | 31 | ||
32 | 32 | ||
33 | 33 | ||
34 | //using namespace Opie::Core; | 34 | //using namespace Opie::Core; |
35 | //using namespace Opie::Ui; | 35 | //using namespace Opie::Ui; |
36 | ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal, WFlags flags ) | 36 | ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal, WFlags flags ) |
37 | : ComposeMailUI( parent, name, modal, flags ) | 37 | : ComposeMailUI( parent, name, modal, flags ) |
38 | { | 38 | { |
39 | 39 | ||
40 | settings = s; | 40 | settings = s; |
41 | m_replyid = ""; | 41 | m_replyid = ""; |
42 | KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( ); | 42 | KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( ); |
43 | QStringList mails = con.emails(); | 43 | QStringList mails = con.emails(); |
44 | QString defmail = con.preferredEmail(); | 44 | QString defmail = con.preferredEmail(); |
45 | if ( mails.count() == 0) | 45 | if ( mails.count() == 0) |
46 | QMessageBox::information( parentWidget(), tr( "Hint" ), | 46 | QMessageBox::information( 0, tr( "Hint" ), |
47 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!" ), | 47 | tr( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), |
48 | tr( "Ok" ) ); | 48 | tr( "Ok" ) ); |
49 | if (defmail.length()!=0) { | 49 | if (defmail.length()!=0) { |
50 | fromBox->insertItem(defmail); | 50 | fromBox->insertItem(defmail); |
51 | } | 51 | } |
52 | QStringList::ConstIterator sit = mails.begin(); | 52 | QStringList::ConstIterator sit = mails.begin(); |
53 | for (;sit!=mails.end();++sit) { | 53 | for (;sit!=mails.end();++sit) { |
54 | if ( (*sit)==defmail) | 54 | if ( (*sit)==defmail) |
55 | continue; | 55 | continue; |
56 | fromBox->insertItem((*sit)); | 56 | fromBox->insertItem((*sit)); |
57 | } | 57 | } |
58 | senderNameEdit->setText(con.formattedName()); | 58 | senderNameEdit->setText(con.formattedName()); |
59 | Config cfg( "mail" ); | 59 | Config cfg( "mail" ); |
60 | cfg.setGroup( "Compose" ); | 60 | cfg.setGroup( "Compose" ); |
61 | checkBoxLater->setChecked( cfg.readBoolEntry( "sendLater", false ) ); | 61 | checkBoxLater->setChecked( cfg.readBoolEntry( "sendLater", false ) ); |
62 | 62 | ||
63 | attList->addColumn( tr( "Name" ) ); | 63 | attList->addColumn( tr( "Name" ) ); |
64 | attList->addColumn( tr( "Size" ) ); | 64 | attList->addColumn( tr( "Size" ) ); |
65 | 65 | ||
66 | QList<Account> accounts = settings->getAccounts(); | 66 | QList<Account> accounts = settings->getAccounts(); |
67 | 67 | ||
68 | Account *it; | 68 | Account *it; |
69 | for ( it = accounts.first(); it; it = accounts.next() ) { | 69 | for ( it = accounts.first(); it; it = accounts.next() ) { |
70 | if ( it->getType()==MAILLIB::A_SMTP ) { | 70 | if ( it->getType()==MAILLIB::A_SMTP ) { |
71 | SMTPaccount *smtp = static_cast<SMTPaccount *>(it); | 71 | SMTPaccount *smtp = static_cast<SMTPaccount *>(it); |
72 | smtpAccountBox->insertItem( smtp->getAccountName() ); | 72 | smtpAccountBox->insertItem( smtp->getAccountName() ); |
73 | smtpAccounts.append( smtp ); | 73 | smtpAccounts.append( smtp ); |
74 | } | 74 | } |
75 | } | 75 | } |
76 | if ( smtpAccounts.count() > 0 ) { | ||
77 | fillValues( smtpAccountBox->currentItem() ); | ||
78 | } else { | ||
79 | QMessageBox::information( parentWidget(), tr( "Problem" ), | ||
80 | tr( "Please create an SMTP account first.\nThe SMTP is needed for sending mail." ), | ||
81 | tr( "Ok" ) ); | ||
82 | return; | ||
83 | } | ||
84 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); | 76 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); |
85 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); | 77 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); |
86 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); | 78 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); |
87 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); | 79 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); |
88 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); | 80 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); |
89 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); | 81 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); |
90 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); | 82 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); |
91 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); | 83 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); |
92 | mMail = 0; | 84 | mMail = 0; |
93 | warnAttach = true; | 85 | warnAttach = true; |
86 | if ( smtpAccounts.count() > 0 ) { | ||
87 | fillValues( smtpAccountBox->currentItem() ); | ||
88 | } else { | ||
89 | QMessageBox::information( 0, tr( "Problem" ), | ||
90 | tr( "Please create an SMTP account first.\nThe SMTP is needed for sending mail.\n" ), | ||
91 | tr( "Ok" ) ); | ||
92 | return; | ||
93 | } | ||
94 | } | 94 | } |
95 | void ComposeMail::saveAsDraft() | 95 | void ComposeMail::saveAsDraft() |
96 | { | 96 | { |
97 | 97 | ||
98 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); | 98 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); |
99 | mail->setMail(fromBox->currentText()); | 99 | mail->setMail(fromBox->currentText()); |
100 | mail->setTo( toLine->text() ); | 100 | mail->setTo( toLine->text() ); |
101 | mail->setName(senderNameEdit->text()); | 101 | mail->setName(senderNameEdit->text()); |
102 | mail->setCC( ccLine->text() ); | 102 | mail->setCC( ccLine->text() ); |
103 | mail->setBCC( bccLine->text() ); | 103 | mail->setBCC( bccLine->text() ); |
104 | mail->setReply( replyLine->text() ); | 104 | mail->setReply( replyLine->text() ); |
105 | mail->setSubject( subjectLine->text() ); | 105 | mail->setSubject( subjectLine->text() ); |
106 | if (!m_replyid.isEmpty()) { | 106 | if (!m_replyid.isEmpty()) { |
107 | QStringList ids; | 107 | QStringList ids; |
108 | ids.append(m_replyid); | 108 | ids.append(m_replyid); |
109 | mail->setInreply(ids); | 109 | mail->setInreply(ids); |
110 | } | 110 | } |
111 | QString txt = message->text(); | 111 | QString txt = message->text(); |
112 | if ( !sigMultiLine->text().isEmpty() ) { | 112 | if ( !sigMultiLine->text().isEmpty() ) { |
113 | txt.append( "\n--\n" ); | 113 | txt.append( "\n--\n" ); |
114 | txt.append( sigMultiLine->text() ); | 114 | txt.append( sigMultiLine->text() ); |
115 | } | 115 | } |
116 | mail->setMessage( txt ); | 116 | mail->setMessage( txt ); |
117 | 117 | ||
118 | /* only use the default drafts folder name! */ | 118 | /* only use the default drafts folder name! */ |
119 | Storemail wrapper(AbstractMail::draftFolder()); | 119 | Storemail wrapper(AbstractMail::draftFolder()); |
120 | wrapper.storeMail(mail); | 120 | wrapper.storeMail(mail); |
121 | 121 | ||
122 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); | 122 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); |
123 | /* attachments we will ignore! */ | 123 | /* attachments we will ignore! */ |
124 | if ( it != 0 ) { | 124 | if ( it != 0 ) { |
125 | if ( warnAttach ) | 125 | if ( warnAttach ) |
126 | QMessageBox::warning(0,tr("Store message"), | 126 | QMessageBox::warning(0,tr("Store message"), |
127 | tr("<center>Attachments will not be stored in \"Draft\" folder</center>")); | 127 | tr("<center>Attachments will not be stored in \"Draft\" folder</center>")); |
128 | warnAttach = false; | 128 | warnAttach = false; |
129 | } | 129 | } |
130 | setStatus( tr("Mail saved as draft!") ); | 130 | setStatus( tr("Mail saved as draft!") ); |
131 | } | 131 | } |
132 | void ComposeMail::clearStatus() | 132 | void ComposeMail::clearStatus() |
133 | { | 133 | { |
134 | topLevelWidget()->setCaption( tr("Compose mail") ); | 134 | topLevelWidget()->setCaption( tr("Compose mail") ); |
135 | } | 135 | } |
136 | void ComposeMail::setStatus( QString status ) | 136 | void ComposeMail::setStatus( QString status ) |
137 | { | 137 | { |
138 | topLevelWidget()->setCaption( status ); | 138 | topLevelWidget()->setCaption( status ); |
139 | QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ; | 139 | QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ; |
140 | } | 140 | } |
141 | void ComposeMail::pickAddress( QLineEdit *line ) | 141 | void ComposeMail::pickAddress( QLineEdit *line ) |
142 | { | 142 | { |
143 | //qDebug(" ComposeMail::pickAddress "); | 143 | //qDebug(" ComposeMail::pickAddress "); |
144 | QString names ;//= AddressPicker::getNames(); | 144 | QString names ;//= AddressPicker::getNames(); |
145 | 145 | ||
146 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); | 146 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); |
147 | uint i=0; | 147 | uint i=0; |
148 | for (i=0; i < list.count(); i++) { | 148 | for (i=0; i < list.count(); i++) { |
149 | if ( !list[i].preferredEmail().isEmpty()) { | 149 | if ( !list[i].preferredEmail().isEmpty()) { |
150 | names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">"; | 150 | names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">"; |
151 | if ( i < list.count() -1 ) | 151 | if ( i < list.count() -1 ) |
152 | names+= ","; | 152 | names+= ","; |
153 | } | 153 | } |
154 | } | 154 | } |
155 | 155 | ||
156 | 156 | ||
157 | if ( line->text().isEmpty() ) { | 157 | if ( line->text().isEmpty() ) { |
158 | line->setText( names ); | 158 | line->setText( names ); |
159 | } else if ( !names.isEmpty() ) { | 159 | } else if ( !names.isEmpty() ) { |
160 | line->setText( line->text() + ", " + names ); | 160 | line->setText( line->text() + ", " + names ); |
161 | } | 161 | } |
162 | } | 162 | } |
163 | 163 | ||
164 | 164 | ||
165 | void ComposeMail::setTo( const QString & to ) | 165 | void ComposeMail::setTo( const QString & to ) |
166 | { | 166 | { |
167 | toLine->setText( to ); | 167 | toLine->setText( to ); |
168 | } | 168 | } |
169 | 169 | ||
170 | void ComposeMail::setSubject( const QString & subject ) | 170 | void ComposeMail::setSubject( const QString & subject ) |
171 | { | 171 | { |
172 | subjectLine->setText( subject ); | 172 | subjectLine->setText( subject ); |
173 | } | 173 | } |
174 | 174 | ||
175 | void ComposeMail::setInReplyTo( const QString & messageId ) | 175 | void ComposeMail::setInReplyTo( const QString & messageId ) |
176 | { | 176 | { |
177 | m_replyid = messageId; | 177 | m_replyid = messageId; |
178 | } | 178 | } |
179 | 179 | ||
180 | void ComposeMail::setMessage( const QString & text ) | 180 | void ComposeMail::setMessage( const QString & text ) |
181 | { | 181 | { |
182 | message->setText( text ); | 182 | message->setText( text ); |
183 | } | 183 | } |
184 | 184 | ||
185 | 185 | ||
186 | void ComposeMail::pickAddressTo() | 186 | void ComposeMail::pickAddressTo() |
187 | { | 187 | { |
188 | pickAddress( toLine ); | 188 | pickAddress( toLine ); |
189 | } | 189 | } |
190 | 190 | ||
191 | void ComposeMail::pickAddressCC() | 191 | void ComposeMail::pickAddressCC() |
192 | { | 192 | { |
193 | pickAddress( ccLine ); | 193 | pickAddress( ccLine ); |
194 | } | 194 | } |
195 | 195 | ||
196 | void ComposeMail::pickAddressBCC() | 196 | void ComposeMail::pickAddressBCC() |
197 | { | 197 | { |
198 | pickAddress( bccLine ); | 198 | pickAddress( bccLine ); |
199 | } | 199 | } |
200 | 200 | ||
201 | void ComposeMail::pickAddressReply() | 201 | void ComposeMail::pickAddressReply() |
202 | { | 202 | { |
203 | pickAddress( replyLine ); | 203 | pickAddress( replyLine ); |
204 | } | 204 | } |
205 | 205 | ||
206 | void ComposeMail::fillValues( int ) | 206 | void ComposeMail::fillValues( int ) |
207 | { | 207 | { |
208 | #if 0 | 208 | #if 0 |
209 | SMTPaccount *smtp = smtpAccounts.at( current ); | 209 | SMTPaccount *smtp = smtpAccounts.at( current ); |
210 | ccLine->clear(); | 210 | ccLine->clear(); |
211 | if ( smtp->getUseCC() ) { | 211 | if ( smtp->getUseCC() ) { |
212 | ccLine->setText( smtp->getCC() ); | 212 | ccLine->setText( smtp->getCC() ); |
213 | } | 213 | } |
214 | bccLine->clear(); | 214 | bccLine->clear(); |
215 | if ( smtp->getUseBCC() ) { | 215 | if ( smtp->getUseBCC() ) { |
216 | bccLine->setText( smtp->getBCC() ); | 216 | bccLine->setText( smtp->getBCC() ); |
217 | } | 217 | } |
218 | replyLine->clear(); | 218 | replyLine->clear(); |
219 | if ( smtp->getUseReply() ) { | 219 | if ( smtp->getUseReply() ) { |
220 | replyLine->setText( smtp->getReply() ); | 220 | replyLine->setText( smtp->getReply() ); |
221 | } | 221 | } |
222 | sigMultiLine->setText( smtp->getSignature() ); | 222 | sigMultiLine->setText( smtp->getSignature() ); |
223 | #endif | 223 | #endif |
224 | } | 224 | } |
225 | 225 | ||
226 | void ComposeMail::slotAdjustColumns() | 226 | void ComposeMail::slotAdjustColumns() |
227 | { | 227 | { |
228 | int currPage = tabWidget->currentPageIndex(); | 228 | int currPage = tabWidget->currentPageIndex(); |
229 | 229 | ||
230 | tabWidget->showPage( attachTab ); | 230 | tabWidget->showPage( attachTab ); |
231 | attList->setColumnWidth( 0, attList->visibleWidth() - 80 ); | 231 | attList->setColumnWidth( 0, attList->visibleWidth() - 80 ); |
232 | attList->setColumnWidth( 1, 80 ); | 232 | attList->setColumnWidth( 1, 80 ); |
233 | 233 | ||
234 | tabWidget->setCurrentPage( currPage ); | 234 | tabWidget->setCurrentPage( currPage ); |
235 | } | 235 | } |
236 | 236 | ||
237 | void ComposeMail::addAttachment() | 237 | void ComposeMail::addAttachment() |
238 | { | 238 | { |
239 | QString lnk = KFileDialog::getOpenFileName( "", "Add Attachment", this ); | 239 | QString lnk = KFileDialog::getOpenFileName( "", "Add Attachment", this ); |
240 | if ( !lnk.isEmpty() ) { | 240 | if ( !lnk.isEmpty() ) { |
241 | Attachment *att = new Attachment( lnk ); | 241 | Attachment *att = new Attachment( lnk ); |
242 | (void) new AttachViewItem( attList, att ); | 242 | (void) new AttachViewItem( attList, att ); |
243 | } | 243 | } |
244 | } | 244 | } |
245 | 245 | ||
246 | void ComposeMail::removeAttachment() | 246 | void ComposeMail::removeAttachment() |
247 | { | 247 | { |
248 | if ( !attList->currentItem() ) { | 248 | if ( !attList->currentItem() ) { |
249 | QMessageBox::information( this, tr( "Error" ), | 249 | QMessageBox::information( this, tr( "Error" ), |
250 | tr( "<p>Please select a File.</p>" ), | 250 | tr( "<p>Please select a File.</p>" ), |
251 | tr( "Ok" ) ); | 251 | tr( "Ok" ) ); |
252 | } else { | 252 | } else { |
253 | attList->takeItem( attList->currentItem() ); | 253 | attList->takeItem( attList->currentItem() ); |
254 | } | 254 | } |
255 | } | 255 | } |
256 | 256 | ||
257 | void ComposeMail::accept() | 257 | void ComposeMail::accept() |
258 | { | 258 | { |
259 | if (! checkBoxLater->isChecked() ) { | 259 | if (! checkBoxLater->isChecked() ) { |
260 | int yesno = QMessageBox::warning(0,tr("Stop editing message"), | 260 | int yesno = QMessageBox::warning(0,tr("Stop editing message"), |
261 | tr("Send this message?"), | 261 | tr("Send this message?"), |
262 | tr("Yes"), | 262 | tr("Yes"), |
263 | tr("Cancel")); | 263 | tr("Cancel")); |
264 | 264 | ||
265 | if (yesno == 1) { | 265 | if (yesno == 1) { |
266 | return; | 266 | return; |
267 | } | 267 | } |
268 | } | 268 | } |
269 | #if 0 | 269 | #if 0 |
270 | odebug << "Sending Mail with " | 270 | odebug << "Sending Mail with " |
271 | << smtpAccounts.at( smtpAccountBox->currentItem() )->getAccountName() << oendl; | 271 | << smtpAccounts.at( smtpAccountBox->currentItem() )->getAccountName() << oendl; |
272 | #endif | 272 | #endif |
273 | Opie::Core::OSmartPointer<Mail> mail=new Mail; | 273 | Opie::Core::OSmartPointer<Mail> mail=new Mail; |
274 | 274 | ||
275 | SMTPaccount *smtp = smtpAccounts.at( smtpAccountBox->currentItem() ); | 275 | SMTPaccount *smtp = smtpAccounts.at( smtpAccountBox->currentItem() ); |
276 | mail->setMail(fromBox->currentText()); | 276 | mail->setMail(fromBox->currentText()); |
277 | 277 | ||
278 | if ( !toLine->text().isEmpty() ) { | 278 | if ( !toLine->text().isEmpty() ) { |
279 | mail->setTo( toLine->text() ); | 279 | mail->setTo( toLine->text() ); |
280 | } else { | 280 | } else { |
281 | QMessageBox::warning(0,tr("Sending mail"), | 281 | QMessageBox::warning(0,tr("Sending mail"), |
282 | tr("No Receiver spezified" ) ); | 282 | tr("No Receiver spezified" ) ); |
283 | return; | 283 | return; |
284 | } | 284 | } |
285 | 285 | ||
286 | mail->setName(senderNameEdit->text()); | 286 | mail->setName(senderNameEdit->text()); |
287 | mail->setCC( ccLine->text() ); | 287 | mail->setCC( ccLine->text() ); |
288 | mail->setBCC( bccLine->text() ); | 288 | mail->setBCC( bccLine->text() ); |
289 | mail->setReply( replyLine->text() ); | 289 | mail->setReply( replyLine->text() ); |
290 | mail->setSubject( subjectLine->text() ); | 290 | mail->setSubject( subjectLine->text() ); |
291 | if (!m_replyid.isEmpty()) { | 291 | if (!m_replyid.isEmpty()) { |
292 | QStringList ids; | 292 | QStringList ids; |
293 | ids.append(m_replyid); | 293 | ids.append(m_replyid); |
294 | mail->setInreply(ids); | 294 | mail->setInreply(ids); |
295 | } | 295 | } |
296 | QString txt = message->text(); | 296 | QString txt = message->text(); |
297 | if ( !sigMultiLine->text().isEmpty() ) { | 297 | if ( !sigMultiLine->text().isEmpty() ) { |
298 | txt.append( "\n--\n" ); | 298 | txt.append( "\n--\n" ); |
299 | txt.append( sigMultiLine->text() ); | 299 | txt.append( sigMultiLine->text() ); |
300 | } | 300 | } |
301 | mail->setMessage( txt ); | 301 | mail->setMessage( txt ); |
302 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); | 302 | AttachViewItem *it = (AttachViewItem *) attList->firstChild(); |
303 | while ( it != 0 ) { | 303 | while ( it != 0 ) { |
304 | mail->addAttachment( it->getAttachment() ); | 304 | mail->addAttachment( it->getAttachment() ); |
305 | it = (AttachViewItem *) it->nextSibling(); | 305 | it = (AttachViewItem *) it->nextSibling(); |
306 | } | 306 | } |
307 | 307 | ||
308 | SMTPwrapper wrapper( smtp ); | 308 | SMTPwrapper wrapper( smtp ); |
309 | if ( wrapper.sendMail( mail,checkBoxLater->isChecked() ) ) | 309 | if ( wrapper.sendMail( mail,checkBoxLater->isChecked() ) ) |
310 | setStatus( tr ("Mail sent")); | 310 | setStatus( tr ("Mail sent")); |
311 | else { | 311 | else { |
312 | setStatus( tr ("Error: Something went wrong. Nothing sent")); | 312 | setStatus( tr ("Error: Something went wrong. Nothing sent")); |
313 | return; | 313 | return; |
314 | } | 314 | } |
315 | 315 | ||
316 | 316 | ||
317 | QDialog::accept(); | 317 | QDialog::accept(); |
318 | } | 318 | } |
319 | 319 | ||
320 | void ComposeMail::reject() | 320 | void ComposeMail::reject() |
321 | { | 321 | { |
322 | //qDebug("ComposeMail::reject() "); | 322 | //qDebug("ComposeMail::reject() "); |
323 | int yesno = QMessageBox::warning(0,tr("Stop editing message"), | 323 | int yesno = QMessageBox::warning(0,tr("Store message?"), |
324 | tr("Store message into drafts?"), | 324 | tr("Store message into drafts?\n"), |
325 | tr("Yes"), | 325 | tr("Yes"), |
326 | tr("No")); | 326 | tr("No")); |
327 | 327 | ||
328 | //qDebug("button %d ", yesno); | 328 | //qDebug("button %d ", yesno); |
329 | if (yesno == 0) { | 329 | if (yesno == 0) { |
330 | saveAsDraft(); | 330 | saveAsDraft(); |
331 | } | 331 | } |
332 | if (yesno == 2) { | 332 | if (yesno == 2) { |
333 | qDebug("return "); | 333 | qDebug("return "); |
334 | return; | 334 | return; |
335 | } | 335 | } |
336 | QDialog::reject(); | 336 | QDialog::reject(); |
337 | } | 337 | } |
338 | 338 | ||
339 | ComposeMail::~ComposeMail() | 339 | ComposeMail::~ComposeMail() |
340 | { | 340 | { |
341 | } | 341 | } |
342 | 342 | ||
343 | void ComposeMail::reEditMail(const RecMailP¤t) | 343 | void ComposeMail::reEditMail(const RecMailP¤t) |
344 | { | 344 | { |
345 | RecMailP data = current; | 345 | RecMailP data = current; |
346 | message->setText(data->Wrapper()->fetchBody(current)->Bodytext()); | 346 | message->setText(data->Wrapper()->fetchBody(current)->Bodytext()); |
347 | subjectLine->setText( data->getSubject()); | 347 | subjectLine->setText( data->getSubject()); |
348 | toLine->setText(data->To().join(",")); | 348 | toLine->setText(data->To().join(",")); |
349 | ccLine->setText(data->CC().join(",")); | 349 | ccLine->setText(data->CC().join(",")); |
350 | bccLine->setText(data->Bcc().join(",")); | 350 | bccLine->setText(data->Bcc().join(",")); |
351 | replyLine->setText(data->Replyto()); | 351 | replyLine->setText(data->Replyto()); |
352 | } | 352 | } |
353 | 353 | ||
354 | AttachViewItem::AttachViewItem( QListView *parent, Attachment *att ) | 354 | AttachViewItem::AttachViewItem( QListView *parent, Attachment *att ) |
355 | : QListViewItem( parent ) | 355 | : QListViewItem( parent ) |
356 | { | 356 | { |
357 | attachment = att; | 357 | attachment = att; |
358 | if ( !attachment->getPixmap().isNull() ) | 358 | if ( !attachment->getPixmap().isNull() ) |
359 | setPixmap( 0,attachment->getPixmap() ); | 359 | setPixmap( 0,attachment->getPixmap() ); |
360 | setText( 0, att->getName().isEmpty() ? att->getFileName() : att->getName() ); | 360 | setText( 0, att->getName().isEmpty() ? att->getFileName() : att->getName() ); |
361 | setText( 1, QString::number( att->getSize() ) ); | 361 | setText( 1, QString::number( att->getSize() ) ); |
362 | } | 362 | } |
363 | 363 | ||
diff --git a/kmicromail/mailistviewitem.cpp b/kmicromail/mailistviewitem.cpp index b9b4cd9..1ca0ada 100644 --- a/kmicromail/mailistviewitem.cpp +++ b/kmicromail/mailistviewitem.cpp | |||
@@ -1,115 +1,142 @@ | |||
1 | #include "mailistviewitem.h" | 1 | #include "mailistviewitem.h" |
2 | #include <libmailwrapper/abstractmail.h> | 2 | #include <libmailwrapper/abstractmail.h> |
3 | #include <qtextstream.h> | 3 | #include <qtextstream.h> |
4 | #include <kiconloader.h> | 4 | #include <kiconloader.h> |
5 | //#include <qpe/resource.h> | 5 | //#include <qpe/resource.h> |
6 | 6 | ||
7 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) | 7 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) |
8 | :QListViewItem(parent,item),mail_data() | 8 | :QListViewItem(parent,item),mail_data() |
9 | { | 9 | { |
10 | } | 10 | } |
11 | 11 | ||
12 | void MailListViewItem::showEntry() | 12 | void MailListViewItem::showEntry() |
13 | { | 13 | { |
14 | if ( mail_data->getFlags().testBit( FLAG_ANSWERED ) == true) { | 14 | if ( mail_data->getFlags().testBit( FLAG_ANSWERED ) == true) { |
15 | setPixmap( 0, SmallIcon ( "kmmsgreplied") ); | 15 | setPixmap( 0, SmallIcon ( "kmmsgreplied") ); |
16 | } else if ( mail_data->getFlags().testBit( FLAG_SEEN ) == true ) { | 16 | } else if ( mail_data->getFlags().testBit( FLAG_SEEN ) == true ) { |
17 | /* I think it looks nicer if there are not such a log of icons but only on mails | 17 | /* I think it looks nicer if there are not such a log of icons but only on mails |
18 | replied or new - Alwin*/ | 18 | replied or new - Alwin*/ |
19 | //setPixmap( 0,SmallIcon ("kmmsgunseen") ); | 19 | //setPixmap( 0,SmallIcon ("kmmsgunseen") ); |
20 | } else { | 20 | } else { |
21 | setPixmap( 0,SmallIcon ( "kmmsgnew") ); | 21 | setPixmap( 0,SmallIcon ( "kmmsgnew") ); |
22 | } | 22 | } |
23 | double s = mail_data->Msgsize(); | 23 | double s = mail_data->Msgsize(); |
24 | int w; | 24 | int w = 0; |
25 | w=0; | 25 | s/=1024; |
26 | 26 | if (s>999.0) { | |
27 | while (s>1024) { | 27 | s/=1024.0; |
28 | s/=1024; | ||
29 | ++w; | 28 | ++w; |
30 | if (w>=2) break; | ||
31 | } | 29 | } |
32 | 30 | QString fsort; | |
33 | QString q=""; | 31 | fsort.sprintf( "%.2f", s ); |
34 | QString fsize=""; | 32 | QString fsize = QString::number( s, 'f', 2 ); |
35 | switch(w) { | 33 | // 1.23 |
36 | case 1: | 34 | // 11.23 |
37 | q="k"; | 35 | // 111.23 |
36 | // 999.23 maxlen | ||
37 | switch(fsize.length() ) { | ||
38 | case 4: | ||
39 | fsort = "00" + fsize ; | ||
38 | break; | 40 | break; |
39 | case 2: | 41 | case 5: |
40 | q="M"; | 42 | fsort = "0" + fsize ; |
41 | break; | 43 | break; |
42 | default: | 44 | default: |
43 | break; | 45 | fsort = fsize ; |
46 | break; | ||
47 | |||
44 | } | 48 | } |
45 | 49 | if ( w == 0 ) { | |
46 | { | 50 | setText(3, fsize + "kB" ); |
47 | QTextOStream o(&fsize); | 51 | mKeyMap.insert(3, "k" + fsort); |
48 | if (w>0) o.precision(2); else o.precision(0); | 52 | //setText(3, "kB" + fsort ); // test only |
49 | o.setf(QTextStream::fixed); | 53 | } else { |
50 | o << s << " " << q << "Byte"; | 54 | //setText(3, fsize + "MB"); |
55 | mKeyMap.insert(4, "M" +fsort ); | ||
51 | } | 56 | } |
52 | |||
53 | setText(1,mail_data->getSubject()); | 57 | setText(1,mail_data->getSubject()); |
54 | setText(2,mail_data->getFrom()); | 58 | setText(2,mail_data->getFrom()); |
55 | setText(3,fsize); | 59 | |
56 | QString date = mail_data->getDate(); | 60 | QString date = mail_data->getDate(); |
57 | 61 | ||
58 | int kom = date.find( ",")+2; | 62 | int kom = date.find( ",")+2; |
59 | if ( kom == 1 ) | 63 | if ( kom == 1 ) |
60 | kom = 0; | 64 | kom = 0; |
61 | if ( date.mid(kom,1) == " ") | 65 | if ( date.mid(kom,1) == " ") |
62 | ++kom; | 66 | ++kom; |
63 | if ( date.mid(kom+1,1) == " " ) | 67 | if ( date.mid(kom+1,1) == " " ) |
64 | date = "0" + date.mid( kom ); | 68 | date = "0" + date.mid( kom ); |
65 | else if ( kom ) | 69 | else if ( kom ) |
66 | date = date.mid( kom ); | 70 | date = date.mid( kom ); |
67 | if ( kom || date.mid(2,1 ) == " ") { | 71 | if ( kom || date.mid(2,1 ) == " ") { |
68 | QString mon = date.mid(3,3); | 72 | QString mon = date.mid(3,3); |
69 | QString so = 00; | 73 | QString so = 00; |
70 | if ( mon == "Jan" ) | 74 | if ( mon == "Jan" ) |
71 | so = "01"; | 75 | so = "01"; |
72 | else if ( mon == "Feb" ) | 76 | else if ( mon == "Feb" ) |
73 | so = "02"; | 77 | so = "02"; |
74 | else if ( mon == "Mar" ) | 78 | else if ( mon == "Mar" ) |
75 | so = "03"; | 79 | so = "03"; |
76 | else if ( mon == "Apr" ) | 80 | else if ( mon == "Apr" ) |
77 | so = "04"; | 81 | so = "04"; |
78 | else if ( mon == "May" ) | 82 | else if ( mon == "May" ) |
79 | so = "05"; | 83 | so = "05"; |
80 | else if ( mon == "Jun" ) | 84 | else if ( mon == "Jun" ) |
81 | so = "06"; | 85 | so = "06"; |
82 | else if ( mon == "Jul" ) | 86 | else if ( mon == "Jul" ) |
83 | so = "07"; | 87 | so = "07"; |
84 | else if ( mon == "Aug" ) | 88 | else if ( mon == "Aug" ) |
85 | so = "08"; | 89 | so = "08"; |
86 | else if ( mon == "Sep" ) | 90 | else if ( mon == "Sep" ) |
87 | so = "09"; | 91 | so = "09"; |
88 | else if ( mon == "Oct" ) | 92 | else if ( mon == "Oct" ) |
89 | so = "10"; | 93 | so = "10"; |
90 | else if ( mon == "Nov" ) | 94 | else if ( mon == "Nov" ) |
91 | so = "11"; | 95 | so = "11"; |
92 | else if ( mon == "Dec" ) | 96 | else if ( mon == "Dec" ) |
93 | so = "12"; | 97 | so = "12"; |
94 | date = date.mid(7,4)+"-"+so+"-"+date.left(2)+" "+date.mid(12,14); | 98 | date = date.mid(7,4)+so+date.left(2)+date.mid(12,14); |
95 | } | 99 | } |
96 | // if ( date.left(1) != "1" || date.left(1) != "2" ) | 100 | // if ( date.left(1) != "1" || date.left(1) != "2" ) |
97 | // date = date.mid(5); | 101 | // date = date.mid(5); |
98 | setText(4,date); | 102 | mKeyMap.insert(4,date); |
103 | setText(4,mail_data->getDate()); | ||
99 | } | 104 | } |
100 | 105 | ||
101 | void MailListViewItem::storeData(const RecMailP&data) | 106 | void MailListViewItem::storeData(const RecMailP&data) |
102 | { | 107 | { |
103 | mail_data = data; | 108 | mail_data = data; |
104 | } | 109 | } |
110 | void MailListViewItem::setSortKey(int column,const QString &key) | ||
111 | { | ||
112 | mKeyMap.insert(column,key); | ||
113 | } | ||
114 | QString MailListViewItem::key(int column, bool) const | ||
115 | { | ||
116 | // to make is fast, we use here special cases | ||
117 | if ( column == 3 || column == 4 ) { | ||
118 | return *mKeyMap.find(column); | ||
119 | } | ||
120 | if ( column == 1 ) { | ||
121 | if ( text(1).left(4).lower() == "re: " ) | ||
122 | return text(1).mid(4); | ||
123 | |||
124 | } | ||
125 | return text(column); | ||
126 | /* | ||
127 | QMap<int,QString>::ConstIterator it = mKeyMap.find(column); | ||
128 | if (it == mKeyMap.end()) return text(column); | ||
129 | else return *it; | ||
130 | */ | ||
131 | } | ||
105 | 132 | ||
106 | const RecMailP& MailListViewItem::data()const | 133 | const RecMailP& MailListViewItem::data()const |
107 | { | 134 | { |
108 | return mail_data; | 135 | return mail_data; |
109 | } | 136 | } |
110 | 137 | ||
111 | MAILLIB::ATYPE MailListViewItem::wrapperType() | 138 | MAILLIB::ATYPE MailListViewItem::wrapperType() |
112 | { | 139 | { |
113 | if (!mail_data->Wrapper()) return MAILLIB::A_UNDEFINED; | 140 | if (!mail_data->Wrapper()) return MAILLIB::A_UNDEFINED; |
114 | return mail_data->Wrapper()->getType(); | 141 | return mail_data->Wrapper()->getType(); |
115 | } | 142 | } |
diff --git a/kmicromail/mailistviewitem.h b/kmicromail/mailistviewitem.h index d953d83..cf8040b 100644 --- a/kmicromail/mailistviewitem.h +++ b/kmicromail/mailistviewitem.h | |||
@@ -1,23 +1,26 @@ | |||
1 | #ifndef __MAILLISTVIEWITEM_H | 1 | #ifndef __MAILLISTVIEWITEM_H |
2 | #define __MAILLISTVIEWITEM_H | 2 | #define __MAILLISTVIEWITEM_H |
3 | 3 | ||
4 | #include <qlistview.h> | 4 | #include <qlistview.h> |
5 | #include <libmailwrapper/mailtypes.h> | 5 | #include <libmailwrapper/mailtypes.h> |
6 | #include <libmailwrapper/maildefines.h> | 6 | #include <libmailwrapper/maildefines.h> |
7 | 7 | ||
8 | class MailListViewItem:public QListViewItem | 8 | class MailListViewItem:public QListViewItem |
9 | { | 9 | { |
10 | public: | 10 | public: |
11 | MailListViewItem(QListView * parent, MailListViewItem * after ); | 11 | MailListViewItem(QListView * parent, MailListViewItem * after ); |
12 | virtual ~MailListViewItem(){} | 12 | virtual ~MailListViewItem(){} |
13 | 13 | ||
14 | void storeData(const RecMailP&data); | 14 | void storeData(const RecMailP&data); |
15 | const RecMailP&data()const; | 15 | const RecMailP&data()const; |
16 | void showEntry(); | 16 | void showEntry(); |
17 | MAILLIB::ATYPE wrapperType(); | 17 | MAILLIB::ATYPE wrapperType(); |
18 | 18 | QString key(int column, bool) const; | |
19 | void setSortKey(int column,const QString &key); | ||
19 | protected: | 20 | protected: |
20 | RecMailP mail_data; | 21 | RecMailP mail_data; |
22 | private: | ||
23 | QMap<int,QString> mKeyMap; | ||
21 | }; | 24 | }; |
22 | 25 | ||
23 | #endif | 26 | #endif |
diff --git a/kmicromail/mainwindow.cpp b/kmicromail/mainwindow.cpp index 78377ea..ddc7b3e 100644 --- a/kmicromail/mainwindow.cpp +++ b/kmicromail/mainwindow.cpp | |||
@@ -1,232 +1,232 @@ | |||
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 <kdialog.h> | 6 | #include <kdialog.h> |
7 | #include <kiconloader.h> | 7 | #include <kiconloader.h> |
8 | 8 | ||
9 | #ifndef DESKTOP_VERSION | 9 | #ifndef DESKTOP_VERSION |
10 | #include <qpe/qpeapplication.h> | 10 | #include <qpe/qpeapplication.h> |
11 | #endif | 11 | #endif |
12 | #include "defines.h" | 12 | #include "defines.h" |
13 | #include "mainwindow.h" | 13 | #include "mainwindow.h" |
14 | #include <KDGanttMinimizeSplitter.h> | 14 | #include <KDGanttMinimizeSplitter.h> |
15 | 15 | ||
16 | 16 | ||
17 | #include <kabc/stdaddressbook.h> | 17 | #include <kabc/stdaddressbook.h> |
18 | 18 | ||
19 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) | 19 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) |
20 | : QMainWindow( parent, name, flags ) | 20 | : QMainWindow( parent, name, flags ) |
21 | { | 21 | { |
22 | setCaption( tr( "KMicroMail" ) ); | 22 | setCaption( tr( "KMicroMail" ) ); |
23 | setToolBarsMovable( false ); | 23 | setToolBarsMovable( false ); |
24 | KABC::StdAddressBook::self(); | 24 | KABC::StdAddressBook::self(); |
25 | toolBar = new QToolBar( this ); | 25 | toolBar = new QToolBar( this ); |
26 | menuBar = new QMenuBar( toolBar ); | 26 | menuBar = new QMenuBar( toolBar ); |
27 | mailMenu = new QPopupMenu( menuBar ); | 27 | mailMenu = new QPopupMenu( menuBar ); |
28 | menuBar->insertItem( tr( "Mail" ), mailMenu ); | 28 | menuBar->insertItem( tr( "Mail" ), mailMenu ); |
29 | settingsMenu = new QPopupMenu( menuBar ); | 29 | settingsMenu = new QPopupMenu( menuBar ); |
30 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); | 30 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); |
31 | 31 | ||
32 | addToolBar( toolBar ); | 32 | addToolBar( toolBar ); |
33 | toolBar->setHorizontalStretchable( true ); | 33 | toolBar->setHorizontalStretchable( true ); |
34 | 34 | ||
35 | QLabel *spacer = new QLabel( toolBar ); | 35 | QLabel *spacer = new QLabel( toolBar ); |
36 | spacer->setBackgroundMode( QWidget::PaletteButton ); | 36 | spacer->setBackgroundMode( QWidget::PaletteButton ); |
37 | toolBar->setStretchableWidget( spacer ); | 37 | toolBar->setStretchableWidget( spacer ); |
38 | 38 | ||
39 | composeMail = new QAction( tr( "Compose new mail" ), SmallIcon("composemail"), | 39 | composeMail = new QAction( tr( "Compose new mail" ), SmallIcon("composemail"), |
40 | 0, 0, this ); | 40 | 0, 0, this ); |
41 | composeMail->addTo( toolBar ); | 41 | composeMail->addTo( toolBar ); |
42 | composeMail->addTo( mailMenu ); | 42 | composeMail->addTo( mailMenu ); |
43 | 43 | ||
44 | sendQueued = new QAction( tr( "Send queued mails" ), SmallIcon("sendqueued") , | 44 | sendQueued = new QAction( tr( "Send queued mails" ), SmallIcon("sendqueued") , |
45 | 0, 0, this ); | 45 | 0, 0, this ); |
46 | sendQueued->addTo( toolBar ); | 46 | sendQueued->addTo( toolBar ); |
47 | sendQueued->addTo( mailMenu ); | 47 | sendQueued->addTo( mailMenu ); |
48 | 48 | ||
49 | /* | 49 | /* |
50 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, | 50 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, |
51 | 0, 0, this ); | 51 | 0, 0, this ); |
52 | syncFolders->addTo( toolBar ); | 52 | syncFolders->addTo( toolBar ); |
53 | syncFolders->addTo( mailMenu ); | 53 | syncFolders->addTo( mailMenu ); |
54 | */ | 54 | */ |
55 | 55 | ||
56 | showFolders = new QAction( tr( "Show/Hide folders" ), SmallIcon("showfolders") , | 56 | showFolders = new QAction( tr( "Show/Hide folders" ), SmallIcon("showfolders") , |
57 | 0, 0, this, 0, true ); | 57 | 0, 0, this, 0, true ); |
58 | showFolders->addTo( toolBar ); | 58 | showFolders->addTo( toolBar ); |
59 | showFolders->addTo( mailMenu ); | 59 | showFolders->addTo( mailMenu ); |
60 | showFolders->setOn( true ); | 60 | showFolders->setOn( true ); |
61 | connect(showFolders, SIGNAL( toggled(bool) ), | 61 | connect(showFolders, SIGNAL( toggled(bool) ), |
62 | SLOT( slotShowFolders(bool) ) ); | 62 | SLOT( slotShowFolders(bool) ) ); |
63 | 63 | ||
64 | /* | 64 | /* |
65 | searchMails = new QAction( tr( "Search mails" ), SmallIcon("find") ), | 65 | searchMails = new QAction( tr( "Search mails" ), SmallIcon("find") ), |
66 | 0, 0, this ); | 66 | 0, 0, this ); |
67 | searchMails->addTo( toolBar ); | 67 | searchMails->addTo( toolBar ); |
68 | searchMails->addTo( mailMenu ); | 68 | searchMails->addTo( mailMenu ); |
69 | */ | 69 | */ |
70 | 70 | ||
71 | deleteMails = new QAction(tr("Delete Mail"), SmallIcon("trash"), 0, 0, this); | 71 | deleteMails = new QAction(tr("Delete Mail"), SmallIcon("trash"), 0, 0, this); |
72 | deleteMails->addTo( toolBar ); | 72 | deleteMails->addTo( toolBar ); |
73 | deleteMails->addTo( mailMenu ); | 73 | deleteMails->addTo( mailMenu ); |
74 | connect( deleteMails, SIGNAL( activated() ), | 74 | connect( deleteMails, SIGNAL( activated() ), |
75 | SLOT( slotDeleteMail() ) ); | 75 | SLOT( slotDeleteMail() ) ); |
76 | 76 | ||
77 | editSettings = new QAction( tr( "Edit settings" ), SmallIcon("SettingsIcon") , | 77 | editSettings = new QAction( tr( "Edit settings" ), SmallIcon("SettingsIcon") , |
78 | 0, 0, this ); | 78 | 0, 0, this ); |
79 | editSettings->addTo( settingsMenu ); | 79 | editSettings->addTo( settingsMenu ); |
80 | connect( editSettings, SIGNAL( activated() ), | 80 | connect( editSettings, SIGNAL( activated() ), |
81 | SLOT( slotEditSettings() ) ); | 81 | SLOT( slotEditSettings() ) ); |
82 | editAccounts = new QAction( tr( "Configure accounts" ), SmallIcon("editaccounts") , | 82 | editAccounts = new QAction( tr( "Configure accounts" ), SmallIcon("editaccounts") , |
83 | 0, 0, this ); | 83 | 0, 0, this ); |
84 | editAccounts->addTo( settingsMenu ); | 84 | editAccounts->addTo( settingsMenu ); |
85 | 85 | ||
86 | //setCentralWidget( view ); | 86 | //setCentralWidget( view ); |
87 | 87 | ||
88 | QVBox* wrapperBox = new QVBox( this ); | 88 | QVBox* wrapperBox = new QVBox( this ); |
89 | setCentralWidget( wrapperBox ); | 89 | setCentralWidget( wrapperBox ); |
90 | 90 | ||
91 | // QWidget *view = new QWidget( wrapperBox ); | 91 | // QWidget *view = new QWidget( wrapperBox ); |
92 | KDGanttMinimizeSplitter* split = new KDGanttMinimizeSplitter( Qt::Horizontal, wrapperBox); | 92 | KDGanttMinimizeSplitter* split = new KDGanttMinimizeSplitter( Qt::Horizontal, wrapperBox); |
93 | split->setMinimizeDirection( KDGanttMinimizeSplitter::Left); | 93 | split->setMinimizeDirection( KDGanttMinimizeSplitter::Left); |
94 | //layout = new QBoxLayout ( split, QBoxLayout::LeftToRight ); | 94 | //layout = new QBoxLayout ( split, QBoxLayout::LeftToRight ); |
95 | 95 | ||
96 | folderView = new AccountView( split ); | 96 | folderView = new AccountView( split ); |
97 | folderView->header()->hide(); | 97 | folderView->header()->hide(); |
98 | folderView->setRootIsDecorated( true ); | 98 | folderView->setRootIsDecorated( false ); |
99 | folderView->addColumn( tr( "Mailbox" ) ); | 99 | folderView->addColumn( tr( "Mailbox" ) ); |
100 | 100 | ||
101 | //layout->addWidget( folderView ); | 101 | //layout->addWidget( folderView ); |
102 | 102 | ||
103 | mailView = new QListView( split ); | 103 | mailView = new QListView( split ); |
104 | mailView->addColumn( tr( "" ) ); | 104 | mailView->addColumn( tr( " " ) ); |
105 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); | 105 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); |
106 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); | 106 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); |
107 | mailView->addColumn( tr( "Size" ),QListView::Manual); | 107 | mailView->addColumn( tr( "Size" ),QListView::Manual); |
108 | mailView->addColumn( tr( "Date" )); | 108 | mailView->addColumn( tr( "Date" ),QListView::Manual); |
109 | mailView->setAllColumnsShowFocus(true); | 109 | mailView->setAllColumnsShowFocus(true); |
110 | //mailView->setSorting(-1); | 110 | //mailView->setSorting(-1); |
111 | 111 | mailView->setRootIsDecorated( false ); | |
112 | statusWidget = new StatusWidget( wrapperBox ); | 112 | statusWidget = new StatusWidget( wrapperBox ); |
113 | statusWidget->hide(); | 113 | statusWidget->hide(); |
114 | 114 | ||
115 | //layout->addWidget( mailView ); | 115 | //layout->addWidget( mailView ); |
116 | //layout->setStretchFactor( folderView, 1 ); | 116 | //layout->setStretchFactor( folderView, 1 ); |
117 | //layout->setStretchFactor( mailView, 2 ); | 117 | //layout->setStretchFactor( mailView, 2 ); |
118 | 118 | ||
119 | slotAdjustLayout(); | 119 | slotAdjustLayout(); |
120 | #ifndef DESKTOP_VERSION | 120 | #ifndef DESKTOP_VERSION |
121 | QPEApplication::setStylusOperation( mailView->viewport(),QPEApplication::RightOnHold); | 121 | QPEApplication::setStylusOperation( mailView->viewport(),QPEApplication::RightOnHold); |
122 | QPEApplication::setStylusOperation( folderView->viewport(),QPEApplication::RightOnHold); | 122 | QPEApplication::setStylusOperation( folderView->viewport(),QPEApplication::RightOnHold); |
123 | #endif | 123 | #endif |
124 | connect( mailView, SIGNAL( doubleClicked (QListViewItem* )),this, | 124 | connect( mailView, SIGNAL( doubleClicked (QListViewItem* )),this, |
125 | SLOT( mailLeftClicked(QListViewItem*) ) ); | 125 | SLOT( mailLeftClicked(QListViewItem*) ) ); |
126 | connect( mailView, SIGNAL( returnPressed (QListViewItem* )),this, | 126 | connect( mailView, SIGNAL( returnPressed (QListViewItem* )),this, |
127 | SLOT( mailLeftClicked(QListViewItem*) ) ); | 127 | SLOT( mailLeftClicked(QListViewItem*) ) ); |
128 | connect( mailView, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int) ),this, | 128 | connect( mailView, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int) ),this, |
129 | SLOT( mailHold(int,QListViewItem*,const QPoint&,int) ) ); | 129 | SLOT( mailHold(int,QListViewItem*,const QPoint&,int) ) ); |
130 | connect(folderView, SIGNAL(refreshMailview(const QValueList<RecMailP>&)), | 130 | connect(folderView, SIGNAL(refreshMailview(const QValueList<RecMailP>&)), |
131 | this,SLOT(refreshMailView(const QValueList<RecMailP>&))); | 131 | this,SLOT(refreshMailView(const QValueList<RecMailP>&))); |
132 | connect( composeMail, SIGNAL( activated() ), SLOT( slotComposeMail() ) ); | 132 | connect( composeMail, SIGNAL( activated() ), SLOT( slotComposeMail() ) ); |
133 | connect( sendQueued, SIGNAL( activated() ), SLOT( slotSendQueued() ) ); | 133 | connect( sendQueued, SIGNAL( activated() ), SLOT( slotSendQueued() ) ); |
134 | // connect( searchMails, SIGNAL( activated() ), SLOT( slotSearchMails() ) ); | 134 | // connect( searchMails, SIGNAL( activated() ), SLOT( slotSearchMails() ) ); |
135 | connect( editAccounts, SIGNAL( activated() ), SLOT( slotEditAccounts() ) ); | 135 | connect( editAccounts, SIGNAL( activated() ), SLOT( slotEditAccounts() ) ); |
136 | mailView->setMultiSelection ( true ); | 136 | mailView->setMultiSelection ( true ); |
137 | //mailView->setSelectionMode( QListView::Extended ); | 137 | //mailView->setSelectionMode( QListView::Extended ); |
138 | QValueList<int> list; | 138 | QValueList<int> list; |
139 | int fw = 100; | 139 | int fw = 100; |
140 | if ( QApplication::desktop()->width() > 320 ) | 140 | if ( QApplication::desktop()->width() > 320 ) |
141 | fw = 50; | 141 | fw = 50; |
142 | list.append( fw ); | 142 | list.append( fw ); |
143 | list.append( 100 ); | 143 | list.append( 100 ); |
144 | split->setSizes( list ); | 144 | split->setSizes( list ); |
145 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); | 145 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); |
146 | mailView->setShowSortIndicator ( true ); | 146 | mailView->setShowSortIndicator ( true ); |
147 | } | 147 | } |
148 | 148 | ||
149 | MainWindow::~MainWindow() | 149 | MainWindow::~MainWindow() |
150 | { | 150 | { |
151 | } | 151 | } |
152 | 152 | ||
153 | void MainWindow::appMessage(const QCString &, const QByteArray &) | 153 | void MainWindow::appMessage(const QCString &, const QByteArray &) |
154 | { | 154 | { |
155 | qDebug("appMessage implemented by subclass"); | 155 | qDebug("appMessage implemented by subclass"); |
156 | } | 156 | } |
157 | 157 | ||
158 | void MainWindow::slotAdjustLayout() { | 158 | void MainWindow::slotAdjustLayout() { |
159 | 159 | ||
160 | /* | 160 | /* |
161 | QWidget *d = QApplication::desktop(); | 161 | QWidget *d = QApplication::desktop(); |
162 | 162 | ||
163 | if ( d->width() < d->height() ) { | 163 | if ( d->width() < d->height() ) { |
164 | layout->setDirection( QBoxLayout::TopToBottom ); | 164 | layout->setDirection( QBoxLayout::TopToBottom ); |
165 | } else { | 165 | } else { |
166 | layout->setDirection( QBoxLayout::LeftToRight ); | 166 | layout->setDirection( QBoxLayout::LeftToRight ); |
167 | } | 167 | } |
168 | */ | 168 | */ |
169 | } | 169 | } |
170 | 170 | ||
171 | void MainWindow::slotAdjustColumns() | 171 | void MainWindow::slotAdjustColumns() |
172 | { | 172 | { |
173 | bool hidden = folderView->isHidden(); | 173 | bool hidden = folderView->isHidden(); |
174 | if ( hidden ) folderView->show(); | 174 | if ( hidden ) folderView->show(); |
175 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); | 175 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); |
176 | if ( hidden ) folderView->hide(); | 176 | if ( hidden ) folderView->hide(); |
177 | 177 | ||
178 | mailView->setColumnWidth( 0, 10 ); | 178 | mailView->setColumnWidth( 0, 10 ); |
179 | mailView->setColumnWidth( 1, mailView->visibleWidth() - 130 ); | 179 | mailView->setColumnWidth( 1, 80 ); |
180 | mailView->setColumnWidth( 2, 80 ); | 180 | mailView->setColumnWidth( 2, 80 ); |
181 | mailView->setColumnWidth( 3, 50 ); | 181 | mailView->setColumnWidth( 3, 50 ); |
182 | mailView->setColumnWidth( 4, 50 ); | 182 | mailView->setColumnWidth( 4, 50 ); |
183 | } | 183 | } |
184 | 184 | ||
185 | void MainWindow::slotEditSettings() | 185 | void MainWindow::slotEditSettings() |
186 | { | 186 | { |
187 | } | 187 | } |
188 | 188 | ||
189 | void MainWindow::slotShowFolders( bool ) | 189 | void MainWindow::slotShowFolders( bool ) |
190 | { | 190 | { |
191 | qDebug("not implemented: "); | 191 | qDebug("not implemented: "); |
192 | } | 192 | } |
193 | 193 | ||
194 | void MainWindow::refreshMailView(const QValueList<RecMailP>&) | 194 | void MainWindow::refreshMailView(const QValueList<RecMailP>&) |
195 | { | 195 | { |
196 | qDebug("not implemented: "); | 196 | qDebug("not implemented: "); |
197 | } | 197 | } |
198 | 198 | ||
199 | void MainWindow::mailLeftClicked(QListViewItem * ) | 199 | void MainWindow::mailLeftClicked(QListViewItem * ) |
200 | { | 200 | { |
201 | qDebug("not implemented: "); | 201 | qDebug("not implemented: "); |
202 | } | 202 | } |
203 | 203 | ||
204 | void MainWindow::displayMail() | 204 | void MainWindow::displayMail() |
205 | { | 205 | { |
206 | qDebug("not implemented: "); | 206 | qDebug("not implemented: "); |
207 | } | 207 | } |
208 | 208 | ||
209 | void MainWindow::slotDeleteMail() | 209 | void MainWindow::slotDeleteMail() |
210 | { | 210 | { |
211 | qDebug("not implemented: "); | 211 | qDebug("not implemented: "); |
212 | } | 212 | } |
213 | 213 | ||
214 | void MainWindow::mailHold(int, QListViewItem *,const QPoint&,int ) | 214 | void MainWindow::mailHold(int, QListViewItem *,const QPoint&,int ) |
215 | { | 215 | { |
216 | qDebug("not implemented: "); | 216 | qDebug("not implemented: "); |
217 | } | 217 | } |
218 | 218 | ||
219 | void MainWindow::slotSendQueued() | 219 | void MainWindow::slotSendQueued() |
220 | { | 220 | { |
221 | qDebug("not implemented: "); | 221 | qDebug("not implemented: "); |
222 | } | 222 | } |
223 | 223 | ||
224 | void MainWindow::slotEditAccounts() | 224 | void MainWindow::slotEditAccounts() |
225 | { | 225 | { |
226 | qDebug("not implemented: "); | 226 | qDebug("not implemented: "); |
227 | } | 227 | } |
228 | 228 | ||
229 | void MainWindow::slotComposeMail() | 229 | void MainWindow::slotComposeMail() |
230 | { | 230 | { |
231 | qDebug("not implemented: "); | 231 | qDebug("not implemented: "); |
232 | } | 232 | } |
diff --git a/kmicromail/opiemail.cpp b/kmicromail/opiemail.cpp index b1992ec..bdbd93a 100644 --- a/kmicromail/opiemail.cpp +++ b/kmicromail/opiemail.cpp | |||
@@ -1,363 +1,363 @@ | |||
1 | 1 | ||
2 | #include "settingsdialog.h" | 2 | #include "settingsdialog.h" |
3 | #include "opiemail.h" | 3 | #include "opiemail.h" |
4 | #include "editaccounts.h" | 4 | #include "editaccounts.h" |
5 | #include "composemail.h" | 5 | #include "composemail.h" |
6 | #include "mailistviewitem.h" | 6 | #include "mailistviewitem.h" |
7 | #include "viewmail.h" | 7 | #include "viewmail.h" |
8 | #include "selectstore.h" | 8 | #include "selectstore.h" |
9 | #include "selectsmtp.h" | 9 | #include "selectsmtp.h" |
10 | 10 | ||
11 | #include <qmessagebox.h> | 11 | #include <qmessagebox.h> |
12 | 12 | ||
13 | #include <qpe/qpeapplication.h> | 13 | #include <qpe/qpeapplication.h> |
14 | #include <libmailwrapper/smtpwrapper.h> | 14 | #include <libmailwrapper/smtpwrapper.h> |
15 | #include <libmailwrapper/mailtypes.h> | 15 | #include <libmailwrapper/mailtypes.h> |
16 | #include <libmailwrapper/abstractmail.h> | 16 | #include <libmailwrapper/abstractmail.h> |
17 | /* OPIE */ | 17 | /* OPIE */ |
18 | //#include <qpe/resource.h> | 18 | //#include <qpe/resource.h> |
19 | #include <qpe/qpeapplication.h> | 19 | #include <qpe/qpeapplication.h> |
20 | 20 | ||
21 | /* QT */ | 21 | /* QT */ |
22 | 22 | ||
23 | using namespace Opie::Core; | 23 | using namespace Opie::Core; |
24 | 24 | ||
25 | OpieMail::OpieMail( QWidget *parent, const char *name, WFlags flags ) | 25 | OpieMail::OpieMail( QWidget *parent, const char *name, WFlags flags ) |
26 | : MainWindow( parent, name, WStyle_ContextHelp ) | 26 | : MainWindow( parent, name, WStyle_ContextHelp ) |
27 | { | 27 | { |
28 | settings = new Settings(); | 28 | settings = new Settings(); |
29 | 29 | ||
30 | folderView->populate( settings->getAccounts() ); | 30 | folderView->populate( settings->getAccounts() ); |
31 | 31 | ||
32 | } | 32 | } |
33 | 33 | ||
34 | OpieMail::~OpieMail() | 34 | OpieMail::~OpieMail() |
35 | { | 35 | { |
36 | if (settings) delete settings; | 36 | if (settings) delete settings; |
37 | } | 37 | } |
38 | 38 | ||
39 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) | 39 | void OpieMail::appMessage(const QCString &msg, const QByteArray &data) |
40 | { | 40 | { |
41 | 41 | ||
42 | } | 42 | } |
43 | #include <stdlib.h> | 43 | #include <stdlib.h> |
44 | void OpieMail::message(const QCString &msg, const QByteArray &data) | 44 | void OpieMail::message(const QCString &msg, const QByteArray &data) |
45 | { | 45 | { |
46 | // copied from old mail2 | 46 | // copied from old mail2 |
47 | static int ii = 0; | 47 | static int ii = 0; |
48 | 48 | ||
49 | // block second call | 49 | // block second call |
50 | if ( ii < 2 ) { | 50 | if ( ii < 2 ) { |
51 | ++ii; | 51 | ++ii; |
52 | if ( ii > 1 ) { | 52 | if ( ii > 1 ) { |
53 | qDebug("qcop call blocked "); | 53 | qDebug("qcop call blocked "); |
54 | return; | 54 | return; |
55 | } | 55 | } |
56 | } | 56 | } |
57 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); | 57 | //qDebug("KM:appMessage %d *%s* %x", ii, msg.data(), this); |
58 | if (msg == "writeMail(QString,QString)") | 58 | if (msg == "writeMail(QString,QString)") |
59 | { | 59 | { |
60 | QDataStream stream(data,IO_ReadOnly); | 60 | QDataStream stream(data,IO_ReadOnly); |
61 | QString name, email; | 61 | QString name, email; |
62 | stream >> name >> email; | 62 | stream >> name >> email; |
63 | // removing the whitespaces at beginning and end is needed! | 63 | // removing the whitespaces at beginning and end is needed! |
64 | slotwriteMail(name.stripWhiteSpace(),email.stripWhiteSpace()); | 64 | slotwriteMail(name.stripWhiteSpace(),email.stripWhiteSpace()); |
65 | } | 65 | } |
66 | else if (msg == "newMail()") | 66 | else if (msg == "newMail()") |
67 | { | 67 | { |
68 | slotComposeMail(); | 68 | slotComposeMail(); |
69 | } | 69 | } |
70 | else if (msg == "newMail(QString)") | 70 | else if (msg == "newMail(QString)") |
71 | { | 71 | { |
72 | QDataStream stream(data,IO_ReadOnly); | 72 | QDataStream stream(data,IO_ReadOnly); |
73 | QString nameemail; | 73 | QString nameemail; |
74 | stream >> nameemail; | 74 | stream >> nameemail; |
75 | // the format is | 75 | // the format is |
76 | // NAME <EMAIL>:SUBJECT | 76 | // NAME <EMAIL>:SUBJECT |
77 | //qDebug("message %s ", nameemail.latin1()); | 77 | //qDebug("message %s ", nameemail.latin1()); |
78 | 78 | ||
79 | slotwriteMail2( nameemail ); | 79 | slotwriteMail2( nameemail ); |
80 | } | 80 | } |
81 | } | 81 | } |
82 | void OpieMail::slotwriteMail2(const QString& namemail ) | 82 | void OpieMail::slotwriteMail2(const QString& namemail ) |
83 | { | 83 | { |
84 | // qDebug("OpieMail::slotwriteMail2 "); | 84 | // qDebug("OpieMail::slotwriteMail2 "); |
85 | qApp->processEvents(); | 85 | qApp->processEvents(); |
86 | ComposeMail compose( settings, this, 0, true ); | 86 | ComposeMail compose( settings, this, 0, true ); |
87 | if ( !namemail.isEmpty() ) { | 87 | if ( !namemail.isEmpty() ) { |
88 | QString to = namemail; | 88 | QString to = namemail; |
89 | if ( namemail.find( " <") > 1 ) { | 89 | if ( namemail.find( " <") > 1 ) { |
90 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; | 90 | to = "\"" +to.replace( QRegExp( " <"), "\" <") ; |
91 | } else | 91 | } else |
92 | if ( namemail.find( "<") > 1 ) { | 92 | if ( namemail.find( "<") > 1 ) { |
93 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; | 93 | to = "\"" +to.replace( QRegExp( "<"), "\" <") ; |
94 | } | 94 | } |
95 | int sub = to.find( ">:"); | 95 | int sub = to.find( ">:"); |
96 | if ( sub > 0 ) { | 96 | if ( sub > 0 ) { |
97 | compose.setTo( to.left(sub+1) ); | 97 | compose.setTo( to.left(sub+1) ); |
98 | compose.setSubject( to.mid(sub+2) ); | 98 | compose.setSubject( to.mid(sub+2) ); |
99 | } else | 99 | } else |
100 | compose.setTo( to ); | 100 | compose.setTo( to ); |
101 | } | 101 | } |
102 | compose.slotAdjustColumns(); | 102 | compose.slotAdjustColumns(); |
103 | compose.showMaximized(); | 103 | compose.showMaximized(); |
104 | compose.exec(); | 104 | compose.exec(); |
105 | //qDebug("retttich "); | 105 | //qDebug("retttich "); |
106 | } | 106 | } |
107 | void OpieMail::slotwriteMail(const QString&name,const QString&email) | 107 | void OpieMail::slotwriteMail(const QString&name,const QString&email) |
108 | { | 108 | { |
109 | // qDebug("OpieMail::slotwriteMail "); | 109 | // qDebug("OpieMail::slotwriteMail "); |
110 | ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp ); | 110 | ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp ); |
111 | if (!email.isEmpty()) | 111 | if (!email.isEmpty()) |
112 | { | 112 | { |
113 | if (!name.isEmpty()) | 113 | if (!name.isEmpty()) |
114 | { | 114 | { |
115 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); | 115 | compose.setTo("\"" + name + "\"" + " " + "<"+ email + ">"); |
116 | } | 116 | } |
117 | else | 117 | else |
118 | { | 118 | { |
119 | compose.setTo(email); | 119 | compose.setTo(email); |
120 | } | 120 | } |
121 | } | 121 | } |
122 | compose.slotAdjustColumns(); | 122 | compose.slotAdjustColumns(); |
123 | compose.showMaximized(); | 123 | compose.showMaximized(); |
124 | compose.exec(); | 124 | compose.exec(); |
125 | } | 125 | } |
126 | 126 | ||
127 | void OpieMail::slotComposeMail() | 127 | void OpieMail::slotComposeMail() |
128 | { | 128 | { |
129 | slotwriteMail2( QString () ); | 129 | slotwriteMail2( QString () ); |
130 | //slotwriteMail(0l,0l); | 130 | //slotwriteMail(0l,0l); |
131 | } | 131 | } |
132 | 132 | ||
133 | void OpieMail::slotSendQueued() | 133 | void OpieMail::slotSendQueued() |
134 | { | 134 | { |
135 | SMTPaccount *smtp = 0; | 135 | SMTPaccount *smtp = 0; |
136 | 136 | ||
137 | QList<Account> list = settings->getAccounts(); | 137 | QList<Account> list = settings->getAccounts(); |
138 | QList<SMTPaccount> smtpList; | 138 | QList<SMTPaccount> smtpList; |
139 | smtpList.setAutoDelete(false); | 139 | smtpList.setAutoDelete(false); |
140 | Account *it; | 140 | Account *it; |
141 | for ( it = list.first(); it; it = list.next() ) | 141 | for ( it = list.first(); it; it = list.next() ) |
142 | { | 142 | { |
143 | if ( it->getType() == MAILLIB::A_SMTP ) | 143 | if ( it->getType() == MAILLIB::A_SMTP ) |
144 | { | 144 | { |
145 | smtp = static_cast<SMTPaccount *>(it); | 145 | smtp = static_cast<SMTPaccount *>(it); |
146 | smtpList.append(smtp); | 146 | smtpList.append(smtp); |
147 | } | 147 | } |
148 | } | 148 | } |
149 | if (smtpList.count()==0) | 149 | if (smtpList.count()==0) |
150 | { | 150 | { |
151 | QMessageBox::information(0,tr("Info"),tr("Define a smtp account first")); | 151 | QMessageBox::information(0,tr("Info"),tr("Define a smtp account first!\n")); |
152 | return; | 152 | return; |
153 | } | 153 | } |
154 | if (smtpList.count()==1) | 154 | if (smtpList.count()==1) |
155 | { | 155 | { |
156 | smtp = smtpList.at(0); | 156 | smtp = smtpList.at(0); |
157 | } | 157 | } |
158 | else | 158 | else |
159 | { | 159 | { |
160 | smtp = 0; | 160 | smtp = 0; |
161 | selectsmtp selsmtp; | 161 | selectsmtp selsmtp; |
162 | selsmtp.setSelectionlist(&smtpList); | 162 | selsmtp.setSelectionlist(&smtpList); |
163 | selsmtp.showMaximized(); | 163 | selsmtp.showMaximized(); |
164 | if ( selsmtp.exec() == QDialog::Accepted ) | 164 | if ( selsmtp.exec() == QDialog::Accepted ) |
165 | { | 165 | { |
166 | smtp = selsmtp.selected_smtp(); | 166 | smtp = selsmtp.selected_smtp(); |
167 | } | 167 | } |
168 | } | 168 | } |
169 | if (smtp) | 169 | if (smtp) |
170 | { | 170 | { |
171 | SMTPwrapper * wrap = new SMTPwrapper(smtp); | 171 | SMTPwrapper * wrap = new SMTPwrapper(smtp); |
172 | if ( wrap->flushOutbox() ) | 172 | if ( wrap->flushOutbox() ) |
173 | { | 173 | { |
174 | QMessageBox::information(0,tr("Info"),tr("Mail queue flushed")); | 174 | QMessageBox::information(0,tr("Info"),tr("Mail queue flushed")); |
175 | } | 175 | } |
176 | delete wrap; | 176 | delete wrap; |
177 | } | 177 | } |
178 | } | 178 | } |
179 | 179 | ||
180 | void OpieMail::slotSearchMails() | 180 | void OpieMail::slotSearchMails() |
181 | { | 181 | { |
182 | qDebug("OpieMail::slotSearchMails():not implemented "); | 182 | qDebug("OpieMail::slotSearchMails():not implemented "); |
183 | } | 183 | } |
184 | 184 | ||
185 | void OpieMail::slotEditSettings() | 185 | void OpieMail::slotEditSettings() |
186 | { | 186 | { |
187 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); | 187 | SettingsDialog settingsDialog( this, 0, true, WStyle_ContextHelp ); |
188 | settingsDialog.showMaximized(); | 188 | settingsDialog.showMaximized(); |
189 | settingsDialog.exec(); | 189 | settingsDialog.exec(); |
190 | } | 190 | } |
191 | 191 | ||
192 | void OpieMail::slotEditAccounts() | 192 | void OpieMail::slotEditAccounts() |
193 | { | 193 | { |
194 | EditAccounts eaDialog( settings, this, 0, true, WStyle_ContextHelp ); | 194 | EditAccounts eaDialog( settings, this, 0, true, WStyle_ContextHelp ); |
195 | eaDialog.slotAdjustColumns(); | 195 | eaDialog.slotAdjustColumns(); |
196 | eaDialog.showMaximized(); | 196 | eaDialog.showMaximized(); |
197 | eaDialog.exec(); | 197 | eaDialog.exec(); |
198 | if ( settings ) delete settings; | 198 | if ( settings ) delete settings; |
199 | settings = new Settings(); | 199 | settings = new Settings(); |
200 | 200 | ||
201 | folderView->populate( settings->getAccounts() ); | 201 | folderView->populate( settings->getAccounts() ); |
202 | } | 202 | } |
203 | 203 | ||
204 | void OpieMail::displayMail() | 204 | void OpieMail::displayMail() |
205 | { | 205 | { |
206 | QListViewItem*item = mailView->currentItem(); | 206 | QListViewItem*item = mailView->currentItem(); |
207 | if (!item) return; | 207 | if (!item) return; |
208 | RecMailP mail = ((MailListViewItem*)item)->data(); | 208 | RecMailP mail = ((MailListViewItem*)item)->data(); |
209 | RecBodyP body = folderView->fetchBody(mail); | 209 | RecBodyP body = folderView->fetchBody(mail); |
210 | ViewMail readMail( this,"", Qt::WType_Modal | WStyle_ContextHelp ); | 210 | ViewMail readMail( this,"", Qt::WType_Modal | WStyle_ContextHelp ); |
211 | readMail.setBody( body ); | 211 | readMail.setBody( body ); |
212 | readMail.setMail( mail ); | 212 | readMail.setMail( mail ); |
213 | readMail.showMaximized(); | 213 | readMail.showMaximized(); |
214 | readMail.exec(); | 214 | readMail.exec(); |
215 | 215 | ||
216 | if ( readMail.deleted ) | 216 | if ( readMail.deleted ) |
217 | { | 217 | { |
218 | folderView->refreshCurrent(); | 218 | folderView->refreshCurrent(); |
219 | } | 219 | } |
220 | else | 220 | else |
221 | { | 221 | { |
222 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); | 222 | ( (MailListViewItem*)item )->setPixmap( 0, QPixmap() ); |
223 | } | 223 | } |
224 | } | 224 | } |
225 | 225 | ||
226 | void OpieMail::slotDeleteMail() | 226 | void OpieMail::slotDeleteMail() |
227 | { | 227 | { |
228 | if (!mailView->currentItem()) return; | 228 | if (!mailView->currentItem()) return; |
229 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); | 229 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); |
230 | 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 ) | 230 | 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 ) |
231 | { | 231 | { |
232 | mail->Wrapper()->deleteMail( mail ); | 232 | mail->Wrapper()->deleteMail( mail ); |
233 | folderView->refreshCurrent(); | 233 | folderView->refreshCurrent(); |
234 | } | 234 | } |
235 | } | 235 | } |
236 | void OpieMail::slotDeleteAllMail() | 236 | void OpieMail::slotDeleteAllMail() |
237 | { | 237 | { |
238 | if (!mailView->currentItem()) return; | 238 | if (!mailView->currentItem()) return; |
239 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); | 239 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); |
240 | if ( QMessageBox::warning(this, tr("Delete All Mails"), tr("Do you really want to delete\nall selected mails?" ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) | 240 | if ( QMessageBox::warning(this, tr("Delete All Mails"), tr("Do you really want to delete\nall selected mails?" ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) |
241 | { | 241 | { |
242 | MailListViewItem* item = (MailListViewItem*)mailView->firstChild (); | 242 | MailListViewItem* item = (MailListViewItem*)mailView->firstChild (); |
243 | while ( item ) { | 243 | while ( item ) { |
244 | if ( item->isSelected() ) { | 244 | if ( item->isSelected() ) { |
245 | RecMailP mail = item->data(); | 245 | RecMailP mail = item->data(); |
246 | mail->Wrapper()->deleteMail( mail ); | 246 | mail->Wrapper()->deleteMail( mail ); |
247 | } | 247 | } |
248 | item = (MailListViewItem*)item->nextSibling(); | 248 | item = (MailListViewItem*)item->nextSibling(); |
249 | } | 249 | } |
250 | folderView->refreshCurrent(); | 250 | folderView->refreshCurrent(); |
251 | } | 251 | } |
252 | } | 252 | } |
253 | void OpieMail::clearSelection() | 253 | void OpieMail::clearSelection() |
254 | { | 254 | { |
255 | mailView->clearSelection(); | 255 | mailView->clearSelection(); |
256 | 256 | ||
257 | } | 257 | } |
258 | 258 | ||
259 | void OpieMail::mailHold(int button, QListViewItem *item,const QPoint&,int ) | 259 | void OpieMail::mailHold(int button, QListViewItem *item,const QPoint&,int ) |
260 | { | 260 | { |
261 | if (!mailView->currentItem()) return; | 261 | if (!mailView->currentItem()) return; |
262 | MAILLIB::ATYPE mailtype = ((MailListViewItem*)mailView->currentItem() )->wrapperType(); | 262 | MAILLIB::ATYPE mailtype = ((MailListViewItem*)mailView->currentItem() )->wrapperType(); |
263 | /* just the RIGHT button - or hold on pda */ | 263 | /* just the RIGHT button - or hold on pda */ |
264 | if (button!=2) {return;} | 264 | if (button!=2) {return;} |
265 | if (!item) return; | 265 | if (!item) return; |
266 | QPopupMenu *m = new QPopupMenu(0); | 266 | QPopupMenu *m = new QPopupMenu(0); |
267 | if (m) | 267 | if (m) |
268 | { | 268 | { |
269 | if (mailtype==MAILLIB::A_NNTP) { | 269 | if (mailtype==MAILLIB::A_NNTP) { |
270 | m->insertItem(tr("Read this posting"),this,SLOT(displayMail())); | 270 | m->insertItem(tr("Read this posting"),this,SLOT(displayMail())); |
271 | // m->insertItem(tr("Copy this posting"),this,SLOT(slotMoveCopyMail())); | 271 | // m->insertItem(tr("Copy this posting"),this,SLOT(slotMoveCopyMail())); |
272 | } else { | 272 | } else { |
273 | if (folderView->currentisDraft()) { | 273 | if (folderView->currentisDraft()) { |
274 | m->insertItem(tr("Edit this mail"),this,SLOT(reEditMail())); | 274 | m->insertItem(tr("Edit this mail"),this,SLOT(reEditMail())); |
275 | } | 275 | } |
276 | m->insertItem(tr("Read this mail"),this,SLOT(displayMail())); | 276 | m->insertItem(tr("Read this mail"),this,SLOT(displayMail())); |
277 | m->insertItem(tr("Copy/Move this mail"),this,SLOT(slotMoveCopyMail())); | 277 | m->insertItem(tr("Copy/Move this mail"),this,SLOT(slotMoveCopyMail())); |
278 | m->insertItem(tr("Delete this mail"),this,SLOT(slotDeleteMail())); | 278 | m->insertItem(tr("Delete this mail"),this,SLOT(slotDeleteMail())); |
279 | m->insertSeparator(); | 279 | m->insertSeparator(); |
280 | m->insertItem(tr("Delete all selected mails"),this,SLOT(slotDeleteAllMail())); | 280 | m->insertItem(tr("Delete all selected mails"),this,SLOT(slotDeleteAllMail())); |
281 | m->insertItem(tr("Clear selection"),this,SLOT(clearSelection())); | 281 | m->insertItem(tr("Clear selection"),this,SLOT(clearSelection())); |
282 | } | 282 | } |
283 | m->setFocus(); | 283 | m->setFocus(); |
284 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); | 284 | m->exec( QPoint( QCursor::pos().x(), QCursor::pos().y()) ); |
285 | delete m; | 285 | delete m; |
286 | } | 286 | } |
287 | } | 287 | } |
288 | 288 | ||
289 | void OpieMail::slotShowFolders( bool show ) | 289 | void OpieMail::slotShowFolders( bool show ) |
290 | { | 290 | { |
291 | if ( show && folderView->isHidden() ) | 291 | if ( show && folderView->isHidden() ) |
292 | { | 292 | { |
293 | folderView->show(); | 293 | folderView->show(); |
294 | } | 294 | } |
295 | else if ( !show && !folderView->isHidden() ) | 295 | else if ( !show && !folderView->isHidden() ) |
296 | { | 296 | { |
297 | folderView->hide(); | 297 | folderView->hide(); |
298 | } | 298 | } |
299 | } | 299 | } |
300 | 300 | ||
301 | void OpieMail::refreshMailView(const QValueList<RecMailP>&list) | 301 | void OpieMail::refreshMailView(const QValueList<RecMailP>&list) |
302 | { | 302 | { |
303 | MailListViewItem*item = 0; | 303 | MailListViewItem*item = 0; |
304 | mailView->clear(); | 304 | mailView->clear(); |
305 | 305 | ||
306 | QValueList<RecMailP>::ConstIterator it; | 306 | QValueList<RecMailP>::ConstIterator it; |
307 | for (it = list.begin(); it != list.end();++it) | 307 | for (it = list.begin(); it != list.end();++it) |
308 | { | 308 | { |
309 | item = new MailListViewItem(mailView,item); | 309 | item = new MailListViewItem(mailView,item); |
310 | item->storeData((*it)); | 310 | item->storeData((*it)); |
311 | item->showEntry(); | 311 | item->showEntry(); |
312 | } | 312 | } |
313 | } | 313 | } |
314 | 314 | ||
315 | void OpieMail::mailLeftClicked( QListViewItem *item ) | 315 | void OpieMail::mailLeftClicked( QListViewItem *item ) |
316 | { | 316 | { |
317 | mailView->clearSelection(); | 317 | mailView->clearSelection(); |
318 | /* just LEFT button - or tap with stylus on pda */ | 318 | /* just LEFT button - or tap with stylus on pda */ |
319 | //if (button!=1) return; | 319 | //if (button!=1) return; |
320 | if (!item) return; | 320 | if (!item) return; |
321 | if (folderView->currentisDraft()) { | 321 | if (folderView->currentisDraft()) { |
322 | reEditMail(); | 322 | reEditMail(); |
323 | } else { | 323 | } else { |
324 | displayMail(); | 324 | displayMail(); |
325 | } | 325 | } |
326 | } | 326 | } |
327 | 327 | ||
328 | void OpieMail::slotMoveCopyMail() | 328 | void OpieMail::slotMoveCopyMail() |
329 | { | 329 | { |
330 | if (!mailView->currentItem()) return; | 330 | if (!mailView->currentItem()) return; |
331 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); | 331 | RecMailP mail = ((MailListViewItem*)mailView->currentItem() )->data(); |
332 | AbstractMail*targetMail = 0; | 332 | AbstractMail*targetMail = 0; |
333 | QString targetFolder = ""; | 333 | QString targetFolder = ""; |
334 | Selectstore sels; | 334 | Selectstore sels; |
335 | folderView->setupFolderselect(&sels); | 335 | folderView->setupFolderselect(&sels); |
336 | if (!sels.exec()) return; | 336 | if (!sels.exec()) return; |
337 | targetMail = sels.currentMail(); | 337 | targetMail = sels.currentMail(); |
338 | targetFolder = sels.currentFolder(); | 338 | targetFolder = sels.currentFolder(); |
339 | if ( (mail->Wrapper()==targetMail && mail->getMbox()==targetFolder) || | 339 | if ( (mail->Wrapper()==targetMail && mail->getMbox()==targetFolder) || |
340 | targetFolder.isEmpty()) | 340 | targetFolder.isEmpty()) |
341 | { | 341 | { |
342 | return; | 342 | return; |
343 | } | 343 | } |
344 | if (sels.newFolder() && !targetMail->createMbox(targetFolder)) | 344 | if (sels.newFolder() && !targetMail->createMbox(targetFolder)) |
345 | { | 345 | { |
346 | QMessageBox::critical(0,tr("Error creating new Folder"), | 346 | QMessageBox::critical(0,tr("Error creating new Folder"), |
347 | tr("<center>Error while creating<br>new folder - breaking.</center>")); | 347 | tr("<center>Error while creating<br>new folder - breaking.</center>")); |
348 | return; | 348 | return; |
349 | } | 349 | } |
350 | mail->Wrapper()->mvcpMail(mail,targetFolder,targetMail,sels.moveMails()); | 350 | mail->Wrapper()->mvcpMail(mail,targetFolder,targetMail,sels.moveMails()); |
351 | folderView->refreshCurrent(); | 351 | folderView->refreshCurrent(); |
352 | } | 352 | } |
353 | 353 | ||
354 | void OpieMail::reEditMail() | 354 | void OpieMail::reEditMail() |
355 | { | 355 | { |
356 | if (!mailView->currentItem()) return; | 356 | if (!mailView->currentItem()) return; |
357 | 357 | ||
358 | ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp ); | 358 | ComposeMail compose( settings, this, 0, true , WStyle_ContextHelp ); |
359 | compose.reEditMail(((MailListViewItem*)mailView->currentItem() )->data()); | 359 | compose.reEditMail(((MailListViewItem*)mailView->currentItem() )->data()); |
360 | compose.slotAdjustColumns(); | 360 | compose.slotAdjustColumns(); |
361 | compose.showMaximized(); | 361 | compose.showMaximized(); |
362 | compose.exec(); | 362 | compose.exec(); |
363 | } | 363 | } |