-rw-r--r-- | core/pim/datebook/datebook.cpp | 35 |
1 files changed, 14 insertions, 21 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp index 706cc08..832b2f8 100644 --- a/core/pim/datebook/datebook.cpp +++ b/core/pim/datebook/datebook.cpp | |||
@@ -173,33 +173,32 @@ DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | |||
173 | if(defaultView==MONTH) viewMonth(); | 173 | if(defaultView==MONTH) viewMonth(); |
174 | 174 | ||
175 | connect( qApp, SIGNAL(clockChanged(bool)), this, SLOT(changeClock(bool)) ); | 175 | connect( qApp, SIGNAL(clockChanged(bool)), this, SLOT(changeClock(bool)) ); |
176 | connect( qApp, SIGNAL(weekChanged(bool)), this, SLOT(changeWeek(bool)) ); | 176 | connect( qApp, SIGNAL(weekChanged(bool)), this, SLOT(changeWeek(bool)) ); |
177 | 177 | ||
178 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 178 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
179 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), this, SLOT(appMessage(const QCString&, const QByteArray&)) ); | 179 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), this, SLOT(appMessage(const QCString&, const QByteArray&)) ); |
180 | #endif | 180 | #endif |
181 | 181 | ||
182 | // listen on QPE/System | 182 | // listen on QPE/System |
183 | #if defined(Q_WS_QWS) | 183 | #if defined(Q_WS_QWS) |
184 | #if !defined(QT_NO_COP) | 184 | #if !defined(QT_NO_COP) |
185 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); | 185 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); |
186 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); | 186 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); |
187 | channel = new QCopChannel( "QPE/Datebook", this ); | 187 | channel = new QCopChannel( "QPE/Datebook", this ); |
188 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); | 188 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); |
189 | qDebug("olle\n"); | ||
190 | #endif | 189 | #endif |
191 | #endif | 190 | #endif |
192 | 191 | ||
193 | qDebug("done t=%d", t.elapsed() ); | 192 | qDebug("done t=%d", t.elapsed() ); |
194 | 193 | ||
195 | connect( qApp, SIGNAL( flush() ), this, SLOT( flush() ) ); | 194 | connect( qApp, SIGNAL( flush() ), this, SLOT( flush() ) ); |
196 | connect( qApp, SIGNAL( reload()), this, SLOT( reload() ) ); | 195 | connect( qApp, SIGNAL( reload()), this, SLOT( reload() ) ); |
197 | /* | 196 | /* |
198 | * Here is a problem description: | 197 | * Here is a problem description: |
199 | * When Weekview is the default view | 198 | * When Weekview is the default view |
200 | * a DateBookWeekView get's created | 199 | * a DateBookWeekView get's created |
201 | * redraw() get's called. So what? | 200 | * redraw() get's called. So what? |
202 | * Remember that we're still in the c'tor | 201 | * Remember that we're still in the c'tor |
203 | * and no final layout has happened? Ok | 202 | * and no final layout has happened? Ok |
204 | * now all Events get arranged. Their x | 203 | * now all Events get arranged. Their x |
205 | * position get's determined by a QHeader | 204 | * position get's determined by a QHeader |
@@ -396,33 +395,32 @@ void DateBook::viewMonth() { | |||
396 | view(MONTH,currentDate()); | 395 | view(MONTH,currentDate()); |
397 | } | 396 | } |
398 | 397 | ||
399 | void DateBook::insertEvent( const Event &e ) | 398 | void DateBook::insertEvent( const Event &e ) |
400 | { | 399 | { |
401 | Event dupEvent=e; | 400 | Event dupEvent=e; |
402 | if(!dupEvent.isValidUid() ) // tkcRom seems to be different | 401 | if(!dupEvent.isValidUid() ) // tkcRom seems to be different |
403 | dupEvent.assignUid(); | 402 | dupEvent.assignUid(); |
404 | dupEvent.setLocation(defaultLocation); | 403 | dupEvent.setLocation(defaultLocation); |
405 | dupEvent.setCategories(defaultCategories); | 404 | dupEvent.setCategories(defaultCategories); |
406 | db->addEvent(dupEvent); | 405 | db->addEvent(dupEvent); |
407 | emit newEvent(); | 406 | emit newEvent(); |
408 | } | 407 | } |
409 | 408 | ||
410 | void DateBook::duplicateEvent( const Event &e ) | 409 | void DateBook::duplicateEvent( const Event &e ) |
411 | { | 410 | { |
412 | qWarning("Hmmm..."); | ||
413 | // Alot of code duplication, as this is almost like editEvent(); | 411 | // Alot of code duplication, as this is almost like editEvent(); |
414 | if (syncing) { | 412 | if (syncing) { |
415 | QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); | 413 | QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); |
416 | return; | 414 | return; |
417 | } | 415 | } |
418 | 416 | ||
419 | Event dupevent(e);// Make a duplicate. | 417 | Event dupevent(e);// Make a duplicate. |
420 | 418 | ||
421 | // workaround added for text input. | 419 | // workaround added for text input. |
422 | QDialog editDlg( this, 0, TRUE ); | 420 | QDialog editDlg( this, 0, TRUE ); |
423 | DateEntry *entry; | 421 | DateEntry *entry; |
424 | editDlg.setCaption( tr("Duplicate Event") ); | 422 | editDlg.setCaption( tr("Duplicate Event") ); |
425 | QVBoxLayout *vb = new QVBoxLayout( &editDlg ); | 423 | QVBoxLayout *vb = new QVBoxLayout( &editDlg ); |
426 | QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); | 424 | QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); |
427 | sv->setResizePolicy( QScrollView::AutoOneFit ); | 425 | sv->setResizePolicy( QScrollView::AutoOneFit ); |
428 | // KLUDGE!!! | 426 | // KLUDGE!!! |
@@ -495,32 +493,33 @@ void DateBook::editEvent( const Event &e ) | |||
495 | 493 | ||
496 | void DateBook::removeEvent( const Event &e ) | 494 | void DateBook::removeEvent( const Event &e ) |
497 | { | 495 | { |
498 | if (syncing) { | 496 | if (syncing) { |
499 | QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); | 497 | QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); |
500 | return; | 498 | return; |
501 | } | 499 | } |
502 | 500 | ||
503 | QString strName = e.description(); | 501 | QString strName = e.description(); |
504 | 502 | ||
505 | if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) ) | 503 | if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) ) |
506 | return; | 504 | return; |
507 | 505 | ||
508 | db->removeEvent( e ); | 506 | db->removeEvent( e ); |
509 | if ( views->visibleWidget() == dayView && dayView ) | 507 | if ( views->visibleWidget() == dayView && dayView ) |
510 | dayView->redraw(); | 508 | dayView->redraw(); |
509 | |||
511 | } | 510 | } |
512 | 511 | ||
513 | void DateBook::addEvent( const Event &e ) | 512 | void DateBook::addEvent( const Event &e ) |
514 | { | 513 | { |
515 | QDate d = e.start().date(); | 514 | QDate d = e.start().date(); |
516 | initDay(); | 515 | initDay(); |
517 | dayView->setDate( d ); | 516 | dayView->setDate( d ); |
518 | } | 517 | } |
519 | 518 | ||
520 | void DateBook::showDay( int year, int month, int day ) | 519 | void DateBook::showDay( int year, int month, int day ) |
521 | { | 520 | { |
522 | QDate d(year, month, day); | 521 | QDate d(year, month, day); |
523 | view(DAY,d); | 522 | view(DAY,d); |
524 | } | 523 | } |
525 | 524 | ||
526 | void DateBook::initDay() | 525 | void DateBook::initDay() |
@@ -978,66 +977,62 @@ bool catComp( QArray<int> cats, int category ) | |||
978 | } | 977 | } |
979 | return returnMe; | 978 | return returnMe; |
980 | } | 979 | } |
981 | 980 | ||
982 | 981 | ||
983 | void DateBook::slotDoFind( const QString& txt, const QDate &dt, | 982 | void DateBook::slotDoFind( const QString& txt, const QDate &dt, |
984 | bool caseSensitive, bool /*backwards*/, | 983 | bool caseSensitive, bool /*backwards*/, |
985 | int category ) | 984 | int category ) |
986 | { | 985 | { |
987 | QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ), | 986 | QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ), |
988 | next; | 987 | next; |
989 | 988 | ||
990 | QRegExp r( txt ); | 989 | QRegExp r( txt ); |
991 | r.setCaseSensitive( caseSensitive ); | 990 | r.setCaseSensitive( caseSensitive ); |
992 | 991 | ||
993 | 992 | ||
994 | static Event rev, | 993 | static Event rev, nonrev; |
995 | nonrev; | ||
996 | if ( !inSearch ) { | 994 | if ( !inSearch ) { |
997 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); | 995 | rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); |
998 | nonrev.setStart( rev.start() ); | 996 | nonrev.setStart( rev.start() ); |
999 | inSearch = true; | 997 | inSearch = true; |
1000 | } | 998 | } |
1001 | static QDate searchDate = dt; | 999 | static QDate searchDate = dt; |
1002 | static bool wrapAround = true; | 1000 | static bool wrapAround = true; |
1003 | bool candidtate; | 1001 | bool candidtate; |
1004 | candidtate = false; | 1002 | candidtate = false; |
1005 | 1003 | ||
1006 | QValueList<Event> repeats = db->getRawRepeats(); | 1004 | QValueList<Event> repeats = db->getRawRepeats(); |
1007 | 1005 | ||
1008 | // find the candidate for the first repeat that matches... | 1006 | // find the candidate for the first repeat that matches... |
1009 | QValueListConstIterator<Event> it; | 1007 | QValueListConstIterator<Event> it; |
1010 | QDate start = dt; | 1008 | QDate start = dt; |
1011 | for ( it = repeats.begin(); it != repeats.end(); ++it ) { | 1009 | for ( it = repeats.begin(); it != repeats.end(); ++it ) { |
1012 | if ( catComp( (*it).categories(), category ) ) { | 1010 | if ( catComp( (*it).categories(), category ) ) { |
1013 | while ( nextOccurance( *it, start, next ) ) { | 1011 | if ( (*it).match( r ) ) { |
1014 | if ( next < dtEnd ) { | 1012 | if ( nextOccurance( *it, start, next ) ) { |
1015 | if ( (*it).match( r ) && !(next <= rev.start()) ) { | 1013 | if ( next < dtEnd && !(next <= rev.start() ) ) { |
1016 | rev = *it; | 1014 | rev = *it; |
1017 | dtEnd = next; | 1015 | dtEnd = next; |
1018 | rev.setStart( next ); | 1016 | rev.setStart( next ); |
1019 | candidtate = true; | 1017 | candidtate = true; |
1020 | wrapAround = true; | 1018 | wrapAround = true; |
1021 | start = dt; | 1019 | } |
1022 | break; | 1020 | } |
1023 | } else | 1021 | } |
1024 | start = next.date().addDays( 1 ); | 1022 | } |
1025 | } | ||
1026 | } | ||
1027 | } | ||
1028 | } | 1023 | } |
1029 | 1024 | ||
1030 | // now the for first non repeat... | 1025 | // now the for first non repeat... |
1031 | QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() ); | 1026 | QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() ); |
1032 | qHeapSort( nonRepeats.begin(), nonRepeats.end() ); | 1027 | qHeapSort( nonRepeats.begin(), nonRepeats.end() ); |
1033 | for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) { | 1028 | for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) { |
1034 | if ( catComp( (*it).categories(), category ) ) { | 1029 | if ( catComp( (*it).categories(), category ) ) { |
1035 | if ( (*it).start() < dtEnd ) { | 1030 | if ( (*it).start() < dtEnd ) { |
1036 | if ( (*it).match( r ) && !(*it <= nonrev) ) { | 1031 | if ( (*it).match( r ) && !(*it <= nonrev) ) { |
1037 | nonrev = *it; | 1032 | nonrev = *it; |
1038 | dtEnd = nonrev.start(); | 1033 | dtEnd = nonrev.start(); |
1039 | candidtate = true; | 1034 | candidtate = true; |
1040 | wrapAround = true; | 1035 | wrapAround = true; |
1041 | break; | 1036 | break; |
1042 | } | 1037 | } |
1043 | } | 1038 | } |
@@ -1062,21 +1057,19 @@ Event DateBookDBHack::eventByUID(int uid) { | |||
1062 | 1057 | ||
1063 | // FIXME: Dirty Hacks to get hold of the private event lists | 1058 | // FIXME: Dirty Hacks to get hold of the private event lists |
1064 | QDate start; | 1059 | QDate start; |
1065 | QDate end=start.addDays(-1); | 1060 | QDate end=start.addDays(-1); |
1066 | QValueList<Event> myEventList=getNonRepeatingEvents(start,end); | 1061 | QValueList<Event> myEventList=getNonRepeatingEvents(start,end); |
1067 | QValueList<Event> myRepeatEvents=getRawRepeats(); | 1062 | QValueList<Event> myRepeatEvents=getRawRepeats(); |
1068 | 1063 | ||
1069 | QValueList<Event>::ConstIterator it; | 1064 | QValueList<Event>::ConstIterator it; |
1070 | 1065 | ||
1071 | for (it = myEventList.begin(); it != myEventList.end(); it++) { | 1066 | for (it = myEventList.begin(); it != myEventList.end(); it++) { |
1072 | if ((*it).uid() == uid) return *it; | 1067 | if ((*it).uid() == uid) return *it; |
1073 | } | 1068 | } |
1074 | for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) { | 1069 | for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) { |
1075 | if ((*it).uid() == uid) return *it; | 1070 | if ((*it).uid() == uid) return *it; |
1076 | } | 1071 | } |
1077 | 1072 | ||
1078 | qDebug("Event not found: uid=%d\n", uid); | ||
1079 | Event ev; | 1073 | Event ev; |
1080 | return ev; // return at least | 1074 | return ev; // return at least |
1081 | } | 1075 | } |
1082 | |||