-rw-r--r-- | core/pim/datebook/datebook.cpp | 120 | ||||
-rw-r--r-- | core/pim/datebook/datebook.h | 6 | ||||
-rw-r--r-- | core/pim/datebook/datebooksettingsbase.ui | 394 | ||||
-rw-r--r-- | core/pim/datebook/datebookweeklst.cpp | 123 | ||||
-rw-r--r-- | core/pim/datebook/datebookweeklst.h | 2 |
5 files changed, 396 insertions, 249 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp index 829f8f8..4fbcb10 100644 --- a/core/pim/datebook/datebook.cpp +++ b/core/pim/datebook/datebook.cpp | |||
@@ -67,18 +67,12 @@ | |||
67 | #include <sys/types.h> | 67 | #include <sys/types.h> |
68 | #include <fcntl.h> | 68 | #include <fcntl.h> |
69 | #include <unistd.h> | 69 | #include <unistd.h> |
70 | 70 | ||
71 | #include <stdlib.h> | 71 | #include <stdlib.h> |
72 | 72 | ||
73 | #define DAY 1 | ||
74 | #define WEEK 2 | ||
75 | #define WEEKLST 4 | ||
76 | #define MONTH 3 | ||
77 | |||
78 | |||
79 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | 73 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) |
80 | : QMainWindow( parent, "datebook", f ), | 74 | : QMainWindow( parent, "datebook", f ), |
81 | aPreset( FALSE ), | 75 | aPreset( FALSE ), |
82 | presetTime( -1 ), | 76 | presetTime( -1 ), |
83 | startTime( 8 ), // an acceptable default | 77 | startTime( 8 ), // an acceptable default |
84 | rowStyle( 0 ), | 78 | rowStyle( 0 ), |
@@ -163,62 +157,35 @@ DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | |||
163 | monthAction = a; | 157 | monthAction = a; |
164 | 158 | ||
165 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ), QString::null, 0, g, 0 ); | 159 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ), QString::null, 0, g, 0 ); |
166 | connect( a, SIGNAL(activated()), this, SLOT(slotFind()) ); | 160 | connect( a, SIGNAL(activated()), this, SLOT(slotFind()) ); |
167 | a->addTo( sub_bar ); | 161 | a->addTo( sub_bar ); |
168 | 162 | ||
169 | a = new QAction( tr( "Alarm and Start Time..." ), QString::null, 0, 0 ); | 163 | a = new QAction( tr( "Edit..." ), QString::null, 0, 0 ); |
170 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); | 164 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); |
171 | a->addTo( settings ); | 165 | a->addTo( settings ); |
172 | 166 | ||
173 | QPopupMenu *default_view = new QPopupMenu(this); | 167 | if(defaultView==DAY) viewDay(); |
174 | settings->insertItem( tr( "Default View" ),default_view ); | 168 | if(defaultView==WEEK) needEvilHack=true;// viewWeek(); |
175 | default_view->setCheckable(TRUE); | 169 | if(defaultView==WEEKLST) viewWeekLst(); |
170 | if(defaultView==MONTH) viewMonth(); | ||
176 | 171 | ||
177 | Config config("DateBook"); | 172 | connect( qApp, SIGNAL(clockChanged(bool)), this, SLOT(changeClock(bool)) ); |
178 | config.setGroup("Main"); | 173 | connect( qApp, SIGNAL(weekChanged(bool)), this, SLOT(changeWeek(bool)) ); |
179 | int current=config.readNumEntry("defaultview", DAY); | ||
180 | |||
181 | QActionGroup *ag = new QActionGroup(this); | ||
182 | a = new QAction( tr( "Day" ), QString::null, 0, 0, 0, true ); | ||
183 | if (current==DAY) a->setOn(true), viewDay(); | ||
184 | ag->insert(a); | ||
185 | a = new QAction( tr( "Week" ), QString::null, 0, 0, 0, true ); | ||
186 | if (current==WEEK) a->setOn(true), /*viewWeek(),*/ needEvilHack = true; | ||
187 | ag->insert(a); | ||
188 | a = new QAction( tr( "WeekLst" ), QString::null, 0, 0, 0, true ); | ||
189 | if (current==WEEKLST) a->setOn(true), viewWeekLst(); | ||
190 | ag->insert(a); | ||
191 | a = new QAction( tr( "Month" ), QString::null, 0, 0, 0, true ); | ||
192 | if (current==MONTH) a->setOn(true), viewMonth(); | ||
193 | ag->insert(a); | ||
194 | |||
195 | ag->addTo(default_view); | ||
196 | connect(ag, SIGNAL( selected ( QAction * ) ), | ||
197 | this, SLOT( newDefaultView(QAction *) ) | ||
198 | ); | ||
199 | |||
200 | connect( qApp, SIGNAL(clockChanged(bool)), | ||
201 | this, SLOT(changeClock(bool)) ); | ||
202 | connect( qApp, SIGNAL(weekChanged(bool)), | ||
203 | this, SLOT(changeWeek(bool)) ); | ||
204 | 174 | ||
205 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 175 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
206 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), | 176 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), this, SLOT(appMessage(const QCString&, const QByteArray&)) ); |
207 | this, SLOT(appMessage(const QCString&, const QByteArray&)) ); | ||
208 | #endif | 177 | #endif |
209 | 178 | ||
210 | // listen on QPE/System | 179 | // listen on QPE/System |
211 | #if defined(Q_WS_QWS) | 180 | #if defined(Q_WS_QWS) |
212 | #if !defined(QT_NO_COP) | 181 | #if !defined(QT_NO_COP) |
213 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); | 182 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); |
214 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 183 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); |
215 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | ||
216 | channel = new QCopChannel( "QPE/Datebook", this ); | 184 | channel = new QCopChannel( "QPE/Datebook", this ); |
217 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 185 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), this, SLOT(receive(const QCString&, const QByteArray&)) ); |
218 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | ||
219 | qDebug("olle\n"); | 186 | qDebug("olle\n"); |
220 | #endif | 187 | #endif |
221 | #endif | 188 | #endif |
222 | 189 | ||
223 | qDebug("done t=%d", t.elapsed() ); | 190 | qDebug("done t=%d", t.elapsed() ); |
224 | 191 | ||
@@ -269,23 +236,28 @@ void DateBook::slotSettings() | |||
269 | { | 236 | { |
270 | DateBookSettings frmSettings( ampm, this ); | 237 | DateBookSettings frmSettings( ampm, this ); |
271 | frmSettings.setStartTime( startTime ); | 238 | frmSettings.setStartTime( startTime ); |
272 | frmSettings.setAlarmPreset( aPreset, presetTime ); | 239 | frmSettings.setAlarmPreset( aPreset, presetTime ); |
273 | frmSettings.setJumpToCurTime( bJumpToCurTime ); | 240 | frmSettings.setJumpToCurTime( bJumpToCurTime ); |
274 | frmSettings.setRowStyle( rowStyle ); | 241 | frmSettings.setRowStyle( rowStyle ); |
242 | frmSettings.comboDefaultView->setCurrentItem(defaultView-1); | ||
243 | frmSettings.comboWeekListView->setCurrentItem(weeklistviewconfig); | ||
244 | |||
275 | #if defined (Q_WS_QWS) || defined(_WS_QWS_) | 245 | #if defined (Q_WS_QWS) || defined(_WS_QWS_) |
276 | frmSettings.showMaximized(); | 246 | frmSettings.showMaximized(); |
277 | #endif | 247 | #endif |
278 | 248 | ||
279 | if ( frmSettings.exec() ) { | 249 | if ( frmSettings.exec() ) { |
280 | 250 | ||
281 | aPreset = frmSettings.alarmPreset(); | 251 | aPreset = frmSettings.alarmPreset(); |
282 | presetTime = frmSettings.presetTime(); | 252 | presetTime = frmSettings.presetTime(); |
283 | startTime = frmSettings.startTime(); | 253 | startTime = frmSettings.startTime(); |
284 | bJumpToCurTime = frmSettings.jumpToCurTime(); | 254 | bJumpToCurTime = frmSettings.jumpToCurTime(); |
285 | rowStyle = frmSettings.rowStyle(); | 255 | rowStyle = frmSettings.rowStyle(); |
256 | defaultView=frmSettings.comboDefaultView->currentItem()+1; | ||
257 | weeklistviewconfig=frmSettings.comboWeekListView->currentItem(); | ||
286 | 258 | ||
287 | if ( dayView ) { | 259 | if ( dayView ) { |
288 | dayView->setStartViewTime( startTime ); | 260 | dayView->setStartViewTime( startTime ); |
289 | dayView->setJumpToCurTime( bJumpToCurTime ); | 261 | dayView->setJumpToCurTime( bJumpToCurTime ); |
290 | dayView->setRowStyle( rowStyle ); | 262 | dayView->setRowStyle( rowStyle ); |
291 | } | 263 | } |
@@ -297,12 +269,14 @@ void DateBook::slotSettings() | |||
297 | // make the change obvious | 269 | // make the change obvious |
298 | if ( views->visibleWidget() ) { | 270 | if ( views->visibleWidget() ) { |
299 | if ( views->visibleWidget() == dayView ) | 271 | if ( views->visibleWidget() == dayView ) |
300 | dayView->redraw(); | 272 | dayView->redraw(); |
301 | else if ( views->visibleWidget() == weekView ) | 273 | else if ( views->visibleWidget() == weekView ) |
302 | weekView->redraw(); | 274 | weekView->redraw(); |
275 | else if ( views->visibleWidget() == weekLstView ) | ||
276 | weekLstView->redraw(); | ||
303 | } | 277 | } |
304 | } | 278 | } |
305 | } | 279 | } |
306 | 280 | ||
307 | void DateBook::fileNew() | 281 | void DateBook::fileNew() |
308 | { | 282 | { |
@@ -380,17 +354,20 @@ void DateBook::view(int v, const QDate &d) { | |||
380 | views->raiseWidget( monthView ); | 354 | views->raiseWidget( monthView ); |
381 | monthView->redraw(); | 355 | monthView->redraw(); |
382 | } | 356 | } |
383 | } | 357 | } |
384 | 358 | ||
385 | void DateBook::viewDefault(const QDate &d) { | 359 | void DateBook::viewDefault(const QDate &d) { |
360 | /* | ||
386 | Config config("DateBook"); | 361 | Config config("DateBook"); |
387 | config.setGroup("Main"); | 362 | config.setGroup("Main"); |
388 | int current=config.readNumEntry("defaultview", DAY); | 363 | int current=config.readNumEntry("defaultview", DAY); |
389 | 364 | ||
390 | view(current,d); | 365 | view(current,d); |
366 | */ | ||
367 | view(defaultView,d); | ||
391 | } | 368 | } |
392 | 369 | ||
393 | void DateBook::viewDay() { | 370 | void DateBook::viewDay() { |
394 | view(DAY,currentDate()); | 371 | view(DAY,currentDate()); |
395 | } | 372 | } |
396 | 373 | ||
@@ -605,52 +582,40 @@ void DateBook::initMonth() | |||
605 | qApp->processEvents(); | 582 | qApp->processEvents(); |
606 | } | 583 | } |
607 | } | 584 | } |
608 | 585 | ||
609 | void DateBook::loadSettings() | 586 | void DateBook::loadSettings() |
610 | { | 587 | { |
611 | { | 588 | Config qpeconfig( "qpe" ); |
612 | Config config( "qpe" ); | 589 | qpeconfig.setGroup("Time"); |
613 | config.setGroup("Time"); | 590 | ampm = qpeconfig.readBoolEntry( "AMPM", TRUE ); |
614 | ampm = config.readBoolEntry( "AMPM", TRUE ); | 591 | onMonday = qpeconfig.readBoolEntry( "MONDAY" ); |
615 | onMonday = config.readBoolEntry( "MONDAY" ); | ||
616 | } | ||
617 | 592 | ||
618 | { | ||
619 | Config config("DateBook"); | 593 | Config config("DateBook"); |
620 | config.setGroup("Main"); | 594 | config.setGroup("Main"); |
621 | startTime = config.readNumEntry("startviewtime", 8); | 595 | startTime = config.readNumEntry("startviewtime", 8); |
622 | aPreset = config.readBoolEntry("alarmpreset"); | 596 | aPreset = config.readBoolEntry("alarmpreset"); |
623 | presetTime = config.readNumEntry("presettime"); | 597 | presetTime = config.readNumEntry("presettime"); |
624 | bJumpToCurTime = config.readBoolEntry("jumptocurtime"); | 598 | bJumpToCurTime = config.readBoolEntry("jumptocurtime"); |
625 | rowStyle = config.readNumEntry("rowstyle"); | 599 | rowStyle = config.readNumEntry("rowstyle"); |
626 | } | 600 | defaultView = config.readNumEntry("defaultview",DAY); |
601 | weeklistviewconfig = config.readNumEntry("weeklistviewconfig",NORMAL); | ||
627 | } | 602 | } |
628 | 603 | ||
629 | void DateBook::saveSettings() | 604 | void DateBook::saveSettings() |
630 | { | 605 | { |
631 | Config config( "qpe" ); | 606 | Config config( "qpe" ); |
632 | Config configDB( "DateBook" ); | 607 | Config configDB( "DateBook" ); |
633 | configDB.setGroup( "Main" ); | 608 | configDB.setGroup( "Main" ); |
634 | configDB.writeEntry("startviewtime",startTime); | 609 | configDB.writeEntry("startviewtime",startTime); |
635 | configDB.writeEntry("alarmpreset",aPreset); | 610 | configDB.writeEntry("alarmpreset",aPreset); |
636 | configDB.writeEntry("presettime",presetTime); | 611 | configDB.writeEntry("presettime",presetTime); |
637 | configDB.writeEntry("jumptocurtime", bJumpToCurTime); | 612 | configDB.writeEntry("jumptocurtime", bJumpToCurTime); |
638 | configDB.writeEntry("rowstyle", rowStyle); | 613 | configDB.writeEntry("rowstyle", rowStyle); |
639 | } | 614 | configDB.writeEntry("defaultview",defaultView); |
640 | 615 | configDB.writeEntry("weeklistviewconfig",weeklistviewconfig); | |
641 | void DateBook::newDefaultView(QAction *a) { | ||
642 | int val=DAY; | ||
643 | if (a->text() == "Day") val=DAY; | ||
644 | if (a->text() == "Week") val=WEEK; | ||
645 | if (a->text() == "WeekLst") val=WEEKLST; | ||
646 | if (a->text() == "Month") val=MONTH; | ||
647 | |||
648 | Config configDB( "DateBook" ); | ||
649 | configDB.setGroup( "Main" ); | ||
650 | configDB.writeEntry("defaultview",val); | ||
651 | } | 616 | } |
652 | 617 | ||
653 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) | 618 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) |
654 | { | 619 | { |
655 | bool needShow = FALSE; | 620 | bool needShow = FALSE; |
656 | if ( msg == "alarm(QDateTime,int)" ) { | 621 | if ( msg == "alarm(QDateTime,int)" ) { |
@@ -659,24 +624,22 @@ void DateBook::appMessage(const QCString& msg, const QByteArray& data) | |||
659 | ds >> when >> warn; | 624 | ds >> when >> warn; |
660 | 625 | ||
661 | // check to make it's okay to continue, | 626 | // check to make it's okay to continue, |
662 | // this is the case that the time was set ahead, and | 627 | // this is the case that the time was set ahead, and |
663 | // we are forced given a stale alarm... | 628 | // we are forced given a stale alarm... |
664 | QDateTime current = QDateTime::currentDateTime(); | 629 | QDateTime current = QDateTime::currentDateTime(); |
665 | if ( current.time().hour() != when.time().hour() | 630 | if ( current.time().hour() != when.time().hour() && current.time().minute() != when.time().minute() ) |
666 | && current.time().minute() != when.time().minute() ) | ||
667 | return; | 631 | return; |
668 | 632 | ||
669 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); | 633 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); |
670 | if ( list.count() > 0 ) { | 634 | if ( list.count() > 0 ) { |
671 | QString msg; | 635 | QString msg; |
672 | bool bSound = FALSE; | 636 | bool bSound = FALSE; |
673 | int stopTimer = 0; | 637 | int stopTimer = 0; |
674 | bool found = FALSE; | 638 | bool found = FALSE; |
675 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); | 639 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); it!=list.end(); ++it ) { |
676 | it!=list.end(); ++it ) { | ||
677 | if ( (*it).event().hasAlarm() ) { | 640 | if ( (*it).event().hasAlarm() ) { |
678 | found = TRUE; | 641 | found = TRUE; |
679 | msg += "<CENTER><B>" + (*it).description() + "</B>" | 642 | msg += "<CENTER><B>" + (*it).description() + "</B>" |
680 | + "<BR>" + (*it).location() + "<BR>" | 643 | + "<BR>" + (*it).location() + "<BR>" |
681 | + TimeString::dateString((*it).event().start(),ampm) | 644 | + TimeString::dateString((*it).event().start(),ampm) |
682 | + (warn | 645 | + (warn |
@@ -693,13 +656,12 @@ void DateBook::appMessage(const QCString& msg, const QByteArray& data) | |||
693 | if ( found ) { | 656 | if ( found ) { |
694 | if ( bSound ) { | 657 | if ( bSound ) { |
695 | Sound::soundAlarm(); | 658 | Sound::soundAlarm(); |
696 | alarmCounter = 0; | 659 | alarmCounter = 0; |
697 | stopTimer = startTimer( 5000 ); | 660 | stopTimer = startTimer( 5000 ); |
698 | } | 661 | } |
699 | |||
700 | QDialog dlg( this, 0, TRUE ); | 662 | QDialog dlg( this, 0, TRUE ); |
701 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); | 663 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); |
702 | QScrollView *view = new QScrollView( &dlg, "scrollView"); | 664 | QScrollView *view = new QScrollView( &dlg, "scrollView"); |
703 | view->setResizePolicy( QScrollView::AutoOneFit ); | 665 | view->setResizePolicy( QScrollView::AutoOneFit ); |
704 | vb->addWidget( view ); | 666 | vb->addWidget( view ); |
705 | QLabel *lblMsg = new QLabel( msg, &dlg ); | 667 | QLabel *lblMsg = new QLabel( msg, &dlg ); |
@@ -717,14 +679,13 @@ void DateBook::appMessage(const QCString& msg, const QByteArray& data) | |||
717 | killTimer( stopTimer ); | 679 | killTimer( stopTimer ); |
718 | } | 680 | } |
719 | } | 681 | } |
720 | } else if ( msg == "nextView()" ) { | 682 | } else if ( msg == "nextView()" ) { |
721 | if ( !qApp-> activeWindow ( )) { | 683 | if ( !qApp-> activeWindow ( )) { |
722 | needShow = TRUE; | 684 | needShow = TRUE; |
723 | } | 685 | } else { |
724 | else { | ||
725 | QWidget* cur = views->visibleWidget(); | 686 | QWidget* cur = views->visibleWidget(); |
726 | if ( cur ) { | 687 | if ( cur ) { |
727 | if ( cur == dayView ) | 688 | if ( cur == dayView ) |
728 | viewWeek(); | 689 | viewWeek(); |
729 | else if ( cur == weekView ) | 690 | else if ( cur == weekView ) |
730 | viewWeekLst(); | 691 | viewWeekLst(); |
@@ -748,18 +709,15 @@ void DateBook::appMessage(const QCString& msg, const QByteArray& data) | |||
748 | } | 709 | } |
749 | } | 710 | } |
750 | 711 | ||
751 | void DateBook::reload() | 712 | void DateBook::reload() |
752 | { | 713 | { |
753 | db->reload(); | 714 | db->reload(); |
754 | if ( dayAction->isOn() ) | 715 | if ( dayAction->isOn() ) viewDay(); |
755 | viewDay(); | 716 | else if ( weekAction->isOn() ) viewWeek(); |
756 | else if ( weekAction->isOn() ) | 717 | else if ( monthAction->isOn() ) viewMonth(); |
757 | viewWeek(); | ||
758 | else if ( monthAction->isOn() ) | ||
759 | viewMonth(); | ||
760 | syncing = FALSE; | 718 | syncing = FALSE; |
761 | } | 719 | } |
762 | 720 | ||
763 | void DateBook::flush() | 721 | void DateBook::flush() |
764 | { | 722 | { |
765 | syncing = TRUE; | 723 | syncing = TRUE; |
@@ -768,16 +726,16 @@ void DateBook::flush() | |||
768 | 726 | ||
769 | void DateBook::timerEvent( QTimerEvent *e ) | 727 | void DateBook::timerEvent( QTimerEvent *e ) |
770 | { | 728 | { |
771 | if ( alarmCounter < 10 ) { | 729 | if ( alarmCounter < 10 ) { |
772 | alarmCounter++; | 730 | alarmCounter++; |
773 | Sound::soundAlarm(); | 731 | Sound::soundAlarm(); |
774 | } | 732 | } else { |
775 | else | ||
776 | killTimer( e->timerId() ); | 733 | killTimer( e->timerId() ); |
777 | } | 734 | } |
735 | } | ||
778 | 736 | ||
779 | void DateBook::changeClock( bool newClock ) | 737 | void DateBook::changeClock( bool newClock ) |
780 | { | 738 | { |
781 | ampm = newClock; | 739 | ampm = newClock; |
782 | // repaint the affected objects... | 740 | // repaint the affected objects... |
783 | if (dayView) dayView->redraw(); | 741 | if (dayView) dayView->redraw(); |
@@ -792,13 +750,13 @@ void DateBook::changeWeek( bool m ) | |||
792 | onMonday = m; | 750 | onMonday = m; |
793 | } | 751 | } |
794 | 752 | ||
795 | void DateBook::slotToday() | 753 | void DateBook::slotToday() |
796 | { | 754 | { |
797 | // we need to view today using default view | 755 | // we need to view today using default view |
798 | viewDefault(QDate::currentDate()); | 756 | view(defaultView,QDate::currentDate()); |
799 | } | 757 | } |
800 | 758 | ||
801 | void DateBook::closeEvent( QCloseEvent *e ) | 759 | void DateBook::closeEvent( QCloseEvent *e ) |
802 | { | 760 | { |
803 | if(syncing) { | 761 | if(syncing) { |
804 | /* no need to save, did that at flush */ | 762 | /* no need to save, did that at flush */ |
@@ -806,15 +764,15 @@ void DateBook::closeEvent( QCloseEvent *e ) | |||
806 | return; | 764 | return; |
807 | } | 765 | } |
808 | 766 | ||
809 | // save settings will generate it's own error messages, no | 767 | // save settings will generate it's own error messages, no |
810 | // need to do checking ourselves. | 768 | // need to do checking ourselves. |
811 | saveSettings(); | 769 | saveSettings(); |
812 | if ( db->save() ) | 770 | if ( db->save() ) { |
813 | e->accept(); | 771 | e->accept(); |
814 | else { | 772 | } else { |
815 | if ( QMessageBox::critical( this, tr( "Out of space" ), | 773 | if ( QMessageBox::critical( this, tr( "Out of space" ), |
816 | tr("Calendar was unable to save\n" | 774 | tr("Calendar was unable to save\n" |
817 | "your changes.\n" | 775 | "your changes.\n" |
818 | "Free up some space and try again.\n" | 776 | "Free up some space and try again.\n" |
819 | "\nQuit anyway?"), | 777 | "\nQuit anyway?"), |
820 | QMessageBox::Yes|QMessageBox::Escape, | 778 | QMessageBox::Yes|QMessageBox::Escape, |
diff --git a/core/pim/datebook/datebook.h b/core/pim/datebook/datebook.h index 623862b..5216770 100644 --- a/core/pim/datebook/datebook.h +++ b/core/pim/datebook/datebook.h | |||
@@ -21,12 +21,15 @@ | |||
21 | #define DATEBOOK_H | 21 | #define DATEBOOK_H |
22 | 22 | ||
23 | #include <qpe/datebookdb.h> | 23 | #include <qpe/datebookdb.h> |
24 | 24 | ||
25 | #include <qmainwindow.h> | 25 | #include <qmainwindow.h> |
26 | 26 | ||
27 | enum { DAY=1,WEEK,WEEKLST,MONTH };// defaultView values | ||
28 | enum { NONE=0,NORMAL,EXTENDED };// WeekLstView's modes. | ||
29 | |||
27 | class QAction; | 30 | class QAction; |
28 | class QWidgetStack; | 31 | class QWidgetStack; |
29 | class DateBookDay; | 32 | class DateBookDay; |
30 | class DateBookWeek; | 33 | class DateBookWeek; |
31 | class DateBookWeekLst; | 34 | class DateBookWeekLst; |
32 | class DateBookMonth; | 35 | class DateBookMonth; |
@@ -64,13 +67,12 @@ public slots: | |||
64 | void reload(); | 67 | void reload(); |
65 | 68 | ||
66 | private slots: | 69 | private slots: |
67 | void fileNew(); | 70 | void fileNew(); |
68 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str, const QString &location=0); | 71 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str, const QString &location=0); |
69 | void slotSettings(); | 72 | void slotSettings(); |
70 | void newDefaultView(QAction *a); | ||
71 | void slotToday();// view today | 73 | void slotToday();// view today |
72 | void changeClock( bool newClock ); | 74 | void changeClock( bool newClock ); |
73 | void changeWeek( bool newDay ); | 75 | void changeWeek( bool newDay ); |
74 | void appMessage(const QCString& msg, const QByteArray& data); | 76 | void appMessage(const QCString& msg, const QByteArray& data); |
75 | // handle key events in the day view... | 77 | // handle key events in the day view... |
76 | void slotNewEventFromKey( const QString &str ); | 78 | void slotNewEventFromKey( const QString &str ); |
@@ -109,16 +111,18 @@ private: | |||
109 | QWidgetStack *views; | 111 | QWidgetStack *views; |
110 | DateBookDay *dayView; | 112 | DateBookDay *dayView; |
111 | DateBookWeek *weekView; | 113 | DateBookWeek *weekView; |
112 | DateBookMonth *monthView; | 114 | DateBookMonth *monthView; |
113 | DateBookWeekLst *weekLstView; | 115 | DateBookWeekLst *weekLstView; |
114 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; | 116 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; |
117 | int weeklistviewconfig; | ||
115 | bool aPreset; // have everything set to alarm? | 118 | bool aPreset; // have everything set to alarm? |
116 | int presetTime; // the standard time for the alarm | 119 | int presetTime; // the standard time for the alarm |
117 | int startTime; | 120 | int startTime; |
118 | int rowStyle; | 121 | int rowStyle; |
122 | int defaultView; | ||
119 | bool bJumpToCurTime; //should jump to current time in dayview? | 123 | bool bJumpToCurTime; //should jump to current time in dayview? |
120 | bool ampm; | 124 | bool ampm; |
121 | bool onMonday; | 125 | bool onMonday; |
122 | 126 | ||
123 | bool syncing; | 127 | bool syncing; |
124 | bool inSearch; | 128 | bool inSearch; |
diff --git a/core/pim/datebook/datebooksettingsbase.ui b/core/pim/datebook/datebooksettingsbase.ui index 816a441..3836330 100644 --- a/core/pim/datebook/datebooksettingsbase.ui +++ b/core/pim/datebook/datebooksettingsbase.ui | |||
@@ -29,85 +29,83 @@ | |||
29 | </property> | 29 | </property> |
30 | <property stdset="1"> | 30 | <property stdset="1"> |
31 | <name>geometry</name> | 31 | <name>geometry</name> |
32 | <rect> | 32 | <rect> |
33 | <x>0</x> | 33 | <x>0</x> |
34 | <y>0</y> | 34 | <y>0</y> |
35 | <width>220</width> | 35 | <width>273</width> |
36 | <height>290</height> | 36 | <height>303</height> |
37 | </rect> | 37 | </rect> |
38 | </property> | 38 | </property> |
39 | <property stdset="1"> | 39 | <property stdset="1"> |
40 | <name>caption</name> | 40 | <name>caption</name> |
41 | <string>Preferences</string> | 41 | <string>Preferences</string> |
42 | </property> | 42 | </property> |
43 | <property> | 43 | <property> |
44 | <name>layoutMargin</name> | 44 | <name>layoutMargin</name> |
45 | </property> | 45 | </property> |
46 | <property> | 46 | <property> |
47 | <name>layoutSpacing</name> | 47 | <name>layoutSpacing</name> |
48 | </property> | 48 | </property> |
49 | <grid> | 49 | <vbox> |
50 | <property stdset="1"> | 50 | <property stdset="1"> |
51 | <name>margin</name> | 51 | <name>margin</name> |
52 | <number>11</number> | 52 | <number>11</number> |
53 | </property> | 53 | </property> |
54 | <property stdset="1"> | 54 | <property stdset="1"> |
55 | <name>spacing</name> | 55 | <name>spacing</name> |
56 | <number>6</number> | 56 | <number>6</number> |
57 | </property> | 57 | </property> |
58 | <widget row="0" column="0" > | 58 | <widget> |
59 | <class>QGroupBox</class> | 59 | <class>QTabWidget</class> |
60 | <property stdset="1"> | 60 | <property stdset="1"> |
61 | <name>name</name> | 61 | <name>name</name> |
62 | <cstring>fraStart</cstring> | 62 | <cstring>TabWidget2</cstring> |
63 | </property> | 63 | </property> |
64 | <widget> | ||
65 | <class>QWidget</class> | ||
64 | <property stdset="1"> | 66 | <property stdset="1"> |
65 | <name>frameShape</name> | 67 | <name>name</name> |
66 | <enum>Box</enum> | 68 | <cstring>tab</cstring> |
67 | </property> | 69 | </property> |
70 | <attribute> | ||
71 | <name>title</name> | ||
72 | <string>Views</string> | ||
73 | </attribute> | ||
74 | <vbox> | ||
68 | <property stdset="1"> | 75 | <property stdset="1"> |
69 | <name>frameShadow</name> | 76 | <name>margin</name> |
70 | <enum>Sunken</enum> | 77 | <number>11</number> |
71 | </property> | 78 | </property> |
72 | <property stdset="1"> | 79 | <property stdset="1"> |
73 | <name>title</name> | 80 | <name>spacing</name> |
74 | <string>Start viewing events</string> | 81 | <number>6</number> |
75 | </property> | 82 | </property> |
76 | <widget> | 83 | <widget> |
77 | <class>QLayoutWidget</class> | 84 | <class>QLayoutWidget</class> |
78 | <property stdset="1"> | 85 | <property stdset="1"> |
79 | <name>name</name> | 86 | <name>name</name> |
80 | <cstring>Layout6</cstring> | 87 | <cstring>Layout5</cstring> |
81 | </property> | ||
82 | <property stdset="1"> | ||
83 | <name>geometry</name> | ||
84 | <rect> | ||
85 | <x>3</x> | ||
86 | <y>21</y> | ||
87 | <width>210</width> | ||
88 | <height>53</height> | ||
89 | </rect> | ||
90 | </property> | 88 | </property> |
91 | <grid> | 89 | <hbox> |
92 | <property stdset="1"> | 90 | <property stdset="1"> |
93 | <name>margin</name> | 91 | <name>margin</name> |
94 | <number>0</number> | 92 | <number>0</number> |
95 | </property> | 93 | </property> |
96 | <property stdset="1"> | 94 | <property stdset="1"> |
97 | <name>spacing</name> | 95 | <name>spacing</name> |
98 | <number>6</number> | 96 | <number>6</number> |
99 | </property> | 97 | </property> |
100 | <spacer row="1" column="0" > | 98 | <spacer> |
101 | <property> | 99 | <property> |
102 | <name>name</name> | 100 | <name>name</name> |
103 | <cstring>Spacer1</cstring> | 101 | <cstring>Spacer1</cstring> |
104 | </property> | 102 | </property> |
105 | <property stdset="1"> | 103 | <property stdset="1"> |
106 | <name>orientation</name> | 104 | <name>orientation</name> |
107 | <enum>Vertical</enum> | 105 | <enum>Horizontal</enum> |
108 | </property> | 106 | </property> |
109 | <property stdset="1"> | 107 | <property stdset="1"> |
110 | <name>sizeType</name> | 108 | <name>sizeType</name> |
111 | <enum>Expanding</enum> | 109 | <enum>Expanding</enum> |
112 | </property> | 110 | </property> |
113 | <property> | 111 | <property> |
@@ -115,100 +113,240 @@ | |||
115 | <size> | 113 | <size> |
116 | <width>20</width> | 114 | <width>20</width> |
117 | <height>20</height> | 115 | <height>20</height> |
118 | </size> | 116 | </size> |
119 | </property> | 117 | </property> |
120 | </spacer> | 118 | </spacer> |
121 | <widget row="0" column="0" > | 119 | <widget> |
122 | <class>QLayoutWidget</class> | 120 | <class>QLabel</class> |
123 | <property stdset="1"> | 121 | <property stdset="1"> |
124 | <name>name</name> | 122 | <name>name</name> |
125 | <cstring>Layout1</cstring> | 123 | <cstring>TextLabel1_2</cstring> |
124 | </property> | ||
125 | <property stdset="1"> | ||
126 | <name>text</name> | ||
127 | <string>Default view:</string> | ||
128 | </property> | ||
129 | </widget> | ||
130 | <widget> | ||
131 | <class>QComboBox</class> | ||
132 | <item> | ||
133 | <property> | ||
134 | <name>text</name> | ||
135 | <string>Day</string> | ||
136 | </property> | ||
137 | </item> | ||
138 | <item> | ||
139 | <property> | ||
140 | <name>text</name> | ||
141 | <string>Week</string> | ||
142 | </property> | ||
143 | </item> | ||
144 | <item> | ||
145 | <property> | ||
146 | <name>text</name> | ||
147 | <string>Week List</string> | ||
148 | </property> | ||
149 | </item> | ||
150 | <item> | ||
151 | <property> | ||
152 | <name>text</name> | ||
153 | <string>Month</string> | ||
154 | </property> | ||
155 | </item> | ||
156 | <property stdset="1"> | ||
157 | <name>name</name> | ||
158 | <cstring>comboDefaultView</cstring> | ||
159 | </property> | ||
160 | </widget> | ||
161 | <spacer> | ||
162 | <property> | ||
163 | <name>name</name> | ||
164 | <cstring>Spacer2</cstring> | ||
165 | </property> | ||
166 | <property stdset="1"> | ||
167 | <name>orientation</name> | ||
168 | <enum>Horizontal</enum> | ||
169 | </property> | ||
170 | <property stdset="1"> | ||
171 | <name>sizeType</name> | ||
172 | <enum>Expanding</enum> | ||
173 | </property> | ||
174 | <property> | ||
175 | <name>sizeHint</name> | ||
176 | <size> | ||
177 | <width>20</width> | ||
178 | <height>20</height> | ||
179 | </size> | ||
180 | </property> | ||
181 | </spacer> | ||
182 | </hbox> | ||
183 | </widget> | ||
184 | <widget> | ||
185 | <class>QGroupBox</class> | ||
186 | <property stdset="1"> | ||
187 | <name>name</name> | ||
188 | <cstring>GroupBox4</cstring> | ||
126 | </property> | 189 | </property> |
127 | <hbox> | 190 | <property stdset="1"> |
191 | <name>title</name> | ||
192 | <string>Day</string> | ||
193 | </property> | ||
194 | <vbox> | ||
128 | <property stdset="1"> | 195 | <property stdset="1"> |
129 | <name>margin</name> | 196 | <name>margin</name> |
130 | <number>0</number> | 197 | <number>11</number> |
131 | </property> | 198 | </property> |
132 | <property stdset="1"> | 199 | <property stdset="1"> |
133 | <name>spacing</name> | 200 | <name>spacing</name> |
134 | <number>6</number> | 201 | <number>6</number> |
135 | </property> | 202 | </property> |
136 | <widget> | 203 | <widget> |
137 | <class>QLabel</class> | 204 | <class>QCheckBox</class> |
138 | <property stdset="1"> | 205 | <property stdset="1"> |
139 | <name>name</name> | 206 | <name>name</name> |
140 | <cstring>lblStartTime</cstring> | 207 | <cstring>chkJumpToCurTime</cstring> |
141 | </property> | 208 | </property> |
142 | <property stdset="1"> | 209 | <property stdset="1"> |
143 | <name>text</name> | 210 | <name>text</name> |
144 | <string>Start Time:</string> | 211 | <string>Jump to current time</string> |
145 | </property> | 212 | </property> |
146 | </widget> | 213 | </widget> |
147 | <widget> | 214 | <widget> |
148 | <class>QSpinBox</class> | 215 | <class>QLayoutWidget</class> |
149 | <property stdset="1"> | 216 | <property stdset="1"> |
150 | <name>name</name> | 217 | <name>name</name> |
151 | <cstring>spinStart</cstring> | 218 | <cstring>Layout5</cstring> |
152 | </property> | 219 | </property> |
220 | <hbox> | ||
153 | <property stdset="1"> | 221 | <property stdset="1"> |
154 | <name>suffix</name> | 222 | <name>margin</name> |
155 | <string>:00</string> | 223 | <number>0</number> |
156 | </property> | 224 | </property> |
157 | <property stdset="1"> | 225 | <property stdset="1"> |
158 | <name>wrapping</name> | 226 | <name>spacing</name> |
159 | <bool>true</bool> | 227 | <number>6</number> |
160 | </property> | 228 | </property> |
229 | <widget> | ||
230 | <class>QLabel</class> | ||
161 | <property stdset="1"> | 231 | <property stdset="1"> |
162 | <name>maxValue</name> | 232 | <name>name</name> |
163 | <number>23</number> | 233 | <cstring>TextLabel1</cstring> |
234 | </property> | ||
235 | <property stdset="1"> | ||
236 | <name>text</name> | ||
237 | <string>Row style:</string> | ||
164 | </property> | 238 | </property> |
165 | </widget> | 239 | </widget> |
166 | </hbox> | 240 | <widget> |
241 | <class>QComboBox</class> | ||
242 | <item> | ||
243 | <property> | ||
244 | <name>text</name> | ||
245 | <string>Default</string> | ||
246 | </property> | ||
247 | </item> | ||
248 | <item> | ||
249 | <property> | ||
250 | <name>text</name> | ||
251 | <string>Medium</string> | ||
252 | </property> | ||
253 | </item> | ||
254 | <item> | ||
255 | <property> | ||
256 | <name>text</name> | ||
257 | <string>Large</string> | ||
258 | </property> | ||
259 | </item> | ||
260 | <property stdset="1"> | ||
261 | <name>name</name> | ||
262 | <cstring>comboRowStyle</cstring> | ||
263 | </property> | ||
167 | </widget> | 264 | </widget> |
168 | </grid> | 265 | </hbox> |
169 | </widget> | 266 | </widget> |
267 | </vbox> | ||
170 | </widget> | 268 | </widget> |
171 | <widget row="1" column="0" > | 269 | <widget> |
172 | <class>QGroupBox</class> | 270 | <class>QGroupBox</class> |
173 | <property stdset="1"> | 271 | <property stdset="1"> |
174 | <name>name</name> | 272 | <name>name</name> |
175 | <cstring>fraAlarm</cstring> | 273 | <cstring>GroupBox5</cstring> |
176 | </property> | 274 | </property> |
177 | <property stdset="1"> | 275 | <property stdset="1"> |
178 | <name>title</name> | 276 | <name>title</name> |
179 | <string>Alarm Settings</string> | 277 | <string>Week List</string> |
278 | </property> | ||
279 | <vbox> | ||
280 | <property stdset="1"> | ||
281 | <name>margin</name> | ||
282 | <number>11</number> | ||
283 | </property> | ||
284 | <property stdset="1"> | ||
285 | <name>spacing</name> | ||
286 | <number>6</number> | ||
180 | </property> | 287 | </property> |
181 | <widget> | 288 | <widget> |
182 | <class>QLayoutWidget</class> | 289 | <class>QLayoutWidget</class> |
183 | <property stdset="1"> | 290 | <property stdset="1"> |
184 | <name>name</name> | 291 | <name>name</name> |
185 | <cstring>Layout4</cstring> | 292 | <cstring>Layout6</cstring> |
186 | </property> | ||
187 | <property stdset="1"> | ||
188 | <name>geometry</name> | ||
189 | <rect> | ||
190 | <x>10</x> | ||
191 | <y>20</y> | ||
192 | <width>200</width> | ||
193 | <height>53</height> | ||
194 | </rect> | ||
195 | </property> | 293 | </property> |
196 | <grid> | 294 | <hbox> |
197 | <property stdset="1"> | 295 | <property stdset="1"> |
198 | <name>margin</name> | 296 | <name>margin</name> |
199 | <number>0</number> | 297 | <number>0</number> |
200 | </property> | 298 | </property> |
201 | <property stdset="1"> | 299 | <property stdset="1"> |
202 | <name>spacing</name> | 300 | <name>spacing</name> |
203 | <number>6</number> | 301 | <number>6</number> |
204 | </property> | 302 | </property> |
205 | <spacer row="1" column="0" > | 303 | <widget> |
304 | <class>QLabel</class> | ||
305 | <property stdset="1"> | ||
306 | <name>name</name> | ||
307 | <cstring>TextLabel2</cstring> | ||
308 | </property> | ||
309 | <property stdset="1"> | ||
310 | <name>text</name> | ||
311 | <string>Time display</string> | ||
312 | </property> | ||
313 | </widget> | ||
314 | <widget> | ||
315 | <class>QComboBox</class> | ||
316 | <item> | ||
317 | <property> | ||
318 | <name>text</name> | ||
319 | <string>None</string> | ||
320 | </property> | ||
321 | </item> | ||
322 | <item> | ||
323 | <property> | ||
324 | <name>text</name> | ||
325 | <string>Start</string> | ||
326 | </property> | ||
327 | </item> | ||
328 | <item> | ||
206 | <property> | 329 | <property> |
330 | <name>text</name> | ||
331 | <string>Start-End</string> | ||
332 | </property> | ||
333 | </item> | ||
334 | <property stdset="1"> | ||
207 | <name>name</name> | 335 | <name>name</name> |
208 | <cstring>Spacer2</cstring> | 336 | <cstring>comboWeekListView</cstring> |
337 | </property> | ||
338 | </widget> | ||
339 | </hbox> | ||
340 | </widget> | ||
341 | </vbox> | ||
342 | </widget> | ||
343 | <spacer> | ||
344 | <property> | ||
345 | <name>name</name> | ||
346 | <cstring>Spacer3_2</cstring> | ||
209 | </property> | 347 | </property> |
210 | <property stdset="1"> | 348 | <property stdset="1"> |
211 | <name>orientation</name> | 349 | <name>orientation</name> |
212 | <enum>Vertical</enum> | 350 | <enum>Vertical</enum> |
213 | </property> | 351 | </property> |
214 | <property stdset="1"> | 352 | <property stdset="1"> |
@@ -220,13 +358,53 @@ | |||
220 | <size> | 358 | <size> |
221 | <width>20</width> | 359 | <width>20</width> |
222 | <height>20</height> | 360 | <height>20</height> |
223 | </size> | 361 | </size> |
224 | </property> | 362 | </property> |
225 | </spacer> | 363 | </spacer> |
226 | <widget row="0" column="0" > | 364 | </vbox> |
365 | </widget> | ||
366 | <widget> | ||
367 | <class>QWidget</class> | ||
368 | <property stdset="1"> | ||
369 | <name>name</name> | ||
370 | <cstring>tab</cstring> | ||
371 | </property> | ||
372 | <attribute> | ||
373 | <name>title</name> | ||
374 | <string>Misc</string> | ||
375 | </attribute> | ||
376 | <vbox> | ||
377 | <property stdset="1"> | ||
378 | <name>margin</name> | ||
379 | <number>11</number> | ||
380 | </property> | ||
381 | <property stdset="1"> | ||
382 | <name>spacing</name> | ||
383 | <number>6</number> | ||
384 | </property> | ||
385 | <widget> | ||
386 | <class>QGroupBox</class> | ||
387 | <property stdset="1"> | ||
388 | <name>name</name> | ||
389 | <cstring>GroupBox6</cstring> | ||
390 | </property> | ||
391 | <property stdset="1"> | ||
392 | <name>title</name> | ||
393 | <string>Alarm Settings</string> | ||
394 | </property> | ||
395 | <vbox> | ||
396 | <property stdset="1"> | ||
397 | <name>margin</name> | ||
398 | <number>11</number> | ||
399 | </property> | ||
400 | <property stdset="1"> | ||
401 | <name>spacing</name> | ||
402 | <number>6</number> | ||
403 | </property> | ||
404 | <widget> | ||
227 | <class>QLayoutWidget</class> | 405 | <class>QLayoutWidget</class> |
228 | <property stdset="1"> | 406 | <property stdset="1"> |
229 | <name>name</name> | 407 | <name>name</name> |
230 | <cstring>Layout6</cstring> | 408 | <cstring>Layout6</cstring> |
231 | </property> | 409 | </property> |
232 | <hbox> | 410 | <hbox> |
@@ -279,39 +457,38 @@ | |||
279 | <name>value</name> | 457 | <name>value</name> |
280 | <number>5</number> | 458 | <number>5</number> |
281 | </property> | 459 | </property> |
282 | </widget> | 460 | </widget> |
283 | </hbox> | 461 | </hbox> |
284 | </widget> | 462 | </widget> |
285 | </grid> | 463 | </vbox> |
286 | </widget> | ||
287 | </widget> | 464 | </widget> |
288 | <widget row="2" column="0" > | 465 | <widget> |
289 | <class>QGroupBox</class> | 466 | <class>QGroupBox</class> |
290 | <property stdset="1"> | 467 | <property stdset="1"> |
291 | <name>name</name> | 468 | <name>name</name> |
292 | <cstring>fraMisc</cstring> | 469 | <cstring>GroupBox7</cstring> |
293 | </property> | 470 | </property> |
294 | <property stdset="1"> | 471 | <property stdset="1"> |
295 | <name>title</name> | 472 | <name>title</name> |
296 | <string>Misc</string> | 473 | <string>Start viewing events</string> |
474 | </property> | ||
475 | <vbox> | ||
476 | <property stdset="1"> | ||
477 | <name>margin</name> | ||
478 | <number>11</number> | ||
479 | </property> | ||
480 | <property stdset="1"> | ||
481 | <name>spacing</name> | ||
482 | <number>6</number> | ||
297 | </property> | 483 | </property> |
298 | <widget> | 484 | <widget> |
299 | <class>QLayoutWidget</class> | 485 | <class>QLayoutWidget</class> |
300 | <property stdset="1"> | 486 | <property stdset="1"> |
301 | <name>name</name> | 487 | <name>name</name> |
302 | <cstring>Layout5</cstring> | 488 | <cstring>Layout1</cstring> |
303 | </property> | ||
304 | <property stdset="1"> | ||
305 | <name>geometry</name> | ||
306 | <rect> | ||
307 | <x>10</x> | ||
308 | <y>40</y> | ||
309 | <width>170</width> | ||
310 | <height>24</height> | ||
311 | </rect> | ||
312 | </property> | 489 | </property> |
313 | <hbox> | 490 | <hbox> |
314 | <property stdset="1"> | 491 | <property stdset="1"> |
315 | <name>margin</name> | 492 | <name>margin</name> |
316 | <number>0</number> | 493 | <number>0</number> |
317 | </property> | 494 | </property> |
@@ -320,68 +497,67 @@ | |||
320 | <number>6</number> | 497 | <number>6</number> |
321 | </property> | 498 | </property> |
322 | <widget> | 499 | <widget> |
323 | <class>QLabel</class> | 500 | <class>QLabel</class> |
324 | <property stdset="1"> | 501 | <property stdset="1"> |
325 | <name>name</name> | 502 | <name>name</name> |
326 | <cstring>TextLabel1</cstring> | 503 | <cstring>lblStartTime</cstring> |
327 | </property> | 504 | </property> |
328 | <property stdset="1"> | 505 | <property stdset="1"> |
329 | <name>text</name> | 506 | <name>text</name> |
330 | <string>Row style:</string> | 507 | <string>Start Time:</string> |
331 | </property> | 508 | </property> |
332 | </widget> | 509 | </widget> |
333 | <widget> | 510 | <widget> |
334 | <class>QComboBox</class> | 511 | <class>QSpinBox</class> |
335 | <item> | 512 | <property stdset="1"> |
336 | <property> | 513 | <name>name</name> |
337 | <name>text</name> | 514 | <cstring>spinStart</cstring> |
338 | <string>Default</string> | ||
339 | </property> | 515 | </property> |
340 | </item> | 516 | <property stdset="1"> |
341 | <item> | 517 | <name>suffix</name> |
342 | <property> | 518 | <string>:00</string> |
343 | <name>text</name> | ||
344 | <string>Medium</string> | ||
345 | </property> | 519 | </property> |
346 | </item> | 520 | <property stdset="1"> |
347 | <item> | 521 | <name>wrapping</name> |
348 | <property> | 522 | <bool>true</bool> |
349 | <name>text</name> | ||
350 | <string>Large</string> | ||
351 | </property> | 523 | </property> |
352 | </item> | ||
353 | <property stdset="1"> | 524 | <property stdset="1"> |
354 | <name>name</name> | 525 | <name>maxValue</name> |
355 | <cstring>comboRowStyle</cstring> | 526 | <number>23</number> |
356 | </property> | 527 | </property> |
357 | </widget> | 528 | </widget> |
358 | </hbox> | 529 | </hbox> |
359 | </widget> | 530 | </widget> |
360 | <widget> | 531 | </vbox> |
361 | <class>QCheckBox</class> | 532 | </widget> |
362 | <property stdset="1"> | 533 | <spacer> |
534 | <property> | ||
363 | <name>name</name> | 535 | <name>name</name> |
364 | <cstring>chkJumpToCurTime</cstring> | 536 | <cstring>Spacer9</cstring> |
365 | </property> | 537 | </property> |
366 | <property stdset="1"> | 538 | <property stdset="1"> |
367 | <name>geometry</name> | 539 | <name>orientation</name> |
368 | <rect> | 540 | <enum>Vertical</enum> |
369 | <x>10</x> | ||
370 | <y>20</y> | ||
371 | <width>200</width> | ||
372 | <height>20</height> | ||
373 | </rect> | ||
374 | </property> | 541 | </property> |
375 | <property stdset="1"> | 542 | <property stdset="1"> |
376 | <name>text</name> | 543 | <name>sizeType</name> |
377 | <string>Jump to current time (dayview)</string> | 544 | <enum>Expanding</enum> |
378 | </property> | 545 | </property> |
546 | <property> | ||
547 | <name>sizeHint</name> | ||
548 | <size> | ||
549 | <width>20</width> | ||
550 | <height>20</height> | ||
551 | </size> | ||
552 | </property> | ||
553 | </spacer> | ||
554 | </vbox> | ||
379 | </widget> | 555 | </widget> |
380 | </widget> | 556 | </widget> |
381 | </grid> | 557 | </vbox> |
382 | </widget> | 558 | </widget> |
383 | <connections> | 559 | <connections> |
384 | <connection> | 560 | <connection> |
385 | <sender>chkAlarmPreset</sender> | 561 | <sender>chkAlarmPreset</sender> |
386 | <signal>toggled(bool)</signal> | 562 | <signal>toggled(bool)</signal> |
387 | <receiver>spinPreset</receiver> | 563 | <receiver>spinPreset</receiver> |
diff --git a/core/pim/datebook/datebookweeklst.cpp b/core/pim/datebook/datebookweeklst.cpp index 3d6a029..3c8fc89 100644 --- a/core/pim/datebook/datebookweeklst.cpp +++ b/core/pim/datebook/datebookweeklst.cpp | |||
@@ -1,10 +1,12 @@ | |||
1 | #include "datebookweeklst.h" | 1 | #include "datebookweeklst.h" |
2 | 2 | ||
3 | #include "datebookweekheaderimpl.h" | 3 | #include "datebookweekheaderimpl.h" |
4 | 4 | ||
5 | #include "datebook.h" | ||
6 | |||
5 | #include <qpe/calendar.h> | 7 | #include <qpe/calendar.h> |
6 | #include <qpe/datebookdb.h> | 8 | #include <qpe/datebookdb.h> |
7 | #include <qpe/event.h> | 9 | #include <qpe/event.h> |
8 | #include <qpe/qpeapplication.h> | 10 | #include <qpe/qpeapplication.h> |
9 | #include <qpe/timestring.h> | 11 | #include <qpe/timestring.h> |
10 | #include <qpe/datebookmonth.h> | 12 | #include <qpe/datebookmonth.h> |
@@ -140,30 +142,50 @@ void DateBookWeekLstDayHdr::newEvent() { | |||
140 | start.setTime(QTime(10,0)); | 142 | start.setTime(QTime(10,0)); |
141 | stop.setTime(QTime(12,0)); | 143 | stop.setTime(QTime(12,0)); |
142 | 144 | ||
143 | emit addEvent(start,stop,"",0); | 145 | emit addEvent(start,stop,"",0); |
144 | } | 146 | } |
145 | DateBookWeekLstEvent::DateBookWeekLstEvent(const EffectiveEvent &ev, | 147 | DateBookWeekLstEvent::DateBookWeekLstEvent(const EffectiveEvent &ev, |
148 | int weeklistviewconfig, | ||
146 | QWidget* parent, | 149 | QWidget* parent, |
147 | const char* name, | 150 | const char* name, |
148 | WFlags fl) : | 151 | WFlags fl ) : OClickableLabel(parent,name,fl), event(ev) |
149 | OClickableLabel(parent,name,fl), | ||
150 | event(ev) | ||
151 | { | 152 | { |
152 | char s[10]; | 153 | // old values... lastday = "__|__", middle=" |---", Firstday="00:00", |
153 | if ( ev.startDate() != ev.date() ) { // multiday event (not first day) | 154 | QString s,start,middle,end,day; |
154 | if ( ev.endDate() == ev.date() ) { // last day | 155 | |
155 | strcpy(s, "__|__"); | 156 | qDebug("weeklistviewconfig=%d",weeklistviewconfig); |
156 | } else { | 157 | if(weeklistviewconfig==NONE) {// No times displayed. |
157 | strcpy(s, " |---"); | 158 | // start.sprintf("%.2d:%.2d-",ev.start().hour(),ev.start().minute()); |
159 | // middle.sprintf("<--->"); | ||
160 | // end.sprintf("-%.2d:%.2d",ev.end().hour(),ev.end().minute()); | ||
161 | // day.sprintf("%.2d:%.2d-%.2d:%.2d",ev.start().hour(),ev.start().minute(),ev.end().hour(),ev.end().minute()); | ||
162 | } else if(weeklistviewconfig==NORMAL) {// "Normal", only display start time. | ||
163 | start.sprintf("%.2d:%.2d",ev.start().hour(),ev.start().minute()); | ||
164 | middle.sprintf(" |---"); | ||
165 | end.sprintf("__|__"); | ||
166 | day.sprintf("%.2d:%.2d",ev.start().hour(),ev.start().minute()); | ||
167 | } else if(weeklistviewconfig==EXTENDED) { // Extended mode, display start and end times. | ||
168 | start.sprintf("%.2d:%.2d-",ev.start().hour(),ev.start().minute()); | ||
169 | middle.sprintf("<--->"); | ||
170 | end.sprintf("-%.2d:%.2d",ev.end().hour(),ev.end().minute()); | ||
171 | day.sprintf("%.2d:%.2d-%.2d:%.2d",ev.start().hour(),ev.start().minute(),ev.end().hour(),ev.end().minute()); | ||
172 | } | ||
173 | |||
174 | if(ev.event().type() == Event::Normal) { | ||
175 | if(ev.startDate()==ev.date() && ev.endDate()==ev.date()) {// day event. | ||
176 | s=day; | ||
177 | } else if(ev.startDate()==ev.date()) {// start event. | ||
178 | s=start; | ||
179 | } else if(ev.endDate()==ev.date()) { // end event. | ||
180 | s=end; | ||
181 | } else {// middle day. | ||
182 | s=middle; | ||
158 | } | 183 | } |
159 | } else { | 184 | } else { |
160 | if(ev.event().type() == Event::Normal ) | 185 | s=""; |
161 | sprintf(s,"%.2d:%.2d",ev.start().hour(),ev.start().minute()); | ||
162 | else | ||
163 | sprintf(s," "); | ||
164 | } | 186 | } |
165 | setText(QString(s) + " " + ev.description()); | 187 | setText(QString(s) + " " + ev.description()); |
166 | connect(this, SIGNAL(clicked()), this, SLOT(editMe())); | 188 | connect(this, SIGNAL(clicked()), this, SLOT(editMe())); |
167 | setAlignment( int( QLabel::WordBreak | QLabel::AlignLeft ) ); | 189 | setAlignment( int( QLabel::WordBreak | QLabel::AlignLeft ) ); |
168 | } | 190 | } |
169 | void DateBookWeekLstEvent::editMe() { | 191 | void DateBookWeekLstEvent::editMe() { |
@@ -174,51 +196,50 @@ void DateBookWeekLstEvent::editMe() { | |||
174 | DateBookWeekLstView::DateBookWeekLstView(QValueList<EffectiveEvent> &ev, | 196 | DateBookWeekLstView::DateBookWeekLstView(QValueList<EffectiveEvent> &ev, |
175 | const QDate &d, bool onM, | 197 | const QDate &d, bool onM, |
176 | QWidget* parent, | 198 | QWidget* parent, |
177 | const char* name, WFlags fl) | 199 | const char* name, WFlags fl) |
178 | : QWidget( parent, name, fl ) | 200 | : QWidget( parent, name, fl ) |
179 | { | 201 | { |
202 | Config config("DateBook"); | ||
203 | config.setGroup("Main"); | ||
204 | int weeklistviewconfig=config.readNumEntry("weeklistviewconfig", NORMAL); | ||
205 | qDebug("Read weeklistviewconfig: %d",weeklistviewconfig); | ||
206 | |||
180 | onMonday=onM; | 207 | onMonday=onM; |
181 | setPalette(white); | 208 | setPalette(white); |
182 | setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding)); | 209 | setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding)); |
183 | 210 | ||
184 | QVBoxLayout *layout = new QVBoxLayout( this ); | 211 | QVBoxLayout *layout = new QVBoxLayout( this ); |
185 | 212 | ||
186 | qBubbleSort(ev); | 213 | qBubbleSort(ev); |
187 | QValueListIterator<EffectiveEvent> it; | 214 | QValueListIterator<EffectiveEvent> it; |
188 | it=ev.begin(); | 215 | it=ev.begin(); |
189 | 216 | ||
190 | int dayOrder[7]; | 217 | int dayOrder[7]; |
191 | if (onMonday) | 218 | if (onMonday) { |
192 | for (int d=0; d<7; d++) dayOrder[d]=d+1; | 219 | for (int d=0; d<7; d++) dayOrder[d]=d+1; |
193 | else { | 220 | } else { |
194 | for (int d=0; d<7; d++) dayOrder[d]=d; | 221 | for (int d=0; d<7; d++) dayOrder[d]=d; |
195 | dayOrder[0]=7; | 222 | dayOrder[0]=7; |
196 | } | 223 | } |
197 | 224 | ||
198 | for (int i=0; i<7; i++) { | 225 | for (int i=0; i<7; i++) { |
199 | // Header | 226 | // Header |
200 | DateBookWeekLstDayHdr *hdr=new DateBookWeekLstDayHdr(d.addDays(i), | 227 | DateBookWeekLstDayHdr *hdr=new DateBookWeekLstDayHdr(d.addDays(i), onMonday,this); |
201 | onMonday,this); | ||
202 | connect(hdr, SIGNAL(showDate(int,int,int)), | 228 | connect(hdr, SIGNAL(showDate(int,int,int)), |
203 | this, SIGNAL(showDate(int,int,int))); | 229 | this, SIGNAL(showDate(int,int,int))); |
204 | connect(hdr, SIGNAL(addEvent(const QDateTime &, | 230 | connect(hdr, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &)), |
205 | const QDateTime &, | 231 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &))); |
206 | const QString &, const QString &)), | ||
207 | this, SIGNAL(addEvent(const QDateTime &, | ||
208 | const QDateTime &, | ||
209 | const QString &, const QString &))); | ||
210 | layout->addWidget(hdr); | 232 | layout->addWidget(hdr); |
211 | 233 | ||
212 | // Events | 234 | // Events |
213 | while ( (*it).date().dayOfWeek() == dayOrder[i] && it!=ev.end() ) { | 235 | while ( (*it).date().dayOfWeek() == dayOrder[i] && it!=ev.end() ) { |
214 | if(!(((*it).end().hour()==0) && ((*it).end().minute()==0) && ((*it).startDate()!=(*it).date()))) {// Skip events ending at 00:00 starting at another day. | 236 | if(!(((*it).end().hour()==0) && ((*it).end().minute()==0) && ((*it).startDate()!=(*it).date()))) {// Skip events ending at 00:00 starting at another day. |
215 | DateBookWeekLstEvent *l=new DateBookWeekLstEvent(*it,this); | 237 | DateBookWeekLstEvent *l=new DateBookWeekLstEvent(*it,weeklistviewconfig,this); |
216 | layout->addWidget(l); | 238 | layout->addWidget(l); |
217 | connect (l, SIGNAL(editEvent(const Event &)), | 239 | connect (l, SIGNAL(editEvent(const Event &)), this, SIGNAL(editEvent(const Event &))); |
218 | this, SIGNAL(editEvent(const Event &))); | ||
219 | } | 240 | } |
220 | it++; | 241 | it++; |
221 | } | 242 | } |
222 | 243 | ||
223 | layout->addItem(new QSpacerItem(1,1, QSizePolicy::Minimum, QSizePolicy::Expanding)); | 244 | layout->addItem(new QSpacerItem(1,1, QSizePolicy::Minimum, QSizePolicy::Expanding)); |
224 | } | 245 | } |
@@ -234,32 +255,24 @@ DateBookWeekLstDblView::DateBookWeekLstDblView(QValueList<EffectiveEvent> &ev1, | |||
234 | : QWidget( parent, name, fl ) | 255 | : QWidget( parent, name, fl ) |
235 | { | 256 | { |
236 | QHBoxLayout *layout = new QHBoxLayout( this ); | 257 | QHBoxLayout *layout = new QHBoxLayout( this ); |
237 | 258 | ||
238 | DateBookWeekLstView *w=new DateBookWeekLstView(ev1,d,onM,this); | 259 | DateBookWeekLstView *w=new DateBookWeekLstView(ev1,d,onM,this); |
239 | layout->addWidget(w); | 260 | layout->addWidget(w); |
240 | connect (w, SIGNAL(editEvent(const Event &)), | 261 | connect (w, SIGNAL(editEvent(const Event &)), this, SIGNAL(editEvent(const Event &))); |
241 | this, SIGNAL(editEvent(const Event &))); | 262 | connect (w, SIGNAL(showDate(int,int,int)), this, SIGNAL(showDate(int,int,int))); |
242 | connect (w, SIGNAL(showDate(int,int,int)), | 263 | connect (w, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &,const QString &)), |
243 | this, SIGNAL(showDate(int,int,int))); | 264 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &))); |
244 | connect (w, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
245 | const QString &,const QString &)), | ||
246 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
247 | const QString &, const QString &))); | ||
248 | 265 | ||
249 | 266 | ||
250 | w=new DateBookWeekLstView(ev2,d.addDays(7),onM,this); | 267 | w=new DateBookWeekLstView(ev2,d.addDays(7),onM,this); |
251 | layout->addWidget(w); | 268 | layout->addWidget(w); |
252 | connect (w, SIGNAL(editEvent(const Event &)), | 269 | connect (w, SIGNAL(editEvent(const Event &)), this, SIGNAL(editEvent(const Event &))); |
253 | this, SIGNAL(editEvent(const Event &))); | 270 | connect (w, SIGNAL(showDate(int,int,int)), this, SIGNAL(showDate(int,int,int))); |
254 | connect (w, SIGNAL(showDate(int,int,int)), | 271 | connect (w, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &)), |
255 | this, SIGNAL(showDate(int,int,int))); | 272 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &))); |
256 | connect (w, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
257 | const QString &, const QString &)), | ||
258 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
259 | const QString &, const QString &))); | ||
260 | } | 273 | } |
261 | 274 | ||
262 | DateBookWeekLst::DateBookWeekLst( bool ap, bool onM, DateBookDB *newDB, | 275 | DateBookWeekLst::DateBookWeekLst( bool ap, bool onM, DateBookDB *newDB, |
263 | QWidget *parent, | 276 | QWidget *parent, |
264 | const char *name ) | 277 | const char *name ) |
265 | : QWidget( parent, name ), | 278 | : QWidget( parent, name ), |
@@ -271,16 +284,14 @@ DateBookWeekLst::DateBookWeekLst( bool ap, bool onM, DateBookDB *newDB, | |||
271 | setFocusPolicy(StrongFocus); | 284 | setFocusPolicy(StrongFocus); |
272 | layout = new QVBoxLayout( this ); | 285 | layout = new QVBoxLayout( this ); |
273 | layout->setMargin(0); | 286 | layout->setMargin(0); |
274 | 287 | ||
275 | header=new DateBookWeekLstHeader(onM, this); | 288 | header=new DateBookWeekLstHeader(onM, this); |
276 | layout->addWidget( header ); | 289 | layout->addWidget( header ); |
277 | connect(header, SIGNAL(dateChanged(int,int)), | 290 | connect(header, SIGNAL(dateChanged(int,int)), this, SLOT(dateChanged(int,int))); |
278 | this, SLOT(dateChanged(int,int))); | 291 | connect(header, SIGNAL(setDbl(bool)), this, SLOT(setDbl(bool))); |
279 | connect(header, SIGNAL(setDbl(bool)), | ||
280 | this, SLOT(setDbl(bool))); | ||
281 | 292 | ||
282 | scroll=new QScrollView(this); | 293 | scroll=new QScrollView(this); |
283 | //scroll->setVScrollBarMode(QScrollView::AlwaysOn); | 294 | //scroll->setVScrollBarMode(QScrollView::AlwaysOn); |
284 | //scroll->setHScrollBarMode(QScrollView::AlwaysOff); | 295 | //scroll->setHScrollBarMode(QScrollView::AlwaysOff); |
285 | scroll->setResizePolicy(QScrollView::AutoOneFit); | 296 | scroll->setResizePolicy(QScrollView::AutoOneFit); |
286 | layout->addWidget(scroll); | 297 | layout->addWidget(scroll); |
@@ -313,14 +324,17 @@ void DateBookWeekLst::redraw() {getEvents();} | |||
313 | QDate DateBookWeekLst::date() const { | 324 | QDate DateBookWeekLst::date() const { |
314 | QDate d; | 325 | QDate d; |
315 | d.setYMD(year,1,1); | 326 | d.setYMD(year,1,1); |
316 | 327 | ||
317 | int dow= d.dayOfWeek(); | 328 | int dow= d.dayOfWeek(); |
318 | if (!onMonday) | 329 | if (!onMonday) |
319 | if (dow==7) dow=1; | 330 | if (dow==7) { |
320 | else dow++; | 331 | dow=1; |
332 | } else { | ||
333 | dow++; | ||
334 | } | ||
321 | 335 | ||
322 | d=d.addDays( (_week-1)*7 - dow + 1 ); | 336 | d=d.addDays( (_week-1)*7 - dow + 1 ); |
323 | return d; | 337 | return d; |
324 | } | 338 | } |
325 | 339 | ||
326 | void DateBookWeekLst::getEvents() { | 340 | void DateBookWeekLst::getEvents() { |
@@ -330,26 +344,21 @@ void DateBookWeekLst::getEvents() { | |||
330 | 344 | ||
331 | if (view) delete view; | 345 | if (view) delete view; |
332 | if (dbl) { | 346 | if (dbl) { |
333 | QDate start2=start.addDays(7); | 347 | QDate start2=start.addDays(7); |
334 | stop=start2.addDays(6); | 348 | stop=start2.addDays(6); |
335 | QValueList<EffectiveEvent> el2 = db->getEffectiveEvents(start2, stop); | 349 | QValueList<EffectiveEvent> el2 = db->getEffectiveEvents(start2, stop); |
336 | |||
337 | view=new DateBookWeekLstDblView(el,el2,start,onMonday,scroll); | 350 | view=new DateBookWeekLstDblView(el,el2,start,onMonday,scroll); |
338 | } else { | 351 | } else { |
339 | view=new DateBookWeekLstView(el,start,onMonday,scroll); | 352 | view=new DateBookWeekLstView(el,start,onMonday,scroll); |
340 | } | 353 | } |
341 | 354 | ||
342 | connect (view, SIGNAL(editEvent(const Event &)), | 355 | connect (view, SIGNAL(editEvent(const Event &)), this, SIGNAL(editEvent(const Event &))); |
343 | this, SIGNAL(editEvent(const Event &))); | 356 | connect (view, SIGNAL(showDate(int,int,int)), this, SIGNAL(showDate(int,int,int))); |
344 | connect (view, SIGNAL(showDate(int,int,int)), | 357 | connect (view, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &)), |
345 | this, SIGNAL(showDate(int,int,int))); | 358 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, const QString &, const QString &))); |
346 | connect (view, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
347 | const QString &, const QString &)), | ||
348 | this, SIGNAL(addEvent(const QDateTime &, const QDateTime &, | ||
349 | const QString &, const QString &))); | ||
350 | 359 | ||
351 | scroll->addChild(view); | 360 | scroll->addChild(view); |
352 | view->show(); | 361 | view->show(); |
353 | scroll->updateScrollBars(); | 362 | scroll->updateScrollBars(); |
354 | } | 363 | } |
355 | 364 | ||
diff --git a/core/pim/datebook/datebookweeklst.h b/core/pim/datebook/datebookweeklst.h index ea88f20..17dc01f 100644 --- a/core/pim/datebook/datebookweeklst.h +++ b/core/pim/datebook/datebookweeklst.h | |||
@@ -56,13 +56,13 @@ private: | |||
56 | }; | 56 | }; |
57 | 57 | ||
58 | class DateBookWeekLstEvent: public OClickableLabel | 58 | class DateBookWeekLstEvent: public OClickableLabel |
59 | { | 59 | { |
60 | Q_OBJECT | 60 | Q_OBJECT |
61 | public: | 61 | public: |
62 | DateBookWeekLstEvent(const EffectiveEvent &ev, | 62 | DateBookWeekLstEvent(const EffectiveEvent &ev, int weeklistviewconfig =1, |
63 | QWidget* parent = 0, const char* name = 0, | 63 | QWidget* parent = 0, const char* name = 0, |
64 | WFlags fl = 0); | 64 | WFlags fl = 0); |
65 | signals: | 65 | signals: |
66 | void editEvent(const Event &e); | 66 | void editEvent(const Event &e); |
67 | private slots: | 67 | private slots: |
68 | void editMe(); | 68 | void editMe(); |