-rw-r--r-- | kmicromail/composemail.cpp | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/kmicromail/composemail.cpp b/kmicromail/composemail.cpp index c1b58a4..9060364 100644 --- a/kmicromail/composemail.cpp +++ b/kmicromail/composemail.cpp | |||
@@ -64,42 +64,43 @@ ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool m | |||
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( 0, tr( "Problem" ), | ||
80 | tr( "Please create an SMTP account first.\nThe SMTP is needed for sending mail.\n" ), | ||
81 | tr( "Ok" ) ); | ||
82 | return; | ||
83 | } | ||
76 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); | 84 | connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); |
77 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); | 85 | connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); |
78 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); | 86 | connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); |
79 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); | 87 | connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); |
80 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); | 88 | connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); |
81 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); | 89 | connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); |
82 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); | 90 | connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); |
83 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); | 91 | connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); |
84 | mMail = 0; | 92 | mMail = 0; |
85 | warnAttach = true; | 93 | warnAttach = true; |
86 | if ( smtpAccounts.count() > 0 ) { | 94 | |
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 | } | 95 | } |
95 | void ComposeMail::saveAsDraft() | 96 | void ComposeMail::saveAsDraft() |
96 | { | 97 | { |
97 | 98 | ||
98 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); | 99 | Opie::Core::OSmartPointer<Mail> mail= new Mail(); |
99 | mail->setMail(fromBox->currentText()); | 100 | mail->setMail(fromBox->currentText()); |
100 | mail->setTo( toLine->text() ); | 101 | mail->setTo( toLine->text() ); |
101 | mail->setName(senderNameEdit->text()); | 102 | mail->setName(senderNameEdit->text()); |
102 | mail->setCC( ccLine->text() ); | 103 | mail->setCC( ccLine->text() ); |
103 | mail->setBCC( bccLine->text() ); | 104 | mail->setBCC( bccLine->text() ); |
104 | mail->setReply( replyLine->text() ); | 105 | mail->setReply( replyLine->text() ); |
105 | mail->setSubject( subjectLine->text() ); | 106 | mail->setSubject( subjectLine->text() ); |
@@ -247,24 +248,30 @@ void ComposeMail::removeAttachment() | |||
247 | { | 248 | { |
248 | if ( !attList->currentItem() ) { | 249 | if ( !attList->currentItem() ) { |
249 | QMessageBox::information( this, tr( "Error" ), | 250 | QMessageBox::information( this, tr( "Error" ), |
250 | tr( "<p>Please select a File.</p>" ), | 251 | tr( "<p>Please select a File.</p>" ), |
251 | tr( "Ok" ) ); | 252 | tr( "Ok" ) ); |
252 | } else { | 253 | } else { |
253 | attList->takeItem( attList->currentItem() ); | 254 | attList->takeItem( attList->currentItem() ); |
254 | } | 255 | } |
255 | } | 256 | } |
256 | 257 | ||
257 | void ComposeMail::accept() | 258 | void ComposeMail::accept() |
258 | { | 259 | { |
260 | if ( smtpAccountBox->count() == 0 ) { | ||
261 | |||
262 | reject(); | ||
263 | return; | ||
264 | } | ||
265 | |||
259 | if (! checkBoxLater->isChecked() ) { | 266 | if (! checkBoxLater->isChecked() ) { |
260 | int yesno = QMessageBox::warning(0,tr("Stop editing message"), | 267 | int yesno = QMessageBox::warning(0,tr("Stop editing message"), |
261 | tr("Send this message?"), | 268 | tr("Send this message?"), |
262 | tr("Yes"), | 269 | tr("Yes"), |
263 | tr("Cancel")); | 270 | tr("Cancel")); |
264 | 271 | ||
265 | if (yesno == 1) { | 272 | if (yesno == 1) { |
266 | return; | 273 | return; |
267 | } | 274 | } |
268 | } | 275 | } |
269 | #if 0 | 276 | #if 0 |
270 | odebug << "Sending Mail with " | 277 | odebug << "Sending Mail with " |
@@ -318,24 +325,29 @@ void ComposeMail::accept() | |||
318 | } | 325 | } |
319 | 326 | ||
320 | void ComposeMail::reject() | 327 | void ComposeMail::reject() |
321 | { | 328 | { |
322 | //qDebug("ComposeMail::reject() "); | 329 | //qDebug("ComposeMail::reject() "); |
323 | int yesno = QMessageBox::warning(0,tr("Store message?"), | 330 | int yesno = QMessageBox::warning(0,tr("Store message?"), |
324 | tr("Store message into drafts?\n"), | 331 | tr("Store message into drafts?\n"), |
325 | tr("Yes"), | 332 | tr("Yes"), |
326 | tr("No")); | 333 | tr("No")); |
327 | 334 | ||
328 | //qDebug("button %d ", yesno); | 335 | //qDebug("button %d ", yesno); |
329 | if (yesno == 0) { | 336 | if (yesno == 0) { |
337 | if ( toLine->text().isEmpty() ) { | ||
338 | QMessageBox::warning(0,tr("Sending mail"), | ||
339 | tr("No Receiver spezified" ) ); | ||
340 | return; | ||
341 | } | ||
330 | saveAsDraft(); | 342 | saveAsDraft(); |
331 | } | 343 | } |
332 | if (yesno == 2) { | 344 | if (yesno == 2) { |
333 | qDebug("return "); | 345 | qDebug("return "); |
334 | return; | 346 | return; |
335 | } | 347 | } |
336 | QDialog::reject(); | 348 | QDialog::reject(); |
337 | } | 349 | } |
338 | 350 | ||
339 | ComposeMail::~ComposeMail() | 351 | ComposeMail::~ComposeMail() |
340 | { | 352 | { |
341 | } | 353 | } |