summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/today/today.cpp109
-rw-r--r--core/pim/today/today.h5
-rw-r--r--core/pim/today/todaybase.cpp25
-rw-r--r--core/pim/today/todaybase.h2
4 files changed, 101 insertions, 40 deletions
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index 81d4d36..08efe2d 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -28,4 +28,6 @@
28#include <qpe/qprocess.h> 28#include <qpe/qprocess.h>
29#include <qpe/resource.h> 29#include <qpe/resource.h>
30#include <qpe/contact.h>
31#include <qpe/global.h>
30 32
31#include <qdir.h> 33#include <qdir.h>
@@ -67,9 +69,58 @@ Today::Today( QWidget* parent, const char* name, WFlags fl )
67 QObject::connect( (QObject*)DatesButton, SIGNAL( clicked() ), this, SLOT(startDatebook() ) ); 69 QObject::connect( (QObject*)DatesButton, SIGNAL( clicked() ), this, SLOT(startDatebook() ) );
68 QObject::connect( (QObject*)MailButton, SIGNAL( clicked() ), this, SLOT(startMail() ) ); 70 QObject::connect( (QObject*)MailButton, SIGNAL( clicked() ), this, SLOT(startMail() ) );
69 71
72#if defined(Q_WS_QWS)
73#if !defined(QT_NO_COP)
74 QCopChannel *todayChannel = new QCopChannel("QPE/Today" , this );
75 connect (todayChannel, SIGNAL( received(const QCString &, const QByteArray &)),
76 this, SLOT ( channelReceived(const QCString &, const QByteArray &)) );
77#endif
78#endif
79
70 draw(); 80 draw();
81 setOwnerField();
71 autoStart(); 82 autoStart();
72} 83}
73 84
85/*
86 * Qcop receive method.
87 */
88void Today::channelReceived(const QCString &msg, const QByteArray & data) {
89 QDataStream stream(data, IO_ReadOnly );
90 if ( msg == "message(QString)" ) {
91 QString message;
92 stream >> message;
93 setOwnerField(message);
94 }
95
96}
97
98/*
99 * Initialises the owner field with the default value, the username
100 */
101void Today::setOwnerField() {
102 QString file = Global::applicationFileName("addressbook", "businesscard.vcf");
103 if (QFile::exists(file)) {
104 Contact cont = Contact::readVCard(file)[0];
105 QString returnString = cont.fullName();
106 OwnerField->setText( tr ("<b>Owned by " + returnString + "</b>"));
107 } else {
108 OwnerField->setText( tr ("<b>to lame to fill out the business card </b>"));
109 }
110}
111
112/*
113 * Set the owner field with a given QString, for example per qcop.
114 */
115void Today::setOwnerField(QString &message) {
116 if (!message.isEmpty()) {
117 OwnerField->setText("<b>" + message + "</b>");
118 }
119}
120
121/*
122 * Autostart, uses the new (opie only) autostart method in the launcher code.
123 * If registered against that today ist started on each resume.
124 */
74void Today::autoStart() { 125void Today::autoStart() {
75 Config cfg("today"); 126 Config cfg("today");
@@ -87,4 +138,7 @@ void Today::autoStart() {
87} 138}
88 139
140/*
141 * Repaint method. Reread all fields.
142 */
89void Today::draw() { 143void Today::draw() {
90 init(); 144 init();
@@ -96,5 +150,4 @@ void Today::draw() {
96} 150}
97 151
98
99/* 152/*
100 * Check if the todolist.xml was modified (if there are new entries. 153 * Check if the todolist.xml was modified (if there are new entries.
@@ -123,8 +176,10 @@ bool Today::checkIfModified() {
123 176
124 177
178/*
179 * Init stuff needed for today. Reads the config file.
180 */
125void Today::init() { 181void Today::init() {
126 QDate date = QDate::currentDate(); 182 QDate date = QDate::currentDate();
127 QString time = (tr( date.toString()) ); 183 QString time = (tr( date.toString()) );
128// QString time = (tr( date.toString()) , white);
129 184
130 TextLabel1->setText(time); 185 TextLabel1->setText(time);
@@ -134,9 +189,10 @@ void Today::init() {
134 Config cfg("today"); 189 Config cfg("today");
135 cfg.setGroup("BaseConfig"); 190 cfg.setGroup("BaseConfig");
136 191
192 // -- config file section --
137 // how many lines should be showed in the task section 193 // how many lines should be showed in the task section
138 MAX_LINES_TASK = cfg.readNumEntry("maxlinestask",5); 194 MAX_LINES_TASK = cfg.readNumEntry("maxlinestask",5);
139 // after how many chars should the be cut off on tasks and notes 195 // after how many chars should the be cut off on tasks and notes
140 MAX_CHAR_CLIP = cfg.readNumEntry("maxcharclip",30); 196 MAX_CHAR_CLIP = cfg.readNumEntry("maxcharclip",40);
141 // how many lines should be showed in the datebook section 197 // how many lines should be showed in the datebook section
142 MAX_LINES_MEET = cfg.readNumEntry("maxlinesmeet",5); 198 MAX_LINES_MEET = cfg.readNumEntry("maxlinesmeet",5);
@@ -145,14 +201,15 @@ void Today::init() {
145 // if notes should be shown 201 // if notes should be shown
146 SHOW_NOTES = cfg.readNumEntry("shownotes",0); 202 SHOW_NOTES = cfg.readNumEntry("shownotes",0);
203 // should only later appointments be shown or all for the current day.
147 ONLY_LATER = cfg.readNumEntry("onlylater",1); 204 ONLY_LATER = cfg.readNumEntry("onlylater",1);
148
149} 205}
150 206
207
208/*
209 * The method for the configuration dialog.
210 */
151void Today::startConfig() { 211void Today::startConfig() {
152 conf = new todayconfig ( this, "", true );
153
154
155 //Config cfg = new Config("today");
156 212
213 conf = new todayconfig ( this, "", true );
157 // read the config 214 // read the config
158 Config cfg("today"); 215 Config cfg("today");
@@ -172,5 +229,5 @@ void Today::startConfig() {
172 // only later 229 // only later
173 conf->CheckBox3->setChecked(ONLY_LATER); 230 conf->CheckBox3->setChecked(ONLY_LATER);
174 231 // if today should be autostarted
175 conf->CheckBoxAuto->setChecked(AUTOSTART); 232 conf->CheckBoxAuto->setChecked(AUTOSTART);
176 233
@@ -193,4 +250,5 @@ void Today::startConfig() {
193 cfg.setGroup("Autostart"); 250 cfg.setGroup("Autostart");
194 cfg.writeEntry("autostart", autostart); 251 cfg.writeEntry("autostart", autostart);
252
195 // sync it to "disk" 253 // sync it to "disk"
196 cfg.write(); 254 cfg.write();
@@ -223,5 +281,5 @@ void Today::getDates() {
223 281
224 if ( list.count() > 0 ) { 282 if ( list.count() > 0 ) {
225 283
226 for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); 284 for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin();
227 it!=list.end(); ++it ) { 285 it!=list.end(); ++it ) {
@@ -233,5 +291,5 @@ void Today::getDates() {
233 291
234 if (!ONLY_LATER) { 292 if (!ONLY_LATER) {
235 count++; 293 count++;
236 DateBookEvent *l=new DateBookEvent(*it, AllDateBookEvents); 294 DateBookEvent *l=new DateBookEvent(*it, AllDateBookEvents);
237 layoutDates->addWidget(l); 295 layoutDates->addWidget(l);
@@ -239,6 +297,6 @@ void Today::getDates() {
239 this, SLOT(editEvent(const Event &))); 297 this, SLOT(editEvent(const Event &)));
240 } else if ((time.toString() <= TimeString::dateString((*it).event().end())) ) { 298 } else if ((time.toString() <= TimeString::dateString((*it).event().end())) ) {
241 count++; 299 count++;
242 300
243 // show only later appointments 301 // show only later appointments
244 DateBookEventLater *l=new DateBookEventLater(*it, AllDateBookEvents); 302 DateBookEventLater *l=new DateBookEventLater(*it, AllDateBookEvents);
@@ -263,6 +321,4 @@ void Today::getDates() {
263 sv1->addChild(AllDateBookEvents); 321 sv1->addChild(AllDateBookEvents);
264 AllDateBookEvents->show(); 322 AllDateBookEvents->show();
265
266
267} 323}
268 324
@@ -340,8 +396,6 @@ void Today::getMail() {
340 int OUTGOING = cfg.readNumEntry("outgoing",0); 396 int OUTGOING = cfg.readNumEntry("outgoing",0);
341 397
342
343 QString output = tr("<b>%1</b> new mail(s), <b>%2</b> outgoing").arg(NEW_MAILS).arg(OUTGOING); 398 QString output = tr("<b>%1</b> new mail(s), <b>%2</b> outgoing").arg(NEW_MAILS).arg(OUTGOING);
344 399
345
346 MailField->setText(output); 400 MailField->setText(output);
347} 401}
@@ -350,5 +404,4 @@ void Today::getMail() {
350/* 404/*
351 * Get the todos 405 * Get the todos
352 *
353 */ 406 */
354void Today::getTodo() { 407void Today::getTodo() {
@@ -358,4 +411,5 @@ void Today::getTodo() {
358 return; 411 return;
359 } 412 }
413 // since it was the new start or the return from config dialog, set it to 0 again.
360 NEW_START=0; 414 NEW_START=0;
361 415
@@ -403,4 +457,8 @@ void Today::startDatebook() {
403 e << QString("datebook"); 457 e << QString("datebook");
404} 458}
459
460/*
461 * starts the edit dialog as known from datebook
462 */
405void Today::editEvent(const Event &e) { 463void Today::editEvent(const Event &e) {
406 startDatebook(); 464 startDatebook();
@@ -430,12 +488,13 @@ void Today::startMail() {
430} 488}
431 489
432/* 490
433 * Destroys the object and frees any allocated resources
434 */
435Today::~Today() { 491Today::~Today() {
436 // no need to delete child widgets, Qt does it all for us
437} 492}
438 493
439 494
495
496/*
497 * Gets the events for the current day, if it should get all dates
498 */
440DateBookEvent::DateBookEvent(const EffectiveEvent &ev, 499DateBookEvent::DateBookEvent(const EffectiveEvent &ev,
441 QWidget* parent = 0, 500 QWidget* parent = 0,
@@ -466,4 +525,5 @@ DateBookEvent::DateBookEvent(const EffectiveEvent &ev,
466 + "<b> - </b>" + TimeString::timeString(QTime((ev).event().end().time()) ); 525 + "<b> - </b>" + TimeString::timeString(QTime((ev).event().end().time()) );
467 } 526 }
527
468 // include possible note or not 528 // include possible note or not
469 if (SHOW_NOTES == 1) { 529 if (SHOW_NOTES == 1) {
@@ -520,4 +580,5 @@ DateBookEventLater::DateBookEventLater(const EffectiveEvent &ev,
520} 580}
521 581
582
522void DateBookEvent::editMe() { 583void DateBookEvent::editMe() {
523 emit editEvent(event.event()); 584 emit editEvent(event.event());
diff --git a/core/pim/today/today.h b/core/pim/today/today.h
index 0b4356c..6dec2c2 100644
--- a/core/pim/today/today.h
+++ b/core/pim/today/today.h
@@ -56,5 +56,10 @@ class Today : public TodayBase {
56 void autoStart(); 56 void autoStart();
57 bool checkIfModified(); 57 bool checkIfModified();
58 void setOwnerField();
59 void setOwnerField(QString &string);
58 QList<TodoItem> loadTodo(const char *filename); 60 QList<TodoItem> loadTodo(const char *filename);
61private slots:
62 void channelReceived(const QCString &msg, const QByteArray & data);
63
59 private: 64 private:
60 DateBookDB *db; 65 DateBookDB *db;
diff --git a/core/pim/today/todaybase.cpp b/core/pim/today/todaybase.cpp
index 552e2eb..c0b8d34 100644
--- a/core/pim/today/todaybase.cpp
+++ b/core/pim/today/todaybase.cpp
@@ -86,6 +86,10 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
86 TextLabel1->setBackgroundOrigin( QLabel::ParentOrigin ); 86 TextLabel1->setBackgroundOrigin( QLabel::ParentOrigin );
87 TextLabel1->setTextFormat( RichText ); 87 TextLabel1->setTextFormat( RichText );
88 88
89 89 OwnerField = new QLabel(this , "Owner" );
90 OwnerField->setGeometry(QRect(0,0, this->width(), 12 ));
91 OwnerField->setAlignment(int (QLabel::AlignTop | QLabel::AlignLeft ) );
92 OwnerField->setMaximumHeight(12);
93
90 // --- dates section --- 94 // --- dates section ---
91 Frame4 = new QFrame( this, "Frame4" ); 95 Frame4 = new QFrame( this, "Frame4" );
@@ -95,7 +99,6 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
95 Frame4->setBackgroundOrigin( QScrollView::ParentOrigin ); 99 Frame4->setBackgroundOrigin( QScrollView::ParentOrigin );
96 Frame4->setFrameStyle( QFrame::NoFrame ); 100 Frame4->setFrameStyle( QFrame::NoFrame );
97 Frame4->setGeometry (QRect( 0, 0, this->width() , this->height()) ); 101 Frame4->setGeometry (QRect( 0, 8, this->width() , this->height()) );
98 102
99 // QScrollView* sv1 = new QScrollView( Frame4 );
100 sv1 = new QScrollView( Frame4 ); 103 sv1 = new QScrollView( Frame4 );
101 sv1->setResizePolicy(QScrollView::AutoOneFit); 104 sv1->setResizePolicy(QScrollView::AutoOneFit);
@@ -111,14 +114,6 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
111 DatesButton->setPixmap( datebook ); 114 DatesButton->setPixmap( datebook );
112 DatesButton->setFlat( TRUE ); 115 DatesButton->setFlat( TRUE );
113 116
114 //DatesField = new QLabel( sv1->viewport(), "DatesField" ); 117 // --- mail section ---)
115 //DatesField = new QVBox(sv1->viewport());
116 //QWidget *dummy = new QWidget(sv1->viewport());
117 //sv1->addChild(DatesField);
118 //DatesField->setText( tr( "No appointments today" ) );
119 // DatesField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) );
120
121
122 // --- mail section ---)
123 MailFrame = new QFrame( this ,"MailFrame" ); 118 MailFrame = new QFrame( this ,"MailFrame" );
124 MailFrame->setBackgroundOrigin( QScrollView::ParentOrigin ); 119 MailFrame->setBackgroundOrigin( QScrollView::ParentOrigin );
@@ -143,5 +138,4 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
143 MailField->setMinimumHeight(15); 138 MailField->setMinimumHeight(15);
144 139
145
146 // --- todo section -- 140 // --- todo section --
147 Frame15 = new QFrame( this, "Frame15" ); 141 Frame15 = new QFrame( this, "Frame15" );
@@ -180,4 +174,5 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
180 // -- layout -- 174 // -- layout --
181 layout->addWidget(Frame); 175 layout->addWidget(Frame);
176 layout->addWidget(OwnerField);
182 layout->addWidget(Frame4); 177 layout->addWidget(Frame4);
183 layout->addWidget(MailFrame); 178 layout->addWidget(MailFrame);
diff --git a/core/pim/today/todaybase.h b/core/pim/today/todaybase.h
index 8840125..0118faa 100644
--- a/core/pim/today/todaybase.h
+++ b/core/pim/today/todaybase.h
@@ -33,5 +33,5 @@ public:
33 QFrame* Frame4; 33 QFrame* Frame4;
34 QPushButton* DatesButton; 34 QPushButton* DatesButton;
35 //QLabel* DatesField; 35 QLabel* OwnerField;
36 QLabel* Frame; 36 QLabel* Frame;
37 QFrame* MailFrame; 37 QFrame* MailFrame;