summaryrefslogtreecommitdiff
authorgroucho <groucho>2003-04-11 14:48:19 (UTC)
committer groucho <groucho>2003-04-11 14:48:19 (UTC)
commitd37f3eac6b876285eb7a03ab01194ea261458ea5 (patch) (unidiff)
tree47420d872c6d298db7e26715c80cf3aebb055033
parentebf5bb083d47179918d47f083a3cc98a5ed5d2e0 (diff)
downloadopie-d37f3eac6b876285eb7a03ab01194ea261458ea5.zip
opie-d37f3eac6b876285eb7a03ab01194ea261458ea5.tar.gz
opie-d37f3eac6b876285eb7a03ab01194ea261458ea5.tar.bz2
Lots of improvements regarding usability and stability:
- Now uses ofileselector for sending attachments (reading follows, does not crash any more) - Uses DocLnks for attachments (when composing a message) - Beautified the attachments dialog with doc icons - removed a crash when sending attachments and no account was set - smaller fixes ToDo: - Attachment viewer should use doclnk too - get rid of teh save button in ofileselector - fix the bug with GMX mail provider sending mail (user encoding wrong) - replace the Attach and Remove buttons with a nice toolbar - Maybe integrate attview into the mail sending window on demand - get rid of crashes
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mailit/addatt.cpp119
-rw-r--r--noncore/net/mailit/addatt.h24
-rw-r--r--noncore/net/mailit/emailclient.cpp10
-rw-r--r--noncore/net/mailit/emailhandler.cpp7
-rw-r--r--noncore/net/mailit/writemail.cpp6
-rw-r--r--noncore/unsupported/mailit/addatt.cpp119
-rw-r--r--noncore/unsupported/mailit/addatt.h24
-rw-r--r--noncore/unsupported/mailit/emailclient.cpp10
-rw-r--r--noncore/unsupported/mailit/emailhandler.cpp7
-rw-r--r--noncore/unsupported/mailit/writemail.cpp6
10 files changed, 200 insertions, 132 deletions
diff --git a/noncore/net/mailit/addatt.cpp b/noncore/net/mailit/addatt.cpp
index c030e36..f279f52 100644
--- a/noncore/net/mailit/addatt.cpp
+++ b/noncore/net/mailit/addatt.cpp
@@ -1,209 +1,230 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qlayout.h> 20#include <qlayout.h>
21#include <qdir.h> 21#include <qdir.h>
22#include <qstringlist.h> 22#include <qstringlist.h>
23#include "resource.h" 23#include "resource.h"
24#include "addatt.h" 24#include "addatt.h"
25 25
26FileItem::FileItem(QListView *parent, QFileInfo fileInfo, QString fileType) 26FileItem::FileItem(QListView *parent, DocLnk* dl)
27 : QListViewItem(parent) 27 : QListViewItem(parent)
28{ 28{
29 file = fileInfo; 29 /*file = fileInfo;
30 type = fileType; 30 type = fileType;*/
31
32 doclnk=dl;
31 33
32 setText(0, fileInfo.baseName()); 34 setText(0, doclnk->name());
33 35
34 if (fileType == "Picture") { 36 /*if (fileType == "Picture") {
35 setPixmap(0, Resource::loadPixmap("pixmap")); 37 setPixmap(0, Resource::loadPixmap("pixmap"));
36 } else if (fileType == "Document") { 38 } else if (fileType == "Document") {
37 setPixmap(0, Resource::loadPixmap("txt")); 39 setPixmap(0, Resource::loadPixmap("txt"));
38 } else if (fileType == "Sound") { 40 } else if (fileType == "Sound") {
39 setPixmap(0, Resource::loadPixmap("play")); 41 setPixmap(0, Resource::loadPixmap("play"));
40 } else if (fileType == "Movie") { 42 } else if (fileType == "Movie") {
41 setPixmap(0, Resource::loadPixmap("MPEGPlayer")); 43 setPixmap(0, Resource::loadPixmap("MPEGPlayer"));
42 } else if (fileType == "File") { 44 } else if (fileType == "File") {
43 setPixmap(0, Resource::loadPixmap("exec")); 45 setPixmap(0, Resource::loadPixmap("exec"));
44 } 46 }*/
45} 47}
46 48
47QFileInfo FileItem::getFileInfo() 49FileItem::~FileItem()
48{ 50{
49 return file; 51 if (doclnk!=NULL) delete doclnk;
50} 52 doclnk=NULL;
51
52QString FileItem::getFileType()
53{
54 return type;
55} 53}
56 54
57AddAtt::AddAtt(QWidget *parent, const char *name, WFlags f) 55AddAtt::AddAtt(QWidget *parent, const char *name, WFlags f)
58 : QDialog(parent, name, f) 56 : QDialog(parent, name, f)
59{ 57{
60 setCaption("Adding attatchments"); 58 setCaption("Adding attatchments");
61 59
62 QGridLayout *top = new QGridLayout(this, 3, 2); 60 QGridLayout *top = new QGridLayout(this, 3,1 );
61
63 62
64 fileCategoryButton = new QPushButton(this); 63 /*fileCategoryButton = new QPushButton(this);*/
65 attatchButton = new QPushButton("Attatch ->", this); 64 attatchButton = new QPushButton("Attatch ->", this);
66 removeButton = new QPushButton("Remove", this); 65 removeButton = new QPushButton("Remove", this);
67 66
68 fileCategories = new QPopupMenu(fileCategoryButton); 67 /*fileCategories = new QPopupMenu(fileCategoryButton);
69 fileCategoryButton->setPopup(fileCategories); 68 fileCategoryButton->setPopup(fileCategories);
70 fileCategories->insertItem("Document"); 69 fileCategories->insertItem("Document");
71 fileCategories->insertItem("Picture"); 70 fileCategories->insertItem("Picture");
72 fileCategories->insertItem("Sound"); 71 fileCategories->insertItem("Sound");
73 fileCategories->insertItem("Movie"); 72 fileCategories->insertItem("Movie");
74 fileCategories->insertItem("File"); 73 fileCategories->insertItem("File");
75 74
76 fileCategoryButton->setText("Document"); 75 fileCategoryButton->setText("Document");
77 top->addWidget(fileCategoryButton, 0, 0); 76 top->addWidget(fileCategoryButton, 0, 0);*/
78 top->addWidget(attatchButton, 2, 0); 77
79 top->addWidget(removeButton, 2, 1); 78 //ofs=new OFileSelector(this,2,0,"/root/Documents");
79
80
81 top->addWidget(attatchButton,1,0);
82 top->addWidget(removeButton,2,0);
80 83
81 connect(fileCategories, SIGNAL(activated(int)), this, 84 /*connect(fileCategories, SIGNAL(activated(int)), this,
82 SLOT(fileCategorySelected(int)) ); 85 SLOT(fileCategorySelected(int)) );*/
83 connect(attatchButton, SIGNAL(clicked()), this, 86 connect(attatchButton, SIGNAL(clicked()), this,
84 SLOT(addAttatchment()) ); 87 SLOT(addAttatchment()) );
85 connect(removeButton, SIGNAL(clicked()), this, 88 connect(removeButton, SIGNAL(clicked()), this,
86 SLOT(removeAttatchment()) ); 89 SLOT(removeAttatchment()) );
87 90
88 listView = new QListView(this, "AttView"); 91 /*listView = new QListView(this, "AttView");
89 listView->addColumn("Documents"); 92 listView->addColumn("Documents");*
90 connect(listView, SIGNAL(doubleClicked(QListViewItem *)), this, 93 connect(listView, SIGNAL(doubleClicked(QListViewItem *)), this,
91 SLOT(addAttatchment()) ); 94 SLOT(addAttatchment()) );*/
95
92 96
93 attView = new QListView(this, "Selected"); 97 attView = new QListView(this, "Selected");
94 attView->addColumn("Attatched"); 98 attView->addColumn(tr("Attached"));
99 attView->addColumn(tr("File type"));
95 connect(attView, SIGNAL(doubleClicked(QListViewItem *)), this, 100 connect(attView, SIGNAL(doubleClicked(QListViewItem *)), this,
96 SLOT(removeAttatchment()) ); 101 SLOT(removeAttatchment()) );
97 102
98 top->addWidget(listView, 1,0); 103 //top->addWidget(ofs, 0,0);
99 top->addWidget(attView, 1,1); 104 top->addWidget(attView, 0,0);
105
106 clear();
100 107
101 clear(); 108
102} 109}
103 110
104void AddAtt::clear() 111void AddAtt::clear()
105{ 112{
106 attView->clear(); 113 attView->clear();
107 getFiles(); 114 //getFiles();
108 modified = FALSE; 115 modified = FALSE;
109} 116}
110 117
111void AddAtt::fileCategorySelected(int id) 118/*void AddAtt::fileCategorySelected(int id)
112{ 119{
113 fileCategoryButton->setText(fileCategories->text(id)); 120 fileCategoryButton->setText(fileCategories->text(id));
114 getFiles(); 121 getFiles();
115} 122}*/
116 123
117void AddAtt::addAttatchment() 124void AddAtt::addAttatchment()
118{ 125 {
119 QFileInfo info; 126 QDialog qd(this,tr("Select attachment"),true);
120 QString type; 127
128 QGridLayout top(&qd,1,1);
129
130 OFileSelector ofs(&qd,1,0,"/root/Documents");
131
132 top.addWidget(&ofs,0,0);
121 133
122 if (listView->selectedItem() != NULL) { 134 qd.showMaximized();
123 item = (FileItem *) listView->selectedItem(); 135
124 info = item->getFileInfo(); 136 if (qd.exec()==QDialog::Accepted)
125 type = item->getFileType(); 137 {
126 item = new FileItem(attView, info, type); 138 DocLnk* dl=new DocLnk(ofs.selectedDocument());
139 FileItem* fi=new FileItem(attView,dl);
140 fi->setPixmap(0,dl->pixmap());
141 fi->setText(1,dl->type());
142 attView->insertItem(fi);
143 modified = TRUE;
127 } 144 }
128 modified = TRUE;
129} 145}
130 146
131void AddAtt::removeAttatchment() 147void AddAtt::removeAttatchment()
132{ 148{
133 if (attView->selectedItem() != NULL) { 149 if (attView->selectedItem() != NULL)
150 {
134 attView->takeItem(attView->selectedItem()); 151 attView->takeItem(attView->selectedItem());
135 } 152 }
136 modified = TRUE; 153 modified = TRUE;
137} 154}
138 155
139void AddAtt::reject() 156void AddAtt::reject()
140{ 157{
141 if (modified) { 158 if (modified) {
142 attView->clear(); 159 attView->clear();
143 modified = FALSE; 160 modified = FALSE;
144 } 161 }
145} 162}
146 163
147void AddAtt::accept() 164void AddAtt::accept()
148{ 165{
149 modified = FALSE; 166 modified = FALSE;
150 hide(); 167 hide();
151} 168}
152 169
153void AddAtt::getFiles() 170void AddAtt::getFiles()
154{ 171{
155 QString path, selected; 172 QString path, selected;
156 QDir *dir;
157 173
158 listView->clear(); 174 /*listView->clear();
159 175
160 selected = fileCategoryButton->text(); 176 selected = fileCategoryButton->text();
161 if (selected == "Picture") { 177 if (selected == "Picture") {
162 path = "../pics/"; 178 path = "../pics/";
163 } else if (selected == "Document") { 179 } else if (selected == "Document") {
164 path = "" ; //sub-dirs not decided 180 path = "" ; //sub-dirs not decided
165 } else if (selected == "Sound") { 181 } else if (selected == "Sound") {
166 path = "../sounds/"; //sub-dirs not decided 182 path = "../sounds/"; //sub-dirs not decided
167 } else if (selected == "Movie") { 183 } else if (selected == "Movie") {
168 path = ""; //sub-dirs not decided 184 path = ""; //sub-dirs not decided
169 } else if (selected == "File") { 185 } else if (selected == "File") {
170 path = ""; //sub-dirs not decided 186 path = ""; //sub-dirs not decided
171 } 187 }
172 188
173 dir = new QDir(path); 189 dir = new QDir(path);
174 dir->setFilter(QDir::Files); 190 dir->setFilter(QDir::Files);
175 const QFileInfoList *dirInfoList = dir->entryInfoList(); 191 const QFileInfoList *dirInfoList = dir->entryInfoList();
176 192
177 QFileInfoListIterator it(*dirInfoList); // create list iterator 193 QFileInfoListIterator it(*dirInfoList); // create list iterator
178 194
179 while ( (fi=it.current()) ) { // for each file... 195 while ( (fi=it.current()) ) { // for each file...
180 item = new FileItem(listView, *fi, selected); 196 item = new FileItem(listView, *fi, selected);
181 ++it; // goto next list element 197 ++it; // goto next list element
182 } 198 }*/
183} 199}
184 200
185QStringList AddAtt::returnAttatchedFiles() 201QStringList AddAtt::returnAttatchedFiles()
186{ 202{
187 QFileInfo info; 203 QFileInfo info;
188 QStringList list; 204 QStringList list;
189 205
190 item = (FileItem *) attView->firstChild(); 206 item = (FileItem *) attView->firstChild();
207
208
191 while (item != NULL) { 209 while (item != NULL) {
192 info = item->getFileInfo(); 210 DocLnk* dl=item->getDocLnk();
193 list += info.filePath(); 211 list+=dl->file();
212 /*info = item->getFileInfo();
213 list += info.filePath();*/
194 item = (FileItem *) item->nextSibling(); 214 item = (FileItem *) item->nextSibling();
195 } 215 }
196 return list; 216 return list;
197} 217}
198 218
199QStringList AddAtt::returnFileTypes() 219QStringList AddAtt::returnFileTypes()
200{ 220{
201 QStringList list; 221 QStringList list;
202 222
203 item = (FileItem *) attView->firstChild(); 223 item = (FileItem *) attView->firstChild();
224
204 while (item != NULL) { 225 while (item != NULL) {
205 list += item->getFileType(); 226 list += item->getDocLnk()->type();
206 item = (FileItem *) item->nextSibling(); 227 item = (FileItem *) item->nextSibling();
207 } 228 }
208 return list; 229 return list;
209} 230}
diff --git a/noncore/net/mailit/addatt.h b/noncore/net/mailit/addatt.h
index 867c905..73062e2 100644
--- a/noncore/net/mailit/addatt.h
+++ b/noncore/net/mailit/addatt.h
@@ -1,70 +1,76 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef ADDATT_H 20#ifndef ADDATT_H
21#define ADDATT_H 21#define ADDATT_H
22 22
23#include <qdialog.h> 23#include <qdialog.h>
24#include <qlistview.h> 24#include <qlistview.h>
25#include <qpushbutton.h> 25#include <qpushbutton.h>
26#include <qpopupmenu.h> 26#include <qpopupmenu.h>
27#include <qstring.h> 27#include <qstring.h>
28#include <qfileinfo.h> 28#include <qfileinfo.h>
29#include <qstringlist.h> 29#include <qstringlist.h>
30#include <opie/ofileselector.h>
31#include <qpe/applnk.h>
30 32
31class FileItem : public QListViewItem 33class FileItem : public QListViewItem
32{ 34{
33public: 35public:
34 FileItem(QListView *parent, QFileInfo fileInfo, QString fileType); 36 //FileItem(QListView *parent, QFileInfo fileInfo, QString fileType);
35 QFileInfo getFileInfo(); 37 FileItem(QListView*, DocLnk*);
36 QString getFileType(); 38 ~FileItem();
37 39 DocLnk* getDocLnk() {return doclnk;}
40
41
38private: 42private:
39 QFileInfo file; 43 DocLnk* doclnk;
40 QString type;
41}; 44};
42 45
43class AddAtt : public QDialog 46class AddAtt : public QDialog
44{ 47{
45 Q_OBJECT 48 Q_OBJECT
46 49
47public: 50public:
48 AddAtt(QWidget *parent = 0, const char *name = 0, WFlags f = 0); 51 AddAtt(QWidget *parent = 0, const char *name = 0, WFlags f = 0);
49 QStringList returnAttatchedFiles(); 52 QStringList returnAttatchedFiles();
50 QStringList returnFileTypes(); 53 QStringList returnFileTypes();
51 void getFiles(); 54 void getFiles();
52 void clear(); 55 void clear();
53 56
57
54public slots: 58public slots:
55 void fileCategorySelected(int); 59 //void fileCategorySelected(int);
56 void addAttatchment(); 60 void addAttatchment();
57 void removeAttatchment(); 61 void removeAttatchment();
58 void reject(); 62 void reject();
59 void accept(); 63 void accept();
60 64
61private: 65private:
62 FileItem *item; 66 FileItem* item;
63 QListView *listView, *attView; 67 QListView *attView;
64 QPushButton *fileCategoryButton, *attatchButton, *removeButton; 68 QPushButton *fileCategoryButton, *attatchButton, *removeButton;
65 QPopupMenu *fileCategories; 69 QPopupMenu *fileCategories;
66 bool modified; 70 bool modified;
67 QFileInfo *fi; 71 QFileInfo *fi;
72
73 OFileSelector* ofs;
68}; 74};
69 75
70#endif 76#endif
diff --git a/noncore/net/mailit/emailclient.cpp b/noncore/net/mailit/emailclient.cpp
index fc4276b..9258aac 100644
--- a/noncore/net/mailit/emailclient.cpp
+++ b/noncore/net/mailit/emailclient.cpp
@@ -1,858 +1,864 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qapplication.h> 20#include <qapplication.h>
21#include <qmessagebox.h> 21#include <qmessagebox.h>
22#include <qfile.h> 22#include <qfile.h>
23#include <qcheckbox.h> 23#include <qcheckbox.h>
24#include <qmenubar.h> 24#include <qmenubar.h>
25#include <qaction.h> 25#include <qaction.h>
26#include "resource.h" 26#include "resource.h"
27#include "emailclient.h" 27#include "emailclient.h"
28 28
29QCollection::Item AccountList::newItem(QCollection::Item d) 29QCollection::Item AccountList::newItem(QCollection::Item d)
30{ 30{
31 return dupl( (MailAccount *) d); 31 return dupl( (MailAccount *) d);
32} 32}
33 33
34MailAccount* AccountList::dupl(MailAccount *in) 34MailAccount* AccountList::dupl(MailAccount *in)
35{ 35{
36 ac = new MailAccount(*in); 36 ac = new MailAccount(*in);
37 return ac; 37 return ac;
38} 38}
39 39
40EmailClient::EmailClient( QWidget* parent, const char* name, WFlags fl ) 40EmailClient::EmailClient( QWidget* parent, const char* name, WFlags fl )
41 : QMainWindow( parent, name, fl ) 41 : QMainWindow( parent, name, fl )
42{ 42{
43 emailHandler = new EmailHandler(); 43 emailHandler = new EmailHandler();
44 addressList = new AddressList( getPath(FALSE) + "mail_adr"); 44 addressList = new AddressList( getPath(FALSE) + "mail_adr");
45 45
46 sending = FALSE; 46 sending = FALSE;
47 receiving = FALSE; 47 receiving = FALSE;
48 previewingMail = FALSE; 48 previewingMail = FALSE;
49 mailIdCount = 1; 49 mailIdCount = 1;
50 accountIdCount = 1; 50 accountIdCount = 1;
51 allAccounts = FALSE; 51 allAccounts = FALSE;
52 52
53 init(); 53 init();
54 54
55 connect(emailHandler, SIGNAL(mailSent()), this, SLOT(mailSent()) ); 55 connect(emailHandler, SIGNAL(mailSent()), this, SLOT(mailSent()) );
56 56
57 connect(emailHandler, SIGNAL(smtpError(int)), this, 57 connect(emailHandler, SIGNAL(smtpError(int)), this,
58 SLOT(smtpError(int)) ); 58 SLOT(smtpError(int)) );
59 connect(emailHandler, SIGNAL(popError(int)), this, 59 connect(emailHandler, SIGNAL(popError(int)), this,
60 SLOT(popError(int)) ); 60 SLOT(popError(int)) );
61 61
62 connect(inboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(inboxItemSelected()) ); 62 connect(inboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(inboxItemSelected()) );
63 connect(outboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(outboxItemSelected()) ); 63 connect(outboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(outboxItemSelected()) );
64 64
65 connect(emailHandler, SIGNAL(mailArrived(const Email &, bool)), this, 65 connect(emailHandler, SIGNAL(mailArrived(const Email &, bool)), this,
66 SLOT(mailArrived(const Email &, bool)) ); 66 SLOT(mailArrived(const Email &, bool)) );
67 connect(emailHandler, SIGNAL(mailTransfered(int)), this, 67 connect(emailHandler, SIGNAL(mailTransfered(int)), this,
68 SLOT(allMailArrived(int)) ); 68 SLOT(allMailArrived(int)) );
69 69
70 mailconf = new Config("mailit"); 70 mailconf = new Config("mailit");
71 //In case Synchronize is not defined in settings.txt 71 //In case Synchronize is not defined in settings.txt
72 72
73 readSettings(); 73 readSettings();
74 74
75 updateAccounts(); 75 updateAccounts();
76 76
77 lineShift = "\n"; 77 lineShift = "\n";
78 readMail(); 78 readMail();
79 lineShift = "\r\n"; 79 lineShift = "\r\n";
80 80
81} 81}
82 82
83 83
84EmailClient::~EmailClient() 84EmailClient::~EmailClient()
85{ 85{
86 //needs to be moved from destructor to closewindow event 86 //needs to be moved from destructor to closewindow event
87 saveMail(getPath(FALSE) + "inbox.txt", inboxView); 87 saveMail(getPath(FALSE) + "inbox.txt", inboxView);
88 //does not currently work. Defining outbox in the same 88 //does not currently work. Defining outbox in the same
89 //format as inbox is not a good solution as they have 89 //format as inbox is not a good solution as they have
90 //different properties 90 //different properties
91 saveMail(getPath(FALSE) + "outbox.txt", outboxView); 91 saveMail(getPath(FALSE) + "outbox.txt", outboxView);
92 saveSettings(); 92 saveSettings();
93 93
94 mailconf->write(); 94 mailconf->write();
95 delete mailconf; 95 delete mailconf;
96 96
97} 97}
98 98
99void EmailClient::init() 99void EmailClient::init()
100{ 100{
101 statusBar = new QStatusBar(this); 101 statusBar = new QStatusBar(this);
102 statusBar->setSizeGripEnabled(FALSE); 102 statusBar->setSizeGripEnabled(FALSE);
103 103
104 status1Label = new QLabel( tr("Idle"), statusBar); 104 status1Label = new QLabel( tr("Idle"), statusBar);
105 status2Label = new QLabel("", statusBar); 105 status2Label = new QLabel("", statusBar);
106 connect(emailHandler, SIGNAL(updatePopStatus(const QString &)), 106 connect(emailHandler, SIGNAL(updatePopStatus(const QString &)),
107 status2Label, SLOT(setText(const QString &)) ); 107 status2Label, SLOT(setText(const QString &)) );
108 connect(emailHandler, SIGNAL(updateSmtpStatus(const QString &)), 108 connect(emailHandler, SIGNAL(updateSmtpStatus(const QString &)),
109 status2Label, SLOT(setText(const QString &)) ); 109 status2Label, SLOT(setText(const QString &)) );
110 110
111 progressBar = new QProgressBar(statusBar); 111 progressBar = new QProgressBar(statusBar);
112 connect(emailHandler, SIGNAL(mailboxSize(int)), 112 connect(emailHandler, SIGNAL(mailboxSize(int)),
113 this, SLOT(setTotalSize(int)) ); 113 this, SLOT(setTotalSize(int)) );
114 connect(emailHandler, SIGNAL(currentMailSize(int)), 114 connect(emailHandler, SIGNAL(currentMailSize(int)),
115 this, SLOT(setMailSize(int)) ); 115 this, SLOT(setMailSize(int)) );
116 connect(emailHandler, SIGNAL(downloadedSize(int)), 116 connect(emailHandler, SIGNAL(downloadedSize(int)),
117 this, SLOT(setDownloadedSize(int)) ); 117 this, SLOT(setDownloadedSize(int)) );
118 118
119 statusBar->addWidget(status1Label); 119 statusBar->addWidget(status1Label);
120 statusBar->addWidget(progressBar); 120 statusBar->addWidget(progressBar);
121 statusBar->addWidget(status2Label); 121 statusBar->addWidget(status2Label);
122 122
123 setToolBarsMovable(FALSE); 123 setToolBarsMovable(FALSE);
124 124
125 bar = new QToolBar(this); 125 bar = new QToolBar(this);
126 bar->setHorizontalStretchable( TRUE ); 126 bar->setHorizontalStretchable( TRUE );
127 127
128 mb = new QMenuBar( bar ); 128 mb = new QMenuBar( bar );
129 129
130 QPopupMenu *mail = new QPopupMenu(mb); 130 QPopupMenu *mail = new QPopupMenu(mb);
131 mb->insertItem( tr( "&Mail" ), mail); 131 mb->insertItem( tr( "&Mail" ), mail);
132 132
133 QPopupMenu *configure = new QPopupMenu(mb); 133 QPopupMenu *configure = new QPopupMenu(mb);
134 mb->insertItem( tr( "Accounts" ), configure); 134 mb->insertItem( tr( "Accounts" ), configure);
135 135
136 selectAccountMenu = new QPopupMenu(mb); 136 selectAccountMenu = new QPopupMenu(mb);
137 editAccountMenu = new QPopupMenu(mb); 137 editAccountMenu = new QPopupMenu(mb);
138 deleteAccountMenu = new QPopupMenu(mb); 138 deleteAccountMenu = new QPopupMenu(mb);
139 139
140 mail->insertItem(tr("Get Mail in"), selectAccountMenu); 140 mail->insertItem(tr("Get Mail in"), selectAccountMenu);
141 configure->insertItem(tr("Edit account"), editAccountMenu); 141 configure->insertItem(tr("Edit account"), editAccountMenu);
142 configure->insertItem(tr("Delete account"), deleteAccountMenu); 142 configure->insertItem(tr("Delete account"), deleteAccountMenu);
143 143
144 bar = new QToolBar(this); 144 bar = new QToolBar(this);
145 145
146 getMailButton = new QAction(tr("Get all mail"), Resource::loadPixmap("mailit/getmail"), QString::null, 0, this, 0); 146 getMailButton = new QAction(tr("Get all mail"), Resource::loadPixmap("mailit/getmail"), QString::null, 0, this, 0);
147 connect(getMailButton, SIGNAL(activated()), this, SLOT(getAllNewMail()) ); 147 connect(getMailButton, SIGNAL(activated()), this, SLOT(getAllNewMail()) );
148 getMailButton->addTo(bar); 148 getMailButton->addTo(bar);
149 getMailButton->addTo(mail); 149 getMailButton->addTo(mail);
150 150
151 sendMailButton = new QAction(tr("Send mail"), Resource::loadPixmap("mailit/sendmail"), QString::null, 0, this, 0); 151 sendMailButton = new QAction(tr("Send mail"), Resource::loadPixmap("mailit/sendmail"), QString::null, 0, this, 0);
152 connect(sendMailButton, SIGNAL(activated()), this, SLOT(sendQuedMail()) ); 152 connect(sendMailButton, SIGNAL(activated()), this, SLOT(sendQuedMail()) );
153 sendMailButton->addTo(bar); 153 sendMailButton->addTo(bar);
154 sendMailButton->addTo(mail); 154 sendMailButton->addTo(mail);
155 155
156 composeButton = new QAction(tr("Compose"), Resource::loadPixmap("new"), QString::null, 0, this, 0); 156 composeButton = new QAction(tr("Compose"), Resource::loadPixmap("new"), QString::null, 0, this, 0);
157 connect(composeButton, SIGNAL(activated()), this, SLOT(compose()) ); 157 connect(composeButton, SIGNAL(activated()), this, SLOT(compose()) );
158 composeButton->addTo(bar); 158 composeButton->addTo(bar);
159 composeButton->addTo(mail); 159 composeButton->addTo(mail);
160 160
161 cancelButton = new QAction(tr("Cancel transfer"), Resource::loadPixmap("close"), QString::null, 0, this, 0); 161 cancelButton = new QAction(tr("Cancel transfer"), Resource::loadPixmap("close"), QString::null, 0, this, 0);
162 connect(cancelButton, SIGNAL(activated()), this, SLOT(cancel()) ); 162 connect(cancelButton, SIGNAL(activated()), this, SLOT(cancel()) );
163 cancelButton->addTo(mail); 163 cancelButton->addTo(mail);
164 cancelButton->addTo(bar);
164 cancelButton->setEnabled(FALSE); 165 cancelButton->setEnabled(FALSE);
165 166
166 mailboxView = new OTabWidget( this, "mailboxView" ); 167 mailboxView = new OTabWidget( this, "mailboxView" );
167 168
168 QWidget* widget = new QWidget( mailboxView, "widget" ); 169 QWidget* widget = new QWidget( mailboxView, "widget" );
169 grid_2 = new QGridLayout( widget ); 170 grid_2 = new QGridLayout( widget );
170// grid_2->setSpacing(6); 171// grid_2->setSpacing(6);
171// grid_2->setMargin( 11 ); 172// grid_2->setMargin( 11 );
172 173
173 inboxView = new QListView( widget, "inboxView" ); 174 inboxView = new QListView( widget, "inboxView" );
174 inboxView->addColumn( tr( "From" ) ); 175 inboxView->addColumn( tr( "From" ) );
175 inboxView->addColumn( tr( "Subject" ) ); 176 inboxView->addColumn( tr( "Subject" ) );
176 inboxView->addColumn( tr( "Date" ) ); 177 inboxView->addColumn( tr( "Date" ) );
177 inboxView->setMinimumSize( QSize( 0, 0 ) ); 178 inboxView->setMinimumSize( QSize( 0, 0 ) );
178 inboxView->setAllColumnsShowFocus(TRUE); 179 inboxView->setAllColumnsShowFocus(TRUE);
179 180
180 grid_2->addWidget( inboxView, 2, 0 ); 181 grid_2->addWidget( inboxView, 2, 0 );
181 mailboxView->addTab( widget, "mailit/inbox", tr( "Inbox" ) ); 182 mailboxView->addTab( widget, "mailit/inbox", tr( "Inbox" ) );
182 183
183 QWidget* widget_2 = new QWidget( mailboxView, "widget_2" ); 184 QWidget* widget_2 = new QWidget( mailboxView, "widget_2" );
184 grid_3 = new QGridLayout( widget_2 ); 185 grid_3 = new QGridLayout( widget_2 );
185// grid_3->setSpacing(6); 186// grid_3->setSpacing(6);
186// grid_3->setMargin( 11 ); 187// grid_3->setMargin( 11 );
187 188
188 outboxView = new QListView( widget_2, "outboxView" ); 189 outboxView = new QListView( widget_2, "outboxView" );
189 outboxView->addColumn( tr( "To" ) ); 190 outboxView->addColumn( tr( "To" ) );
190 outboxView->addColumn( tr( "Subject" ) ); 191 outboxView->addColumn( tr( "Subject" ) );
191 outboxView->setAllColumnsShowFocus(TRUE); 192 outboxView->setAllColumnsShowFocus(TRUE);
192 193
193 grid_3->addWidget( outboxView, 0, 0 ); 194 grid_3->addWidget( outboxView, 0, 0 );
194 mailboxView->addTab( widget_2,"mailit/outbox", tr( "Outbox" ) ); 195 mailboxView->addTab( widget_2,"mailit/outbox", tr( "Outbox" ) );
195 196
196 setCentralWidget(mailboxView); 197 setCentralWidget(mailboxView);
197} 198}
198 199
199void EmailClient::compose() 200void EmailClient::compose()
200{ 201{
201 emit composeRequested(); 202 emit composeRequested();
202} 203}
203 204
204void EmailClient::cancel() 205void EmailClient::cancel()
205{ 206{
206 emailHandler->cancel(); 207 emailHandler->cancel();
207} 208}
208 209
209AddressList* EmailClient::getAdrListRef() 210AddressList* EmailClient::getAdrListRef()
210{ 211{
211 return addressList; 212 return addressList;
212} 213}
213 214
214//this needs to be rewritten to syncronize with outboxView 215//this needs to be rewritten to syncronize with outboxView
215void EmailClient::enqueMail(const Email &mail) 216void EmailClient::enqueMail(const Email &mail)
216{ 217{
218 if (accountList.count() == 0) {
219 QMessageBox::warning(qApp->activeWindow(),
220 tr("No account selected"), tr("You must create an account"), "OK\n");
221 return;
222 }
223
217 if (accountList.count() > 0) { 224 if (accountList.count() > 0) {
218 currentAccount = accountList.first(); 225 currentAccount = accountList.first();
219 qWarning("using account " + currentAccount->name); 226 qWarning("using account " + currentAccount->name);
220 } 227 }
221 228
222 Email addMail = mail; 229 Email addMail = mail;
223 addMail.from = currentAccount->name; 230 addMail.from = currentAccount->name;
224 addMail.fromMail = currentAccount->emailAddress; 231 addMail.fromMail = currentAccount->emailAddress;
225 addMail.rawMail.prepend("From: " + addMail.from + "<" + addMail.fromMail + ">\n"); 232 addMail.rawMail.prepend("From: " + addMail.from + "<" + addMail.fromMail + ">\n");
226 item = new EmailListItem(outboxView, addMail, false); 233 item = new EmailListItem(outboxView, addMail, false);
227 234
228} 235}
229 236
230void EmailClient::sendQuedMail() 237void EmailClient::sendQuedMail()
231{ 238{
232 int count = 0; 239 int count = 0;
233 240
234 if (accountList.count() == 0) { 241 if (accountList.count() == 0) {
235 QMessageBox::warning(qApp->activeWindow(), 242 QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n");
236 "No account selected", "You must create an account", "OK\n");
237 return; 243 return;
238 } 244 }
239 //traverse listview, find messages to send 245 //traverse listview, find messages to send
240 if (! sending) { 246 if (! sending) {
241 item = (EmailListItem *) outboxView->firstChild(); 247 item = (EmailListItem *) outboxView->firstChild();
242 if (item != NULL) { 248 if (item != NULL) {
243 while (item != NULL) { 249 while (item != NULL) {
244 quedMessages.append(item->getMail()); 250 quedMessages.append(item->getMail());
245 item = (EmailListItem *) item->nextSibling(); 251 item = (EmailListItem *) item->nextSibling();
246 count++; 252 count++;
247 } 253 }
248 setMailAccount(); 254 setMailAccount();
249 emailHandler->sendMail(&quedMessages); 255 emailHandler->sendMail(&quedMessages);
250 sending = TRUE; 256 sending = TRUE;
251 sendMailButton->setEnabled(FALSE); 257 sendMailButton->setEnabled(FALSE);
252 cancelButton->setEnabled(TRUE); 258 cancelButton->setEnabled(TRUE);
253 } else { 259 } else {
254 qWarning("sendQuedMail(): no messages to send"); 260 qWarning("sendQuedMail(): no messages to send");
255 } 261 }
256 } 262 }
257} 263}
258 264
259void EmailClient::setMailAccount() 265void EmailClient::setMailAccount()
260{ 266{
261 emailHandler->setAccount(*currentAccount); 267 emailHandler->setAccount(*currentAccount);
262} 268}
263 269
264void EmailClient::mailSent() 270void EmailClient::mailSent()
265{ 271{
266 sending = FALSE; 272 sending = FALSE;
267 sendMailButton->setEnabled(TRUE); 273 sendMailButton->setEnabled(TRUE);
268 274
269 quedMessages.clear(); 275 quedMessages.clear();
270 outboxView->clear(); //should be moved to an sentBox 276 outboxView->clear(); //should be moved to an sentBox
271} 277}
272 278
273void EmailClient::getNewMail() { 279void EmailClient::getNewMail() {
274 280
275 if (accountList.count() == 0) { 281 if (accountList.count() == 0) {
276 QMessageBox::warning(qApp->activeWindow(),"No account selected", 282 QMessageBox::warning(qApp->activeWindow(),"No account selected",
277 "You must create an account", "OK\n"); 283 "You must create an account", "OK\n");
278 return; 284 return;
279 } 285 }
280 286
281 setMailAccount(); 287 setMailAccount();
282 288
283 receiving = TRUE; 289 receiving = TRUE;
284 previewingMail = TRUE; 290 previewingMail = TRUE;
285 getMailButton->setEnabled(FALSE); 291 getMailButton->setEnabled(FALSE);
286 cancelButton->setEnabled(TRUE); 292 cancelButton->setEnabled(TRUE);
287 selectAccountMenu->setEnabled(FALSE); 293 selectAccountMenu->setEnabled(FALSE);
288 294
289 status1Label->setText(currentAccount->accountName + " headers"); 295 status1Label->setText(currentAccount->accountName + " headers");
290 progressBar->reset(); 296 progressBar->reset();
291 297
292 //get any previous mails not downloaded and add to queue 298 //get any previous mails not downloaded and add to queue
293 mailDownloadList.clear(); 299 mailDownloadList.clear();
294 Email *mailPtr; 300 Email *mailPtr;
295 item = (EmailListItem *) inboxView->firstChild(); 301 item = (EmailListItem *) inboxView->firstChild();
296 while (item != NULL) { 302 while (item != NULL) {
297 mailPtr = item->getMail(); 303 mailPtr = item->getMail();
298 if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { 304 if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) {
299 mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); 305 mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size);
300 } 306 }
301 item = (EmailListItem *) item->nextSibling(); 307 item = (EmailListItem *) item->nextSibling();
302 } 308 }
303 309
304 emailHandler->getMailHeaders(); 310 emailHandler->getMailHeaders();
305} 311}
306 312
307void EmailClient::getAllNewMail() 313void EmailClient::getAllNewMail()
308{ 314{
309 allAccounts = TRUE; 315 allAccounts = TRUE;
310 currentAccount = accountList.first(); 316 currentAccount = accountList.first();
311 getNewMail(); 317 getNewMail();
312} 318}
313 319
314void EmailClient::mailArrived(const Email &mail, bool fromDisk) 320void EmailClient::mailArrived(const Email &mail, bool fromDisk)
315{ 321{
316 Enclosure *ePtr; 322 Enclosure *ePtr;
317 Email newMail; 323 Email newMail;
318 int thisMailId; 324 int thisMailId;
319 emailHandler->parse(mail.rawMail, lineShift, &newMail); 325 emailHandler->parse(mail.rawMail, lineShift, &newMail);
320 326
321 mailconf->setGroup(newMail.id); 327 mailconf->setGroup(newMail.id);
322 328
323 if (fromDisk) { 329 if (fromDisk) {
324 newMail.downloaded = mailconf->readBoolEntry("downloaded"); 330 newMail.downloaded = mailconf->readBoolEntry("downloaded");
325 newMail.size = mailconf->readNumEntry("size"); 331 newMail.size = mailconf->readNumEntry("size");
326 newMail.serverId = mailconf->readNumEntry("serverid"); 332 newMail.serverId = mailconf->readNumEntry("serverid");
327 newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); 333 newMail.fromAccountId = mailconf->readNumEntry("fromaccountid");
328 } else { //mail arrived from server 334 } else { //mail arrived from server
329 newMail.serverId = mail.serverId; 335 newMail.serverId = mail.serverId;
330 newMail.size = mail.size; 336 newMail.size = mail.size;
331 newMail.downloaded = mail.downloaded; 337 newMail.downloaded = mail.downloaded;
332 338
333 newMail.fromAccountId = currentAccount->id; 339 newMail.fromAccountId = currentAccount->id;
334 mailconf->writeEntry("fromaccountid", newMail.fromAccountId); 340 mailconf->writeEntry("fromaccountid", newMail.fromAccountId);
335 } 341 }
336 342
337 //add if read or not 343 //add if read or not
338 newMail.read = mailconf->readBoolEntry("mailread"); 344 newMail.read = mailconf->readBoolEntry("mailread");
339 345
340 //check if new mail 346 //check if new mail
341 if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { 347 if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) {
342 thisMailId = mailIdCount; 348 thisMailId = mailIdCount;
343 mailIdCount++; 349 mailIdCount++;
344 350
345 //set server count, so that if the user aborts, the new 351 //set server count, so that if the user aborts, the new
346 //header is not reloaded 352 //header is not reloaded
347 if (currentAccount->synchronize) 353 if (currentAccount->synchronize)
348 currentAccount->lastServerMailCount++; 354 currentAccount->lastServerMailCount++;
349 355
350 mailconf->writeEntry("internalmailid", thisMailId); 356 mailconf->writeEntry("internalmailid", thisMailId);
351 mailconf->writeEntry("downloaded", newMail.downloaded); 357 mailconf->writeEntry("downloaded", newMail.downloaded);
352 mailconf->writeEntry("size", (int) newMail.size); 358 mailconf->writeEntry("size", (int) newMail.size);
353 mailconf->writeEntry("serverid", newMail.serverId); 359 mailconf->writeEntry("serverid", newMail.serverId);
354 360
355 addressList->addContact(newMail.fromMail, newMail.from); 361 addressList->addContact(newMail.fromMail, newMail.from);
356 } else if (!fromDisk) { //body to header arrived 362 } else if (!fromDisk) { //body to header arrived
357 mailconf->writeEntry("downloaded", TRUE); 363 mailconf->writeEntry("downloaded", TRUE);
358 } 364 }
359 QString stringMailId; 365 QString stringMailId;
360 stringMailId.setNum(thisMailId); 366 stringMailId.setNum(thisMailId);
361 //se if any attatchments needs to be stored 367 //se if any attatchments needs to be stored
362 for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { 368 for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) {
363 QString stringId; 369 QString stringId;
364 stringId.setNum(ePtr->id); 370 stringId.setNum(ePtr->id);
365 371
366 int id = mailconf->readNumEntry("enclosureid_" + stringId); 372 int id = mailconf->readNumEntry("enclosureid_" + stringId);
367 if (id != ePtr->id) { //new entry 373 if (id != ePtr->id) { //new entry
368 mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); 374 mailconf->writeEntry("enclosureid_" + stringId, ePtr->id);
369 mailconf->writeEntry("name_" + stringId, ePtr->originalName); 375 mailconf->writeEntry("name_" + stringId, ePtr->originalName);
370 mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); 376 mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType);
371 mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); 377 mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute);
372 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 378 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
373 mailconf->writeEntry("installed_" + stringId, FALSE); 379 mailconf->writeEntry("installed_" + stringId, FALSE);
374 380
375 ePtr->name = stringMailId + "_" + stringId; 381 ePtr->name = stringMailId + "_" + stringId;
376 ePtr->path = getPath(TRUE); 382 ePtr->path = getPath(TRUE);
377 if (emailHandler->getEnclosure(ePtr)) { //file saved 383 if (emailHandler->getEnclosure(ePtr)) { //file saved
378 ePtr->saved = TRUE; 384 ePtr->saved = TRUE;
379 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 385 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
380 mailconf->writeEntry("filename_" + stringId, ePtr->name); 386 mailconf->writeEntry("filename_" + stringId, ePtr->name);
381 mailconf->writeEntry("path_" + stringId, ePtr->path); 387 mailconf->writeEntry("path_" + stringId, ePtr->path);
382 } else { 388 } else {
383 ePtr->saved = FALSE; 389 ePtr->saved = FALSE;
384 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 390 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
385 } 391 }
386 } else { 392 } else {
387 ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); 393 ePtr->saved = mailconf->readBoolEntry("saved_" + stringId);
388 ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); 394 ePtr->installed = mailconf->readBoolEntry("installed_" + stringId);
389 if (ePtr->saved) { 395 if (ePtr->saved) {
390 ePtr->name = mailconf->readEntry("filename_" + stringId); 396 ePtr->name = mailconf->readEntry("filename_" + stringId);
391 ePtr->path = mailconf->readEntry("path_" + stringId); 397 ePtr->path = mailconf->readEntry("path_" + stringId);
392 } 398 }
393 } 399 }
394 } 400 }
395 if (!previewingMail && !fromDisk) { 401 if (!previewingMail && !fromDisk) {
396 Email *mailPtr; 402 Email *mailPtr;
397 item = (EmailListItem *) inboxView->firstChild(); 403 item = (EmailListItem *) inboxView->firstChild();
398 while (item != NULL) { 404 while (item != NULL) {
399 mailPtr = item->getMail(); 405 mailPtr = item->getMail();
400 if (mailPtr->id == newMail.id) { 406 if (mailPtr->id == newMail.id) {
401 item->setMail(newMail); 407 item->setMail(newMail);
402 emit mailUpdated(item->getMail()); 408 emit mailUpdated(item->getMail());
403 } 409 }
404 item = (EmailListItem *) item->nextSibling(); 410 item = (EmailListItem *) item->nextSibling();
405 } 411 }
406 } else { 412 } else {
407 item = new EmailListItem(inboxView, newMail, TRUE); 413 item = new EmailListItem(inboxView, newMail, TRUE);
408 if (!newMail.downloaded) 414 if (!newMail.downloaded)
409 mailDownloadList.sizeInsert(newMail.serverId, newMail.size); 415 mailDownloadList.sizeInsert(newMail.serverId, newMail.size);
410 } 416 }
411 417
412} 418}
413 419
414void EmailClient::allMailArrived(int count) 420void EmailClient::allMailArrived(int count)
415{ 421{
416 // not previewing means all mailtransfer has been done 422 // not previewing means all mailtransfer has been done
417 if (!previewingMail) { 423 if (!previewingMail) {
418 if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { 424 if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) {
419 emit newCaption("Mailit - " + currentAccount->accountName); 425 emit newCaption("Mailit - " + currentAccount->accountName);
420 getNewMail(); 426 getNewMail();
421 return; 427 return;
422 } else { 428 } else {
423 allAccounts = FALSE; 429 allAccounts = FALSE;
424 receiving = FALSE; 430 receiving = FALSE;
425 getMailButton->setEnabled(TRUE); 431 getMailButton->setEnabled(TRUE);
426 cancelButton->setEnabled(FALSE); 432 cancelButton->setEnabled(FALSE);
427 selectAccountMenu->setEnabled(TRUE); 433 selectAccountMenu->setEnabled(TRUE);
428 status1Label->setText("Idle"); 434 status1Label->setText("Idle");
429 435
430 progressBar->reset(); 436 progressBar->reset();
431 return; 437 return;
432 } 438 }
433 } 439 }
434 440
435 // all headers downloaded from server, start downloading remaining mails 441 // all headers downloaded from server, start downloading remaining mails
436 previewingMail = FALSE; 442 previewingMail = FALSE;
437 status1Label->setText(currentAccount->accountName); 443 status1Label->setText(currentAccount->accountName);
438 progressBar->reset(); 444 progressBar->reset();
439 445
440 emailHandler->getMailByList(&mailDownloadList); 446 emailHandler->getMailByList(&mailDownloadList);
441} 447}
442 448
443void EmailClient::moveMailFront(Email *mailPtr) 449void EmailClient::moveMailFront(Email *mailPtr)
444{ 450{
445 if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { 451 if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) {
446 mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); 452 mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size);
447 } 453 }
448} 454}
449 455
450void EmailClient::smtpError(int code) 456void EmailClient::smtpError(int code)
451{ 457{
452 QString temp; 458 QString temp;
453 459
454 if (code == ErrUnknownResponse) 460 if (code == ErrUnknownResponse)
455 temp = "Unknown response from server"; 461 temp = "Unknown response from server";
456 462
457 if (code == QSocket::ErrHostNotFound) 463 if (code == QSocket::ErrHostNotFound)
458 temp = "host not found"; 464 temp = "host not found";
459 if (code == QSocket::ErrConnectionRefused) 465 if (code == QSocket::ErrConnectionRefused)
460 temp = "connection refused"; 466 temp = "connection refused";
461 if (code == QSocket::ErrSocketRead) 467 if (code == QSocket::ErrSocketRead)
462 temp = "socket packet error"; 468 temp = "socket packet error";
463 469
464 if (code != ErrCancel) { 470 if (code != ErrCancel) {
465 QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); 471 QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n");
466 } else { 472 } else {
467 status2Label->setText("Aborted by user"); 473 status2Label->setText("Aborted by user");
468 } 474 }
469 475
470 sending = FALSE; 476 sending = FALSE;
471 sendMailButton->setEnabled(TRUE); 477 sendMailButton->setEnabled(TRUE);
472 cancelButton->setEnabled(FALSE); 478 cancelButton->setEnabled(FALSE);
473 quedMessages.clear(); 479 quedMessages.clear();
474} 480}
475 481
476void EmailClient::popError(int code) 482void EmailClient::popError(int code)
477{ 483{
478 QString temp; 484 QString temp;
479 485
480 if (code == ErrUnknownResponse) 486 if (code == ErrUnknownResponse)
481 temp = "Unknown response from server"; 487 temp = "Unknown response from server";
482 if (code == ErrLoginFailed) 488 if (code == ErrLoginFailed)
483 temp = "Login failed\nCheck user name and password"; 489 temp = "Login failed\nCheck user name and password";
484 490
485 if (code == QSocket::ErrHostNotFound) 491 if (code == QSocket::ErrHostNotFound)
486 temp = "host not found"; 492 temp = "host not found";
487 if (code == QSocket::ErrConnectionRefused) 493 if (code == QSocket::ErrConnectionRefused)
488 temp = "connection refused"; 494 temp = "connection refused";
489 if (code == QSocket::ErrSocketRead) 495 if (code == QSocket::ErrSocketRead)
490 temp = "socket packet error"; 496 temp = "socket packet error";
491 497
492 if (code != ErrCancel) { 498 if (code != ErrCancel) {
493 QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); 499 QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n");
494 } else { 500 } else {
495 status2Label->setText("Aborted by user"); 501 status2Label->setText("Aborted by user");
496 } 502 }
497 503
498 receiving = FALSE; 504 receiving = FALSE;
499 getMailButton->setEnabled(TRUE); 505 getMailButton->setEnabled(TRUE);
500 cancelButton->setEnabled(FALSE); 506 cancelButton->setEnabled(FALSE);
501 selectAccountMenu->setEnabled(TRUE); 507 selectAccountMenu->setEnabled(TRUE);
502} 508}
503 509
504void EmailClient::inboxItemSelected() 510void EmailClient::inboxItemSelected()
505{ 511{
506 item = (EmailListItem*) inboxView->selectedItem(); 512 item = (EmailListItem*) inboxView->selectedItem();
507 if (item != NULL) { 513 if (item != NULL) {
508 emit viewEmail(inboxView, item->getMail()); 514 emit viewEmail(inboxView, item->getMail());
509 } 515 }
510} 516}
511 517
512void EmailClient::outboxItemSelected() 518void EmailClient::outboxItemSelected()
513{ 519{
514 item = (EmailListItem*) outboxView->selectedItem(); 520 item = (EmailListItem*) outboxView->selectedItem();
515 if (item != NULL) { 521 if (item != NULL) {
516 emit viewEmail(outboxView, item->getMail()); 522 emit viewEmail(outboxView, item->getMail());
517 } 523 }
518 524
519} 525}
520 526
521void EmailClient::readMail() 527void EmailClient::readMail()
522{ 528{
523 Email mail; 529 Email mail;
524 int start, stop; 530 int start, stop;
525 QString s, del; 531 QString s, del;
526 532
527 QFile f(getPath(FALSE) + "inbox.txt"); 533 QFile f(getPath(FALSE) + "inbox.txt");
528// QFileInfo fi(f); 534// QFileInfo fi(f);
529 qDebug( f.name()); 535 qDebug( f.name());
530 536
531 if ( f.open(IO_ReadOnly) ) { // file opened successfully 537 if ( f.open(IO_ReadOnly) ) { // file opened successfully
532 QTextStream t( &f ); // use a text stream 538 QTextStream t( &f ); // use a text stream
533 s = t.read(); 539 s = t.read();
534 f.close(); 540 f.close();
535 541
536 start = 0; 542 start = 0;
537 del = "\n.\n"; 543 del = "\n.\n";
538 while ((uint) start < s.length()) { 544 while ((uint) start < s.length()) {
539 stop = s.find(del, start); 545 stop = s.find(del, start);
540 if (stop == -1) 546 if (stop == -1)
541 stop = s.length() - del.length(); 547 stop = s.length() - del.length();
542 548
543 mail.rawMail = s.mid(start, stop + del.length() - start ); 549 mail.rawMail = s.mid(start, stop + del.length() - start );
544 start = stop + del.length(); 550 start = stop + del.length();
545 mailArrived(mail, TRUE); 551 mailArrived(mail, TRUE);
546 } 552 }
547 } 553 }
548 554
549 QFile fo(getPath(FALSE) + "outbox.txt"); 555 QFile fo(getPath(FALSE) + "outbox.txt");
550 if ( fo.open(IO_ReadOnly) ) { // file opened successfully 556 if ( fo.open(IO_ReadOnly) ) { // file opened successfully
551 QTextStream t( &fo ); // use a text stream 557 QTextStream t( &fo ); // use a text stream
552 s = t.read(); 558 s = t.read();
553 fo.close(); 559 fo.close();
554 560
555 start = 0; 561 start = 0;
556 del = "\n.\n"; 562 del = "\n.\n";
557 while ((uint) start < s.length()) { 563 while ((uint) start < s.length()) {
558 stop = s.find(del, start); 564 stop = s.find(del, start);
559 if (stop == -1) 565 if (stop == -1)
560 stop = s.length() - del.length(); 566 stop = s.length() - del.length();
561 567
562 mail.rawMail = s.mid(start, stop + del.length() - start ); 568 mail.rawMail = s.mid(start, stop + del.length() - start );
563 start = stop + del.length(); 569 start = stop + del.length();
564 emailHandler->parse(mail.rawMail, lineShift, &mail); 570 emailHandler->parse(mail.rawMail, lineShift, &mail);
565 mail.sent = false; 571 mail.sent = false;
566 mail.received = false; 572 mail.received = false;
567 enqueMail(mail); 573 enqueMail(mail);
568 574
569 } 575 }
570 } 576 }
571} 577}
572 578
573void EmailClient::saveMail(QString fileName, QListView *view) 579void EmailClient::saveMail(QString fileName, QListView *view)
574{ 580{
575 QFile f(fileName); 581 QFile f(fileName);
576 Email *mail; 582 Email *mail;
577 583
578 if (! f.open(IO_WriteOnly) ) { 584 if (! f.open(IO_WriteOnly) ) {
579 qWarning("could not open file"); 585 qWarning("could not open file");
580 return; 586 return;
581 } 587 }
582 item = (EmailListItem *) view->firstChild(); 588 item = (EmailListItem *) view->firstChild();
583 qDebug (QString("Write : ") ); 589 qDebug (QString("Write : ") );
584 QTextStream t(&f); 590 QTextStream t(&f);
585 while (item != NULL) { 591 while (item != NULL) {
586 mail = item->getMail(); 592 mail = item->getMail();
587 qDebug(mail->rawMail); 593 qDebug(mail->rawMail);
588 qDebug(mail->recipients.first()); 594 qDebug(mail->recipients.first());
589 t << mail->rawMail; 595 t << mail->rawMail;
590 596
591 mailconf->setGroup(mail->id); 597 mailconf->setGroup(mail->id);
592 mailconf->writeEntry("mailread", mail->read); 598 mailconf->writeEntry("mailread", mail->read);
593 599
594 item = (EmailListItem *) item->nextSibling(); 600 item = (EmailListItem *) item->nextSibling();
595 } 601 }
596 f.close(); 602 f.close();
597} 603}
598 604
599//paths for mailit, is settings, inbox, enclosures 605//paths for mailit, is settings, inbox, enclosures
600QString EmailClient::getPath(bool enclosurePath) 606QString EmailClient::getPath(bool enclosurePath)
601{ 607{
602 QString basePath = "qtmail"; 608 QString basePath = "qtmail";
603 QString enclosures = "enclosures"; 609 QString enclosures = "enclosures";
604 610
605 QDir dir = (QString(getenv("HOME")) + "/Applications/" + basePath); 611 QDir dir = (QString(getenv("HOME")) + "/Applications/" + basePath);
606 if ( !dir.exists() ) 612 if ( !dir.exists() )
607 dir.mkdir( dir.path() ); 613 dir.mkdir( dir.path() );
608 614
609 if (enclosurePath) { 615 if (enclosurePath) {
610 dir = (QString(getenv("HOME")) + "/Applications/" + basePath + "/" + enclosures); 616 dir = (QString(getenv("HOME")) + "/Applications/" + basePath + "/" + enclosures);
611 617
612 if ( !dir.exists() ) 618 if ( !dir.exists() )
613 dir.mkdir( dir.path() ); 619 dir.mkdir( dir.path() );
614 620
615 return (dir.path() + "/"); 621 return (dir.path() + "/");
616 622
617 } 623 }
618 return (dir.path() + "/"); 624 return (dir.path() + "/");
619} 625}
620 626
621void EmailClient::readSettings() 627void EmailClient::readSettings()
622{ 628{
623 TextParser *p; 629 TextParser *p;
624 QString s; 630 QString s;
625 int pos, accountPos, y; 631 int pos, accountPos, y;
626 QFile f( getPath(FALSE) + "settings.txt"); 632 QFile f( getPath(FALSE) + "settings.txt");
627 633
628 if ( f.open(IO_ReadOnly) ) { // file opened successfully 634 if ( f.open(IO_ReadOnly) ) { // file opened successfully
629 QTextStream t( &f ); // use a text stream 635 QTextStream t( &f ); // use a text stream
630 s = t.read(); 636 s = t.read();
631 f.close(); 637 f.close();
632 638
633 p = new TextParser(s, "\n"); 639 p = new TextParser(s, "\n");
634 640
635 accountPos = 0; 641 accountPos = 0;
636 while ( (accountPos = p->find("ACCOUNTSTART",';', accountPos, TRUE)) != -1 ) { 642 while ( (accountPos = p->find("ACCOUNTSTART",';', accountPos, TRUE)) != -1 ) {
637 accountPos++; 643 accountPos++;
638 if ( (pos = p->find("ACCOUNTNAME",':', accountPos, TRUE)) != -1 ) 644 if ( (pos = p->find("ACCOUNTNAME",':', accountPos, TRUE)) != -1 )
639 account.accountName = p->getString(& ++pos, 'z', TRUE); 645 account.accountName = p->getString(& ++pos, 'z', TRUE);
640 if ( (pos = p->find("NAME",':', accountPos, TRUE)) != -1) 646 if ( (pos = p->find("NAME",':', accountPos, TRUE)) != -1)
641 account.name = p->getString(& ++pos, 'z', TRUE); 647 account.name = p->getString(& ++pos, 'z', TRUE);
642 if ( (pos = p->find("EMAIL",':', accountPos, TRUE)) != -1) 648 if ( (pos = p->find("EMAIL",':', accountPos, TRUE)) != -1)
643 account.emailAddress = p->getString(& ++pos, 'z', TRUE); 649 account.emailAddress = p->getString(& ++pos, 'z', TRUE);
644 if ( (pos = p->find("POPUSER",':', accountPos, TRUE)) != -1) 650 if ( (pos = p->find("POPUSER",':', accountPos, TRUE)) != -1)
645 account.popUserName = p->getString(& ++pos, 'z', TRUE); 651 account.popUserName = p->getString(& ++pos, 'z', TRUE);
646 if ( (pos = p->find("POPPASSWORD",':', accountPos, TRUE)) != -1) 652 if ( (pos = p->find("POPPASSWORD",':', accountPos, TRUE)) != -1)
647 account.popPasswd = p->getString(& ++pos, 'z', TRUE); 653 account.popPasswd = p->getString(& ++pos, 'z', TRUE);
648 if ( (pos = p->find("POPSERVER",':', accountPos, TRUE)) != -1) 654 if ( (pos = p->find("POPSERVER",':', accountPos, TRUE)) != -1)
649 account.popServer = p->getString(& ++pos, 'z', TRUE); 655 account.popServer = p->getString(& ++pos, 'z', TRUE);
650 if ( (pos = p->find("SMTPSERVER",':', accountPos, TRUE)) != -1) 656 if ( (pos = p->find("SMTPSERVER",':', accountPos, TRUE)) != -1)
651 account.smtpServer = p->getString(& ++pos, 'z', TRUE); 657 account.smtpServer = p->getString(& ++pos, 'z', TRUE);
652 if ( (pos = p->find("ACCOUNTID",':', accountPos, TRUE)) != -1) { 658 if ( (pos = p->find("ACCOUNTID",':', accountPos, TRUE)) != -1) {
653 s = p->getString(& ++pos, 'z', TRUE); 659 s = p->getString(& ++pos, 'z', TRUE);
654 account.id = s.toInt(); 660 account.id = s.toInt();
655 } 661 }
656 662
657 account.lastServerMailCount = 0; 663 account.lastServerMailCount = 0;
658 account.synchronize = FALSE; 664 account.synchronize = FALSE;
659 if ( (pos = p->find("SYNCHRONIZE",':', accountPos, TRUE)) != -1) { 665 if ( (pos = p->find("SYNCHRONIZE",':', accountPos, TRUE)) != -1) {
660 if (p->getString(& ++pos, 'z', TRUE).upper() == "YES") { 666 if (p->getString(& ++pos, 'z', TRUE).upper() == "YES") {
661 account.synchronize = TRUE; 667 account.synchronize = TRUE;
662 if ( (pos = p->find("LASTSERVERMAILCOUNT",':', accountPos, TRUE)) != -1) { 668 if ( (pos = p->find("LASTSERVERMAILCOUNT",':', accountPos, TRUE)) != -1) {
663 s = p->getString(& ++pos, 'z', TRUE); 669 s = p->getString(& ++pos, 'z', TRUE);
664 account.lastServerMailCount = s.toInt(); 670 account.lastServerMailCount = s.toInt();
665 } 671 }
666 } 672 }
667 } 673 }
668 accountList.append(&account); 674 accountList.append(&account);
669 } 675 }
670 delete p; 676 delete p;
671 } 677 }
672 mailconf->setGroup("mailitglobal"); 678 mailconf->setGroup("mailitglobal");
673 if ( (y = mailconf->readNumEntry("mailidcount", -1)) != -1) { 679 if ( (y = mailconf->readNumEntry("mailidcount", -1)) != -1) {
674 mailIdCount = y; 680 mailIdCount = y;
675 } 681 }
676 if ( (y = mailconf->readNumEntry("accountidcount", -1)) != -1) { 682 if ( (y = mailconf->readNumEntry("accountidcount", -1)) != -1) {
677 accountIdCount = y; 683 accountIdCount = y;
678 } 684 }
679} 685}
680 686
681void EmailClient::saveSettings() 687void EmailClient::saveSettings()
682{ 688{
683 QString temp; 689 QString temp;
684 QFile f( getPath(FALSE) + "settings.txt"); 690 QFile f( getPath(FALSE) + "settings.txt");
685 MailAccount *accountPtr; 691 MailAccount *accountPtr;
686 692
687 if (! f.open(IO_WriteOnly) ) { 693 if (! f.open(IO_WriteOnly) ) {
688 qWarning("could not save settings file"); 694 qWarning("could not save settings file");
689 return; 695 return;
690 } 696 }
691 QTextStream t(&f); 697 QTextStream t(&f);
692 t << "#Settings for QPE Mailit program\n"; 698 t << "#Settings for QPE Mailit program\n";
693 699
694 for (accountPtr = accountList.first(); accountPtr != 0; 700 for (accountPtr = accountList.first(); accountPtr != 0;
695 accountPtr = accountList.next()) { 701 accountPtr = accountList.next()) {
696 702
697 t << "accountStart;\n"; 703 t << "accountStart;\n";
698 t << "AccountName: " + accountPtr->accountName + "\n"; 704 t << "AccountName: " + accountPtr->accountName + "\n";
699 t << "Name: " + accountPtr->name + "\n"; 705 t << "Name: " + accountPtr->name + "\n";
700 t << "Email: " + accountPtr->emailAddress + "\n"; 706 t << "Email: " + accountPtr->emailAddress + "\n";
701 t << "POPUser: " + accountPtr->popUserName + "\n"; 707 t << "POPUser: " + accountPtr->popUserName + "\n";
702 t << "POPPAssword: " + accountPtr->popPasswd + "\n"; 708 t << "POPPAssword: " + accountPtr->popPasswd + "\n";
703 t << "POPServer: " + accountPtr->popServer + "\n"; 709 t << "POPServer: " + accountPtr->popServer + "\n";
704 t << "SMTPServer: " + accountPtr->smtpServer + "\n"; 710 t << "SMTPServer: " + accountPtr->smtpServer + "\n";
705 t << "AccountId: " << accountPtr->id << "\n"; 711 t << "AccountId: " << accountPtr->id << "\n";
706 if (accountPtr->synchronize) { 712 if (accountPtr->synchronize) {
707 t << "Synchronize: Yes\n"; 713 t << "Synchronize: Yes\n";
708 t << "LastServerMailCount: "; 714 t << "LastServerMailCount: ";
709 t << accountPtr->lastServerMailCount << "\n"; 715 t << accountPtr->lastServerMailCount << "\n";
710 } else { 716 } else {
711 t << "Synchronize: No\n"; 717 t << "Synchronize: No\n";
712 } 718 }
713 t << "accountEnd;\n"; 719 t << "accountEnd;\n";
714 } 720 }
715 f.close(); 721 f.close();
716 722
717 mailconf->setGroup("mailitglobal"); 723 mailconf->setGroup("mailitglobal");
718 mailconf->writeEntry("mailidcount", mailIdCount); 724 mailconf->writeEntry("mailidcount", mailIdCount);
719 mailconf->writeEntry("accountidcount", accountIdCount); 725 mailconf->writeEntry("accountidcount", accountIdCount);
720} 726}
721 727
722void EmailClient::selectAccount(int id) 728void EmailClient::selectAccount(int id)
723{ 729{
724 if (accountList.count() > 0) { 730 if (accountList.count() > 0) {
725 currentAccount = accountList.at(id); 731 currentAccount = accountList.at(id);
726 emit newCaption("Mailit - " + currentAccount->accountName); 732 emit newCaption("Mailit - " + currentAccount->accountName);
727 getNewMail(); 733 getNewMail();
728 } else { 734 } else {
729 emit newCaption("Mailit ! No account defined"); 735 emit newCaption("Mailit ! No account defined");
730 } 736 }
731} 737}
732 738
733void EmailClient::editAccount(int id) 739void EmailClient::editAccount(int id)
734{ 740{
735 MailAccount *newAccount; 741 MailAccount *newAccount;
736 742
737 editAccountView = new EditAccount(this, "account", TRUE); 743 editAccountView = new EditAccount(this, "account", TRUE);
738 if (id == newAccountId) { //new account 744 if (id == newAccountId) { //new account
739 newAccount = new MailAccount; 745 newAccount = new MailAccount;
740 editAccountView->setAccount(newAccount); 746 editAccountView->setAccount(newAccount);
741 } else { 747 } else {
742 newAccount = accountList.at(id); 748 newAccount = accountList.at(id);
743 editAccountView->setAccount(newAccount, FALSE); 749 editAccountView->setAccount(newAccount, FALSE);
744 } 750 }
745 751
746 editAccountView->showMaximized(); 752 editAccountView->showMaximized();
747 editAccountView->exec(); 753 editAccountView->exec();
748 754
749 if (editAccountView->result() == QDialog::Accepted) { 755 if (editAccountView->result() == QDialog::Accepted) {
750 if (id == newAccountId) { 756 if (id == newAccountId) {
751 newAccount->id = accountIdCount; 757 newAccount->id = accountIdCount;
752 accountIdCount++; 758 accountIdCount++;
753 accountList.append(newAccount); 759 accountList.append(newAccount);
754 updateAccounts(); 760 updateAccounts();
755 } else { 761 } else {
756 updateAccounts(); 762 updateAccounts();
757 } 763 }
758 } 764 }
759 765
760 delete editAccountView; 766 delete editAccountView;
761} 767}
762 768
763void EmailClient::deleteAccount(int id) 769void EmailClient::deleteAccount(int id)
764{ 770{
765 MailAccount *newAccount; 771 MailAccount *newAccount;
766 QString message; 772 QString message;
767 773
768 newAccount = accountList.at(id); 774 newAccount = accountList.at(id);
769 message = "Delete account:\n" + newAccount->accountName; 775 message = "Delete account:\n" + newAccount->accountName;
770 switch( QMessageBox::warning( this, "Mailit", message, 776 switch( QMessageBox::warning( this, "Mailit", message,
771 "Yes", "No", 0, 0, 1 ) ) { 777 "Yes", "No", 0, 0, 1 ) ) {
772 778
773 case 0: accountList.remove(id); 779 case 0: accountList.remove(id);
774 updateAccounts(); 780 updateAccounts();
775 break; 781 break;
776 case 1: 782 case 1:
777 break; 783 break;
778 } 784 }
779} 785}
780 786
781void EmailClient::updateAccounts() 787void EmailClient::updateAccounts()
782{ 788{
783 MailAccount *accountPtr; 789 MailAccount *accountPtr;
784 790
785 //rebuild menus, clear all first 791 //rebuild menus, clear all first
786 editAccountMenu->clear(); 792 editAccountMenu->clear();
787 selectAccountMenu->clear(); 793 selectAccountMenu->clear();
788 deleteAccountMenu->clear(); 794 deleteAccountMenu->clear();
789 795
790 newAccountId = editAccountMenu->insertItem("New", this, 796 newAccountId = editAccountMenu->insertItem("New", this,
791 SLOT(editAccount(int)) ); 797 SLOT(editAccount(int)) );
792 editAccountMenu->insertSeparator(); 798 editAccountMenu->insertSeparator();
793 799
794 idCount = 0; 800 idCount = 0;
795 for (accountPtr = accountList.first(); accountPtr != 0; 801 for (accountPtr = accountList.first(); accountPtr != 0;
796 accountPtr = accountList.next()) { 802 accountPtr = accountList.next()) {
797 803
798 editAccountMenu->insertItem(accountPtr->accountName, 804 editAccountMenu->insertItem(accountPtr->accountName,
799 this, SLOT(editAccount(int)), 0, idCount); 805 this, SLOT(editAccount(int)), 0, idCount);
800 selectAccountMenu->insertItem(accountPtr->accountName, 806 selectAccountMenu->insertItem(accountPtr->accountName,
801 this, SLOT(selectAccount(int)), 0, idCount); 807 this, SLOT(selectAccount(int)), 0, idCount);
802 deleteAccountMenu->insertItem(accountPtr->accountName, 808 deleteAccountMenu->insertItem(accountPtr->accountName,
803 this, SLOT(deleteAccount(int)), 0, idCount); 809 this, SLOT(deleteAccount(int)), 0, idCount);
804 idCount++; 810 idCount++;
805 } 811 }
806} 812}
807 813
808void EmailClient::deleteMail(EmailListItem *mailItem, bool &inbox) 814void EmailClient::deleteMail(EmailListItem *mailItem, bool &inbox)
809{ 815{
810 Email *mPtr; 816 Email *mPtr;
811 Enclosure *ePtr; 817 Enclosure *ePtr;
812 818
813 if (inbox) { 819 if (inbox) {
814 mPtr = mailItem->getMail(); 820 mPtr = mailItem->getMail();
815 821
816 //if mail is in queue for download, remove it from 822 //if mail is in queue for download, remove it from
817 //queue if possible 823 //queue if possible
818 if ( (receiving) && (mPtr->fromAccountId == currentAccount->id) ) { 824 if ( (receiving) && (mPtr->fromAccountId == currentAccount->id) ) {
819 if ( !mPtr->downloaded ) 825 if ( !mPtr->downloaded )
820 mailDownloadList.remove(mPtr->serverId, mPtr->size); 826 mailDownloadList.remove(mPtr->serverId, mPtr->size);
821 } 827 }
822 828
823 mailconf->setGroup(mPtr->id); 829 mailconf->setGroup(mPtr->id);
824 mailconf->clearGroup(); 830 mailconf->clearGroup();
825 831
826 //delete any temporary attatchemnts storing 832 //delete any temporary attatchemnts storing
827 for ( ePtr=mPtr->files.first(); ePtr != 0; ePtr=mPtr->files.next() ) { 833 for ( ePtr=mPtr->files.first(); ePtr != 0; ePtr=mPtr->files.next() ) {
828 if (ePtr->saved) { 834 if (ePtr->saved) {
829 QFile::remove( (ePtr->path + ePtr->name) ); 835 QFile::remove( (ePtr->path + ePtr->name) );
830 } 836 }
831 } 837 }
832 inboxView->takeItem(mailItem); 838 inboxView->takeItem(mailItem);
833 } else { 839 } else {
834 outboxView->takeItem(mailItem); 840 outboxView->takeItem(mailItem);
835 } 841 }
836} 842}
837 843
838void EmailClient::setMailSize(int size) 844void EmailClient::setMailSize(int size)
839{ 845{
840 progressBar->reset(); 846 progressBar->reset();
841 progressBar->setTotalSteps(size); 847 progressBar->setTotalSteps(size);
842} 848}
843 849
844void EmailClient::setTotalSize(int size) 850void EmailClient::setTotalSize(int size)
845{ 851{
846 852
847} 853}
848 854
849void EmailClient::setDownloadedSize(int size) 855void EmailClient::setDownloadedSize(int size)
850{ 856{
851 int total = progressBar->totalSteps(); 857 int total = progressBar->totalSteps();
852 858
853 if (size < total) { 859 if (size < total) {
854 progressBar->setProgress(size); 860 progressBar->setProgress(size);
855 } else { 861 } else {
856 progressBar->setProgress(total); 862 progressBar->setProgress(total);
857 } 863 }
858} 864}
diff --git a/noncore/net/mailit/emailhandler.cpp b/noncore/net/mailit/emailhandler.cpp
index 2144899..1be16d4 100644
--- a/noncore/net/mailit/emailhandler.cpp
+++ b/noncore/net/mailit/emailhandler.cpp
@@ -1,589 +1,592 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qfileinfo.h> 20#include <qfileinfo.h>
21#include <stdlib.h> 21#include <stdlib.h>
22#include <qapplication.h> 22#include <qapplication.h>
23#include <qmessagebox.h> 23#include <qmessagebox.h>
24#include <qcstring.h> 24#include <qcstring.h>
25#include "emailhandler.h" 25#include "emailhandler.h"
26#include <qpe/applnk.h> 26#include <qpe/applnk.h>
27#include <qpe/filemanager.h> 27#include <qpe/filemanager.h>
28 28
29QCollection::Item EnclosureList::newItem(QCollection::Item d) 29QCollection::Item EnclosureList::newItem(QCollection::Item d)
30{ 30{
31 return dupl( (Enclosure *) d); 31 return dupl( (Enclosure *) d);
32} 32}
33 33
34Enclosure* EnclosureList::dupl(Enclosure *in) 34Enclosure* EnclosureList::dupl(Enclosure *in)
35{ 35{
36 ac = new Enclosure(*in); 36 ac = new Enclosure(*in);
37 return ac; 37 return ac;
38} 38}
39 39
40EmailHandler::EmailHandler() 40EmailHandler::EmailHandler()
41{ 41{
42 smtpClient = new SmtpClient(); 42 smtpClient = new SmtpClient();
43 popClient = new PopClient(); 43 popClient = new PopClient();
44 44
45 connect(smtpClient, SIGNAL(errorOccurred(int)), this, 45 connect(smtpClient, SIGNAL(errorOccurred(int)), this,
46 SIGNAL(smtpError(int)) ); 46 SIGNAL(smtpError(int)) );
47 connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); 47 connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) );
48 connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, 48 connect(smtpClient, SIGNAL(updateStatus(const QString &)), this,
49 SIGNAL(updateSmtpStatus(const QString &)) ); 49 SIGNAL(updateSmtpStatus(const QString &)) );
50 50
51 connect(popClient, SIGNAL(errorOccurred(int)), this, 51 connect(popClient, SIGNAL(errorOccurred(int)), this,
52 SIGNAL(popError(int)) ); 52 SIGNAL(popError(int)) );
53 connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), 53 connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)),
54 this, SLOT(messageArrived(const QString &, int, uint, bool)) ); 54 this, SLOT(messageArrived(const QString &, int, uint, bool)) );
55 connect(popClient, SIGNAL(updateStatus(const QString &)), this, 55 connect(popClient, SIGNAL(updateStatus(const QString &)), this,
56 SIGNAL(updatePopStatus(const QString &)) ); 56 SIGNAL(updatePopStatus(const QString &)) );
57 connect(popClient, SIGNAL(mailTransfered(int)), this, 57 connect(popClient, SIGNAL(mailTransfered(int)), this,
58 SIGNAL(mailTransfered(int)) ); 58 SIGNAL(mailTransfered(int)) );
59 59
60 60
61 //relaying size information 61 //relaying size information
62 connect(popClient, SIGNAL(currentMailSize(int)), 62 connect(popClient, SIGNAL(currentMailSize(int)),
63 this, SIGNAL(currentMailSize(int)) ); 63 this, SIGNAL(currentMailSize(int)) );
64 connect(popClient, SIGNAL(downloadedSize(int)), 64 connect(popClient, SIGNAL(downloadedSize(int)),
65 this, SIGNAL(downloadedSize(int)) ); 65 this, SIGNAL(downloadedSize(int)) );
66} 66}
67 67
68void EmailHandler::sendMail(QList<Email> *mailList) 68void EmailHandler::sendMail(QList<Email> *mailList)
69{ 69{
70 Email *currentMail; 70 Email *currentMail;
71 QString temp; 71 QString temp;
72 QString userName = mailAccount.name; 72 QString userName = mailAccount.name;
73 userName += " <" + mailAccount.emailAddress + ">"; 73 userName += " <" + mailAccount.emailAddress + ">";
74 74
75 for (currentMail = mailList->first(); currentMail != 0; 75 for (currentMail = mailList->first(); currentMail != 0;
76 currentMail = mailList->next()) { 76 currentMail = mailList->next()) {
77 77
78 if (encodeMime(currentMail) == 0) { 78 if (encodeMime(currentMail) == 0) {
79 smtpClient->addMail(userName, currentMail->subject, 79 smtpClient->addMail(userName, currentMail->subject,
80 currentMail->recipients, currentMail->rawMail); 80 currentMail->recipients, currentMail->rawMail);
81 } else { //error 81 } else { //error
82 temp = tr("Could not locate all files in \nmail with subject: ") + 82 temp = tr("Could not locate all files in \nmail with subject: ") +
83 currentMail->subject; 83 currentMail->subject;
84 temp += tr("\nMail has NOT been sent"); 84 temp += tr("\nMail has NOT been sent");
85 QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); 85 QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n"));
86 86
87 } 87 }
88 } 88 }
89 smtpClient->newConnection(mailAccount.smtpServer, 25); 89 smtpClient->newConnection(mailAccount.smtpServer, 25);
90} 90}
91 91
92void EmailHandler::setAccount(MailAccount account) 92void EmailHandler::setAccount(MailAccount account)
93{ 93{
94 mailAccount = account; 94 mailAccount = account;
95} 95}
96 96
97void EmailHandler::getMail() 97void EmailHandler::getMail()
98{ 98{
99 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); 99 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd);
100 if (mailAccount.synchronize) { 100 if (mailAccount.synchronize) {
101 popClient->setSynchronize(mailAccount.lastServerMailCount); 101 popClient->setSynchronize(mailAccount.lastServerMailCount);
102 } else { 102 } else {
103 popClient->removeSynchronize(); 103 popClient->removeSynchronize();
104 } 104 }
105 105
106 headers = FALSE; 106 headers = FALSE;
107 popClient->headersOnly(headers, 0); 107 popClient->headersOnly(headers, 0);
108 popClient->newConnection(mailAccount.popServer, 110); 108 popClient->newConnection(mailAccount.popServer, 110);
109} 109}
110 110
111void EmailHandler::getMailHeaders() 111void EmailHandler::getMailHeaders()
112{ 112{
113 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); 113 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd);
114 if (mailAccount.synchronize) { 114 if (mailAccount.synchronize) {
115 popClient->setSynchronize(mailAccount.lastServerMailCount); 115 popClient->setSynchronize(mailAccount.lastServerMailCount);
116 } else { 116 } else {
117 popClient->removeSynchronize(); 117 popClient->removeSynchronize();
118 } 118 }
119 119
120 headers = TRUE; 120 headers = TRUE;
121 popClient->headersOnly(headers, 2000); //less than 2000, download all 121 popClient->headersOnly(headers, 2000); //less than 2000, download all
122 popClient->newConnection(mailAccount.popServer, 110); 122 popClient->newConnection(mailAccount.popServer, 110);
123} 123}
124 124
125void EmailHandler::getMailByList(MailList *mailList) 125void EmailHandler::getMailByList(MailList *mailList)
126{ 126{
127 if (mailList->count() == 0) { //should not occur though 127 if (mailList->count() == 0) { //should not occur though
128 emit mailTransfered(0); 128 emit mailTransfered(0);
129 return; 129 return;
130 } 130 }
131 131
132 headers = FALSE; 132 headers = FALSE;
133 popClient->headersOnly(FALSE, 0); 133 popClient->headersOnly(FALSE, 0);
134 popClient->newConnection(mailAccount.popServer, 110); 134 popClient->newConnection(mailAccount.popServer, 110);
135 popClient->setSelectedMails(mailList); 135 popClient->setSelectedMails(mailList);
136} 136}
137 137
138void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) 138void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete)
139{ 139{
140 Email mail; 140 Email mail;
141 141
142 mail.rawMail = message; 142 mail.rawMail = message;
143 mail.serverId = id; 143 mail.serverId = id;
144 mail.size = size; 144 mail.size = size;
145 mail.downloaded = complete; 145 mail.downloaded = complete;
146 146
147 emit mailArrived(mail, FALSE); 147 emit mailArrived(mail, FALSE);
148} 148}
149 149
150bool EmailHandler::parse(QString in, QString lineShift, Email *mail) 150bool EmailHandler::parse(QString in, QString lineShift, Email *mail)
151{ 151{
152 QString temp, boundary; 152 QString temp, boundary;
153 int pos; 153 int pos;
154 QString delimiter, header, body, mimeHeader, mimeBody; 154 QString delimiter, header, body, mimeHeader, mimeBody;
155 QString content, contentType, contentAttribute, id, encoding; 155 QString content, contentType, contentAttribute, id, encoding;
156 QString fileName, storedName; 156 QString fileName, storedName;
157 int enclosureId = 0; 157 int enclosureId = 0;
158 158
159 mail->rawMail = in; 159 mail->rawMail = in;
160 mail->received = TRUE; 160 mail->received = TRUE;
161 mail->files.setAutoDelete(TRUE); 161 mail->files.setAutoDelete(TRUE);
162 162
163 temp = lineShift + "." + lineShift; 163 temp = lineShift + "." + lineShift;
164 164
165 if (in.right(temp.length()) != temp) { 165 if (in.right(temp.length()) != temp) {
166 qWarning(in.right(temp.length())); 166 qWarning(in.right(temp.length()));
167 qWarning(" . added at end of email as separator"); 167 qWarning(" . added at end of email as separator");
168 mail->rawMail += temp; 168 mail->rawMail += temp;
169 } 169 }
170 170
171 171
172 delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" 172 delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n"
173 pos = in.find(delimiter, 0, FALSE); 173 pos = in.find(delimiter, 0, FALSE);
174 header = in.left(pos); 174 header = in.left(pos);
175 body = in.right(in.length() - pos - delimiter.length()); 175 body = in.right(in.length() - pos - delimiter.length());
176 if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) 176 if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n'))
177 body.truncate(body.length()-2); 177 body.truncate(body.length()-2);
178 178
179 TextParser p(header, lineShift); 179 TextParser p(header, lineShift);
180 180
181 if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { 181 if ((pos = p.find("FROM",':', 0, TRUE)) != -1) {
182 pos++; 182 pos++;
183 if (p.separatorAt(pos) == ' ') { 183 if (p.separatorAt(pos) == ' ') {
184 mail->from = p.getString(&pos, '<', false); 184 mail->from = p.getString(&pos, '<', false);
185 mail->from = mail->from.stripWhiteSpace(); 185 mail->from = mail->from.stripWhiteSpace();
186 if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { 186 if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) {
187 mail->from = mail->from.left(mail->from.length() - 1); 187 mail->from = mail->from.left(mail->from.length() - 1);
188 mail->from = mail->from.right(mail->from.length() - 1); 188 mail->from = mail->from.right(mail->from.length() - 1);
189 } 189 }
190 pos++; 190 pos++;
191 mail->fromMail = p.getString(&pos, '>', false); 191 mail->fromMail = p.getString(&pos, '>', false);
192 } else { 192 } else {
193 if ((p.separatorAt(pos) == '<') 193 if ((p.separatorAt(pos) == '<')
194 || (p.separatorAt(pos) == ' ')) //No name.. nasty 194 || (p.separatorAt(pos) == ' ')) //No name.. nasty
195 pos++; 195 pos++;
196 pos++; 196 pos++;
197 mail->fromMail = p.getString(&pos, 'z', TRUE); 197 mail->fromMail = p.getString(&pos, 'z', TRUE);
198 if (mail->fromMail.at(mail->fromMail.length()-1) == '>') 198 if (mail->fromMail.at(mail->fromMail.length()-1) == '>')
199 mail->fromMail.truncate(mail->fromMail.length() - 1); 199 mail->fromMail.truncate(mail->fromMail.length() - 1);
200 mail->from=mail->fromMail; 200 mail->from=mail->fromMail;
201 } 201 }
202 } 202 }
203 if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { 203 if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) {
204 pos++; 204 pos++;
205 mail->subject = p.getString(&pos, 'z', TRUE); 205 mail->subject = p.getString(&pos, 'z', TRUE);
206 } 206 }
207 if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { 207 if ((pos = p.find("DATE",':', 0, TRUE)) != -1) {
208 pos++; 208 pos++;
209 mail->date = p.getString(&pos, 'z', true); 209 mail->date = p.getString(&pos, 'z', true);
210 } 210 }
211 if ((pos = p.find("TO",':', 0, TRUE)) != -1) { 211 if ((pos = p.find("TO",':', 0, TRUE)) != -1) {
212 pos++; 212 pos++;
213 mail->recipients.append (p.getString(&pos, 'z', TRUE) ); 213 mail->recipients.append (p.getString(&pos, 'z', TRUE) );
214 } 214 }
215 if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { 215 if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) {
216 pos++; 216 pos++;
217 if ( (p.wordAt(pos).upper() == "ID") && 217 if ( (p.wordAt(pos).upper() == "ID") &&
218 (p.separatorAt(pos) == ':') ) { 218 (p.separatorAt(pos) == ':') ) {
219 219
220 id = p.getString(&pos, 'z', TRUE); 220 id = p.getString(&pos, 'z', TRUE);
221 mail->id = id; 221 mail->id = id;
222 } 222 }
223 } 223 }
224 224
225 pos = 0; 225 pos = 0;
226 while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { 226 while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) {
227 pos++; 227 pos++;
228 if ( (p.wordAt(pos).upper() == "VERSION") && 228 if ( (p.wordAt(pos).upper() == "VERSION") &&
229 (p.separatorAt(pos) == ':') ) { 229 (p.separatorAt(pos) == ':') ) {
230 pos++; 230 pos++;
231 if (p.getString(&pos, 'z', true) == "1.0") { 231 if (p.getString(&pos, 'z', true) == "1.0") {
232 mail->mimeType = 1; 232 mail->mimeType = 1;
233 } 233 }
234 } 234 }
235 } 235 }
236 236
237 if (mail->mimeType == 1) { 237 if (mail->mimeType == 1) {
238 boundary = ""; 238 boundary = "";
239 if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { 239 if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) {
240 pos++; 240 pos++;
241 boundary = p.getString(&pos, 'z', true); 241 boundary = p.getString(&pos, 'z', true);
242 if (boundary[0] == '"') { 242 if (boundary[0] == '"') {
243 boundary = boundary.left(boundary.length() - 1); //strip " 243 boundary = boundary.left(boundary.length() - 1); //strip "
244 boundary = boundary.right(boundary.length() - 1); //strip " 244 boundary = boundary.right(boundary.length() - 1); //strip "
245 } 245 }
246 boundary = "--" + boundary; //create boundary field 246 boundary = "--" + boundary; //create boundary field
247 } 247 }
248 248
249 if (boundary == "") { //fooled by Mime-Version 249 if (boundary == "") { //fooled by Mime-Version
250 mail->body = body; 250 mail->body = body;
251 mail->bodyPlain = body; 251 mail->bodyPlain = body;
252 return mail; 252 return mail;
253 } 253 }
254 254
255 while (body.length() > 0) { 255 while (body.length() > 0) {
256 pos = body.find(boundary, 0, FALSE); 256 pos = body.find(boundary, 0, FALSE);
257 pos = body.find(delimiter, pos, FALSE); 257 pos = body.find(delimiter, pos, FALSE);
258 mimeHeader = body.left(pos); 258 mimeHeader = body.left(pos);
259 mimeBody = body.right(body.length() - pos - delimiter.length()); 259 mimeBody = body.right(body.length() - pos - delimiter.length());
260 TextParser bp(mimeHeader, lineShift); 260 TextParser bp(mimeHeader, lineShift);
261 261
262 contentType = ""; 262 contentType = "";
263 contentAttribute = ""; 263 contentAttribute = "";
264 fileName = ""; 264 fileName = "";
265 if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { 265 if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) {
266 pos++; 266 pos++;
267 if ( (bp.wordAt(pos).upper() == "TYPE") && 267 if ( (bp.wordAt(pos).upper() == "TYPE") &&
268 (bp.separatorAt(pos) == ':') ) { 268 (bp.separatorAt(pos) == ':') ) {
269 contentType = bp.nextWord().upper(); 269 contentType = bp.nextWord().upper();
270 if (bp.nextSeparator() == '/') 270 if (bp.nextSeparator() == '/')
271 contentAttribute = bp.nextWord().upper(); 271 contentAttribute = bp.nextWord().upper();
272 content = contentType + "/" + contentAttribute; 272 content = contentType + "/" + contentAttribute;
273 } 273 }
274 if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { 274 if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) {
275 pos++; 275 pos++;
276 encoding = bp.getString(&pos, 'z', TRUE); 276 encoding = bp.getString(&pos, 'z', TRUE);
277 } 277 }
278 278
279 if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { 279 if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) {
280 pos++; 280 pos++;
281 fileName = bp.getString(&pos, 'z', TRUE); 281 fileName = bp.getString(&pos, 'z', TRUE);
282 fileName = fileName.right(fileName.length() - 1); 282 fileName = fileName.right(fileName.length() - 1);
283 fileName = fileName.left(fileName.length() - 1); 283 fileName = fileName.left(fileName.length() - 1);
284 } 284 }
285 285
286 } 286 }
287 pos = mimeBody.find(boundary, 0, FALSE); 287 pos = mimeBody.find(boundary, 0, FALSE);
288 if (pos == -1) //should not occur, malformed mail 288 if (pos == -1) //should not occur, malformed mail
289 pos = mimeBody.length(); 289 pos = mimeBody.length();
290 body = mimeBody.right(mimeBody.length() - pos); 290 body = mimeBody.right(mimeBody.length() - pos);
291 mimeBody = mimeBody.left(pos); 291 mimeBody = mimeBody.left(pos);
292 292
293 if (fileName != "") { //attatchments of some type, audio, image etc. 293 if (fileName != "") { //attatchments of some type, audio, image etc.
294 294
295 Enclosure e; 295 Enclosure e;
296 e.id = enclosureId; 296 e.id = enclosureId;
297 e.originalName = fileName; 297 e.originalName = fileName;
298 e.contentType = contentType; 298 e.contentType = contentType;
299 e.contentAttribute = contentAttribute; 299 e.contentAttribute = contentAttribute;
300 e.encoding = encoding; 300 e.encoding = encoding;
301 e.body = mimeBody; 301 e.body = mimeBody;
302 e.saved = FALSE; 302 e.saved = FALSE;
303 mail->addEnclosure(&e); 303 mail->addEnclosure(&e);
304 enclosureId++; 304 enclosureId++;
305 305
306 } else if (contentType == "TEXT") { 306 } else if (contentType == "TEXT") {
307 if (contentAttribute == "PLAIN") { 307 if (contentAttribute == "PLAIN") {
308 mail->body = mimeBody; 308 mail->body = mimeBody;
309 mail->bodyPlain = mimeBody; 309 mail->bodyPlain = mimeBody;
310 } 310 }
311 if (contentAttribute == "HTML") { 311 if (contentAttribute == "HTML") {
312 mail->body = mimeBody; 312 mail->body = mimeBody;
313 } 313 }
314 } 314 }
315 } 315 }
316 } else { 316 } else {
317 mail->bodyPlain = body; 317 mail->bodyPlain = body;
318 mail->body = body; 318 mail->body = body;
319 } 319 }
320 return TRUE; 320 return TRUE;
321} 321}
322 322
323bool EmailHandler::getEnclosure(Enclosure *ePtr) 323bool EmailHandler::getEnclosure(Enclosure *ePtr)
324{ 324{
325 QFile f(ePtr->path + ePtr->name); 325 QFile f(ePtr->path + ePtr->name);
326 char src[4]; 326 char src[4];
327 char *destPtr; 327 char *destPtr;
328 QByteArray buffer; 328 QByteArray buffer;
329 uint bufCount, pos, decodedCount, size, x; 329 uint bufCount, pos, decodedCount, size, x;
330 330
331 if (! f.open(IO_WriteOnly) ) { 331 if (! f.open(IO_WriteOnly) ) {
332 qWarning("could not save: " + ePtr->path + ePtr->name); 332 qWarning("could not save: " + ePtr->path + ePtr->name);
333 return FALSE; 333 return FALSE;
334 } 334 }
335 335
336 if (ePtr->encoding.upper() == "BASE64") { 336 if (ePtr->encoding.upper() == "BASE64") {
337 size = (ePtr->body.length() * 3 / 4); //approximate size (always above) 337 size = (ePtr->body.length() * 3 / 4); //approximate size (always above)
338 buffer.resize(size); 338 buffer.resize(size);
339 bufCount = 0; 339 bufCount = 0;
340 pos = 0; 340 pos = 0;
341 destPtr = buffer.data(); 341 destPtr = buffer.data();
342 342
343 while (pos < ePtr->body.length()) { 343 while (pos < ePtr->body.length()) {
344 decodedCount = 4; 344 decodedCount = 4;
345 x = 0; 345 x = 0;
346 while ( (x < 4) && (pos < ePtr->body.length()) ) { 346 while ( (x < 4) && (pos < ePtr->body.length()) ) {
347 src[x] = ePtr->body[pos].latin1(); 347 src[x] = ePtr->body[pos].latin1();
348 pos++; 348 pos++;
349 if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') 349 if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ')
350 x--; 350 x--;
351 x++; 351 x++;
352 } 352 }
353 if (x > 1) { 353 if (x > 1) {
354 decodedCount = parse64base(src, destPtr); 354 decodedCount = parse64base(src, destPtr);
355 destPtr += decodedCount; 355 destPtr += decodedCount;
356 bufCount += decodedCount; 356 bufCount += decodedCount;
357 } 357 }
358 } 358 }
359 359
360 buffer.resize(bufCount); //set correct length of file 360 buffer.resize(bufCount); //set correct length of file
361 f.writeBlock(buffer); 361 f.writeBlock(buffer);
362 } else { 362 } else {
363 QTextStream t(&f); 363 QTextStream t(&f);
364 t << ePtr->body; 364 t << ePtr->body;
365 } 365 }
366 return TRUE; 366 return TRUE;
367} 367}
368 368
369int EmailHandler::parse64base(char *src, char *bufOut) { 369int EmailHandler::parse64base(char *src, char *bufOut) {
370 370
371 char c, z; 371 char c, z;
372 char li[4]; 372 char li[4];
373 int processed; 373 int processed;
374 374
375 //conversion table withouth table... 375 //conversion table withouth table...
376 for (int x = 0; x < 4; x++) { 376 for (int x = 0; x < 4; x++) {
377 c = src[x]; 377 c = src[x];
378 378
379 if ( (int) c >= 'A' && (int) c <= 'Z') 379 if ( (int) c >= 'A' && (int) c <= 'Z')
380 li[x] = (int) c - (int) 'A'; 380 li[x] = (int) c - (int) 'A';
381 if ( (int) c >= 'a' && (int) c <= 'z') 381 if ( (int) c >= 'a' && (int) c <= 'z')
382 li[x] = (int) c - (int) 'a' + 26; 382 li[x] = (int) c - (int) 'a' + 26;
383 if ( (int) c >= '0' && (int) c <= '9') 383 if ( (int) c >= '0' && (int) c <= '9')
384 li[x] = (int) c - (int) '0' + 52; 384 li[x] = (int) c - (int) '0' + 52;
385 if (c == '+') 385 if (c == '+')
386 li[x] = 62; 386 li[x] = 62;
387 if (c == '/') 387 if (c == '/')
388 li[x] = 63; 388 li[x] = 63;
389 } 389 }
390 390
391 processed = 1; 391 processed = 1;
392 bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits 392 bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits
393 bufOut[0] <<= 2; 393 bufOut[0] <<= 2;
394 z = li[1] >> 4; 394 z = li[1] >> 4;
395 bufOut[0] = bufOut[0] | z; //first byte retrived 395 bufOut[0] = bufOut[0] | z; //first byte retrived
396 396
397 if (src[2] != '=') { 397 if (src[2] != '=') {
398 bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits 398 bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits
399 bufOut[1] <<= 4; 399 bufOut[1] <<= 4;
400 z = li[2] >> 2; 400 z = li[2] >> 2;
401 bufOut[1] = bufOut[1] | z; //second byte retrived 401 bufOut[1] = bufOut[1] | z; //second byte retrived
402 processed++; 402 processed++;
403 403
404 if (src[3] != '=') { 404 if (src[3] != '=') {
405 bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits 405 bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits
406 bufOut[2] <<= 6; 406 bufOut[2] <<= 6;
407 z = li[3]; 407 z = li[3];
408 bufOut[2] = bufOut[2] | z; //third byte retrieved 408 bufOut[2] = bufOut[2] | z; //third byte retrieved
409 processed++; 409 processed++;
410 } 410 }
411 } 411 }
412 return processed; 412 return processed;
413} 413}
414 414
415int EmailHandler::encodeMime(Email *mail) { 415int EmailHandler::encodeMime(Email *mail)
416{
417
416 QString fileName, fileType, contentType, newBody, boundary; 418 QString fileName, fileType, contentType, newBody, boundary;
417 Enclosure *ePtr; 419 Enclosure *ePtr;
418 420
419 QString userName = mailAccount.name; 421 QString userName = mailAccount.name;
420 userName += " <" + mailAccount.emailAddress + ">"; 422 if (userName.length()>0)//only embrace it if there is a user name
423 userName += " <" + mailAccount.emailAddress + ">";
421 424
422 //add standard headers 425 //add standard headers
423 newBody = "From: " + userName + "\r\nTo: "; 426 newBody = "From: " + userName + "\r\nTo: ";
424 for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { 427 for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) {
425 newBody += *it + " "; 428 newBody += *it + " ";
426 } 429 }
427 newBody += "\r\nSubject: " + mail->subject + "\r\n"; 430 newBody += "\r\nSubject: " + mail->subject + "\r\n";
428 431
429 if (mail->files.count() == 0) { //just a simple mail 432 if (mail->files.count() == 0) { //just a simple mail
430 newBody += "\r\n" + mail->body; 433 newBody += "\r\n" + mail->body;
431 mail->rawMail = newBody; 434 mail->rawMail = newBody;
432 return 0; 435 return 0;
433 } 436 }
434 437
435 //Build mime encoded mail 438 //Build mime encoded mail
436 boundary = "-----4345=next_bound=0495----"; 439 boundary = "-----4345=next_bound=0495----";
437 440
438 newBody += "Mime-Version: 1.0\r\n"; 441 newBody += "Mime-Version: 1.0\r\n";
439 newBody += "Content-Type: multipart/mixed; boundary=\"" + 442 newBody += "Content-Type: multipart/mixed; boundary=\"" +
440 boundary + "\"\r\n\r\n"; 443 boundary + "\"\r\n\r\n";
441 444
442 newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; 445 newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n";
443 newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; 446 newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n";
444 newBody += mail->body; 447 newBody += mail->body;
445 448
446 for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { 449 for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) {
447 fileName = ePtr->originalName; 450 fileName = ePtr->originalName;
448 fileType = ePtr->contentType; 451 fileType = ePtr->contentType;
449 QFileInfo fi(fileName); 452 QFileInfo fi(fileName);
450 453
451 // This specification of contentType is temporary 454 // This specification of contentType is temporary
452 contentType = ""; 455 contentType = "";
453 if (fileType == "Picture") { 456 if (fileType == "Picture") {
454 contentType = "image/x-image"; 457 contentType = "image/x-image";
455 } else if (fileType == "Document") { 458 } else if (fileType == "Document") {
456 contentType = "text/plain"; 459 contentType = "text/plain";
457 } else if (fileType == "Sound") { 460 } else if (fileType == "Sound") {
458 contentType = "audio/x-wav"; 461 contentType = "audio/x-wav";
459 } else if (fileType == "Movie") { 462 } else if (fileType == "Movie") {
460 contentType = "video/mpeg"; 463 contentType = "video/mpeg";
461 } else { 464 } else {
462 contentType = "application/octet-stream"; 465 contentType = "application/octet-stream";
463 } 466 }
464 467
465 newBody += "\r\n\r\n--" + boundary + "\r\n"; 468 newBody += "\r\n\r\n--" + boundary + "\r\n";
466 newBody += "Content-Type: " + contentType + "; name=\"" + 469 newBody += "Content-Type: " + contentType + "; name=\"" +
467 fi.fileName() + "\"\r\n"; 470 fi.fileName() + "\"\r\n";
468 newBody += "Content-Transfer-Encoding: base64\r\n"; 471 newBody += "Content-Transfer-Encoding: base64\r\n";
469 newBody += "Content-Disposition: inline; filename=\"" + 472 newBody += "Content-Disposition: inline; filename=\"" +
470 fi.fileName() + "\"\r\n\r\n"; 473 fi.fileName() + "\"\r\n\r\n";
471 474
472 if (encodeFile(fileName, &newBody) == -1) //file not found? 475 if (encodeFile(fileName, &newBody) == -1) //file not found?
473 return -1; 476 return -1;
474 } 477 }
475 478
476 newBody += "\r\n\r\n--" + boundary + "--"; 479 newBody += "\r\n\r\n--" + boundary + "--";
477 mail->rawMail = newBody; 480 mail->rawMail = newBody;
478 481
479 return 0; 482 return 0;
480} 483}
481 484
482int EmailHandler::encodeFile(QString fileName, QString *toBody) 485int EmailHandler::encodeFile(QString fileName, QString *toBody)
483{ 486{
484 char *fileData; 487 char *fileData;
485 char *dataPtr; 488 char *dataPtr;
486 QString temp; 489 QString temp;
487 uint dataSize, count; 490 uint dataSize, count;
488 QFile f(fileName); 491 QFile f(fileName);
489 492
490 if (! f.open(IO_ReadOnly) ) { 493 if (! f.open(IO_ReadOnly) ) {
491 qWarning("could not open file: " + fileName); 494 qWarning("could not open file: " + fileName);
492 return -1; 495 return -1;
493 } 496 }
494 QTextStream s(&f); 497 QTextStream s(&f);
495 dataSize = f.size(); 498 dataSize = f.size();
496 fileData = (char *) malloc(dataSize + 3); 499 fileData = (char *) malloc(dataSize + 3);
497 s.readRawBytes(fileData, dataSize); 500 s.readRawBytes(fileData, dataSize);
498 501
499 temp = ""; 502 temp = "";
500 dataPtr = fileData; 503 dataPtr = fileData;
501 count = 0; 504 count = 0;
502 while (dataSize > 0) { 505 while (dataSize > 0) {
503 if (dataSize < 3) { 506 if (dataSize < 3) {
504 encode64base(dataPtr, &temp, dataSize); 507 encode64base(dataPtr, &temp, dataSize);
505 dataSize = 0; 508 dataSize = 0;
506 } else { 509 } else {
507 encode64base(dataPtr, &temp, 3); 510 encode64base(dataPtr, &temp, 3);
508 dataSize -= 3; 511 dataSize -= 3;
509 dataPtr += 3; 512 dataPtr += 3;
510 count += 4; 513 count += 4;
511 } 514 }
512 if (count > 72) { 515 if (count > 72) {
513 count = 0; 516 count = 0;
514 temp += "\r\n"; 517 temp += "\r\n";
515 } 518 }
516 } 519 }
517 toBody->append(temp); 520 toBody->append(temp);
518 521
519 delete(fileData); 522 delete(fileData);
520 f.close(); 523 f.close();
521 return 0; 524 return 0;
522} 525}
523 526
524void EmailHandler::encode64base(char *src, QString *dest, int len) 527void EmailHandler::encode64base(char *src, QString *dest, int len)
525{ 528{
526 QString temp; 529 QString temp;
527 uchar c; 530 uchar c;
528 uchar bufOut[4]; 531 uchar bufOut[4];
529 532
530 bufOut[0] = src[0]; 533 bufOut[0] = src[0];
531 bufOut[0] >>= 2; //Done byte 0 534 bufOut[0] >>= 2; //Done byte 0
532 535
533 bufOut[1] = src[0]; 536 bufOut[1] = src[0];
534 bufOut[1] = bufOut[1] & (1 + 2); //mask out top 6 bits 537 bufOut[1] = bufOut[1] & (1 + 2); //mask out top 6 bits
535 bufOut[1] <<= 4; //copy up 4 places 538 bufOut[1] <<= 4; //copy up 4 places
536 if (len > 1) { 539 if (len > 1) {
537 c = src[1]; 540 c = src[1];
538 } else { 541 } else {
539 c = 0; 542 c = 0;
540 } 543 }
541 544
542 c = c & (16 + 32 + 64 + 128); 545 c = c & (16 + 32 + 64 + 128);
543 c >>= 4; 546 c >>= 4;
544 bufOut[1] = bufOut[1] | c; //Done byte 1 547 bufOut[1] = bufOut[1] | c; //Done byte 1
545 548
546 bufOut[2] = src[1]; 549 bufOut[2] = src[1];
547 bufOut[2] = bufOut[2] & (1 + 2 + 4 + 8); 550 bufOut[2] = bufOut[2] & (1 + 2 + 4 + 8);
548 bufOut[2] <<= 2; 551 bufOut[2] <<= 2;
549 if (len > 2) { 552 if (len > 2) {
550 c = src[2]; 553 c = src[2];
551 } else { 554 } else {
552 c = 0; 555 c = 0;
553 } 556 }
554 c >>= 6; 557 c >>= 6;
555 bufOut[2] = bufOut[2] | c; 558 bufOut[2] = bufOut[2] | c;
556 559
557 bufOut[3] = src[2]; 560 bufOut[3] = src[2];
558 bufOut[3] = bufOut[3] & (1 + 2 + 4 + 8 + 16 + 32); 561 bufOut[3] = bufOut[3] & (1 + 2 + 4 + 8 + 16 + 32);
559 562
560 if (len == 1) { 563 if (len == 1) {
561 bufOut[2] = 64; 564 bufOut[2] = 64;
562 bufOut[3] = 64; 565 bufOut[3] = 64;
563 } 566 }
564 if (len == 2) { 567 if (len == 2) {
565 bufOut[3] = 64; 568 bufOut[3] = 64;
566 } 569 }
567 for (int x = 0; x < 4; x++) { 570 for (int x = 0; x < 4; x++) {
568 if (bufOut[x] <= 25) 571 if (bufOut[x] <= 25)
569 bufOut[x] += (uint) 'A'; 572 bufOut[x] += (uint) 'A';
570 else if (bufOut[x] >= 26 && bufOut[x] <= 51) 573 else if (bufOut[x] >= 26 && bufOut[x] <= 51)
571 bufOut[x] += (uint) 'a' - 26; 574 bufOut[x] += (uint) 'a' - 26;
572 else if (bufOut[x] >= 52 && bufOut[x] <= 61) 575 else if (bufOut[x] >= 52 && bufOut[x] <= 61)
573 bufOut[x] += (uint) '0' - 52; 576 bufOut[x] += (uint) '0' - 52;
574 else if (bufOut[x] == 62) 577 else if (bufOut[x] == 62)
575 bufOut[x] = '+'; 578 bufOut[x] = '+';
576 else if (bufOut[x] == 63) 579 else if (bufOut[x] == 63)
577 bufOut[x] = '/'; 580 bufOut[x] = '/';
578 else if (bufOut[x] == 64) 581 else if (bufOut[x] == 64)
579 bufOut[x] = '='; 582 bufOut[x] = '=';
580 583
581 dest->append(bufOut[x]); 584 dest->append(bufOut[x]);
582 } 585 }
583} 586}
584 587
585void EmailHandler::cancel() 588void EmailHandler::cancel()
586{ 589{
587 popClient->errorHandling(ErrCancel); 590 popClient->errorHandling(ErrCancel);
588 smtpClient->errorHandling(ErrCancel); 591 smtpClient->errorHandling(ErrCancel);
589} 592}
diff --git a/noncore/net/mailit/writemail.cpp b/noncore/net/mailit/writemail.cpp
index 1a7185e..70332a9 100644
--- a/noncore/net/mailit/writemail.cpp
+++ b/noncore/net/mailit/writemail.cpp
@@ -1,299 +1,297 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21#include "writemail.h" 21#include "writemail.h"
22#include "resource.h" 22#include "resource.h"
23 23
24WriteMail::WriteMail( QWidget* parent, const char* name, WFlags fl ) 24WriteMail::WriteMail( QWidget* parent, const char* name, WFlags fl )
25 : QMainWindow( parent, name, fl ) 25 : QMainWindow( parent, name, fl )
26{ 26{
27 showingAddressList = FALSE; 27 showingAddressList = FALSE;
28 init(); 28 init();
29 29
30 addAtt = new AddAtt(0, "Add Attatchments"); 30 addAtt = new AddAtt(0, "Add Attatchments");
31} 31}
32 32
33WriteMail::~WriteMail() 33WriteMail::~WriteMail()
34{ 34{
35 delete addAtt; 35 delete addAtt;
36} 36}
37 37
38void WriteMail::setAddressList(AddressList *list) 38void WriteMail::setAddressList(AddressList *list)
39{ 39{
40 Contact *cPtr; 40 Contact *cPtr;
41 41
42 addressList = list; 42 addressList = list;
43 43
44 addressView->clear(); 44 addressView->clear();
45 QList<Contact> *cListPtr = addressList->getContactList(); 45 QList<Contact> *cListPtr = addressList->getContactList();
46 QListViewItem *item; 46 QListViewItem *item;
47 for (cPtr = cListPtr->first(); cPtr != 0; cPtr = cListPtr->next() ) { 47 for (cPtr = cListPtr->first(); cPtr != 0; cPtr = cListPtr->next() ) {
48 item = new QListViewItem(addressView, cPtr->email, cPtr->name); 48 item = new QListViewItem(addressView, cPtr->email, cPtr->name);
49 } 49 }
50} 50}
51 51
52void WriteMail::init() 52void WriteMail::init()
53{ 53{
54 setToolBarsMovable(FALSE); 54 setToolBarsMovable(FALSE);
55 55
56 bar = new QToolBar(this); 56 bar = new QToolBar(this);
57 bar->setHorizontalStretchable( TRUE ); 57 bar->setHorizontalStretchable( TRUE );
58 58
59 menu = new QMenuBar( bar ); 59 menu = new QMenuBar( bar );
60 60
61 mailMenu = new QPopupMenu(menu); 61 mailMenu = new QPopupMenu(menu);
62 menu->insertItem( tr( "&Mail" ), mailMenu); 62 menu->insertItem( tr( "&Mail" ), mailMenu);
63 addMenu = new QPopupMenu(menu); 63 addMenu = new QPopupMenu(menu);
64 menu->insertItem( tr( "&Add" ), addMenu); 64 menu->insertItem( tr( "&Add" ), addMenu);
65 65
66 bar = new QToolBar(this); 66 bar = new QToolBar(this);
67 attatchButton = new QAction(tr("Attatchment"), Resource::loadPixmap("fileopen"), QString::null, 0, this, 0); 67 attatchButton = new QAction(tr("Attatchment"), Resource::loadPixmap("mailit/attach"), QString::null, 0, this, 0);
68 attatchButton->addTo(bar); 68 attatchButton->addTo(bar);
69 attatchButton->addTo(addMenu); 69 attatchButton->addTo(addMenu);
70 connect( attatchButton, SIGNAL( activated() ), this, SLOT( attatchFile() ) ); 70 connect( attatchButton, SIGNAL( activated() ), this, SLOT( attatchFile() ) );
71 71
72 confirmButton = new QAction(tr("Enque mail"), Resource::loadPixmap("OKButton"), QString::null, 0, this, 0); 72 confirmButton = new QAction(tr("Enque mail"), Resource::loadPixmap("OKButton"), QString::null, 0, this, 0);
73 confirmButton->addTo(bar); 73 confirmButton->addTo(bar);
74 confirmButton->addTo(mailMenu); 74 confirmButton->addTo(mailMenu);
75 connect( confirmButton, SIGNAL( activated() ), this, SLOT( accept() ) ); 75 connect( confirmButton, SIGNAL( activated() ), this, SLOT( accept() ) );
76 76
77 newButton = new QAction(tr("New mail"), Resource::loadPixmap("new"), QString::null, 0, this, 0); 77 newButton = new QAction(tr("New mail"), Resource::loadPixmap("new"), QString::null, 0, this, 0);
78 newButton->addTo(mailMenu); 78 newButton->addTo(mailMenu);
79 connect( newButton, SIGNAL( activated() ), this, SLOT( newMail() ) ); 79 connect( newButton, SIGNAL( activated() ), this, SLOT( newMail() ) );
80 80
81 widget = new QWidget(this, "widget"); 81 widget = new QWidget(this, "widget");
82 grid = new QGridLayout( widget ); 82 grid = new QGridLayout( widget );
83 83
84 recipientsBox = new QComboBox( FALSE, widget, "toLabel" ); 84 recipientsBox = new QComboBox( FALSE, widget, "toLabel" );
85 recipientsBox->insertItem( tr( "To:" ) ); 85 recipientsBox->insertItem( tr( "To:" ) );
86 recipientsBox->insertItem( tr( "CC:" ) ); 86 recipientsBox->insertItem( tr( "CC:" ) );
87 recipientsBox->setCurrentItem(0); 87 recipientsBox->setCurrentItem(0);
88 grid->addWidget( recipientsBox, 0, 0 ); 88 grid->addWidget( recipientsBox, 0, 0 );
89 89
90 subjetLabel = new QLabel( widget, "subjetLabel" ); 90 subjetLabel = new QLabel( widget, "subjetLabel" );
91 subjetLabel->setText( tr( "Subject:" ) ); 91 subjetLabel->setText( tr( "Subject:" ) );
92 92
93 grid->addWidget( subjetLabel, 1, 0 ); 93 grid->addWidget( subjetLabel, 1, 0 );
94 94
95 ToolButton13_2 = new QToolButton( widget, "ToolButton13_2" ); 95 ToolButton13_2 = new QToolButton( widget, "ToolButton13_2" );
96 ToolButton13_2->setText( tr( "..." ) ); 96 ToolButton13_2->setText( tr( "..." ) );
97 grid->addWidget( ToolButton13_2, 1, 2 ); 97 grid->addWidget( ToolButton13_2, 1, 2 );
98 98
99 subjectInput = new QLineEdit( widget, "subjectInput" ); 99 subjectInput = new QLineEdit( widget, "subjectInput" );
100 grid->addWidget( subjectInput, 1, 1 ); 100 grid->addWidget( subjectInput, 1, 1 );
101 101
102 toInput = new QLineEdit( widget, "toInput" ); 102 toInput = new QLineEdit( widget, "toInput" );
103 grid->addWidget( toInput, 0, 1 ); 103 grid->addWidget( toInput, 0, 1 );
104 104
105 addressButton = new QToolButton( widget, "addressButton" ); 105 addressButton = new QToolButton( widget, "addressButton" );
106 addressButton->setPixmap( Resource::loadPixmap("AddressBook") ); 106 addressButton->setPixmap( Resource::loadPixmap("AddressBook") );
107 addressButton->setToggleButton(TRUE); 107 addressButton->setToggleButton(TRUE);
108 grid->addWidget( addressButton, 0, 2 ); 108 grid->addWidget( addressButton, 0, 2 );
109 connect(addressButton, SIGNAL(clicked()), this, SLOT(getAddress()) ); 109 connect(addressButton, SIGNAL(clicked()), this, SLOT(getAddress()) );
110 110
111 emailInput = new QMultiLineEdit( widget, "emailInput" ); 111 emailInput = new QMultiLineEdit( widget, "emailInput" );
112 grid->addMultiCellWidget( emailInput, 2, 2, 0, 2); 112 grid->addMultiCellWidget( emailInput, 2, 2, 0, 2);
113 113
114 addressView = new QListView( widget, "addressView"); 114 addressView = new QListView( widget, "addressView");
115 addressView->addColumn("Email"); 115 addressView->addColumn("Email");
116 addressView->addColumn("Name"); 116 addressView->addColumn("Name");
117 addressView->setAllColumnsShowFocus(TRUE); 117 addressView->setAllColumnsShowFocus(TRUE);
118 addressView->setMultiSelection(TRUE); 118 addressView->setMultiSelection(TRUE);
119 addressView->hide(); 119 addressView->hide();
120 grid->addMultiCellWidget( addressView, 3, 3, 0, 2); 120 grid->addMultiCellWidget( addressView, 3, 3, 0, 2);
121 121
122 okButton = new QToolButton(bar, "ok"); 122 okButton = new QToolButton(bar, "ok");
123 okButton->setPixmap( Resource::loadPixmap("enter") ); 123 okButton->setPixmap( Resource::loadPixmap("enter") );
124 okButton->hide(); 124 okButton->hide();
125 connect(okButton, SIGNAL(clicked()), this, SLOT(addRecipients()) ); 125 connect(okButton, SIGNAL(clicked()), this, SLOT(addRecipients()) );
126 126
127 setCentralWidget(widget); 127 setCentralWidget(widget);
128} 128}
129 129
130void WriteMail::reject() 130void WriteMail::reject()
131{ 131{
132 emit cancelMail(); 132 emit cancelMail();
133} 133}
134 134
135// need to insert date 135// need to insert date
136void WriteMail::accept() 136void WriteMail::accept()
137{ 137{
138 QStringList attatchedFiles, attatchmentsType; 138 QStringList attatchedFiles, attatchmentsType;
139 int idCount = 0; 139 int idCount = 0;
140 140
141 if (toInput->text() == "") { 141 if (toInput->text() == "") {
142 QMessageBox::warning(this,"No recipient", "Send mail to whom?", "OK\n"); 142 QMessageBox::warning(this,"No recipient", "Send mail to whom?", "OK\n");
143 return; 143 return;
144 } 144 }
145 if (! getRecipients() ) { 145 if (! getRecipients() ) {
146 QMessageBox::warning(this,"Incorrect recipient separator", 146 QMessageBox::warning(this,"Incorrect recipient separator",
147 "Recipients must be separated by ;\nand be valid emailaddresses", "OK\n"); 147 "Recipients must be separated by ;\nand be valid emailaddresses", "OK\n");
148 return; 148 return;
149 } 149 }
150 mail.subject = subjectInput->text(); 150 mail.subject = subjectInput->text();
151 mail.body = emailInput->text(); 151 mail.body = emailInput->text();
152 mail.sent = false; 152 mail.sent = false;
153 mail.received = false; 153 mail.received = false;
154 mail.rawMail = "To: "; 154 mail.rawMail = "To: ";
155 155
156 for (QStringList::Iterator it = mail.recipients.begin(); 156 for (QStringList::Iterator it = mail.recipients.begin();
157 it != mail.recipients.end(); ++it) { 157 it != mail.recipients.end(); ++it) {
158 158
159 mail.rawMail += (*it); 159 mail.rawMail += (*it);
160 mail.rawMail += ",\n"; 160 mail.rawMail += ",\n";
161 } 161 }
162 mail.rawMail.truncate(mail.rawMail.length()-2); 162 mail.rawMail.truncate(mail.rawMail.length()-2);
163 mail.rawMail += mail.from; 163 mail.rawMail += mail.from;
164 mail.rawMail += "\nSubject: "; 164 mail.rawMail += "\nSubject: ";
165 mail.rawMail += mail.subject; 165 mail.rawMail += mail.subject;
166 mail.rawMail += "\n\n"; 166 mail.rawMail += "\n\n";
167 167
168 attatchedFiles = addAtt->returnAttatchedFiles(); 168 attatchedFiles = addAtt->returnAttatchedFiles();
169 attatchmentsType = addAtt->returnFileTypes(); 169 attatchmentsType = addAtt->returnFileTypes();
170 170
171 QStringList::Iterator itType = attatchmentsType.begin(); 171 QStringList::Iterator itType = attatchmentsType.begin();
172 172
173 Enclosure e; 173 Enclosure e;
174 for ( QStringList::Iterator it = attatchedFiles.begin(); 174 for ( QStringList::Iterator it = attatchedFiles.begin(); it != attatchedFiles.end(); ++it ) {
175 it != attatchedFiles.end(); ++it ) {
176
177 e.id = idCount; 175 e.id = idCount;
178 e.originalName = (*it).latin1(); 176 e.originalName = (*it).latin1();
179 e.contentType = (*itType).latin1(); 177 e.contentType = (*itType).latin1();
180 e.contentAttribute = (*itType).latin1(); 178 e.contentAttribute = (*itType).latin1();
181 e.saved = TRUE; 179 e.saved = TRUE;
182 mail.addEnclosure(&e); 180 mail.addEnclosure(&e);
183 181
184 itType++; 182 itType++;
185 idCount++; 183 idCount++;
186 } 184 }
187 mail.rawMail += mail.body; 185 mail.rawMail += mail.body;
188 mail.rawMail += "\n"; 186 mail.rawMail += "\n";
189 mail.rawMail += ".\n"; 187 mail.rawMail += ".\n";
190 emit sendMailRequested(mail); 188 emit sendMailRequested(mail);
191 addAtt->clear(); 189 addAtt->clear();
192} 190}
193 191
194void WriteMail::getAddress() 192void WriteMail::getAddress()
195{ 193{
196 showingAddressList = !showingAddressList; 194 showingAddressList = !showingAddressList;
197 195
198 if (showingAddressList) { 196 if (showingAddressList) {
199 emailInput->hide(); 197 emailInput->hide();
200 addressView->show(); 198 addressView->show();
201 okButton->show(); 199 okButton->show();
202 200
203 } else { 201 } else {
204 addressView->hide(); 202 addressView->hide();
205 okButton->hide(); 203 okButton->hide();
206 emailInput->show(); 204 emailInput->show();
207 } 205 }
208} 206}
209 207
210void WriteMail::attatchFile() 208void WriteMail::attatchFile()
211{ 209{
212 addAtt->showMaximized(); 210 addAtt->showMaximized();
213} 211}
214 212
215void WriteMail::reply(Email replyMail) 213void WriteMail::reply(Email replyMail)
216{ 214{
217 int pos; 215 int pos;
218 216
219 mail = replyMail; 217 mail = replyMail;
220 mail.files.clear(); 218 mail.files.clear();
221 219
222 toInput->setText(mail.fromMail); 220 toInput->setText(mail.fromMail);
223 subjectInput->setText("Re: " + mail.subject); 221 subjectInput->setText("Re: " + mail.subject);
224 222
225 pos = 0; 223 pos = 0;
226 mail.body.insert(pos, ">>"); 224 mail.body.insert(pos, ">>");
227 while (pos != -1) { 225 while (pos != -1) {
228 pos = mail.body.find('\n', pos); 226 pos = mail.body.find('\n', pos);
229 if (pos != -1) 227 if (pos != -1)
230 mail.body.insert(++pos, ">>"); 228 mail.body.insert(++pos, ">>");
231 } 229 }
232 230
233 emailInput->setText(mail.body); 231 emailInput->setText(mail.body);
234} 232}
235 233
236bool WriteMail::getRecipients() 234bool WriteMail::getRecipients()
237{ 235{
238 QString str, temp; 236 QString str, temp;
239 int pos = 0; 237 int pos = 0;
240 238
241 mail.recipients.clear(); 239 mail.recipients.clear();
242 240
243 temp = toInput->text(); 241 temp = toInput->text();
244 while ( (pos = temp.find(';')) != -1) { 242 while ( (pos = temp.find(';')) != -1) {
245 str = temp.left(pos).stripWhiteSpace(); 243 str = temp.left(pos).stripWhiteSpace();
246 temp = temp.right(temp.length() - (pos + 1)); 244 temp = temp.right(temp.length() - (pos + 1));
247 if ( str.find('@') == -1) 245 if ( str.find('@') == -1)
248 return false; 246 return false;
249 mail.recipients.append(str); 247 mail.recipients.append(str);
250 addressList->addContact(str, ""); 248 addressList->addContact(str, "");
251 } 249 }
252 temp = temp.stripWhiteSpace(); 250 temp = temp.stripWhiteSpace();
253 if ( temp.find('@') == -1) 251 if ( temp.find('@') == -1)
254 return false; 252 return false;
255 mail.recipients.append(temp); 253 mail.recipients.append(temp);
256 addressList->addContact(temp, ""); 254 addressList->addContact(temp, "");
257 255
258 return TRUE; 256 return TRUE;
259} 257}
260 258
261 259
262void WriteMail::addRecipients() 260void WriteMail::addRecipients()
263{ 261{
264 QString recipients = ""; 262 QString recipients = "";
265 263
266 mail.recipients.clear(); 264 mail.recipients.clear();
267 QListViewItem *item = addressView->firstChild(); 265 QListViewItem *item = addressView->firstChild();
268 while (item != NULL) { 266 while (item != NULL) {
269 if ( item->isSelected() ) { 267 if ( item->isSelected() ) {
270 if (recipients == "") { 268 if (recipients == "") {
271 recipients = item->text(0); 269 recipients = item->text(0);
272 } else { 270 } else {
273 recipients += "; " + item->text(0); 271 recipients += "; " + item->text(0);
274 } 272 }
275 } 273 }
276 item = item->nextSibling(); 274 item = item->nextSibling();
277 } 275 }
278 toInput->setText(recipients); 276 toInput->setText(recipients);
279 277
280 addressView->hide(); 278 addressView->hide();
281 okButton->hide(); 279 okButton->hide();
282 emailInput->show(); 280 emailInput->show();
283 addressButton->setOn(FALSE); 281 addressButton->setOn(FALSE);
284 showingAddressList = !showingAddressList; 282 showingAddressList = !showingAddressList;
285} 283}
286 284
287void WriteMail::setRecipient(const QString &recipient) 285void WriteMail::setRecipient(const QString &recipient)
288{ 286{
289 toInput->setText(recipient); 287 toInput->setText(recipient);
290} 288}
291 289
292void WriteMail::newMail() 290void WriteMail::newMail()
293{ 291{
294 toInput->clear(); 292 toInput->clear();
295 subjectInput->clear(); 293 subjectInput->clear();
296 emailInput->clear(); 294 emailInput->clear();
297 //to clear selected 295 //to clear selected
298 setAddressList(addressList); 296 setAddressList(addressList);
299} 297}
diff --git a/noncore/unsupported/mailit/addatt.cpp b/noncore/unsupported/mailit/addatt.cpp
index c030e36..f279f52 100644
--- a/noncore/unsupported/mailit/addatt.cpp
+++ b/noncore/unsupported/mailit/addatt.cpp
@@ -1,209 +1,230 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qlayout.h> 20#include <qlayout.h>
21#include <qdir.h> 21#include <qdir.h>
22#include <qstringlist.h> 22#include <qstringlist.h>
23#include "resource.h" 23#include "resource.h"
24#include "addatt.h" 24#include "addatt.h"
25 25
26FileItem::FileItem(QListView *parent, QFileInfo fileInfo, QString fileType) 26FileItem::FileItem(QListView *parent, DocLnk* dl)
27 : QListViewItem(parent) 27 : QListViewItem(parent)
28{ 28{
29 file = fileInfo; 29 /*file = fileInfo;
30 type = fileType; 30 type = fileType;*/
31
32 doclnk=dl;
31 33
32 setText(0, fileInfo.baseName()); 34 setText(0, doclnk->name());
33 35
34 if (fileType == "Picture") { 36 /*if (fileType == "Picture") {
35 setPixmap(0, Resource::loadPixmap("pixmap")); 37 setPixmap(0, Resource::loadPixmap("pixmap"));
36 } else if (fileType == "Document") { 38 } else if (fileType == "Document") {
37 setPixmap(0, Resource::loadPixmap("txt")); 39 setPixmap(0, Resource::loadPixmap("txt"));
38 } else if (fileType == "Sound") { 40 } else if (fileType == "Sound") {
39 setPixmap(0, Resource::loadPixmap("play")); 41 setPixmap(0, Resource::loadPixmap("play"));
40 } else if (fileType == "Movie") { 42 } else if (fileType == "Movie") {
41 setPixmap(0, Resource::loadPixmap("MPEGPlayer")); 43 setPixmap(0, Resource::loadPixmap("MPEGPlayer"));
42 } else if (fileType == "File") { 44 } else if (fileType == "File") {
43 setPixmap(0, Resource::loadPixmap("exec")); 45 setPixmap(0, Resource::loadPixmap("exec"));
44 } 46 }*/
45} 47}
46 48
47QFileInfo FileItem::getFileInfo() 49FileItem::~FileItem()
48{ 50{
49 return file; 51 if (doclnk!=NULL) delete doclnk;
50} 52 doclnk=NULL;
51
52QString FileItem::getFileType()
53{
54 return type;
55} 53}
56 54
57AddAtt::AddAtt(QWidget *parent, const char *name, WFlags f) 55AddAtt::AddAtt(QWidget *parent, const char *name, WFlags f)
58 : QDialog(parent, name, f) 56 : QDialog(parent, name, f)
59{ 57{
60 setCaption("Adding attatchments"); 58 setCaption("Adding attatchments");
61 59
62 QGridLayout *top = new QGridLayout(this, 3, 2); 60 QGridLayout *top = new QGridLayout(this, 3,1 );
61
63 62
64 fileCategoryButton = new QPushButton(this); 63 /*fileCategoryButton = new QPushButton(this);*/
65 attatchButton = new QPushButton("Attatch ->", this); 64 attatchButton = new QPushButton("Attatch ->", this);
66 removeButton = new QPushButton("Remove", this); 65 removeButton = new QPushButton("Remove", this);
67 66
68 fileCategories = new QPopupMenu(fileCategoryButton); 67 /*fileCategories = new QPopupMenu(fileCategoryButton);
69 fileCategoryButton->setPopup(fileCategories); 68 fileCategoryButton->setPopup(fileCategories);
70 fileCategories->insertItem("Document"); 69 fileCategories->insertItem("Document");
71 fileCategories->insertItem("Picture"); 70 fileCategories->insertItem("Picture");
72 fileCategories->insertItem("Sound"); 71 fileCategories->insertItem("Sound");
73 fileCategories->insertItem("Movie"); 72 fileCategories->insertItem("Movie");
74 fileCategories->insertItem("File"); 73 fileCategories->insertItem("File");
75 74
76 fileCategoryButton->setText("Document"); 75 fileCategoryButton->setText("Document");
77 top->addWidget(fileCategoryButton, 0, 0); 76 top->addWidget(fileCategoryButton, 0, 0);*/
78 top->addWidget(attatchButton, 2, 0); 77
79 top->addWidget(removeButton, 2, 1); 78 //ofs=new OFileSelector(this,2,0,"/root/Documents");
79
80
81 top->addWidget(attatchButton,1,0);
82 top->addWidget(removeButton,2,0);
80 83
81 connect(fileCategories, SIGNAL(activated(int)), this, 84 /*connect(fileCategories, SIGNAL(activated(int)), this,
82 SLOT(fileCategorySelected(int)) ); 85 SLOT(fileCategorySelected(int)) );*/
83 connect(attatchButton, SIGNAL(clicked()), this, 86 connect(attatchButton, SIGNAL(clicked()), this,
84 SLOT(addAttatchment()) ); 87 SLOT(addAttatchment()) );
85 connect(removeButton, SIGNAL(clicked()), this, 88 connect(removeButton, SIGNAL(clicked()), this,
86 SLOT(removeAttatchment()) ); 89 SLOT(removeAttatchment()) );
87 90
88 listView = new QListView(this, "AttView"); 91 /*listView = new QListView(this, "AttView");
89 listView->addColumn("Documents"); 92 listView->addColumn("Documents");*
90 connect(listView, SIGNAL(doubleClicked(QListViewItem *)), this, 93 connect(listView, SIGNAL(doubleClicked(QListViewItem *)), this,
91 SLOT(addAttatchment()) ); 94 SLOT(addAttatchment()) );*/
95
92 96
93 attView = new QListView(this, "Selected"); 97 attView = new QListView(this, "Selected");
94 attView->addColumn("Attatched"); 98 attView->addColumn(tr("Attached"));
99 attView->addColumn(tr("File type"));
95 connect(attView, SIGNAL(doubleClicked(QListViewItem *)), this, 100 connect(attView, SIGNAL(doubleClicked(QListViewItem *)), this,
96 SLOT(removeAttatchment()) ); 101 SLOT(removeAttatchment()) );
97 102
98 top->addWidget(listView, 1,0); 103 //top->addWidget(ofs, 0,0);
99 top->addWidget(attView, 1,1); 104 top->addWidget(attView, 0,0);
105
106 clear();
100 107
101 clear(); 108
102} 109}
103 110
104void AddAtt::clear() 111void AddAtt::clear()
105{ 112{
106 attView->clear(); 113 attView->clear();
107 getFiles(); 114 //getFiles();
108 modified = FALSE; 115 modified = FALSE;
109} 116}
110 117
111void AddAtt::fileCategorySelected(int id) 118/*void AddAtt::fileCategorySelected(int id)
112{ 119{
113 fileCategoryButton->setText(fileCategories->text(id)); 120 fileCategoryButton->setText(fileCategories->text(id));
114 getFiles(); 121 getFiles();
115} 122}*/
116 123
117void AddAtt::addAttatchment() 124void AddAtt::addAttatchment()
118{ 125 {
119 QFileInfo info; 126 QDialog qd(this,tr("Select attachment"),true);
120 QString type; 127
128 QGridLayout top(&qd,1,1);
129
130 OFileSelector ofs(&qd,1,0,"/root/Documents");
131
132 top.addWidget(&ofs,0,0);
121 133
122 if (listView->selectedItem() != NULL) { 134 qd.showMaximized();
123 item = (FileItem *) listView->selectedItem(); 135
124 info = item->getFileInfo(); 136 if (qd.exec()==QDialog::Accepted)
125 type = item->getFileType(); 137 {
126 item = new FileItem(attView, info, type); 138 DocLnk* dl=new DocLnk(ofs.selectedDocument());
139 FileItem* fi=new FileItem(attView,dl);
140 fi->setPixmap(0,dl->pixmap());
141 fi->setText(1,dl->type());
142 attView->insertItem(fi);
143 modified = TRUE;
127 } 144 }
128 modified = TRUE;
129} 145}
130 146
131void AddAtt::removeAttatchment() 147void AddAtt::removeAttatchment()
132{ 148{
133 if (attView->selectedItem() != NULL) { 149 if (attView->selectedItem() != NULL)
150 {
134 attView->takeItem(attView->selectedItem()); 151 attView->takeItem(attView->selectedItem());
135 } 152 }
136 modified = TRUE; 153 modified = TRUE;
137} 154}
138 155
139void AddAtt::reject() 156void AddAtt::reject()
140{ 157{
141 if (modified) { 158 if (modified) {
142 attView->clear(); 159 attView->clear();
143 modified = FALSE; 160 modified = FALSE;
144 } 161 }
145} 162}
146 163
147void AddAtt::accept() 164void AddAtt::accept()
148{ 165{
149 modified = FALSE; 166 modified = FALSE;
150 hide(); 167 hide();
151} 168}
152 169
153void AddAtt::getFiles() 170void AddAtt::getFiles()
154{ 171{
155 QString path, selected; 172 QString path, selected;
156 QDir *dir;
157 173
158 listView->clear(); 174 /*listView->clear();
159 175
160 selected = fileCategoryButton->text(); 176 selected = fileCategoryButton->text();
161 if (selected == "Picture") { 177 if (selected == "Picture") {
162 path = "../pics/"; 178 path = "../pics/";
163 } else if (selected == "Document") { 179 } else if (selected == "Document") {
164 path = "" ; //sub-dirs not decided 180 path = "" ; //sub-dirs not decided
165 } else if (selected == "Sound") { 181 } else if (selected == "Sound") {
166 path = "../sounds/"; //sub-dirs not decided 182 path = "../sounds/"; //sub-dirs not decided
167 } else if (selected == "Movie") { 183 } else if (selected == "Movie") {
168 path = ""; //sub-dirs not decided 184 path = ""; //sub-dirs not decided
169 } else if (selected == "File") { 185 } else if (selected == "File") {
170 path = ""; //sub-dirs not decided 186 path = ""; //sub-dirs not decided
171 } 187 }
172 188
173 dir = new QDir(path); 189 dir = new QDir(path);
174 dir->setFilter(QDir::Files); 190 dir->setFilter(QDir::Files);
175 const QFileInfoList *dirInfoList = dir->entryInfoList(); 191 const QFileInfoList *dirInfoList = dir->entryInfoList();
176 192
177 QFileInfoListIterator it(*dirInfoList); // create list iterator 193 QFileInfoListIterator it(*dirInfoList); // create list iterator
178 194
179 while ( (fi=it.current()) ) { // for each file... 195 while ( (fi=it.current()) ) { // for each file...
180 item = new FileItem(listView, *fi, selected); 196 item = new FileItem(listView, *fi, selected);
181 ++it; // goto next list element 197 ++it; // goto next list element
182 } 198 }*/
183} 199}
184 200
185QStringList AddAtt::returnAttatchedFiles() 201QStringList AddAtt::returnAttatchedFiles()
186{ 202{
187 QFileInfo info; 203 QFileInfo info;
188 QStringList list; 204 QStringList list;
189 205
190 item = (FileItem *) attView->firstChild(); 206 item = (FileItem *) attView->firstChild();
207
208
191 while (item != NULL) { 209 while (item != NULL) {
192 info = item->getFileInfo(); 210 DocLnk* dl=item->getDocLnk();
193 list += info.filePath(); 211 list+=dl->file();
212 /*info = item->getFileInfo();
213 list += info.filePath();*/
194 item = (FileItem *) item->nextSibling(); 214 item = (FileItem *) item->nextSibling();
195 } 215 }
196 return list; 216 return list;
197} 217}
198 218
199QStringList AddAtt::returnFileTypes() 219QStringList AddAtt::returnFileTypes()
200{ 220{
201 QStringList list; 221 QStringList list;
202 222
203 item = (FileItem *) attView->firstChild(); 223 item = (FileItem *) attView->firstChild();
224
204 while (item != NULL) { 225 while (item != NULL) {
205 list += item->getFileType(); 226 list += item->getDocLnk()->type();
206 item = (FileItem *) item->nextSibling(); 227 item = (FileItem *) item->nextSibling();
207 } 228 }
208 return list; 229 return list;
209} 230}
diff --git a/noncore/unsupported/mailit/addatt.h b/noncore/unsupported/mailit/addatt.h
index 867c905..73062e2 100644
--- a/noncore/unsupported/mailit/addatt.h
+++ b/noncore/unsupported/mailit/addatt.h
@@ -1,70 +1,76 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef ADDATT_H 20#ifndef ADDATT_H
21#define ADDATT_H 21#define ADDATT_H
22 22
23#include <qdialog.h> 23#include <qdialog.h>
24#include <qlistview.h> 24#include <qlistview.h>
25#include <qpushbutton.h> 25#include <qpushbutton.h>
26#include <qpopupmenu.h> 26#include <qpopupmenu.h>
27#include <qstring.h> 27#include <qstring.h>
28#include <qfileinfo.h> 28#include <qfileinfo.h>
29#include <qstringlist.h> 29#include <qstringlist.h>
30#include <opie/ofileselector.h>
31#include <qpe/applnk.h>
30 32
31class FileItem : public QListViewItem 33class FileItem : public QListViewItem
32{ 34{
33public: 35public:
34 FileItem(QListView *parent, QFileInfo fileInfo, QString fileType); 36 //FileItem(QListView *parent, QFileInfo fileInfo, QString fileType);
35 QFileInfo getFileInfo(); 37 FileItem(QListView*, DocLnk*);
36 QString getFileType(); 38 ~FileItem();
37 39 DocLnk* getDocLnk() {return doclnk;}
40
41
38private: 42private:
39 QFileInfo file; 43 DocLnk* doclnk;
40 QString type;
41}; 44};
42 45
43class AddAtt : public QDialog 46class AddAtt : public QDialog
44{ 47{
45 Q_OBJECT 48 Q_OBJECT
46 49
47public: 50public:
48 AddAtt(QWidget *parent = 0, const char *name = 0, WFlags f = 0); 51 AddAtt(QWidget *parent = 0, const char *name = 0, WFlags f = 0);
49 QStringList returnAttatchedFiles(); 52 QStringList returnAttatchedFiles();
50 QStringList returnFileTypes(); 53 QStringList returnFileTypes();
51 void getFiles(); 54 void getFiles();
52 void clear(); 55 void clear();
53 56
57
54public slots: 58public slots:
55 void fileCategorySelected(int); 59 //void fileCategorySelected(int);
56 void addAttatchment(); 60 void addAttatchment();
57 void removeAttatchment(); 61 void removeAttatchment();
58 void reject(); 62 void reject();
59 void accept(); 63 void accept();
60 64
61private: 65private:
62 FileItem *item; 66 FileItem* item;
63 QListView *listView, *attView; 67 QListView *attView;
64 QPushButton *fileCategoryButton, *attatchButton, *removeButton; 68 QPushButton *fileCategoryButton, *attatchButton, *removeButton;
65 QPopupMenu *fileCategories; 69 QPopupMenu *fileCategories;
66 bool modified; 70 bool modified;
67 QFileInfo *fi; 71 QFileInfo *fi;
72
73 OFileSelector* ofs;
68}; 74};
69 75
70#endif 76#endif
diff --git a/noncore/unsupported/mailit/emailclient.cpp b/noncore/unsupported/mailit/emailclient.cpp
index fc4276b..9258aac 100644
--- a/noncore/unsupported/mailit/emailclient.cpp
+++ b/noncore/unsupported/mailit/emailclient.cpp
@@ -1,858 +1,864 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qapplication.h> 20#include <qapplication.h>
21#include <qmessagebox.h> 21#include <qmessagebox.h>
22#include <qfile.h> 22#include <qfile.h>
23#include <qcheckbox.h> 23#include <qcheckbox.h>
24#include <qmenubar.h> 24#include <qmenubar.h>
25#include <qaction.h> 25#include <qaction.h>
26#include "resource.h" 26#include "resource.h"
27#include "emailclient.h" 27#include "emailclient.h"
28 28
29QCollection::Item AccountList::newItem(QCollection::Item d) 29QCollection::Item AccountList::newItem(QCollection::Item d)
30{ 30{
31 return dupl( (MailAccount *) d); 31 return dupl( (MailAccount *) d);
32} 32}
33 33
34MailAccount* AccountList::dupl(MailAccount *in) 34MailAccount* AccountList::dupl(MailAccount *in)
35{ 35{
36 ac = new MailAccount(*in); 36 ac = new MailAccount(*in);
37 return ac; 37 return ac;
38} 38}
39 39
40EmailClient::EmailClient( QWidget* parent, const char* name, WFlags fl ) 40EmailClient::EmailClient( QWidget* parent, const char* name, WFlags fl )
41 : QMainWindow( parent, name, fl ) 41 : QMainWindow( parent, name, fl )
42{ 42{
43 emailHandler = new EmailHandler(); 43 emailHandler = new EmailHandler();
44 addressList = new AddressList( getPath(FALSE) + "mail_adr"); 44 addressList = new AddressList( getPath(FALSE) + "mail_adr");
45 45
46 sending = FALSE; 46 sending = FALSE;
47 receiving = FALSE; 47 receiving = FALSE;
48 previewingMail = FALSE; 48 previewingMail = FALSE;
49 mailIdCount = 1; 49 mailIdCount = 1;
50 accountIdCount = 1; 50 accountIdCount = 1;
51 allAccounts = FALSE; 51 allAccounts = FALSE;
52 52
53 init(); 53 init();
54 54
55 connect(emailHandler, SIGNAL(mailSent()), this, SLOT(mailSent()) ); 55 connect(emailHandler, SIGNAL(mailSent()), this, SLOT(mailSent()) );
56 56
57 connect(emailHandler, SIGNAL(smtpError(int)), this, 57 connect(emailHandler, SIGNAL(smtpError(int)), this,
58 SLOT(smtpError(int)) ); 58 SLOT(smtpError(int)) );
59 connect(emailHandler, SIGNAL(popError(int)), this, 59 connect(emailHandler, SIGNAL(popError(int)), this,
60 SLOT(popError(int)) ); 60 SLOT(popError(int)) );
61 61
62 connect(inboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(inboxItemSelected()) ); 62 connect(inboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(inboxItemSelected()) );
63 connect(outboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(outboxItemSelected()) ); 63 connect(outboxView, SIGNAL(clicked(QListViewItem *)), this, SLOT(outboxItemSelected()) );
64 64
65 connect(emailHandler, SIGNAL(mailArrived(const Email &, bool)), this, 65 connect(emailHandler, SIGNAL(mailArrived(const Email &, bool)), this,
66 SLOT(mailArrived(const Email &, bool)) ); 66 SLOT(mailArrived(const Email &, bool)) );
67 connect(emailHandler, SIGNAL(mailTransfered(int)), this, 67 connect(emailHandler, SIGNAL(mailTransfered(int)), this,
68 SLOT(allMailArrived(int)) ); 68 SLOT(allMailArrived(int)) );
69 69
70 mailconf = new Config("mailit"); 70 mailconf = new Config("mailit");
71 //In case Synchronize is not defined in settings.txt 71 //In case Synchronize is not defined in settings.txt
72 72
73 readSettings(); 73 readSettings();
74 74
75 updateAccounts(); 75 updateAccounts();
76 76
77 lineShift = "\n"; 77 lineShift = "\n";
78 readMail(); 78 readMail();
79 lineShift = "\r\n"; 79 lineShift = "\r\n";
80 80
81} 81}
82 82
83 83
84EmailClient::~EmailClient() 84EmailClient::~EmailClient()
85{ 85{
86 //needs to be moved from destructor to closewindow event 86 //needs to be moved from destructor to closewindow event
87 saveMail(getPath(FALSE) + "inbox.txt", inboxView); 87 saveMail(getPath(FALSE) + "inbox.txt", inboxView);
88 //does not currently work. Defining outbox in the same 88 //does not currently work. Defining outbox in the same
89 //format as inbox is not a good solution as they have 89 //format as inbox is not a good solution as they have
90 //different properties 90 //different properties
91 saveMail(getPath(FALSE) + "outbox.txt", outboxView); 91 saveMail(getPath(FALSE) + "outbox.txt", outboxView);
92 saveSettings(); 92 saveSettings();
93 93
94 mailconf->write(); 94 mailconf->write();
95 delete mailconf; 95 delete mailconf;
96 96
97} 97}
98 98
99void EmailClient::init() 99void EmailClient::init()
100{ 100{
101 statusBar = new QStatusBar(this); 101 statusBar = new QStatusBar(this);
102 statusBar->setSizeGripEnabled(FALSE); 102 statusBar->setSizeGripEnabled(FALSE);
103 103
104 status1Label = new QLabel( tr("Idle"), statusBar); 104 status1Label = new QLabel( tr("Idle"), statusBar);
105 status2Label = new QLabel("", statusBar); 105 status2Label = new QLabel("", statusBar);
106 connect(emailHandler, SIGNAL(updatePopStatus(const QString &)), 106 connect(emailHandler, SIGNAL(updatePopStatus(const QString &)),
107 status2Label, SLOT(setText(const QString &)) ); 107 status2Label, SLOT(setText(const QString &)) );
108 connect(emailHandler, SIGNAL(updateSmtpStatus(const QString &)), 108 connect(emailHandler, SIGNAL(updateSmtpStatus(const QString &)),
109 status2Label, SLOT(setText(const QString &)) ); 109 status2Label, SLOT(setText(const QString &)) );
110 110
111 progressBar = new QProgressBar(statusBar); 111 progressBar = new QProgressBar(statusBar);
112 connect(emailHandler, SIGNAL(mailboxSize(int)), 112 connect(emailHandler, SIGNAL(mailboxSize(int)),
113 this, SLOT(setTotalSize(int)) ); 113 this, SLOT(setTotalSize(int)) );
114 connect(emailHandler, SIGNAL(currentMailSize(int)), 114 connect(emailHandler, SIGNAL(currentMailSize(int)),
115 this, SLOT(setMailSize(int)) ); 115 this, SLOT(setMailSize(int)) );
116 connect(emailHandler, SIGNAL(downloadedSize(int)), 116 connect(emailHandler, SIGNAL(downloadedSize(int)),
117 this, SLOT(setDownloadedSize(int)) ); 117 this, SLOT(setDownloadedSize(int)) );
118 118
119 statusBar->addWidget(status1Label); 119 statusBar->addWidget(status1Label);
120 statusBar->addWidget(progressBar); 120 statusBar->addWidget(progressBar);
121 statusBar->addWidget(status2Label); 121 statusBar->addWidget(status2Label);
122 122
123 setToolBarsMovable(FALSE); 123 setToolBarsMovable(FALSE);
124 124
125 bar = new QToolBar(this); 125 bar = new QToolBar(this);
126 bar->setHorizontalStretchable( TRUE ); 126 bar->setHorizontalStretchable( TRUE );
127 127
128 mb = new QMenuBar( bar ); 128 mb = new QMenuBar( bar );
129 129
130 QPopupMenu *mail = new QPopupMenu(mb); 130 QPopupMenu *mail = new QPopupMenu(mb);
131 mb->insertItem( tr( "&Mail" ), mail); 131 mb->insertItem( tr( "&Mail" ), mail);
132 132
133 QPopupMenu *configure = new QPopupMenu(mb); 133 QPopupMenu *configure = new QPopupMenu(mb);
134 mb->insertItem( tr( "Accounts" ), configure); 134 mb->insertItem( tr( "Accounts" ), configure);
135 135
136 selectAccountMenu = new QPopupMenu(mb); 136 selectAccountMenu = new QPopupMenu(mb);
137 editAccountMenu = new QPopupMenu(mb); 137 editAccountMenu = new QPopupMenu(mb);
138 deleteAccountMenu = new QPopupMenu(mb); 138 deleteAccountMenu = new QPopupMenu(mb);
139 139
140 mail->insertItem(tr("Get Mail in"), selectAccountMenu); 140 mail->insertItem(tr("Get Mail in"), selectAccountMenu);
141 configure->insertItem(tr("Edit account"), editAccountMenu); 141 configure->insertItem(tr("Edit account"), editAccountMenu);
142 configure->insertItem(tr("Delete account"), deleteAccountMenu); 142 configure->insertItem(tr("Delete account"), deleteAccountMenu);
143 143
144 bar = new QToolBar(this); 144 bar = new QToolBar(this);
145 145
146 getMailButton = new QAction(tr("Get all mail"), Resource::loadPixmap("mailit/getmail"), QString::null, 0, this, 0); 146 getMailButton = new QAction(tr("Get all mail"), Resource::loadPixmap("mailit/getmail"), QString::null, 0, this, 0);
147 connect(getMailButton, SIGNAL(activated()), this, SLOT(getAllNewMail()) ); 147 connect(getMailButton, SIGNAL(activated()), this, SLOT(getAllNewMail()) );
148 getMailButton->addTo(bar); 148 getMailButton->addTo(bar);
149 getMailButton->addTo(mail); 149 getMailButton->addTo(mail);
150 150
151 sendMailButton = new QAction(tr("Send mail"), Resource::loadPixmap("mailit/sendmail"), QString::null, 0, this, 0); 151 sendMailButton = new QAction(tr("Send mail"), Resource::loadPixmap("mailit/sendmail"), QString::null, 0, this, 0);
152 connect(sendMailButton, SIGNAL(activated()), this, SLOT(sendQuedMail()) ); 152 connect(sendMailButton, SIGNAL(activated()), this, SLOT(sendQuedMail()) );
153 sendMailButton->addTo(bar); 153 sendMailButton->addTo(bar);
154 sendMailButton->addTo(mail); 154 sendMailButton->addTo(mail);
155 155
156 composeButton = new QAction(tr("Compose"), Resource::loadPixmap("new"), QString::null, 0, this, 0); 156 composeButton = new QAction(tr("Compose"), Resource::loadPixmap("new"), QString::null, 0, this, 0);
157 connect(composeButton, SIGNAL(activated()), this, SLOT(compose()) ); 157 connect(composeButton, SIGNAL(activated()), this, SLOT(compose()) );
158 composeButton->addTo(bar); 158 composeButton->addTo(bar);
159 composeButton->addTo(mail); 159 composeButton->addTo(mail);
160 160
161 cancelButton = new QAction(tr("Cancel transfer"), Resource::loadPixmap("close"), QString::null, 0, this, 0); 161 cancelButton = new QAction(tr("Cancel transfer"), Resource::loadPixmap("close"), QString::null, 0, this, 0);
162 connect(cancelButton, SIGNAL(activated()), this, SLOT(cancel()) ); 162 connect(cancelButton, SIGNAL(activated()), this, SLOT(cancel()) );
163 cancelButton->addTo(mail); 163 cancelButton->addTo(mail);
164 cancelButton->addTo(bar);
164 cancelButton->setEnabled(FALSE); 165 cancelButton->setEnabled(FALSE);
165 166
166 mailboxView = new OTabWidget( this, "mailboxView" ); 167 mailboxView = new OTabWidget( this, "mailboxView" );
167 168
168 QWidget* widget = new QWidget( mailboxView, "widget" ); 169 QWidget* widget = new QWidget( mailboxView, "widget" );
169 grid_2 = new QGridLayout( widget ); 170 grid_2 = new QGridLayout( widget );
170// grid_2->setSpacing(6); 171// grid_2->setSpacing(6);
171// grid_2->setMargin( 11 ); 172// grid_2->setMargin( 11 );
172 173
173 inboxView = new QListView( widget, "inboxView" ); 174 inboxView = new QListView( widget, "inboxView" );
174 inboxView->addColumn( tr( "From" ) ); 175 inboxView->addColumn( tr( "From" ) );
175 inboxView->addColumn( tr( "Subject" ) ); 176 inboxView->addColumn( tr( "Subject" ) );
176 inboxView->addColumn( tr( "Date" ) ); 177 inboxView->addColumn( tr( "Date" ) );
177 inboxView->setMinimumSize( QSize( 0, 0 ) ); 178 inboxView->setMinimumSize( QSize( 0, 0 ) );
178 inboxView->setAllColumnsShowFocus(TRUE); 179 inboxView->setAllColumnsShowFocus(TRUE);
179 180
180 grid_2->addWidget( inboxView, 2, 0 ); 181 grid_2->addWidget( inboxView, 2, 0 );
181 mailboxView->addTab( widget, "mailit/inbox", tr( "Inbox" ) ); 182 mailboxView->addTab( widget, "mailit/inbox", tr( "Inbox" ) );
182 183
183 QWidget* widget_2 = new QWidget( mailboxView, "widget_2" ); 184 QWidget* widget_2 = new QWidget( mailboxView, "widget_2" );
184 grid_3 = new QGridLayout( widget_2 ); 185 grid_3 = new QGridLayout( widget_2 );
185// grid_3->setSpacing(6); 186// grid_3->setSpacing(6);
186// grid_3->setMargin( 11 ); 187// grid_3->setMargin( 11 );
187 188
188 outboxView = new QListView( widget_2, "outboxView" ); 189 outboxView = new QListView( widget_2, "outboxView" );
189 outboxView->addColumn( tr( "To" ) ); 190 outboxView->addColumn( tr( "To" ) );
190 outboxView->addColumn( tr( "Subject" ) ); 191 outboxView->addColumn( tr( "Subject" ) );
191 outboxView->setAllColumnsShowFocus(TRUE); 192 outboxView->setAllColumnsShowFocus(TRUE);
192 193
193 grid_3->addWidget( outboxView, 0, 0 ); 194 grid_3->addWidget( outboxView, 0, 0 );
194 mailboxView->addTab( widget_2,"mailit/outbox", tr( "Outbox" ) ); 195 mailboxView->addTab( widget_2,"mailit/outbox", tr( "Outbox" ) );
195 196
196 setCentralWidget(mailboxView); 197 setCentralWidget(mailboxView);
197} 198}
198 199
199void EmailClient::compose() 200void EmailClient::compose()
200{ 201{
201 emit composeRequested(); 202 emit composeRequested();
202} 203}
203 204
204void EmailClient::cancel() 205void EmailClient::cancel()
205{ 206{
206 emailHandler->cancel(); 207 emailHandler->cancel();
207} 208}
208 209
209AddressList* EmailClient::getAdrListRef() 210AddressList* EmailClient::getAdrListRef()
210{ 211{
211 return addressList; 212 return addressList;
212} 213}
213 214
214//this needs to be rewritten to syncronize with outboxView 215//this needs to be rewritten to syncronize with outboxView
215void EmailClient::enqueMail(const Email &mail) 216void EmailClient::enqueMail(const Email &mail)
216{ 217{
218 if (accountList.count() == 0) {
219 QMessageBox::warning(qApp->activeWindow(),
220 tr("No account selected"), tr("You must create an account"), "OK\n");
221 return;
222 }
223
217 if (accountList.count() > 0) { 224 if (accountList.count() > 0) {
218 currentAccount = accountList.first(); 225 currentAccount = accountList.first();
219 qWarning("using account " + currentAccount->name); 226 qWarning("using account " + currentAccount->name);
220 } 227 }
221 228
222 Email addMail = mail; 229 Email addMail = mail;
223 addMail.from = currentAccount->name; 230 addMail.from = currentAccount->name;
224 addMail.fromMail = currentAccount->emailAddress; 231 addMail.fromMail = currentAccount->emailAddress;
225 addMail.rawMail.prepend("From: " + addMail.from + "<" + addMail.fromMail + ">\n"); 232 addMail.rawMail.prepend("From: " + addMail.from + "<" + addMail.fromMail + ">\n");
226 item = new EmailListItem(outboxView, addMail, false); 233 item = new EmailListItem(outboxView, addMail, false);
227 234
228} 235}
229 236
230void EmailClient::sendQuedMail() 237void EmailClient::sendQuedMail()
231{ 238{
232 int count = 0; 239 int count = 0;
233 240
234 if (accountList.count() == 0) { 241 if (accountList.count() == 0) {
235 QMessageBox::warning(qApp->activeWindow(), 242 QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n");
236 "No account selected", "You must create an account", "OK\n");
237 return; 243 return;
238 } 244 }
239 //traverse listview, find messages to send 245 //traverse listview, find messages to send
240 if (! sending) { 246 if (! sending) {
241 item = (EmailListItem *) outboxView->firstChild(); 247 item = (EmailListItem *) outboxView->firstChild();
242 if (item != NULL) { 248 if (item != NULL) {
243 while (item != NULL) { 249 while (item != NULL) {
244 quedMessages.append(item->getMail()); 250 quedMessages.append(item->getMail());
245 item = (EmailListItem *) item->nextSibling(); 251 item = (EmailListItem *) item->nextSibling();
246 count++; 252 count++;
247 } 253 }
248 setMailAccount(); 254 setMailAccount();
249 emailHandler->sendMail(&quedMessages); 255 emailHandler->sendMail(&quedMessages);
250 sending = TRUE; 256 sending = TRUE;
251 sendMailButton->setEnabled(FALSE); 257 sendMailButton->setEnabled(FALSE);
252 cancelButton->setEnabled(TRUE); 258 cancelButton->setEnabled(TRUE);
253 } else { 259 } else {
254 qWarning("sendQuedMail(): no messages to send"); 260 qWarning("sendQuedMail(): no messages to send");
255 } 261 }
256 } 262 }
257} 263}
258 264
259void EmailClient::setMailAccount() 265void EmailClient::setMailAccount()
260{ 266{
261 emailHandler->setAccount(*currentAccount); 267 emailHandler->setAccount(*currentAccount);
262} 268}
263 269
264void EmailClient::mailSent() 270void EmailClient::mailSent()
265{ 271{
266 sending = FALSE; 272 sending = FALSE;
267 sendMailButton->setEnabled(TRUE); 273 sendMailButton->setEnabled(TRUE);
268 274
269 quedMessages.clear(); 275 quedMessages.clear();
270 outboxView->clear(); //should be moved to an sentBox 276 outboxView->clear(); //should be moved to an sentBox
271} 277}
272 278
273void EmailClient::getNewMail() { 279void EmailClient::getNewMail() {
274 280
275 if (accountList.count() == 0) { 281 if (accountList.count() == 0) {
276 QMessageBox::warning(qApp->activeWindow(),"No account selected", 282 QMessageBox::warning(qApp->activeWindow(),"No account selected",
277 "You must create an account", "OK\n"); 283 "You must create an account", "OK\n");
278 return; 284 return;
279 } 285 }
280 286
281 setMailAccount(); 287 setMailAccount();
282 288
283 receiving = TRUE; 289 receiving = TRUE;
284 previewingMail = TRUE; 290 previewingMail = TRUE;
285 getMailButton->setEnabled(FALSE); 291 getMailButton->setEnabled(FALSE);
286 cancelButton->setEnabled(TRUE); 292 cancelButton->setEnabled(TRUE);
287 selectAccountMenu->setEnabled(FALSE); 293 selectAccountMenu->setEnabled(FALSE);
288 294
289 status1Label->setText(currentAccount->accountName + " headers"); 295 status1Label->setText(currentAccount->accountName + " headers");
290 progressBar->reset(); 296 progressBar->reset();
291 297
292 //get any previous mails not downloaded and add to queue 298 //get any previous mails not downloaded and add to queue
293 mailDownloadList.clear(); 299 mailDownloadList.clear();
294 Email *mailPtr; 300 Email *mailPtr;
295 item = (EmailListItem *) inboxView->firstChild(); 301 item = (EmailListItem *) inboxView->firstChild();
296 while (item != NULL) { 302 while (item != NULL) {
297 mailPtr = item->getMail(); 303 mailPtr = item->getMail();
298 if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { 304 if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) {
299 mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); 305 mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size);
300 } 306 }
301 item = (EmailListItem *) item->nextSibling(); 307 item = (EmailListItem *) item->nextSibling();
302 } 308 }
303 309
304 emailHandler->getMailHeaders(); 310 emailHandler->getMailHeaders();
305} 311}
306 312
307void EmailClient::getAllNewMail() 313void EmailClient::getAllNewMail()
308{ 314{
309 allAccounts = TRUE; 315 allAccounts = TRUE;
310 currentAccount = accountList.first(); 316 currentAccount = accountList.first();
311 getNewMail(); 317 getNewMail();
312} 318}
313 319
314void EmailClient::mailArrived(const Email &mail, bool fromDisk) 320void EmailClient::mailArrived(const Email &mail, bool fromDisk)
315{ 321{
316 Enclosure *ePtr; 322 Enclosure *ePtr;
317 Email newMail; 323 Email newMail;
318 int thisMailId; 324 int thisMailId;
319 emailHandler->parse(mail.rawMail, lineShift, &newMail); 325 emailHandler->parse(mail.rawMail, lineShift, &newMail);
320 326
321 mailconf->setGroup(newMail.id); 327 mailconf->setGroup(newMail.id);
322 328
323 if (fromDisk) { 329 if (fromDisk) {
324 newMail.downloaded = mailconf->readBoolEntry("downloaded"); 330 newMail.downloaded = mailconf->readBoolEntry("downloaded");
325 newMail.size = mailconf->readNumEntry("size"); 331 newMail.size = mailconf->readNumEntry("size");
326 newMail.serverId = mailconf->readNumEntry("serverid"); 332 newMail.serverId = mailconf->readNumEntry("serverid");
327 newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); 333 newMail.fromAccountId = mailconf->readNumEntry("fromaccountid");
328 } else { //mail arrived from server 334 } else { //mail arrived from server
329 newMail.serverId = mail.serverId; 335 newMail.serverId = mail.serverId;
330 newMail.size = mail.size; 336 newMail.size = mail.size;
331 newMail.downloaded = mail.downloaded; 337 newMail.downloaded = mail.downloaded;
332 338
333 newMail.fromAccountId = currentAccount->id; 339 newMail.fromAccountId = currentAccount->id;
334 mailconf->writeEntry("fromaccountid", newMail.fromAccountId); 340 mailconf->writeEntry("fromaccountid", newMail.fromAccountId);
335 } 341 }
336 342
337 //add if read or not 343 //add if read or not
338 newMail.read = mailconf->readBoolEntry("mailread"); 344 newMail.read = mailconf->readBoolEntry("mailread");
339 345
340 //check if new mail 346 //check if new mail
341 if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { 347 if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) {
342 thisMailId = mailIdCount; 348 thisMailId = mailIdCount;
343 mailIdCount++; 349 mailIdCount++;
344 350
345 //set server count, so that if the user aborts, the new 351 //set server count, so that if the user aborts, the new
346 //header is not reloaded 352 //header is not reloaded
347 if (currentAccount->synchronize) 353 if (currentAccount->synchronize)
348 currentAccount->lastServerMailCount++; 354 currentAccount->lastServerMailCount++;
349 355
350 mailconf->writeEntry("internalmailid", thisMailId); 356 mailconf->writeEntry("internalmailid", thisMailId);
351 mailconf->writeEntry("downloaded", newMail.downloaded); 357 mailconf->writeEntry("downloaded", newMail.downloaded);
352 mailconf->writeEntry("size", (int) newMail.size); 358 mailconf->writeEntry("size", (int) newMail.size);
353 mailconf->writeEntry("serverid", newMail.serverId); 359 mailconf->writeEntry("serverid", newMail.serverId);
354 360
355 addressList->addContact(newMail.fromMail, newMail.from); 361 addressList->addContact(newMail.fromMail, newMail.from);
356 } else if (!fromDisk) { //body to header arrived 362 } else if (!fromDisk) { //body to header arrived
357 mailconf->writeEntry("downloaded", TRUE); 363 mailconf->writeEntry("downloaded", TRUE);
358 } 364 }
359 QString stringMailId; 365 QString stringMailId;
360 stringMailId.setNum(thisMailId); 366 stringMailId.setNum(thisMailId);
361 //se if any attatchments needs to be stored 367 //se if any attatchments needs to be stored
362 for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { 368 for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) {
363 QString stringId; 369 QString stringId;
364 stringId.setNum(ePtr->id); 370 stringId.setNum(ePtr->id);
365 371
366 int id = mailconf->readNumEntry("enclosureid_" + stringId); 372 int id = mailconf->readNumEntry("enclosureid_" + stringId);
367 if (id != ePtr->id) { //new entry 373 if (id != ePtr->id) { //new entry
368 mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); 374 mailconf->writeEntry("enclosureid_" + stringId, ePtr->id);
369 mailconf->writeEntry("name_" + stringId, ePtr->originalName); 375 mailconf->writeEntry("name_" + stringId, ePtr->originalName);
370 mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); 376 mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType);
371 mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); 377 mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute);
372 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 378 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
373 mailconf->writeEntry("installed_" + stringId, FALSE); 379 mailconf->writeEntry("installed_" + stringId, FALSE);
374 380
375 ePtr->name = stringMailId + "_" + stringId; 381 ePtr->name = stringMailId + "_" + stringId;
376 ePtr->path = getPath(TRUE); 382 ePtr->path = getPath(TRUE);
377 if (emailHandler->getEnclosure(ePtr)) { //file saved 383 if (emailHandler->getEnclosure(ePtr)) { //file saved
378 ePtr->saved = TRUE; 384 ePtr->saved = TRUE;
379 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 385 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
380 mailconf->writeEntry("filename_" + stringId, ePtr->name); 386 mailconf->writeEntry("filename_" + stringId, ePtr->name);
381 mailconf->writeEntry("path_" + stringId, ePtr->path); 387 mailconf->writeEntry("path_" + stringId, ePtr->path);
382 } else { 388 } else {
383 ePtr->saved = FALSE; 389 ePtr->saved = FALSE;
384 mailconf->writeEntry("saved_" + stringId, ePtr->saved); 390 mailconf->writeEntry("saved_" + stringId, ePtr->saved);
385 } 391 }
386 } else { 392 } else {
387 ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); 393 ePtr->saved = mailconf->readBoolEntry("saved_" + stringId);
388 ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); 394 ePtr->installed = mailconf->readBoolEntry("installed_" + stringId);
389 if (ePtr->saved) { 395 if (ePtr->saved) {
390 ePtr->name = mailconf->readEntry("filename_" + stringId); 396 ePtr->name = mailconf->readEntry("filename_" + stringId);
391 ePtr->path = mailconf->readEntry("path_" + stringId); 397 ePtr->path = mailconf->readEntry("path_" + stringId);
392 } 398 }
393 } 399 }
394 } 400 }
395 if (!previewingMail && !fromDisk) { 401 if (!previewingMail && !fromDisk) {
396 Email *mailPtr; 402 Email *mailPtr;
397 item = (EmailListItem *) inboxView->firstChild(); 403 item = (EmailListItem *) inboxView->firstChild();
398 while (item != NULL) { 404 while (item != NULL) {
399 mailPtr = item->getMail(); 405 mailPtr = item->getMail();
400 if (mailPtr->id == newMail.id) { 406 if (mailPtr->id == newMail.id) {
401 item->setMail(newMail); 407 item->setMail(newMail);
402 emit mailUpdated(item->getMail()); 408 emit mailUpdated(item->getMail());
403 } 409 }
404 item = (EmailListItem *) item->nextSibling(); 410 item = (EmailListItem *) item->nextSibling();
405 } 411 }
406 } else { 412 } else {
407 item = new EmailListItem(inboxView, newMail, TRUE); 413 item = new EmailListItem(inboxView, newMail, TRUE);
408 if (!newMail.downloaded) 414 if (!newMail.downloaded)
409 mailDownloadList.sizeInsert(newMail.serverId, newMail.size); 415 mailDownloadList.sizeInsert(newMail.serverId, newMail.size);
410 } 416 }
411 417
412} 418}
413 419
414void EmailClient::allMailArrived(int count) 420void EmailClient::allMailArrived(int count)
415{ 421{
416 // not previewing means all mailtransfer has been done 422 // not previewing means all mailtransfer has been done
417 if (!previewingMail) { 423 if (!previewingMail) {
418 if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { 424 if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) {
419 emit newCaption("Mailit - " + currentAccount->accountName); 425 emit newCaption("Mailit - " + currentAccount->accountName);
420 getNewMail(); 426 getNewMail();
421 return; 427 return;
422 } else { 428 } else {
423 allAccounts = FALSE; 429 allAccounts = FALSE;
424 receiving = FALSE; 430 receiving = FALSE;
425 getMailButton->setEnabled(TRUE); 431 getMailButton->setEnabled(TRUE);
426 cancelButton->setEnabled(FALSE); 432 cancelButton->setEnabled(FALSE);
427 selectAccountMenu->setEnabled(TRUE); 433 selectAccountMenu->setEnabled(TRUE);
428 status1Label->setText("Idle"); 434 status1Label->setText("Idle");
429 435
430 progressBar->reset(); 436 progressBar->reset();
431 return; 437 return;
432 } 438 }
433 } 439 }
434 440
435 // all headers downloaded from server, start downloading remaining mails 441 // all headers downloaded from server, start downloading remaining mails
436 previewingMail = FALSE; 442 previewingMail = FALSE;
437 status1Label->setText(currentAccount->accountName); 443 status1Label->setText(currentAccount->accountName);
438 progressBar->reset(); 444 progressBar->reset();
439 445
440 emailHandler->getMailByList(&mailDownloadList); 446 emailHandler->getMailByList(&mailDownloadList);
441} 447}
442 448
443void EmailClient::moveMailFront(Email *mailPtr) 449void EmailClient::moveMailFront(Email *mailPtr)
444{ 450{
445 if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { 451 if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) {
446 mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); 452 mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size);
447 } 453 }
448} 454}
449 455
450void EmailClient::smtpError(int code) 456void EmailClient::smtpError(int code)
451{ 457{
452 QString temp; 458 QString temp;
453 459
454 if (code == ErrUnknownResponse) 460 if (code == ErrUnknownResponse)
455 temp = "Unknown response from server"; 461 temp = "Unknown response from server";
456 462
457 if (code == QSocket::ErrHostNotFound) 463 if (code == QSocket::ErrHostNotFound)
458 temp = "host not found"; 464 temp = "host not found";
459 if (code == QSocket::ErrConnectionRefused) 465 if (code == QSocket::ErrConnectionRefused)
460 temp = "connection refused"; 466 temp = "connection refused";
461 if (code == QSocket::ErrSocketRead) 467 if (code == QSocket::ErrSocketRead)
462 temp = "socket packet error"; 468 temp = "socket packet error";
463 469
464 if (code != ErrCancel) { 470 if (code != ErrCancel) {
465 QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); 471 QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n");
466 } else { 472 } else {
467 status2Label->setText("Aborted by user"); 473 status2Label->setText("Aborted by user");
468 } 474 }
469 475
470 sending = FALSE; 476 sending = FALSE;
471 sendMailButton->setEnabled(TRUE); 477 sendMailButton->setEnabled(TRUE);
472 cancelButton->setEnabled(FALSE); 478 cancelButton->setEnabled(FALSE);
473 quedMessages.clear(); 479 quedMessages.clear();
474} 480}
475 481
476void EmailClient::popError(int code) 482void EmailClient::popError(int code)
477{ 483{
478 QString temp; 484 QString temp;
479 485
480 if (code == ErrUnknownResponse) 486 if (code == ErrUnknownResponse)
481 temp = "Unknown response from server"; 487 temp = "Unknown response from server";
482 if (code == ErrLoginFailed) 488 if (code == ErrLoginFailed)
483 temp = "Login failed\nCheck user name and password"; 489 temp = "Login failed\nCheck user name and password";
484 490
485 if (code == QSocket::ErrHostNotFound) 491 if (code == QSocket::ErrHostNotFound)
486 temp = "host not found"; 492 temp = "host not found";
487 if (code == QSocket::ErrConnectionRefused) 493 if (code == QSocket::ErrConnectionRefused)
488 temp = "connection refused"; 494 temp = "connection refused";
489 if (code == QSocket::ErrSocketRead) 495 if (code == QSocket::ErrSocketRead)
490 temp = "socket packet error"; 496 temp = "socket packet error";
491 497
492 if (code != ErrCancel) { 498 if (code != ErrCancel) {
493 QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); 499 QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n");
494 } else { 500 } else {
495 status2Label->setText("Aborted by user"); 501 status2Label->setText("Aborted by user");
496 } 502 }
497 503
498 receiving = FALSE; 504 receiving = FALSE;
499 getMailButton->setEnabled(TRUE); 505 getMailButton->setEnabled(TRUE);
500 cancelButton->setEnabled(FALSE); 506 cancelButton->setEnabled(FALSE);
501 selectAccountMenu->setEnabled(TRUE); 507 selectAccountMenu->setEnabled(TRUE);
502} 508}
503 509
504void EmailClient::inboxItemSelected() 510void EmailClient::inboxItemSelected()
505{ 511{
506 item = (EmailListItem*) inboxView->selectedItem(); 512 item = (EmailListItem*) inboxView->selectedItem();
507 if (item != NULL) { 513 if (item != NULL) {
508 emit viewEmail(inboxView, item->getMail()); 514 emit viewEmail(inboxView, item->getMail());
509 } 515 }
510} 516}
511 517
512void EmailClient::outboxItemSelected() 518void EmailClient::outboxItemSelected()
513{ 519{
514 item = (EmailListItem*) outboxView->selectedItem(); 520 item = (EmailListItem*) outboxView->selectedItem();
515 if (item != NULL) { 521 if (item != NULL) {
516 emit viewEmail(outboxView, item->getMail()); 522 emit viewEmail(outboxView, item->getMail());
517 } 523 }
518 524
519} 525}
520 526
521void EmailClient::readMail() 527void EmailClient::readMail()
522{ 528{
523 Email mail; 529 Email mail;
524 int start, stop; 530 int start, stop;
525 QString s, del; 531 QString s, del;
526 532
527 QFile f(getPath(FALSE) + "inbox.txt"); 533 QFile f(getPath(FALSE) + "inbox.txt");
528// QFileInfo fi(f); 534// QFileInfo fi(f);
529 qDebug( f.name()); 535 qDebug( f.name());
530 536
531 if ( f.open(IO_ReadOnly) ) { // file opened successfully 537 if ( f.open(IO_ReadOnly) ) { // file opened successfully
532 QTextStream t( &f ); // use a text stream 538 QTextStream t( &f ); // use a text stream
533 s = t.read(); 539 s = t.read();
534 f.close(); 540 f.close();
535 541
536 start = 0; 542 start = 0;
537 del = "\n.\n"; 543 del = "\n.\n";
538 while ((uint) start < s.length()) { 544 while ((uint) start < s.length()) {
539 stop = s.find(del, start); 545 stop = s.find(del, start);
540 if (stop == -1) 546 if (stop == -1)
541 stop = s.length() - del.length(); 547 stop = s.length() - del.length();
542 548
543 mail.rawMail = s.mid(start, stop + del.length() - start ); 549 mail.rawMail = s.mid(start, stop + del.length() - start );
544 start = stop + del.length(); 550 start = stop + del.length();
545 mailArrived(mail, TRUE); 551 mailArrived(mail, TRUE);
546 } 552 }
547 } 553 }
548 554
549 QFile fo(getPath(FALSE) + "outbox.txt"); 555 QFile fo(getPath(FALSE) + "outbox.txt");
550 if ( fo.open(IO_ReadOnly) ) { // file opened successfully 556 if ( fo.open(IO_ReadOnly) ) { // file opened successfully
551 QTextStream t( &fo ); // use a text stream 557 QTextStream t( &fo ); // use a text stream
552 s = t.read(); 558 s = t.read();
553 fo.close(); 559 fo.close();
554 560
555 start = 0; 561 start = 0;
556 del = "\n.\n"; 562 del = "\n.\n";
557 while ((uint) start < s.length()) { 563 while ((uint) start < s.length()) {
558 stop = s.find(del, start); 564 stop = s.find(del, start);
559 if (stop == -1) 565 if (stop == -1)
560 stop = s.length() - del.length(); 566 stop = s.length() - del.length();
561 567
562 mail.rawMail = s.mid(start, stop + del.length() - start ); 568 mail.rawMail = s.mid(start, stop + del.length() - start );
563 start = stop + del.length(); 569 start = stop + del.length();
564 emailHandler->parse(mail.rawMail, lineShift, &mail); 570 emailHandler->parse(mail.rawMail, lineShift, &mail);
565 mail.sent = false; 571 mail.sent = false;
566 mail.received = false; 572 mail.received = false;
567 enqueMail(mail); 573 enqueMail(mail);
568 574
569 } 575 }
570 } 576 }
571} 577}
572 578
573void EmailClient::saveMail(QString fileName, QListView *view) 579void EmailClient::saveMail(QString fileName, QListView *view)
574{ 580{
575 QFile f(fileName); 581 QFile f(fileName);
576 Email *mail; 582 Email *mail;
577 583
578 if (! f.open(IO_WriteOnly) ) { 584 if (! f.open(IO_WriteOnly) ) {
579 qWarning("could not open file"); 585 qWarning("could not open file");
580 return; 586 return;
581 } 587 }
582 item = (EmailListItem *) view->firstChild(); 588 item = (EmailListItem *) view->firstChild();
583 qDebug (QString("Write : ") ); 589 qDebug (QString("Write : ") );
584 QTextStream t(&f); 590 QTextStream t(&f);
585 while (item != NULL) { 591 while (item != NULL) {
586 mail = item->getMail(); 592 mail = item->getMail();
587 qDebug(mail->rawMail); 593 qDebug(mail->rawMail);
588 qDebug(mail->recipients.first()); 594 qDebug(mail->recipients.first());
589 t << mail->rawMail; 595 t << mail->rawMail;
590 596
591 mailconf->setGroup(mail->id); 597 mailconf->setGroup(mail->id);
592 mailconf->writeEntry("mailread", mail->read); 598 mailconf->writeEntry("mailread", mail->read);
593 599
594 item = (EmailListItem *) item->nextSibling(); 600 item = (EmailListItem *) item->nextSibling();
595 } 601 }
596 f.close(); 602 f.close();
597} 603}
598 604
599//paths for mailit, is settings, inbox, enclosures 605//paths for mailit, is settings, inbox, enclosures
600QString EmailClient::getPath(bool enclosurePath) 606QString EmailClient::getPath(bool enclosurePath)
601{ 607{
602 QString basePath = "qtmail"; 608 QString basePath = "qtmail";
603 QString enclosures = "enclosures"; 609 QString enclosures = "enclosures";
604 610
605 QDir dir = (QString(getenv("HOME")) + "/Applications/" + basePath); 611 QDir dir = (QString(getenv("HOME")) + "/Applications/" + basePath);
606 if ( !dir.exists() ) 612 if ( !dir.exists() )
607 dir.mkdir( dir.path() ); 613 dir.mkdir( dir.path() );
608 614
609 if (enclosurePath) { 615 if (enclosurePath) {
610 dir = (QString(getenv("HOME")) + "/Applications/" + basePath + "/" + enclosures); 616 dir = (QString(getenv("HOME")) + "/Applications/" + basePath + "/" + enclosures);
611 617
612 if ( !dir.exists() ) 618 if ( !dir.exists() )
613 dir.mkdir( dir.path() ); 619 dir.mkdir( dir.path() );
614 620
615 return (dir.path() + "/"); 621 return (dir.path() + "/");
616 622
617 } 623 }
618 return (dir.path() + "/"); 624 return (dir.path() + "/");
619} 625}
620 626
621void EmailClient::readSettings() 627void EmailClient::readSettings()
622{ 628{
623 TextParser *p; 629 TextParser *p;
624 QString s; 630 QString s;
625 int pos, accountPos, y; 631 int pos, accountPos, y;
626 QFile f( getPath(FALSE) + "settings.txt"); 632 QFile f( getPath(FALSE) + "settings.txt");
627 633
628 if ( f.open(IO_ReadOnly) ) { // file opened successfully 634 if ( f.open(IO_ReadOnly) ) { // file opened successfully
629 QTextStream t( &f ); // use a text stream 635 QTextStream t( &f ); // use a text stream
630 s = t.read(); 636 s = t.read();
631 f.close(); 637 f.close();
632 638
633 p = new TextParser(s, "\n"); 639 p = new TextParser(s, "\n");
634 640
635 accountPos = 0; 641 accountPos = 0;
636 while ( (accountPos = p->find("ACCOUNTSTART",';', accountPos, TRUE)) != -1 ) { 642 while ( (accountPos = p->find("ACCOUNTSTART",';', accountPos, TRUE)) != -1 ) {
637 accountPos++; 643 accountPos++;
638 if ( (pos = p->find("ACCOUNTNAME",':', accountPos, TRUE)) != -1 ) 644 if ( (pos = p->find("ACCOUNTNAME",':', accountPos, TRUE)) != -1 )
639 account.accountName = p->getString(& ++pos, 'z', TRUE); 645 account.accountName = p->getString(& ++pos, 'z', TRUE);
640 if ( (pos = p->find("NAME",':', accountPos, TRUE)) != -1) 646 if ( (pos = p->find("NAME",':', accountPos, TRUE)) != -1)
641 account.name = p->getString(& ++pos, 'z', TRUE); 647 account.name = p->getString(& ++pos, 'z', TRUE);
642 if ( (pos = p->find("EMAIL",':', accountPos, TRUE)) != -1) 648 if ( (pos = p->find("EMAIL",':', accountPos, TRUE)) != -1)
643 account.emailAddress = p->getString(& ++pos, 'z', TRUE); 649 account.emailAddress = p->getString(& ++pos, 'z', TRUE);
644 if ( (pos = p->find("POPUSER",':', accountPos, TRUE)) != -1) 650 if ( (pos = p->find("POPUSER",':', accountPos, TRUE)) != -1)
645 account.popUserName = p->getString(& ++pos, 'z', TRUE); 651 account.popUserName = p->getString(& ++pos, 'z', TRUE);
646 if ( (pos = p->find("POPPASSWORD",':', accountPos, TRUE)) != -1) 652 if ( (pos = p->find("POPPASSWORD",':', accountPos, TRUE)) != -1)
647 account.popPasswd = p->getString(& ++pos, 'z', TRUE); 653 account.popPasswd = p->getString(& ++pos, 'z', TRUE);
648 if ( (pos = p->find("POPSERVER",':', accountPos, TRUE)) != -1) 654 if ( (pos = p->find("POPSERVER",':', accountPos, TRUE)) != -1)
649 account.popServer = p->getString(& ++pos, 'z', TRUE); 655 account.popServer = p->getString(& ++pos, 'z', TRUE);
650 if ( (pos = p->find("SMTPSERVER",':', accountPos, TRUE)) != -1) 656 if ( (pos = p->find("SMTPSERVER",':', accountPos, TRUE)) != -1)
651 account.smtpServer = p->getString(& ++pos, 'z', TRUE); 657 account.smtpServer = p->getString(& ++pos, 'z', TRUE);
652 if ( (pos = p->find("ACCOUNTID",':', accountPos, TRUE)) != -1) { 658 if ( (pos = p->find("ACCOUNTID",':', accountPos, TRUE)) != -1) {
653 s = p->getString(& ++pos, 'z', TRUE); 659 s = p->getString(& ++pos, 'z', TRUE);
654 account.id = s.toInt(); 660 account.id = s.toInt();
655 } 661 }
656 662
657 account.lastServerMailCount = 0; 663 account.lastServerMailCount = 0;
658 account.synchronize = FALSE; 664 account.synchronize = FALSE;
659 if ( (pos = p->find("SYNCHRONIZE",':', accountPos, TRUE)) != -1) { 665 if ( (pos = p->find("SYNCHRONIZE",':', accountPos, TRUE)) != -1) {
660 if (p->getString(& ++pos, 'z', TRUE).upper() == "YES") { 666 if (p->getString(& ++pos, 'z', TRUE).upper() == "YES") {
661 account.synchronize = TRUE; 667 account.synchronize = TRUE;
662 if ( (pos = p->find("LASTSERVERMAILCOUNT",':', accountPos, TRUE)) != -1) { 668 if ( (pos = p->find("LASTSERVERMAILCOUNT",':', accountPos, TRUE)) != -1) {
663 s = p->getString(& ++pos, 'z', TRUE); 669 s = p->getString(& ++pos, 'z', TRUE);
664 account.lastServerMailCount = s.toInt(); 670 account.lastServerMailCount = s.toInt();
665 } 671 }
666 } 672 }
667 } 673 }
668 accountList.append(&account); 674 accountList.append(&account);
669 } 675 }
670 delete p; 676 delete p;
671 } 677 }
672 mailconf->setGroup("mailitglobal"); 678 mailconf->setGroup("mailitglobal");
673 if ( (y = mailconf->readNumEntry("mailidcount", -1)) != -1) { 679 if ( (y = mailconf->readNumEntry("mailidcount", -1)) != -1) {
674 mailIdCount = y; 680 mailIdCount = y;
675 } 681 }
676 if ( (y = mailconf->readNumEntry("accountidcount", -1)) != -1) { 682 if ( (y = mailconf->readNumEntry("accountidcount", -1)) != -1) {
677 accountIdCount = y; 683 accountIdCount = y;
678 } 684 }
679} 685}
680 686
681void EmailClient::saveSettings() 687void EmailClient::saveSettings()
682{ 688{
683 QString temp; 689 QString temp;
684 QFile f( getPath(FALSE) + "settings.txt"); 690 QFile f( getPath(FALSE) + "settings.txt");
685 MailAccount *accountPtr; 691 MailAccount *accountPtr;
686 692
687 if (! f.open(IO_WriteOnly) ) { 693 if (! f.open(IO_WriteOnly) ) {
688 qWarning("could not save settings file"); 694 qWarning("could not save settings file");
689 return; 695 return;
690 } 696 }
691 QTextStream t(&f); 697 QTextStream t(&f);
692 t << "#Settings for QPE Mailit program\n"; 698 t << "#Settings for QPE Mailit program\n";
693 699
694 for (accountPtr = accountList.first(); accountPtr != 0; 700 for (accountPtr = accountList.first(); accountPtr != 0;
695 accountPtr = accountList.next()) { 701 accountPtr = accountList.next()) {
696 702
697 t << "accountStart;\n"; 703 t << "accountStart;\n";
698 t << "AccountName: " + accountPtr->accountName + "\n"; 704 t << "AccountName: " + accountPtr->accountName + "\n";
699 t << "Name: " + accountPtr->name + "\n"; 705 t << "Name: " + accountPtr->name + "\n";
700 t << "Email: " + accountPtr->emailAddress + "\n"; 706 t << "Email: " + accountPtr->emailAddress + "\n";
701 t << "POPUser: " + accountPtr->popUserName + "\n"; 707 t << "POPUser: " + accountPtr->popUserName + "\n";
702 t << "POPPAssword: " + accountPtr->popPasswd + "\n"; 708 t << "POPPAssword: " + accountPtr->popPasswd + "\n";
703 t << "POPServer: " + accountPtr->popServer + "\n"; 709 t << "POPServer: " + accountPtr->popServer + "\n";
704 t << "SMTPServer: " + accountPtr->smtpServer + "\n"; 710 t << "SMTPServer: " + accountPtr->smtpServer + "\n";
705 t << "AccountId: " << accountPtr->id << "\n"; 711 t << "AccountId: " << accountPtr->id << "\n";
706 if (accountPtr->synchronize) { 712 if (accountPtr->synchronize) {
707 t << "Synchronize: Yes\n"; 713 t << "Synchronize: Yes\n";
708 t << "LastServerMailCount: "; 714 t << "LastServerMailCount: ";
709 t << accountPtr->lastServerMailCount << "\n"; 715 t << accountPtr->lastServerMailCount << "\n";
710 } else { 716 } else {
711 t << "Synchronize: No\n"; 717 t << "Synchronize: No\n";
712 } 718 }
713 t << "accountEnd;\n"; 719 t << "accountEnd;\n";
714 } 720 }
715 f.close(); 721 f.close();
716 722
717 mailconf->setGroup("mailitglobal"); 723 mailconf->setGroup("mailitglobal");
718 mailconf->writeEntry("mailidcount", mailIdCount); 724 mailconf->writeEntry("mailidcount", mailIdCount);
719 mailconf->writeEntry("accountidcount", accountIdCount); 725 mailconf->writeEntry("accountidcount", accountIdCount);
720} 726}
721 727
722void EmailClient::selectAccount(int id) 728void EmailClient::selectAccount(int id)
723{ 729{
724 if (accountList.count() > 0) { 730 if (accountList.count() > 0) {
725 currentAccount = accountList.at(id); 731 currentAccount = accountList.at(id);
726 emit newCaption("Mailit - " + currentAccount->accountName); 732 emit newCaption("Mailit - " + currentAccount->accountName);
727 getNewMail(); 733 getNewMail();
728 } else { 734 } else {
729 emit newCaption("Mailit ! No account defined"); 735 emit newCaption("Mailit ! No account defined");
730 } 736 }
731} 737}
732 738
733void EmailClient::editAccount(int id) 739void EmailClient::editAccount(int id)
734{ 740{
735 MailAccount *newAccount; 741 MailAccount *newAccount;
736 742
737 editAccountView = new EditAccount(this, "account", TRUE); 743 editAccountView = new EditAccount(this, "account", TRUE);
738 if (id == newAccountId) { //new account 744 if (id == newAccountId) { //new account
739 newAccount = new MailAccount; 745 newAccount = new MailAccount;
740 editAccountView->setAccount(newAccount); 746 editAccountView->setAccount(newAccount);
741 } else { 747 } else {
742 newAccount = accountList.at(id); 748 newAccount = accountList.at(id);
743 editAccountView->setAccount(newAccount, FALSE); 749 editAccountView->setAccount(newAccount, FALSE);
744 } 750 }
745 751
746 editAccountView->showMaximized(); 752 editAccountView->showMaximized();
747 editAccountView->exec(); 753 editAccountView->exec();
748 754
749 if (editAccountView->result() == QDialog::Accepted) { 755 if (editAccountView->result() == QDialog::Accepted) {
750 if (id == newAccountId) { 756 if (id == newAccountId) {
751 newAccount->id = accountIdCount; 757 newAccount->id = accountIdCount;
752 accountIdCount++; 758 accountIdCount++;
753 accountList.append(newAccount); 759 accountList.append(newAccount);
754 updateAccounts(); 760 updateAccounts();
755 } else { 761 } else {
756 updateAccounts(); 762 updateAccounts();
757 } 763 }
758 } 764 }
759 765
760 delete editAccountView; 766 delete editAccountView;
761} 767}
762 768
763void EmailClient::deleteAccount(int id) 769void EmailClient::deleteAccount(int id)
764{ 770{
765 MailAccount *newAccount; 771 MailAccount *newAccount;
766 QString message; 772 QString message;
767 773
768 newAccount = accountList.at(id); 774 newAccount = accountList.at(id);
769 message = "Delete account:\n" + newAccount->accountName; 775 message = "Delete account:\n" + newAccount->accountName;
770 switch( QMessageBox::warning( this, "Mailit", message, 776 switch( QMessageBox::warning( this, "Mailit", message,
771 "Yes", "No", 0, 0, 1 ) ) { 777 "Yes", "No", 0, 0, 1 ) ) {
772 778
773 case 0: accountList.remove(id); 779 case 0: accountList.remove(id);
774 updateAccounts(); 780 updateAccounts();
775 break; 781 break;
776 case 1: 782 case 1:
777 break; 783 break;
778 } 784 }
779} 785}
780 786
781void EmailClient::updateAccounts() 787void EmailClient::updateAccounts()
782{ 788{
783 MailAccount *accountPtr; 789 MailAccount *accountPtr;
784 790
785 //rebuild menus, clear all first 791 //rebuild menus, clear all first
786 editAccountMenu->clear(); 792 editAccountMenu->clear();
787 selectAccountMenu->clear(); 793 selectAccountMenu->clear();
788 deleteAccountMenu->clear(); 794 deleteAccountMenu->clear();
789 795
790 newAccountId = editAccountMenu->insertItem("New", this, 796 newAccountId = editAccountMenu->insertItem("New", this,
791 SLOT(editAccount(int)) ); 797 SLOT(editAccount(int)) );
792 editAccountMenu->insertSeparator(); 798 editAccountMenu->insertSeparator();
793 799
794 idCount = 0; 800 idCount = 0;
795 for (accountPtr = accountList.first(); accountPtr != 0; 801 for (accountPtr = accountList.first(); accountPtr != 0;
796 accountPtr = accountList.next()) { 802 accountPtr = accountList.next()) {
797 803
798 editAccountMenu->insertItem(accountPtr->accountName, 804 editAccountMenu->insertItem(accountPtr->accountName,
799 this, SLOT(editAccount(int)), 0, idCount); 805 this, SLOT(editAccount(int)), 0, idCount);
800 selectAccountMenu->insertItem(accountPtr->accountName, 806 selectAccountMenu->insertItem(accountPtr->accountName,
801 this, SLOT(selectAccount(int)), 0, idCount); 807 this, SLOT(selectAccount(int)), 0, idCount);
802 deleteAccountMenu->insertItem(accountPtr->accountName, 808 deleteAccountMenu->insertItem(accountPtr->accountName,
803 this, SLOT(deleteAccount(int)), 0, idCount); 809 this, SLOT(deleteAccount(int)), 0, idCount);
804 idCount++; 810 idCount++;
805 } 811 }
806} 812}
807 813
808void EmailClient::deleteMail(EmailListItem *mailItem, bool &inbox) 814void EmailClient::deleteMail(EmailListItem *mailItem, bool &inbox)
809{ 815{
810 Email *mPtr; 816 Email *mPtr;
811 Enclosure *ePtr; 817 Enclosure *ePtr;
812 818
813 if (inbox) { 819 if (inbox) {
814 mPtr = mailItem->getMail(); 820 mPtr = mailItem->getMail();
815 821
816 //if mail is in queue for download, remove it from 822 //if mail is in queue for download, remove it from
817 //queue if possible 823 //queue if possible
818 if ( (receiving) && (mPtr->fromAccountId == currentAccount->id) ) { 824 if ( (receiving) && (mPtr->fromAccountId == currentAccount->id) ) {
819 if ( !mPtr->downloaded ) 825 if ( !mPtr->downloaded )
820 mailDownloadList.remove(mPtr->serverId, mPtr->size); 826 mailDownloadList.remove(mPtr->serverId, mPtr->size);
821 } 827 }
822 828
823 mailconf->setGroup(mPtr->id); 829 mailconf->setGroup(mPtr->id);
824 mailconf->clearGroup(); 830 mailconf->clearGroup();
825 831
826 //delete any temporary attatchemnts storing 832 //delete any temporary attatchemnts storing
827 for ( ePtr=mPtr->files.first(); ePtr != 0; ePtr=mPtr->files.next() ) { 833 for ( ePtr=mPtr->files.first(); ePtr != 0; ePtr=mPtr->files.next() ) {
828 if (ePtr->saved) { 834 if (ePtr->saved) {
829 QFile::remove( (ePtr->path + ePtr->name) ); 835 QFile::remove( (ePtr->path + ePtr->name) );
830 } 836 }
831 } 837 }
832 inboxView->takeItem(mailItem); 838 inboxView->takeItem(mailItem);
833 } else { 839 } else {
834 outboxView->takeItem(mailItem); 840 outboxView->takeItem(mailItem);
835 } 841 }
836} 842}
837 843
838void EmailClient::setMailSize(int size) 844void EmailClient::setMailSize(int size)
839{ 845{
840 progressBar->reset(); 846 progressBar->reset();
841 progressBar->setTotalSteps(size); 847 progressBar->setTotalSteps(size);
842} 848}
843 849
844void EmailClient::setTotalSize(int size) 850void EmailClient::setTotalSize(int size)
845{ 851{
846 852
847} 853}
848 854
849void EmailClient::setDownloadedSize(int size) 855void EmailClient::setDownloadedSize(int size)
850{ 856{
851 int total = progressBar->totalSteps(); 857 int total = progressBar->totalSteps();
852 858
853 if (size < total) { 859 if (size < total) {
854 progressBar->setProgress(size); 860 progressBar->setProgress(size);
855 } else { 861 } else {
856 progressBar->setProgress(total); 862 progressBar->setProgress(total);
857 } 863 }
858} 864}
diff --git a/noncore/unsupported/mailit/emailhandler.cpp b/noncore/unsupported/mailit/emailhandler.cpp
index 2144899..1be16d4 100644
--- a/noncore/unsupported/mailit/emailhandler.cpp
+++ b/noncore/unsupported/mailit/emailhandler.cpp
@@ -1,589 +1,592 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qfileinfo.h> 20#include <qfileinfo.h>
21#include <stdlib.h> 21#include <stdlib.h>
22#include <qapplication.h> 22#include <qapplication.h>
23#include <qmessagebox.h> 23#include <qmessagebox.h>
24#include <qcstring.h> 24#include <qcstring.h>
25#include "emailhandler.h" 25#include "emailhandler.h"
26#include <qpe/applnk.h> 26#include <qpe/applnk.h>
27#include <qpe/filemanager.h> 27#include <qpe/filemanager.h>
28 28
29QCollection::Item EnclosureList::newItem(QCollection::Item d) 29QCollection::Item EnclosureList::newItem(QCollection::Item d)
30{ 30{
31 return dupl( (Enclosure *) d); 31 return dupl( (Enclosure *) d);
32} 32}
33 33
34Enclosure* EnclosureList::dupl(Enclosure *in) 34Enclosure* EnclosureList::dupl(Enclosure *in)
35{ 35{
36 ac = new Enclosure(*in); 36 ac = new Enclosure(*in);
37 return ac; 37 return ac;
38} 38}
39 39
40EmailHandler::EmailHandler() 40EmailHandler::EmailHandler()
41{ 41{
42 smtpClient = new SmtpClient(); 42 smtpClient = new SmtpClient();
43 popClient = new PopClient(); 43 popClient = new PopClient();
44 44
45 connect(smtpClient, SIGNAL(errorOccurred(int)), this, 45 connect(smtpClient, SIGNAL(errorOccurred(int)), this,
46 SIGNAL(smtpError(int)) ); 46 SIGNAL(smtpError(int)) );
47 connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); 47 connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) );
48 connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, 48 connect(smtpClient, SIGNAL(updateStatus(const QString &)), this,
49 SIGNAL(updateSmtpStatus(const QString &)) ); 49 SIGNAL(updateSmtpStatus(const QString &)) );
50 50
51 connect(popClient, SIGNAL(errorOccurred(int)), this, 51 connect(popClient, SIGNAL(errorOccurred(int)), this,
52 SIGNAL(popError(int)) ); 52 SIGNAL(popError(int)) );
53 connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), 53 connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)),
54 this, SLOT(messageArrived(const QString &, int, uint, bool)) ); 54 this, SLOT(messageArrived(const QString &, int, uint, bool)) );
55 connect(popClient, SIGNAL(updateStatus(const QString &)), this, 55 connect(popClient, SIGNAL(updateStatus(const QString &)), this,
56 SIGNAL(updatePopStatus(const QString &)) ); 56 SIGNAL(updatePopStatus(const QString &)) );
57 connect(popClient, SIGNAL(mailTransfered(int)), this, 57 connect(popClient, SIGNAL(mailTransfered(int)), this,
58 SIGNAL(mailTransfered(int)) ); 58 SIGNAL(mailTransfered(int)) );
59 59
60 60
61 //relaying size information 61 //relaying size information
62 connect(popClient, SIGNAL(currentMailSize(int)), 62 connect(popClient, SIGNAL(currentMailSize(int)),
63 this, SIGNAL(currentMailSize(int)) ); 63 this, SIGNAL(currentMailSize(int)) );
64 connect(popClient, SIGNAL(downloadedSize(int)), 64 connect(popClient, SIGNAL(downloadedSize(int)),
65 this, SIGNAL(downloadedSize(int)) ); 65 this, SIGNAL(downloadedSize(int)) );
66} 66}
67 67
68void EmailHandler::sendMail(QList<Email> *mailList) 68void EmailHandler::sendMail(QList<Email> *mailList)
69{ 69{
70 Email *currentMail; 70 Email *currentMail;
71 QString temp; 71 QString temp;
72 QString userName = mailAccount.name; 72 QString userName = mailAccount.name;
73 userName += " <" + mailAccount.emailAddress + ">"; 73 userName += " <" + mailAccount.emailAddress + ">";
74 74
75 for (currentMail = mailList->first(); currentMail != 0; 75 for (currentMail = mailList->first(); currentMail != 0;
76 currentMail = mailList->next()) { 76 currentMail = mailList->next()) {
77 77
78 if (encodeMime(currentMail) == 0) { 78 if (encodeMime(currentMail) == 0) {
79 smtpClient->addMail(userName, currentMail->subject, 79 smtpClient->addMail(userName, currentMail->subject,
80 currentMail->recipients, currentMail->rawMail); 80 currentMail->recipients, currentMail->rawMail);
81 } else { //error 81 } else { //error
82 temp = tr("Could not locate all files in \nmail with subject: ") + 82 temp = tr("Could not locate all files in \nmail with subject: ") +
83 currentMail->subject; 83 currentMail->subject;
84 temp += tr("\nMail has NOT been sent"); 84 temp += tr("\nMail has NOT been sent");
85 QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); 85 QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n"));
86 86
87 } 87 }
88 } 88 }
89 smtpClient->newConnection(mailAccount.smtpServer, 25); 89 smtpClient->newConnection(mailAccount.smtpServer, 25);
90} 90}
91 91
92void EmailHandler::setAccount(MailAccount account) 92void EmailHandler::setAccount(MailAccount account)
93{ 93{
94 mailAccount = account; 94 mailAccount = account;
95} 95}
96 96
97void EmailHandler::getMail() 97void EmailHandler::getMail()
98{ 98{
99 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); 99 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd);
100 if (mailAccount.synchronize) { 100 if (mailAccount.synchronize) {
101 popClient->setSynchronize(mailAccount.lastServerMailCount); 101 popClient->setSynchronize(mailAccount.lastServerMailCount);
102 } else { 102 } else {
103 popClient->removeSynchronize(); 103 popClient->removeSynchronize();
104 } 104 }
105 105
106 headers = FALSE; 106 headers = FALSE;
107 popClient->headersOnly(headers, 0); 107 popClient->headersOnly(headers, 0);
108 popClient->newConnection(mailAccount.popServer, 110); 108 popClient->newConnection(mailAccount.popServer, 110);
109} 109}
110 110
111void EmailHandler::getMailHeaders() 111void EmailHandler::getMailHeaders()
112{ 112{
113 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); 113 popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd);
114 if (mailAccount.synchronize) { 114 if (mailAccount.synchronize) {
115 popClient->setSynchronize(mailAccount.lastServerMailCount); 115 popClient->setSynchronize(mailAccount.lastServerMailCount);
116 } else { 116 } else {
117 popClient->removeSynchronize(); 117 popClient->removeSynchronize();
118 } 118 }
119 119
120 headers = TRUE; 120 headers = TRUE;
121 popClient->headersOnly(headers, 2000); //less than 2000, download all 121 popClient->headersOnly(headers, 2000); //less than 2000, download all
122 popClient->newConnection(mailAccount.popServer, 110); 122 popClient->newConnection(mailAccount.popServer, 110);
123} 123}
124 124
125void EmailHandler::getMailByList(MailList *mailList) 125void EmailHandler::getMailByList(MailList *mailList)
126{ 126{
127 if (mailList->count() == 0) { //should not occur though 127 if (mailList->count() == 0) { //should not occur though
128 emit mailTransfered(0); 128 emit mailTransfered(0);
129 return; 129 return;
130 } 130 }
131 131
132 headers = FALSE; 132 headers = FALSE;
133 popClient->headersOnly(FALSE, 0); 133 popClient->headersOnly(FALSE, 0);
134 popClient->newConnection(mailAccount.popServer, 110); 134 popClient->newConnection(mailAccount.popServer, 110);
135 popClient->setSelectedMails(mailList); 135 popClient->setSelectedMails(mailList);
136} 136}
137 137
138void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) 138void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete)
139{ 139{
140 Email mail; 140 Email mail;
141 141
142 mail.rawMail = message; 142 mail.rawMail = message;
143 mail.serverId = id; 143 mail.serverId = id;
144 mail.size = size; 144 mail.size = size;
145 mail.downloaded = complete; 145 mail.downloaded = complete;
146 146
147 emit mailArrived(mail, FALSE); 147 emit mailArrived(mail, FALSE);
148} 148}
149 149
150bool EmailHandler::parse(QString in, QString lineShift, Email *mail) 150bool EmailHandler::parse(QString in, QString lineShift, Email *mail)
151{ 151{
152 QString temp, boundary; 152 QString temp, boundary;
153 int pos; 153 int pos;
154 QString delimiter, header, body, mimeHeader, mimeBody; 154 QString delimiter, header, body, mimeHeader, mimeBody;
155 QString content, contentType, contentAttribute, id, encoding; 155 QString content, contentType, contentAttribute, id, encoding;
156 QString fileName, storedName; 156 QString fileName, storedName;
157 int enclosureId = 0; 157 int enclosureId = 0;
158 158
159 mail->rawMail = in; 159 mail->rawMail = in;
160 mail->received = TRUE; 160 mail->received = TRUE;
161 mail->files.setAutoDelete(TRUE); 161 mail->files.setAutoDelete(TRUE);
162 162
163 temp = lineShift + "." + lineShift; 163 temp = lineShift + "." + lineShift;
164 164
165 if (in.right(temp.length()) != temp) { 165 if (in.right(temp.length()) != temp) {
166 qWarning(in.right(temp.length())); 166 qWarning(in.right(temp.length()));
167 qWarning(" . added at end of email as separator"); 167 qWarning(" . added at end of email as separator");
168 mail->rawMail += temp; 168 mail->rawMail += temp;
169 } 169 }
170 170
171 171
172 delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" 172 delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n"
173 pos = in.find(delimiter, 0, FALSE); 173 pos = in.find(delimiter, 0, FALSE);
174 header = in.left(pos); 174 header = in.left(pos);
175 body = in.right(in.length() - pos - delimiter.length()); 175 body = in.right(in.length() - pos - delimiter.length());
176 if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) 176 if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n'))
177 body.truncate(body.length()-2); 177 body.truncate(body.length()-2);
178 178
179 TextParser p(header, lineShift); 179 TextParser p(header, lineShift);
180 180
181 if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { 181 if ((pos = p.find("FROM",':', 0, TRUE)) != -1) {
182 pos++; 182 pos++;
183 if (p.separatorAt(pos) == ' ') { 183 if (p.separatorAt(pos) == ' ') {
184 mail->from = p.getString(&pos, '<', false); 184 mail->from = p.getString(&pos, '<', false);
185 mail->from = mail->from.stripWhiteSpace(); 185 mail->from = mail->from.stripWhiteSpace();
186 if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { 186 if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) {
187 mail->from = mail->from.left(mail->from.length() - 1); 187 mail->from = mail->from.left(mail->from.length() - 1);
188 mail->from = mail->from.right(mail->from.length() - 1); 188 mail->from = mail->from.right(mail->from.length() - 1);
189 } 189 }
190 pos++; 190 pos++;
191 mail->fromMail = p.getString(&pos, '>', false); 191 mail->fromMail = p.getString(&pos, '>', false);
192 } else { 192 } else {
193 if ((p.separatorAt(pos) == '<') 193 if ((p.separatorAt(pos) == '<')
194 || (p.separatorAt(pos) == ' ')) //No name.. nasty 194 || (p.separatorAt(pos) == ' ')) //No name.. nasty
195 pos++; 195 pos++;
196 pos++; 196 pos++;
197 mail->fromMail = p.getString(&pos, 'z', TRUE); 197 mail->fromMail = p.getString(&pos, 'z', TRUE);
198 if (mail->fromMail.at(mail->fromMail.length()-1) == '>') 198 if (mail->fromMail.at(mail->fromMail.length()-1) == '>')
199 mail->fromMail.truncate(mail->fromMail.length() - 1); 199 mail->fromMail.truncate(mail->fromMail.length() - 1);
200 mail->from=mail->fromMail; 200 mail->from=mail->fromMail;
201 } 201 }
202 } 202 }
203 if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { 203 if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) {
204 pos++; 204 pos++;
205 mail->subject = p.getString(&pos, 'z', TRUE); 205 mail->subject = p.getString(&pos, 'z', TRUE);
206 } 206 }
207 if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { 207 if ((pos = p.find("DATE",':', 0, TRUE)) != -1) {
208 pos++; 208 pos++;
209 mail->date = p.getString(&pos, 'z', true); 209 mail->date = p.getString(&pos, 'z', true);
210 } 210 }
211 if ((pos = p.find("TO",':', 0, TRUE)) != -1) { 211 if ((pos = p.find("TO",':', 0, TRUE)) != -1) {
212 pos++; 212 pos++;
213 mail->recipients.append (p.getString(&pos, 'z', TRUE) ); 213 mail->recipients.append (p.getString(&pos, 'z', TRUE) );
214 } 214 }
215 if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { 215 if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) {
216 pos++; 216 pos++;
217 if ( (p.wordAt(pos).upper() == "ID") && 217 if ( (p.wordAt(pos).upper() == "ID") &&
218 (p.separatorAt(pos) == ':') ) { 218 (p.separatorAt(pos) == ':') ) {
219 219
220 id = p.getString(&pos, 'z', TRUE); 220 id = p.getString(&pos, 'z', TRUE);
221 mail->id = id; 221 mail->id = id;
222 } 222 }
223 } 223 }
224 224
225 pos = 0; 225 pos = 0;
226 while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { 226 while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) {
227 pos++; 227 pos++;
228 if ( (p.wordAt(pos).upper() == "VERSION") && 228 if ( (p.wordAt(pos).upper() == "VERSION") &&
229 (p.separatorAt(pos) == ':') ) { 229 (p.separatorAt(pos) == ':') ) {
230 pos++; 230 pos++;
231 if (p.getString(&pos, 'z', true) == "1.0") { 231 if (p.getString(&pos, 'z', true) == "1.0") {
232 mail->mimeType = 1; 232 mail->mimeType = 1;
233 } 233 }
234 } 234 }
235 } 235 }
236 236
237 if (mail->mimeType == 1) { 237 if (mail->mimeType == 1) {
238 boundary = ""; 238 boundary = "";
239 if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { 239 if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) {
240 pos++; 240 pos++;
241 boundary = p.getString(&pos, 'z', true); 241 boundary = p.getString(&pos, 'z', true);
242 if (boundary[0] == '"') { 242 if (boundary[0] == '"') {
243 boundary = boundary.left(boundary.length() - 1); //strip " 243 boundary = boundary.left(boundary.length() - 1); //strip "
244 boundary = boundary.right(boundary.length() - 1); //strip " 244 boundary = boundary.right(boundary.length() - 1); //strip "
245 } 245 }
246 boundary = "--" + boundary; //create boundary field 246 boundary = "--" + boundary; //create boundary field
247 } 247 }
248 248
249 if (boundary == "") { //fooled by Mime-Version 249 if (boundary == "") { //fooled by Mime-Version
250 mail->body = body; 250 mail->body = body;
251 mail->bodyPlain = body; 251 mail->bodyPlain = body;
252 return mail; 252 return mail;
253 } 253 }
254 254
255 while (body.length() > 0) { 255 while (body.length() > 0) {
256 pos = body.find(boundary, 0, FALSE); 256 pos = body.find(boundary, 0, FALSE);
257 pos = body.find(delimiter, pos, FALSE); 257 pos = body.find(delimiter, pos, FALSE);
258 mimeHeader = body.left(pos); 258 mimeHeader = body.left(pos);
259 mimeBody = body.right(body.length() - pos - delimiter.length()); 259 mimeBody = body.right(body.length() - pos - delimiter.length());
260 TextParser bp(mimeHeader, lineShift); 260 TextParser bp(mimeHeader, lineShift);
261 261
262 contentType = ""; 262 contentType = "";
263 contentAttribute = ""; 263 contentAttribute = "";
264 fileName = ""; 264 fileName = "";
265 if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { 265 if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) {
266 pos++; 266 pos++;
267 if ( (bp.wordAt(pos).upper() == "TYPE") && 267 if ( (bp.wordAt(pos).upper() == "TYPE") &&
268 (bp.separatorAt(pos) == ':') ) { 268 (bp.separatorAt(pos) == ':') ) {
269 contentType = bp.nextWord().upper(); 269 contentType = bp.nextWord().upper();
270 if (bp.nextSeparator() == '/') 270 if (bp.nextSeparator() == '/')
271 contentAttribute = bp.nextWord().upper(); 271 contentAttribute = bp.nextWord().upper();
272 content = contentType + "/" + contentAttribute; 272 content = contentType + "/" + contentAttribute;
273 } 273 }
274 if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { 274 if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) {
275 pos++; 275 pos++;
276 encoding = bp.getString(&pos, 'z', TRUE); 276 encoding = bp.getString(&pos, 'z', TRUE);
277 } 277 }
278 278
279 if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { 279 if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) {
280 pos++; 280 pos++;
281 fileName = bp.getString(&pos, 'z', TRUE); 281 fileName = bp.getString(&pos, 'z', TRUE);
282 fileName = fileName.right(fileName.length() - 1); 282 fileName = fileName.right(fileName.length() - 1);
283 fileName = fileName.left(fileName.length() - 1); 283 fileName = fileName.left(fileName.length() - 1);
284 } 284 }
285 285
286 } 286 }
287 pos = mimeBody.find(boundary, 0, FALSE); 287 pos = mimeBody.find(boundary, 0, FALSE);
288 if (pos == -1) //should not occur, malformed mail 288 if (pos == -1) //should not occur, malformed mail
289 pos = mimeBody.length(); 289 pos = mimeBody.length();
290 body = mimeBody.right(mimeBody.length() - pos); 290 body = mimeBody.right(mimeBody.length() - pos);
291 mimeBody = mimeBody.left(pos); 291 mimeBody = mimeBody.left(pos);
292 292
293 if (fileName != "") { //attatchments of some type, audio, image etc. 293 if (fileName != "") { //attatchments of some type, audio, image etc.
294 294
295 Enclosure e; 295 Enclosure e;
296 e.id = enclosureId; 296 e.id = enclosureId;
297 e.originalName = fileName; 297 e.originalName = fileName;
298 e.contentType = contentType; 298 e.contentType = contentType;
299 e.contentAttribute = contentAttribute; 299 e.contentAttribute = contentAttribute;
300 e.encoding = encoding; 300 e.encoding = encoding;
301 e.body = mimeBody; 301 e.body = mimeBody;
302 e.saved = FALSE; 302 e.saved = FALSE;
303 mail->addEnclosure(&e); 303 mail->addEnclosure(&e);
304 enclosureId++; 304 enclosureId++;
305 305
306 } else if (contentType == "TEXT") { 306 } else if (contentType == "TEXT") {
307 if (contentAttribute == "PLAIN") { 307 if (contentAttribute == "PLAIN") {
308 mail->body = mimeBody; 308 mail->body = mimeBody;
309 mail->bodyPlain = mimeBody; 309 mail->bodyPlain = mimeBody;
310 } 310 }
311 if (contentAttribute == "HTML") { 311 if (contentAttribute == "HTML") {
312 mail->body = mimeBody; 312 mail->body = mimeBody;
313 } 313 }
314 } 314 }
315 } 315 }
316 } else { 316 } else {
317 mail->bodyPlain = body; 317 mail->bodyPlain = body;
318 mail->body = body; 318 mail->body = body;
319 } 319 }
320 return TRUE; 320 return TRUE;
321} 321}
322 322
323bool EmailHandler::getEnclosure(Enclosure *ePtr) 323bool EmailHandler::getEnclosure(Enclosure *ePtr)
324{ 324{
325 QFile f(ePtr->path + ePtr->name); 325 QFile f(ePtr->path + ePtr->name);
326 char src[4]; 326 char src[4];
327 char *destPtr; 327 char *destPtr;
328 QByteArray buffer; 328 QByteArray buffer;
329 uint bufCount, pos, decodedCount, size, x; 329 uint bufCount, pos, decodedCount, size, x;
330 330
331 if (! f.open(IO_WriteOnly) ) { 331 if (! f.open(IO_WriteOnly) ) {
332 qWarning("could not save: " + ePtr->path + ePtr->name); 332 qWarning("could not save: " + ePtr->path + ePtr->name);
333 return FALSE; 333 return FALSE;
334 } 334 }
335 335
336 if (ePtr->encoding.upper() == "BASE64") { 336 if (ePtr->encoding.upper() == "BASE64") {
337 size = (ePtr->body.length() * 3 / 4); //approximate size (always above) 337 size = (ePtr->body.length() * 3 / 4); //approximate size (always above)
338 buffer.resize(size); 338 buffer.resize(size);
339 bufCount = 0; 339 bufCount = 0;
340 pos = 0; 340 pos = 0;
341 destPtr = buffer.data(); 341 destPtr = buffer.data();
342 342
343 while (pos < ePtr->body.length()) { 343 while (pos < ePtr->body.length()) {
344 decodedCount = 4; 344 decodedCount = 4;
345 x = 0; 345 x = 0;
346 while ( (x < 4) && (pos < ePtr->body.length()) ) { 346 while ( (x < 4) && (pos < ePtr->body.length()) ) {
347 src[x] = ePtr->body[pos].latin1(); 347 src[x] = ePtr->body[pos].latin1();
348 pos++; 348 pos++;
349 if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') 349 if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ')
350 x--; 350 x--;
351 x++; 351 x++;
352 } 352 }
353 if (x > 1) { 353 if (x > 1) {
354 decodedCount = parse64base(src, destPtr); 354 decodedCount = parse64base(src, destPtr);
355 destPtr += decodedCount; 355 destPtr += decodedCount;
356 bufCount += decodedCount; 356 bufCount += decodedCount;
357 } 357 }
358 } 358 }
359 359
360 buffer.resize(bufCount); //set correct length of file 360 buffer.resize(bufCount); //set correct length of file
361 f.writeBlock(buffer); 361 f.writeBlock(buffer);
362 } else { 362 } else {
363 QTextStream t(&f); 363 QTextStream t(&f);
364 t << ePtr->body; 364 t << ePtr->body;
365 } 365 }
366 return TRUE; 366 return TRUE;
367} 367}
368 368
369int EmailHandler::parse64base(char *src, char *bufOut) { 369int EmailHandler::parse64base(char *src, char *bufOut) {
370 370
371 char c, z; 371 char c, z;
372 char li[4]; 372 char li[4];
373 int processed; 373 int processed;
374 374
375 //conversion table withouth table... 375 //conversion table withouth table...
376 for (int x = 0; x < 4; x++) { 376 for (int x = 0; x < 4; x++) {
377 c = src[x]; 377 c = src[x];
378 378
379 if ( (int) c >= 'A' && (int) c <= 'Z') 379 if ( (int) c >= 'A' && (int) c <= 'Z')
380 li[x] = (int) c - (int) 'A'; 380 li[x] = (int) c - (int) 'A';
381 if ( (int) c >= 'a' && (int) c <= 'z') 381 if ( (int) c >= 'a' && (int) c <= 'z')
382 li[x] = (int) c - (int) 'a' + 26; 382 li[x] = (int) c - (int) 'a' + 26;
383 if ( (int) c >= '0' && (int) c <= '9') 383 if ( (int) c >= '0' && (int) c <= '9')
384 li[x] = (int) c - (int) '0' + 52; 384 li[x] = (int) c - (int) '0' + 52;
385 if (c == '+') 385 if (c == '+')
386 li[x] = 62; 386 li[x] = 62;
387 if (c == '/') 387 if (c == '/')
388 li[x] = 63; 388 li[x] = 63;
389 } 389 }
390 390
391 processed = 1; 391 processed = 1;
392 bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits 392 bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits
393 bufOut[0] <<= 2; 393 bufOut[0] <<= 2;
394 z = li[1] >> 4; 394 z = li[1] >> 4;
395 bufOut[0] = bufOut[0] | z; //first byte retrived 395 bufOut[0] = bufOut[0] | z; //first byte retrived
396 396
397 if (src[2] != '=') { 397 if (src[2] != '=') {
398 bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits 398 bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits
399 bufOut[1] <<= 4; 399 bufOut[1] <<= 4;
400 z = li[2] >> 2; 400 z = li[2] >> 2;
401 bufOut[1] = bufOut[1] | z; //second byte retrived 401 bufOut[1] = bufOut[1] | z; //second byte retrived
402 processed++; 402 processed++;
403 403
404 if (src[3] != '=') { 404 if (src[3] != '=') {
405 bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits 405 bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits
406 bufOut[2] <<= 6; 406 bufOut[2] <<= 6;
407 z = li[3]; 407 z = li[3];
408 bufOut[2] = bufOut[2] | z; //third byte retrieved 408 bufOut[2] = bufOut[2] | z; //third byte retrieved
409 processed++; 409 processed++;
410 } 410 }
411 } 411 }
412 return processed; 412 return processed;
413} 413}
414 414
415int EmailHandler::encodeMime(Email *mail) { 415int EmailHandler::encodeMime(Email *mail)
416{
417
416 QString fileName, fileType, contentType, newBody, boundary; 418 QString fileName, fileType, contentType, newBody, boundary;
417 Enclosure *ePtr; 419 Enclosure *ePtr;
418 420
419 QString userName = mailAccount.name; 421 QString userName = mailAccount.name;
420 userName += " <" + mailAccount.emailAddress + ">"; 422 if (userName.length()>0)//only embrace it if there is a user name
423 userName += " <" + mailAccount.emailAddress + ">";
421 424
422 //add standard headers 425 //add standard headers
423 newBody = "From: " + userName + "\r\nTo: "; 426 newBody = "From: " + userName + "\r\nTo: ";
424 for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { 427 for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) {
425 newBody += *it + " "; 428 newBody += *it + " ";
426 } 429 }
427 newBody += "\r\nSubject: " + mail->subject + "\r\n"; 430 newBody += "\r\nSubject: " + mail->subject + "\r\n";
428 431
429 if (mail->files.count() == 0) { //just a simple mail 432 if (mail->files.count() == 0) { //just a simple mail
430 newBody += "\r\n" + mail->body; 433 newBody += "\r\n" + mail->body;
431 mail->rawMail = newBody; 434 mail->rawMail = newBody;
432 return 0; 435 return 0;
433 } 436 }
434 437
435 //Build mime encoded mail 438 //Build mime encoded mail
436 boundary = "-----4345=next_bound=0495----"; 439 boundary = "-----4345=next_bound=0495----";
437 440
438 newBody += "Mime-Version: 1.0\r\n"; 441 newBody += "Mime-Version: 1.0\r\n";
439 newBody += "Content-Type: multipart/mixed; boundary=\"" + 442 newBody += "Content-Type: multipart/mixed; boundary=\"" +
440 boundary + "\"\r\n\r\n"; 443 boundary + "\"\r\n\r\n";
441 444
442 newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; 445 newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n";
443 newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; 446 newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n";
444 newBody += mail->body; 447 newBody += mail->body;
445 448
446 for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { 449 for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) {
447 fileName = ePtr->originalName; 450 fileName = ePtr->originalName;
448 fileType = ePtr->contentType; 451 fileType = ePtr->contentType;
449 QFileInfo fi(fileName); 452 QFileInfo fi(fileName);
450 453
451 // This specification of contentType is temporary 454 // This specification of contentType is temporary
452 contentType = ""; 455 contentType = "";
453 if (fileType == "Picture") { 456 if (fileType == "Picture") {
454 contentType = "image/x-image"; 457 contentType = "image/x-image";
455 } else if (fileType == "Document") { 458 } else if (fileType == "Document") {
456 contentType = "text/plain"; 459 contentType = "text/plain";
457 } else if (fileType == "Sound") { 460 } else if (fileType == "Sound") {
458 contentType = "audio/x-wav"; 461 contentType = "audio/x-wav";
459 } else if (fileType == "Movie") { 462 } else if (fileType == "Movie") {
460 contentType = "video/mpeg"; 463 contentType = "video/mpeg";
461 } else { 464 } else {
462 contentType = "application/octet-stream"; 465 contentType = "application/octet-stream";
463 } 466 }
464 467
465 newBody += "\r\n\r\n--" + boundary + "\r\n"; 468 newBody += "\r\n\r\n--" + boundary + "\r\n";
466 newBody += "Content-Type: " + contentType + "; name=\"" + 469 newBody += "Content-Type: " + contentType + "; name=\"" +
467 fi.fileName() + "\"\r\n"; 470 fi.fileName() + "\"\r\n";
468 newBody += "Content-Transfer-Encoding: base64\r\n"; 471 newBody += "Content-Transfer-Encoding: base64\r\n";
469 newBody += "Content-Disposition: inline; filename=\"" + 472 newBody += "Content-Disposition: inline; filename=\"" +
470 fi.fileName() + "\"\r\n\r\n"; 473 fi.fileName() + "\"\r\n\r\n";
471 474
472 if (encodeFile(fileName, &newBody) == -1) //file not found? 475 if (encodeFile(fileName, &newBody) == -1) //file not found?
473 return -1; 476 return -1;
474 } 477 }
475 478
476 newBody += "\r\n\r\n--" + boundary + "--"; 479 newBody += "\r\n\r\n--" + boundary + "--";
477 mail->rawMail = newBody; 480 mail->rawMail = newBody;
478 481
479 return 0; 482 return 0;
480} 483}
481 484
482int EmailHandler::encodeFile(QString fileName, QString *toBody) 485int EmailHandler::encodeFile(QString fileName, QString *toBody)
483{ 486{
484 char *fileData; 487 char *fileData;
485 char *dataPtr; 488 char *dataPtr;
486 QString temp; 489 QString temp;
487 uint dataSize, count; 490 uint dataSize, count;
488 QFile f(fileName); 491 QFile f(fileName);
489 492
490 if (! f.open(IO_ReadOnly) ) { 493 if (! f.open(IO_ReadOnly) ) {
491 qWarning("could not open file: " + fileName); 494 qWarning("could not open file: " + fileName);
492 return -1; 495 return -1;
493 } 496 }
494 QTextStream s(&f); 497 QTextStream s(&f);
495 dataSize = f.size(); 498 dataSize = f.size();
496 fileData = (char *) malloc(dataSize + 3); 499 fileData = (char *) malloc(dataSize + 3);
497 s.readRawBytes(fileData, dataSize); 500 s.readRawBytes(fileData, dataSize);
498 501
499 temp = ""; 502 temp = "";
500 dataPtr = fileData; 503 dataPtr = fileData;
501 count = 0; 504 count = 0;
502 while (dataSize > 0) { 505 while (dataSize > 0) {
503 if (dataSize < 3) { 506 if (dataSize < 3) {
504 encode64base(dataPtr, &temp, dataSize); 507 encode64base(dataPtr, &temp, dataSize);
505 dataSize = 0; 508 dataSize = 0;
506 } else { 509 } else {
507 encode64base(dataPtr, &temp, 3); 510 encode64base(dataPtr, &temp, 3);
508 dataSize -= 3; 511 dataSize -= 3;
509 dataPtr += 3; 512 dataPtr += 3;
510 count += 4; 513 count += 4;
511 } 514 }
512 if (count > 72) { 515 if (count > 72) {
513 count = 0; 516 count = 0;
514 temp += "\r\n"; 517 temp += "\r\n";
515 } 518 }
516 } 519 }
517 toBody->append(temp); 520 toBody->append(temp);
518 521
519 delete(fileData); 522 delete(fileData);
520 f.close(); 523 f.close();
521 return 0; 524 return 0;
522} 525}
523 526
524void EmailHandler::encode64base(char *src, QString *dest, int len) 527void EmailHandler::encode64base(char *src, QString *dest, int len)
525{ 528{
526 QString temp; 529 QString temp;
527 uchar c; 530 uchar c;
528 uchar bufOut[4]; 531 uchar bufOut[4];
529 532
530 bufOut[0] = src[0]; 533 bufOut[0] = src[0];
531 bufOut[0] >>= 2; //Done byte 0 534 bufOut[0] >>= 2; //Done byte 0
532 535
533 bufOut[1] = src[0]; 536 bufOut[1] = src[0];
534 bufOut[1] = bufOut[1] & (1 + 2); //mask out top 6 bits 537 bufOut[1] = bufOut[1] & (1 + 2); //mask out top 6 bits
535 bufOut[1] <<= 4; //copy up 4 places 538 bufOut[1] <<= 4; //copy up 4 places
536 if (len > 1) { 539 if (len > 1) {
537 c = src[1]; 540 c = src[1];
538 } else { 541 } else {
539 c = 0; 542 c = 0;
540 } 543 }
541 544
542 c = c & (16 + 32 + 64 + 128); 545 c = c & (16 + 32 + 64 + 128);
543 c >>= 4; 546 c >>= 4;
544 bufOut[1] = bufOut[1] | c; //Done byte 1 547 bufOut[1] = bufOut[1] | c; //Done byte 1
545 548
546 bufOut[2] = src[1]; 549 bufOut[2] = src[1];
547 bufOut[2] = bufOut[2] & (1 + 2 + 4 + 8); 550 bufOut[2] = bufOut[2] & (1 + 2 + 4 + 8);
548 bufOut[2] <<= 2; 551 bufOut[2] <<= 2;
549 if (len > 2) { 552 if (len > 2) {
550 c = src[2]; 553 c = src[2];
551 } else { 554 } else {
552 c = 0; 555 c = 0;
553 } 556 }
554 c >>= 6; 557 c >>= 6;
555 bufOut[2] = bufOut[2] | c; 558 bufOut[2] = bufOut[2] | c;
556 559
557 bufOut[3] = src[2]; 560 bufOut[3] = src[2];
558 bufOut[3] = bufOut[3] & (1 + 2 + 4 + 8 + 16 + 32); 561 bufOut[3] = bufOut[3] & (1 + 2 + 4 + 8 + 16 + 32);
559 562
560 if (len == 1) { 563 if (len == 1) {
561 bufOut[2] = 64; 564 bufOut[2] = 64;
562 bufOut[3] = 64; 565 bufOut[3] = 64;
563 } 566 }
564 if (len == 2) { 567 if (len == 2) {
565 bufOut[3] = 64; 568 bufOut[3] = 64;
566 } 569 }
567 for (int x = 0; x < 4; x++) { 570 for (int x = 0; x < 4; x++) {
568 if (bufOut[x] <= 25) 571 if (bufOut[x] <= 25)
569 bufOut[x] += (uint) 'A'; 572 bufOut[x] += (uint) 'A';
570 else if (bufOut[x] >= 26 && bufOut[x] <= 51) 573 else if (bufOut[x] >= 26 && bufOut[x] <= 51)
571 bufOut[x] += (uint) 'a' - 26; 574 bufOut[x] += (uint) 'a' - 26;
572 else if (bufOut[x] >= 52 && bufOut[x] <= 61) 575 else if (bufOut[x] >= 52 && bufOut[x] <= 61)
573 bufOut[x] += (uint) '0' - 52; 576 bufOut[x] += (uint) '0' - 52;
574 else if (bufOut[x] == 62) 577 else if (bufOut[x] == 62)
575 bufOut[x] = '+'; 578 bufOut[x] = '+';
576 else if (bufOut[x] == 63) 579 else if (bufOut[x] == 63)
577 bufOut[x] = '/'; 580 bufOut[x] = '/';
578 else if (bufOut[x] == 64) 581 else if (bufOut[x] == 64)
579 bufOut[x] = '='; 582 bufOut[x] = '=';
580 583
581 dest->append(bufOut[x]); 584 dest->append(bufOut[x]);
582 } 585 }
583} 586}
584 587
585void EmailHandler::cancel() 588void EmailHandler::cancel()
586{ 589{
587 popClient->errorHandling(ErrCancel); 590 popClient->errorHandling(ErrCancel);
588 smtpClient->errorHandling(ErrCancel); 591 smtpClient->errorHandling(ErrCancel);
589} 592}
diff --git a/noncore/unsupported/mailit/writemail.cpp b/noncore/unsupported/mailit/writemail.cpp
index 1a7185e..70332a9 100644
--- a/noncore/unsupported/mailit/writemail.cpp
+++ b/noncore/unsupported/mailit/writemail.cpp
@@ -1,299 +1,297 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2001 Trolltech AS. All rights reserved. 2** Copyright (C) 2001 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21#include "writemail.h" 21#include "writemail.h"
22#include "resource.h" 22#include "resource.h"
23 23
24WriteMail::WriteMail( QWidget* parent, const char* name, WFlags fl ) 24WriteMail::WriteMail( QWidget* parent, const char* name, WFlags fl )
25 : QMainWindow( parent, name, fl ) 25 : QMainWindow( parent, name, fl )
26{ 26{
27 showingAddressList = FALSE; 27 showingAddressList = FALSE;
28 init(); 28 init();
29 29
30 addAtt = new AddAtt(0, "Add Attatchments"); 30 addAtt = new AddAtt(0, "Add Attatchments");
31} 31}
32 32
33WriteMail::~WriteMail() 33WriteMail::~WriteMail()
34{ 34{
35 delete addAtt; 35 delete addAtt;
36} 36}
37 37
38void WriteMail::setAddressList(AddressList *list) 38void WriteMail::setAddressList(AddressList *list)
39{ 39{
40 Contact *cPtr; 40 Contact *cPtr;
41 41
42 addressList = list; 42 addressList = list;
43 43
44 addressView->clear(); 44 addressView->clear();
45 QList<Contact> *cListPtr = addressList->getContactList(); 45 QList<Contact> *cListPtr = addressList->getContactList();
46 QListViewItem *item; 46 QListViewItem *item;
47 for (cPtr = cListPtr->first(); cPtr != 0; cPtr = cListPtr->next() ) { 47 for (cPtr = cListPtr->first(); cPtr != 0; cPtr = cListPtr->next() ) {
48 item = new QListViewItem(addressView, cPtr->email, cPtr->name); 48 item = new QListViewItem(addressView, cPtr->email, cPtr->name);
49 } 49 }
50} 50}
51 51
52void WriteMail::init() 52void WriteMail::init()
53{ 53{
54 setToolBarsMovable(FALSE); 54 setToolBarsMovable(FALSE);
55 55
56 bar = new QToolBar(this); 56 bar = new QToolBar(this);
57 bar->setHorizontalStretchable( TRUE ); 57 bar->setHorizontalStretchable( TRUE );
58 58
59 menu = new QMenuBar( bar ); 59 menu = new QMenuBar( bar );
60 60
61 mailMenu = new QPopupMenu(menu); 61 mailMenu = new QPopupMenu(menu);
62 menu->insertItem( tr( "&Mail" ), mailMenu); 62 menu->insertItem( tr( "&Mail" ), mailMenu);
63 addMenu = new QPopupMenu(menu); 63 addMenu = new QPopupMenu(menu);
64 menu->insertItem( tr( "&Add" ), addMenu); 64 menu->insertItem( tr( "&Add" ), addMenu);
65 65
66 bar = new QToolBar(this); 66 bar = new QToolBar(this);
67 attatchButton = new QAction(tr("Attatchment"), Resource::loadPixmap("fileopen"), QString::null, 0, this, 0); 67 attatchButton = new QAction(tr("Attatchment"), Resource::loadPixmap("mailit/attach"), QString::null, 0, this, 0);
68 attatchButton->addTo(bar); 68 attatchButton->addTo(bar);
69 attatchButton->addTo(addMenu); 69 attatchButton->addTo(addMenu);
70 connect( attatchButton, SIGNAL( activated() ), this, SLOT( attatchFile() ) ); 70 connect( attatchButton, SIGNAL( activated() ), this, SLOT( attatchFile() ) );
71 71
72 confirmButton = new QAction(tr("Enque mail"), Resource::loadPixmap("OKButton"), QString::null, 0, this, 0); 72 confirmButton = new QAction(tr("Enque mail"), Resource::loadPixmap("OKButton"), QString::null, 0, this, 0);
73 confirmButton->addTo(bar); 73 confirmButton->addTo(bar);
74 confirmButton->addTo(mailMenu); 74 confirmButton->addTo(mailMenu);
75 connect( confirmButton, SIGNAL( activated() ), this, SLOT( accept() ) ); 75 connect( confirmButton, SIGNAL( activated() ), this, SLOT( accept() ) );
76 76
77 newButton = new QAction(tr("New mail"), Resource::loadPixmap("new"), QString::null, 0, this, 0); 77 newButton = new QAction(tr("New mail"), Resource::loadPixmap("new"), QString::null, 0, this, 0);
78 newButton->addTo(mailMenu); 78 newButton->addTo(mailMenu);
79 connect( newButton, SIGNAL( activated() ), this, SLOT( newMail() ) ); 79 connect( newButton, SIGNAL( activated() ), this, SLOT( newMail() ) );
80 80
81 widget = new QWidget(this, "widget"); 81 widget = new QWidget(this, "widget");
82 grid = new QGridLayout( widget ); 82 grid = new QGridLayout( widget );
83 83
84 recipientsBox = new QComboBox( FALSE, widget, "toLabel" ); 84 recipientsBox = new QComboBox( FALSE, widget, "toLabel" );
85 recipientsBox->insertItem( tr( "To:" ) ); 85 recipientsBox->insertItem( tr( "To:" ) );
86 recipientsBox->insertItem( tr( "CC:" ) ); 86 recipientsBox->insertItem( tr( "CC:" ) );
87 recipientsBox->setCurrentItem(0); 87 recipientsBox->setCurrentItem(0);
88 grid->addWidget( recipientsBox, 0, 0 ); 88 grid->addWidget( recipientsBox, 0, 0 );
89 89
90 subjetLabel = new QLabel( widget, "subjetLabel" ); 90 subjetLabel = new QLabel( widget, "subjetLabel" );
91 subjetLabel->setText( tr( "Subject:" ) ); 91 subjetLabel->setText( tr( "Subject:" ) );
92 92
93 grid->addWidget( subjetLabel, 1, 0 ); 93 grid->addWidget( subjetLabel, 1, 0 );
94 94
95 ToolButton13_2 = new QToolButton( widget, "ToolButton13_2" ); 95 ToolButton13_2 = new QToolButton( widget, "ToolButton13_2" );
96 ToolButton13_2->setText( tr( "..." ) ); 96 ToolButton13_2->setText( tr( "..." ) );
97 grid->addWidget( ToolButton13_2, 1, 2 ); 97 grid->addWidget( ToolButton13_2, 1, 2 );
98 98
99 subjectInput = new QLineEdit( widget, "subjectInput" ); 99 subjectInput = new QLineEdit( widget, "subjectInput" );
100 grid->addWidget( subjectInput, 1, 1 ); 100 grid->addWidget( subjectInput, 1, 1 );
101 101
102 toInput = new QLineEdit( widget, "toInput" ); 102 toInput = new QLineEdit( widget, "toInput" );
103 grid->addWidget( toInput, 0, 1 ); 103 grid->addWidget( toInput, 0, 1 );
104 104
105 addressButton = new QToolButton( widget, "addressButton" ); 105 addressButton = new QToolButton( widget, "addressButton" );
106 addressButton->setPixmap( Resource::loadPixmap("AddressBook") ); 106 addressButton->setPixmap( Resource::loadPixmap("AddressBook") );
107 addressButton->setToggleButton(TRUE); 107 addressButton->setToggleButton(TRUE);
108 grid->addWidget( addressButton, 0, 2 ); 108 grid->addWidget( addressButton, 0, 2 );
109 connect(addressButton, SIGNAL(clicked()), this, SLOT(getAddress()) ); 109 connect(addressButton, SIGNAL(clicked()), this, SLOT(getAddress()) );
110 110
111 emailInput = new QMultiLineEdit( widget, "emailInput" ); 111 emailInput = new QMultiLineEdit( widget, "emailInput" );
112 grid->addMultiCellWidget( emailInput, 2, 2, 0, 2); 112 grid->addMultiCellWidget( emailInput, 2, 2, 0, 2);
113 113
114 addressView = new QListView( widget, "addressView"); 114 addressView = new QListView( widget, "addressView");
115 addressView->addColumn("Email"); 115 addressView->addColumn("Email");
116 addressView->addColumn("Name"); 116 addressView->addColumn("Name");
117 addressView->setAllColumnsShowFocus(TRUE); 117 addressView->setAllColumnsShowFocus(TRUE);
118 addressView->setMultiSelection(TRUE); 118 addressView->setMultiSelection(TRUE);
119 addressView->hide(); 119 addressView->hide();
120 grid->addMultiCellWidget( addressView, 3, 3, 0, 2); 120 grid->addMultiCellWidget( addressView, 3, 3, 0, 2);
121 121
122 okButton = new QToolButton(bar, "ok"); 122 okButton = new QToolButton(bar, "ok");
123 okButton->setPixmap( Resource::loadPixmap("enter") ); 123 okButton->setPixmap( Resource::loadPixmap("enter") );
124 okButton->hide(); 124 okButton->hide();
125 connect(okButton, SIGNAL(clicked()), this, SLOT(addRecipients()) ); 125 connect(okButton, SIGNAL(clicked()), this, SLOT(addRecipients()) );
126 126
127 setCentralWidget(widget); 127 setCentralWidget(widget);
128} 128}
129 129
130void WriteMail::reject() 130void WriteMail::reject()
131{ 131{
132 emit cancelMail(); 132 emit cancelMail();
133} 133}
134 134
135// need to insert date 135// need to insert date
136void WriteMail::accept() 136void WriteMail::accept()
137{ 137{
138 QStringList attatchedFiles, attatchmentsType; 138 QStringList attatchedFiles, attatchmentsType;
139 int idCount = 0; 139 int idCount = 0;
140 140
141 if (toInput->text() == "") { 141 if (toInput->text() == "") {
142 QMessageBox::warning(this,"No recipient", "Send mail to whom?", "OK\n"); 142 QMessageBox::warning(this,"No recipient", "Send mail to whom?", "OK\n");
143 return; 143 return;
144 } 144 }
145 if (! getRecipients() ) { 145 if (! getRecipients() ) {
146 QMessageBox::warning(this,"Incorrect recipient separator", 146 QMessageBox::warning(this,"Incorrect recipient separator",
147 "Recipients must be separated by ;\nand be valid emailaddresses", "OK\n"); 147 "Recipients must be separated by ;\nand be valid emailaddresses", "OK\n");
148 return; 148 return;
149 } 149 }
150 mail.subject = subjectInput->text(); 150 mail.subject = subjectInput->text();
151 mail.body = emailInput->text(); 151 mail.body = emailInput->text();
152 mail.sent = false; 152 mail.sent = false;
153 mail.received = false; 153 mail.received = false;
154 mail.rawMail = "To: "; 154 mail.rawMail = "To: ";
155 155
156 for (QStringList::Iterator it = mail.recipients.begin(); 156 for (QStringList::Iterator it = mail.recipients.begin();
157 it != mail.recipients.end(); ++it) { 157 it != mail.recipients.end(); ++it) {
158 158
159 mail.rawMail += (*it); 159 mail.rawMail += (*it);
160 mail.rawMail += ",\n"; 160 mail.rawMail += ",\n";
161 } 161 }
162 mail.rawMail.truncate(mail.rawMail.length()-2); 162 mail.rawMail.truncate(mail.rawMail.length()-2);
163 mail.rawMail += mail.from; 163 mail.rawMail += mail.from;
164 mail.rawMail += "\nSubject: "; 164 mail.rawMail += "\nSubject: ";
165 mail.rawMail += mail.subject; 165 mail.rawMail += mail.subject;
166 mail.rawMail += "\n\n"; 166 mail.rawMail += "\n\n";
167 167
168 attatchedFiles = addAtt->returnAttatchedFiles(); 168 attatchedFiles = addAtt->returnAttatchedFiles();
169 attatchmentsType = addAtt->returnFileTypes(); 169 attatchmentsType = addAtt->returnFileTypes();
170 170
171 QStringList::Iterator itType = attatchmentsType.begin(); 171 QStringList::Iterator itType = attatchmentsType.begin();
172 172
173 Enclosure e; 173 Enclosure e;
174 for ( QStringList::Iterator it = attatchedFiles.begin(); 174 for ( QStringList::Iterator it = attatchedFiles.begin(); it != attatchedFiles.end(); ++it ) {
175 it != attatchedFiles.end(); ++it ) {
176
177 e.id = idCount; 175 e.id = idCount;
178 e.originalName = (*it).latin1(); 176 e.originalName = (*it).latin1();
179 e.contentType = (*itType).latin1(); 177 e.contentType = (*itType).latin1();
180 e.contentAttribute = (*itType).latin1(); 178 e.contentAttribute = (*itType).latin1();
181 e.saved = TRUE; 179 e.saved = TRUE;
182 mail.addEnclosure(&e); 180 mail.addEnclosure(&e);
183 181
184 itType++; 182 itType++;
185 idCount++; 183 idCount++;
186 } 184 }
187 mail.rawMail += mail.body; 185 mail.rawMail += mail.body;
188 mail.rawMail += "\n"; 186 mail.rawMail += "\n";
189 mail.rawMail += ".\n"; 187 mail.rawMail += ".\n";
190 emit sendMailRequested(mail); 188 emit sendMailRequested(mail);
191 addAtt->clear(); 189 addAtt->clear();
192} 190}
193 191
194void WriteMail::getAddress() 192void WriteMail::getAddress()
195{ 193{
196 showingAddressList = !showingAddressList; 194 showingAddressList = !showingAddressList;
197 195
198 if (showingAddressList) { 196 if (showingAddressList) {
199 emailInput->hide(); 197 emailInput->hide();
200 addressView->show(); 198 addressView->show();
201 okButton->show(); 199 okButton->show();
202 200
203 } else { 201 } else {
204 addressView->hide(); 202 addressView->hide();
205 okButton->hide(); 203 okButton->hide();
206 emailInput->show(); 204 emailInput->show();
207 } 205 }
208} 206}
209 207
210void WriteMail::attatchFile() 208void WriteMail::attatchFile()
211{ 209{
212 addAtt->showMaximized(); 210 addAtt->showMaximized();
213} 211}
214 212
215void WriteMail::reply(Email replyMail) 213void WriteMail::reply(Email replyMail)
216{ 214{
217 int pos; 215 int pos;
218 216
219 mail = replyMail; 217 mail = replyMail;
220 mail.files.clear(); 218 mail.files.clear();
221 219
222 toInput->setText(mail.fromMail); 220 toInput->setText(mail.fromMail);
223 subjectInput->setText("Re: " + mail.subject); 221 subjectInput->setText("Re: " + mail.subject);
224 222
225 pos = 0; 223 pos = 0;
226 mail.body.insert(pos, ">>"); 224 mail.body.insert(pos, ">>");
227 while (pos != -1) { 225 while (pos != -1) {
228 pos = mail.body.find('\n', pos); 226 pos = mail.body.find('\n', pos);
229 if (pos != -1) 227 if (pos != -1)
230 mail.body.insert(++pos, ">>"); 228 mail.body.insert(++pos, ">>");
231 } 229 }
232 230
233 emailInput->setText(mail.body); 231 emailInput->setText(mail.body);
234} 232}
235 233
236bool WriteMail::getRecipients() 234bool WriteMail::getRecipients()
237{ 235{
238 QString str, temp; 236 QString str, temp;
239 int pos = 0; 237 int pos = 0;
240 238
241 mail.recipients.clear(); 239 mail.recipients.clear();
242 240
243 temp = toInput->text(); 241 temp = toInput->text();
244 while ( (pos = temp.find(';')) != -1) { 242 while ( (pos = temp.find(';')) != -1) {
245 str = temp.left(pos).stripWhiteSpace(); 243 str = temp.left(pos).stripWhiteSpace();
246 temp = temp.right(temp.length() - (pos + 1)); 244 temp = temp.right(temp.length() - (pos + 1));
247 if ( str.find('@') == -1) 245 if ( str.find('@') == -1)
248 return false; 246 return false;
249 mail.recipients.append(str); 247 mail.recipients.append(str);
250 addressList->addContact(str, ""); 248 addressList->addContact(str, "");
251 } 249 }
252 temp = temp.stripWhiteSpace(); 250 temp = temp.stripWhiteSpace();
253 if ( temp.find('@') == -1) 251 if ( temp.find('@') == -1)
254 return false; 252 return false;
255 mail.recipients.append(temp); 253 mail.recipients.append(temp);
256 addressList->addContact(temp, ""); 254 addressList->addContact(temp, "");
257 255
258 return TRUE; 256 return TRUE;
259} 257}
260 258
261 259
262void WriteMail::addRecipients() 260void WriteMail::addRecipients()
263{ 261{
264 QString recipients = ""; 262 QString recipients = "";
265 263
266 mail.recipients.clear(); 264 mail.recipients.clear();
267 QListViewItem *item = addressView->firstChild(); 265 QListViewItem *item = addressView->firstChild();
268 while (item != NULL) { 266 while (item != NULL) {
269 if ( item->isSelected() ) { 267 if ( item->isSelected() ) {
270 if (recipients == "") { 268 if (recipients == "") {
271 recipients = item->text(0); 269 recipients = item->text(0);
272 } else { 270 } else {
273 recipients += "; " + item->text(0); 271 recipients += "; " + item->text(0);
274 } 272 }
275 } 273 }
276 item = item->nextSibling(); 274 item = item->nextSibling();
277 } 275 }
278 toInput->setText(recipients); 276 toInput->setText(recipients);
279 277
280 addressView->hide(); 278 addressView->hide();
281 okButton->hide(); 279 okButton->hide();
282 emailInput->show(); 280 emailInput->show();
283 addressButton->setOn(FALSE); 281 addressButton->setOn(FALSE);
284 showingAddressList = !showingAddressList; 282 showingAddressList = !showingAddressList;
285} 283}
286 284
287void WriteMail::setRecipient(const QString &recipient) 285void WriteMail::setRecipient(const QString &recipient)
288{ 286{
289 toInput->setText(recipient); 287 toInput->setText(recipient);
290} 288}
291 289
292void WriteMail::newMail() 290void WriteMail::newMail()
293{ 291{
294 toInput->clear(); 292 toInput->clear();
295 subjectInput->clear(); 293 subjectInput->clear();
296 emailInput->clear(); 294 emailInput->clear();
297 //to clear selected 295 //to clear selected
298 setAddressList(addressList); 296 setAddressList(addressList);
299} 297}