summaryrefslogtreecommitdiffabout
path: root/kmicromail
authorzautrix <zautrix>2004-10-25 23:39:43 (UTC)
committer zautrix <zautrix>2004-10-25 23:39:43 (UTC)
commit7bf9517920766c9cd5e032af9cdd1e07d6604b6b (patch) (unidiff)
tree10ff3855615ba19505907be8ab2f0268f76f3ae1 /kmicromail
parente7c948b76a46c923c21f2f35c677912b462fa1f4 (diff)
downloadkdepimpi-7bf9517920766c9cd5e032af9cdd1e07d6604b6b.zip
kdepimpi-7bf9517920766c9cd5e032af9cdd1e07d6604b6b.tar.gz
kdepimpi-7bf9517920766c9cd5e032af9cdd1e07d6604b6b.tar.bz2
kopiemail fixes
Diffstat (limited to 'kmicromail') (more/less context) (ignore whitespace changes)
-rw-r--r--kmicromail/composemail.cpp9
1 files changed, 3 insertions, 6 deletions
diff --git a/kmicromail/composemail.cpp b/kmicromail/composemail.cpp
index 5f7a76f..c504fdd 100644
--- a/kmicromail/composemail.cpp
+++ b/kmicromail/composemail.cpp
@@ -1,251 +1,248 @@
1// CHANGED 2004-08-06 Lutz Rogowski 1// CHANGED 2004-08-06 Lutz Rogowski
2 2
3#include "composemail.h" 3#include "composemail.h"
4 4
5#include <libmailwrapper/smtpwrapper.h> 5#include <libmailwrapper/smtpwrapper.h>
6#include <libmailwrapper/storemail.h> 6#include <libmailwrapper/storemail.h>
7#include <libmailwrapper/abstractmail.h> 7#include <libmailwrapper/abstractmail.h>
8#include <libmailwrapper/mailtypes.h> 8#include <libmailwrapper/mailtypes.h>
9 9
10/* OPIE */ 10/* OPIE */
11//#include <opie2/ofiledialog.h> 11//#include <opie2/ofiledialog.h>
12//#include <opie2/odebug.h> 12//#include <opie2/odebug.h>
13#include <kfiledialog.h> 13#include <kfiledialog.h>
14//#include <qpe/resource.h> 14//#include <qpe/resource.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 <qiconset.h> 21#include <qiconset.h>
22#include <qtimer.h> 22#include <qtimer.h>
23#include <qmessagebox.h> 23#include <qmessagebox.h>
24#include <qpushbutton.h> 24#include <qpushbutton.h>
25#include <qmultilineedit.h> 25#include <qmultilineedit.h>
26#include <qlabel.h> 26#include <qlabel.h>
27#include <qtabwidget.h> 27#include <qtabwidget.h>
28#include <qlistview.h> 28#include <qlistview.h>
29#include <kabc/addresseedialog.h> 29#include <kabc/addresseedialog.h>
30#include <kabc/stdaddressbook.h> 30#include <kabc/stdaddressbook.h>
31#include <kabc/addressee.h> 31#include <kabc/addressee.h>
32#ifdef DESKTOP_VERSION 32#ifdef DESKTOP_VERSION
33#include <kabc/addresseedialog.h> 33#include <kabc/addresseedialog.h>
34#else //DESKTOP_VERSION 34#else //DESKTOP_VERSION
35#include <libkdepim/externalapphandler.h> 35#include <libkdepim/externalapphandler.h>
36#endif //DESKTOP_VERSION 36#endif //DESKTOP_VERSION
37 37
38#include "koprefs.h" 38#include "koprefs.h"
39 39
40//using namespace Opie::Core; 40//using namespace Opie::Core;
41//using namespace Opie::Ui; 41//using namespace Opie::Ui;
42ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal ) 42ComposeMail::ComposeMail( Settings *s, QWidget *parent, const char *name, bool modal )
43 : ComposeMailUI( parent, name, modal ) 43 : ComposeMailUI( parent, name, modal )
44{ 44{
45 mPickLineEdit = 0; 45 mPickLineEdit = 0;
46 connect(ExternalAppHandler::instance(), SIGNAL(receivedNameEmailUidListEvent(const QString&, const QStringList&, const QStringList&, const QStringList&)), 46 connect(ExternalAppHandler::instance(), SIGNAL(receivedNameEmailUidListEvent(const QString&, const QStringList&, const QStringList&, const QStringList&)),
47 this, SLOT(insertAttendees(const QString&, const QStringList&, const QStringList&, const QStringList&))); 47 this, SLOT(insertAttendees(const QString&, const QStringList&, const QStringList&, const QStringList&)));
48 settings = s; 48 settings = s;
49 m_replyid = ""; 49 m_replyid = "";
50 if ( KOPrefs::instance()->mUseKapi) { 50 if ( KOPrefs::instance()->mUseKapi) {
51 KConfig config( locateLocal("config", "kabcrc") ); 51 KConfig config( locateLocal("config", "kabcrc") );
52 config.setGroup( "General" ); 52 config.setGroup( "General" );
53 QString whoami_uid = config.readEntry( "WhoAmI" ); 53 QString whoami_uid = config.readEntry( "WhoAmI" );
54 54
55 if ( whoami_uid.isEmpty() ) { 55 if ( whoami_uid.isEmpty() ) {
56 QMessageBox::information( 0, i18n( "Hint" ), 56 QMessageBox::information( 0, i18n( "Hint" ),
57 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), 57 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ),
58 i18n( "Ok" ) ); 58 i18n( "Ok" ) );
59 59
60 60
61 fillSettings(); 61 fillSettings();
62 } else 62 } else
63 ExternalAppHandler::instance()->requestDetailsFromKAPI("", "sendbacklist", whoami_uid); 63 ExternalAppHandler::instance()->requestDetailsFromKAPI("", "sendbacklist", whoami_uid);
64 64
65 65
66#ifdef DESKTOP_VERSION 66#ifdef DESKTOP_VERSION
67 KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( ); 67 KABC::Addressee con = KABC::StdAddressBook::self()->whoAmI( );
68 QStringList mails = con.emails(); 68 QStringList mails = con.emails();
69 QString defmail = con.preferredEmail(); 69 QString defmail = con.preferredEmail();
70 if ( mails.count() == 0) 70 if ( mails.count() == 0)
71 QMessageBox::information( 0, i18n( "Hint" ), 71 QMessageBox::information( 0, i18n( "Hint" ),
72 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), 72 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ),
73 i18n( "Ok" ) ); 73 i18n( "Ok" ) );
74 if (defmail.length()!=0) { 74 if (defmail.length()!=0) {
75 fromBox->insertItem(defmail); 75 fromBox->insertItem(defmail);
76 } 76 }
77 QStringList::ConstIterator sit = mails.begin(); 77 QStringList::ConstIterator sit = mails.begin();
78 for (;sit!=mails.end();++sit) { 78 for (;sit!=mails.end();++sit) {
79 if ( (*sit)==defmail) 79 if ( (*sit)==defmail)
80 continue; 80 continue;
81 fromBox->insertItem((*sit)); 81 fromBox->insertItem((*sit));
82 } 82 }
83 senderNameEdit->setText(con.formattedName()); 83 senderNameEdit->setText(con.formattedName());
84#endif 84#endif
85 85
86 } else { 86 } else {
87 fillSettings(); 87 fillSettings();
88 } 88 }
89 checkBoxLater->setChecked( KOPrefs::instance()->mSendLater ); 89 checkBoxLater->setChecked( KOPrefs::instance()->mSendLater );
90 90
91 attList->addColumn( i18n( "Name" ) ); 91 attList->addColumn( i18n( "Name" ) );
92 attList->addColumn( i18n( "Size" ) ); 92 attList->addColumn( i18n( "Size" ) );
93 QList<Account> accounts = settings->getAccounts(); 93 QList<Account> accounts = settings->getAccounts();
94 94
95 if ( QApplication::desktop()->width() < 320 ) 95 if ( QApplication::desktop()->width() < 320 )
96 smtpAccountBox->setMaximumWidth( 80 ); 96 smtpAccountBox->setMaximumWidth( 80 );
97 Account *it; 97 Account *it;
98 for ( it = accounts.first(); it; it = accounts.next() ) { 98 for ( it = accounts.first(); it; it = accounts.next() ) {
99 if ( it->getType()==MAILLIB::A_SMTP ) { 99 if ( it->getType()==MAILLIB::A_SMTP ) {
100 SMTPaccount *smtp = static_cast<SMTPaccount *>(it); 100 SMTPaccount *smtp = static_cast<SMTPaccount *>(it);
101 smtpAccountBox->insertItem( smtp->getAccountName() ); 101 smtpAccountBox->insertItem( smtp->getAccountName() );
102 smtpAccounts.append( smtp ); 102 smtpAccounts.append( smtp );
103 } 103 }
104 } 104 }
105 connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) ); 105 connect( toButton, SIGNAL( clicked() ), SLOT( pickAddressTo() ) );
106 connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) ); 106 connect( ccButton, SIGNAL( clicked() ), SLOT( pickAddressCC() ) );
107 connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) ); 107 connect( bccButton, SIGNAL( clicked() ), SLOT( pickAddressBCC() ) );
108 connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) ); 108 connect( replyButton, SIGNAL( clicked() ), SLOT( pickAddressReply() ) );
109 connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) ); 109 connect( addButton, SIGNAL( clicked() ), SLOT( addAttachment() ) );
110 connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) ); 110 connect( deleteButton, SIGNAL( clicked() ), SLOT( removeAttachment() ) );
111 connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) ); 111 connect( SaveButton, SIGNAL( clicked() ), SLOT( saveAsDraft()) );
112 mMail = 0; 112 mMail = 0;
113 warnAttach = true; 113 warnAttach = true;
114 QIconSet icon; 114 QIconSet icon;
115 //icon = SmallIcon("fileexport"); 115 //icon = SmallIcon("fileexport");
116 icon = SmallIcon("filesave"); 116 icon = SmallIcon("filesave");
117
118 SaveButton->setText ("") ;
117 SaveButton->setIconSet (icon ) ; 119 SaveButton->setIconSet (icon ) ;
118 if ( QApplication::desktop()->width() < 320 ) { 120 SaveButton->setMaximumSize ( SaveButton->sizeHint().height(),SaveButton->sizeHint().height()) ;
119 SaveButton->setText ("") ;
120 SaveButton->setMaximumSize ( SaveButton->sizeHint().height(),SaveButton->sizeHint().height()) ;
121 }
122 else
123 SaveButton->setText (i18n("Save"));
124#ifndef DESKTOP_VERSION 121#ifndef DESKTOP_VERSION
125 QPEApplication::setStylusOperation( message, QPEApplication::RightOnHold ); 122 QPEApplication::setStylusOperation( message, QPEApplication::RightOnHold );
126 QPEApplication::setStylusOperation( senderNameEdit, QPEApplication::RightOnHold ); 123 QPEApplication::setStylusOperation( senderNameEdit, QPEApplication::RightOnHold );
127 QPEApplication::setStylusOperation( subjectLine, QPEApplication::RightOnHold ); 124 QPEApplication::setStylusOperation( subjectLine, QPEApplication::RightOnHold );
128#endif 125#endif
129 message->setFont ( KOPrefs::instance()->mComposeFont ); 126 message->setFont ( KOPrefs::instance()->mComposeFont );
130 message->setWordWrap (QMultiLineEdit::WidgetWidth); 127 message->setWordWrap (QMultiLineEdit::WidgetWidth);
131 if ( smtpAccounts.count() > 0 ) { 128 if ( smtpAccounts.count() > 0 ) {
132 fillValues( smtpAccountBox->currentItem() ); 129 fillValues( smtpAccountBox->currentItem() );
133 } else { 130 } else {
134 QMessageBox::information( 0, i18n( "Problem" ), 131 QMessageBox::information( 0, i18n( "Problem" ),
135 i18n( "Please create an\nSMTP account first.\nThe SMTP is needed\nfor sending mail.\n" ), 132 i18n( "Please create an\nSMTP account first.\nThe SMTP is needed\nfor sending mail.\n" ),
136 i18n( "Ok" ) ); 133 i18n( "Ok" ) );
137 return; 134 return;
138 } 135 }
139 connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) ); 136 connect( smtpAccountBox, SIGNAL( activated(int) ), SLOT( fillValues(int) ) );
140 137
141 138
142} 139}
143 140
144void ComposeMail::fillSettings() 141void ComposeMail::fillSettings()
145{ 142{
146 if ( QApplication::desktop()->width() < 320 ) 143 if ( QApplication::desktop()->width() < 320 )
147 fromBox->setMaximumWidth( 100 ); 144 fromBox->setMaximumWidth( 100 );
148 QStringList mailList = QStringList::split(";",KOPrefs::instance()->mEmail); 145 QStringList mailList = QStringList::split(";",KOPrefs::instance()->mEmail);
149 QStringList::ConstIterator sit = mailList.begin(); 146 QStringList::ConstIterator sit = mailList.begin();
150 int pref = 0; 147 int pref = 0;
151 for (;sit!=mailList.end();++sit) { 148 for (;sit!=mailList.end();++sit) {
152 fromBox->insertItem((*sit)); 149 fromBox->insertItem((*sit));
153 } 150 }
154 senderNameEdit->setText(KOPrefs::instance()->mName); 151 senderNameEdit->setText(KOPrefs::instance()->mName);
155} 152}
156 153
157 154
158void ComposeMail::saveAsDraft() 155void ComposeMail::saveAsDraft()
159{ 156{
160 157
161 Opie::Core::OSmartPointer<Mail> mail= new Mail(); 158 Opie::Core::OSmartPointer<Mail> mail= new Mail();
162 mail->setMail(fromBox->currentText()); 159 mail->setMail(fromBox->currentText());
163 mail->setTo( toLine->text() ); 160 mail->setTo( toLine->text() );
164 mail->setName(senderNameEdit->text()); 161 mail->setName(senderNameEdit->text());
165 mail->setCC( ccLine->text() ); 162 mail->setCC( ccLine->text() );
166 mail->setBCC( bccLine->text() ); 163 mail->setBCC( bccLine->text() );
167 mail->setReply( replyLine->text() ); 164 mail->setReply( replyLine->text() );
168 mail->setSubject( subjectLine->text() ); 165 mail->setSubject( subjectLine->text() );
169 if (!m_replyid.isEmpty()) { 166 if (!m_replyid.isEmpty()) {
170 QStringList ids; 167 QStringList ids;
171 ids.append(m_replyid); 168 ids.append(m_replyid);
172 mail->setInreply(ids); 169 mail->setInreply(ids);
173 } 170 }
174 QString txt = message->text(); 171 QString txt = message->text();
175 if ( !sigMultiLine->text().isEmpty() ) { 172 if ( !sigMultiLine->text().isEmpty() ) {
176 txt.append( "\n--\n" ); 173 txt.append( "\n--\n" );
177 txt.append( sigMultiLine->text() ); 174 txt.append( sigMultiLine->text() );
178 } 175 }
179 mail->setMessage( txt ); 176 mail->setMessage( txt );
180 177
181 /* only use the default drafts folder name! */ 178 /* only use the default drafts folder name! */
182 Storemail wrapper(AbstractMail::draftFolder()); 179 Storemail wrapper(AbstractMail::draftFolder());
183 wrapper.storeMail(mail); 180 wrapper.storeMail(mail);
184 181
185 AttachViewItem *it = (AttachViewItem *) attList->firstChild(); 182 AttachViewItem *it = (AttachViewItem *) attList->firstChild();
186 /* attachments we will ignore! */ 183 /* attachments we will ignore! */
187 if ( it != 0 ) { 184 if ( it != 0 ) {
188 if ( warnAttach ) 185 if ( warnAttach )
189 QMessageBox::warning(0,i18n("Store message"), 186 QMessageBox::warning(0,i18n("Store message"),
190 i18n("<center>Attachments will not be stored in \"Draft\" folder</center>")); 187 i18n("<center>Attachments will not be stored in \"Draft\" folder</center>"));
191 warnAttach = false; 188 warnAttach = false;
192 } 189 }
193 setStatus( i18n("Mail saved as draft!") ); 190 setStatus( i18n("Mail saved as draft!") );
194} 191}
195void ComposeMail::clearStatus() 192void ComposeMail::clearStatus()
196{ 193{
197 topLevelWidget()->setCaption( i18n("Compose mail") ); 194 topLevelWidget()->setCaption( i18n("Compose mail") );
198} 195}
199void ComposeMail::setStatus( QString status ) 196void ComposeMail::setStatus( QString status )
200{ 197{
201 topLevelWidget()->setCaption( status ); 198 topLevelWidget()->setCaption( status );
202 QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ; 199 QTimer::singleShot ( 10000, this, SLOT( clearStatus() ) ) ;
203} 200}
204void ComposeMail::pickAddress( ) 201void ComposeMail::pickAddress( )
205{ 202{
206 203
207 QLineEdit *line = mPickLineEdit; 204 QLineEdit *line = mPickLineEdit;
208 if ( line == 0 ) 205 if ( line == 0 )
209 return; 206 return;
210#ifdef DESKTOP_VERSION 207#ifdef DESKTOP_VERSION
211 //qDebug(" ComposeMail::pickAddress "); 208 //qDebug(" ComposeMail::pickAddress ");
212 QString names ;//= AddressPicker::getNames(); 209 QString names ;//= AddressPicker::getNames();
213 210
214 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); 211 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this);
215 uint i=0; 212 uint i=0;
216 for (i=0; i < list.count(); i++) { 213 for (i=0; i < list.count(); i++) {
217 if ( !list[i].preferredEmail().isEmpty()) { 214 if ( !list[i].preferredEmail().isEmpty()) {
218 if ( ! names.isEmpty() ) 215 if ( ! names.isEmpty() )
219 names+= ","; 216 names+= ",";
220 names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">"; 217 names+= "\""+list[i].realName() +"\"<" +list[i].preferredEmail() +">";
221 218
222 } 219 }
223 } 220 }
224 221
225 222
226 if ( line->text().isEmpty() ) { 223 if ( line->text().isEmpty() ) {
227 line->setText( names ); 224 line->setText( names );
228 } else if ( !names.isEmpty() ) { 225 } else if ( !names.isEmpty() ) {
229 line->setText( line->text() + ", " + names ); 226 line->setText( line->text() + ", " + names );
230 } 227 }
231#else 228#else
232 bool res = ExternalAppHandler::instance()->requestNameEmailUidListFromKAPI("QPE/Application/ompi", this->name() /* name is here the unique uid*/); 229 bool res = ExternalAppHandler::instance()->requestNameEmailUidListFromKAPI("QPE/Application/ompi", this->name() /* name is here the unique uid*/);
233 // the result should now arrive through method insertAttendees 230 // the result should now arrive through method insertAttendees
234#endif 231#endif
235} 232}
236//the map includes name/email pairs, that comes from Ka/Pi 233//the map includes name/email pairs, that comes from Ka/Pi
237void ComposeMail::insertAttendees(const QString& uid,const QStringList& nameList,const QStringList& emailList,const QStringList& uidList) 234void ComposeMail::insertAttendees(const QString& uid,const QStringList& nameList,const QStringList& emailList,const QStringList& uidList)
238{ 235{
239 //qDebug("ComposeMail::insertAttendees "); 236 //qDebug("ComposeMail::insertAttendees ");
240 raise(); 237 raise();
241 238
242 if ( mPickLineEdit == 0 ) { //whoami received 239 if ( mPickLineEdit == 0 ) { //whoami received
243 QString defmail = uidList[0]; 240 QString defmail = uidList[0];
244 if ( emailList.count() == 0 ) 241 if ( emailList.count() == 0 )
245 QMessageBox::information( 0, i18n( "Hint" ), 242 QMessageBox::information( 0, i18n( "Hint" ),
246 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ), 243 i18n( "Please apply\n\"Set Who Am I\"\nin KA/Pi to get the from\nfield automatically filled out!\n" ),
247 i18n( "Ok" ) ); 244 i18n( "Ok" ) );
248 if (defmail.length()!=0) { 245 if (defmail.length()!=0) {
249 fromBox->insertItem(defmail); 246 fromBox->insertItem(defmail);
250 } 247 }
251 QStringList::ConstIterator sit = emailList.begin(); 248 QStringList::ConstIterator sit = emailList.begin();