author | sandman <sandman> | 2002-06-09 23:42:42 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-06-09 23:42:42 (UTC) |
commit | 1c56ab829f04ea5b127c1c632cec330e47bca524 (patch) (unidiff) | |
tree | 30f0bd7c2d124cbf2dc41f32234922d2f3be19a7 | |
parent | 25d084dd1a4b69cefcf16a889f22feb39d60f541 (diff) | |
download | opie-1c56ab829f04ea5b127c1c632cec330e47bca524.zip opie-1c56ab829f04ea5b127c1c632cec330e47bca524.tar.gz opie-1c56ab829f04ea5b127c1c632cec330e47bca524.tar.bz2 |
Fixed a counter bug in alarm timer loop.
-rw-r--r-- | core/pim/datebook/datebook.cpp | 14 | ||||
-rw-r--r-- | core/pim/datebook/datebook.h | 2 |
2 files changed, 9 insertions, 7 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp index 8614b3f..2c2965e 100644 --- a/core/pim/datebook/datebook.cpp +++ b/core/pim/datebook/datebook.cpp | |||
@@ -20,129 +20,130 @@ | |||
20 | ** | 20 | ** |
21 | **********************************************************************/ | 21 | **********************************************************************/ |
22 | 22 | ||
23 | #define QTOPIA_INTERNAL_FD | 23 | #define QTOPIA_INTERNAL_FD |
24 | 24 | ||
25 | #include "datebook.h" | 25 | #include "datebook.h" |
26 | #include "datebookday.h" | 26 | #include "datebookday.h" |
27 | #include "datebooksettings.h" | 27 | #include "datebooksettings.h" |
28 | #include "datebookweek.h" | 28 | #include "datebookweek.h" |
29 | #include "datebookweeklst.h" | 29 | #include "datebookweeklst.h" |
30 | #include "dateentryimpl.h" | 30 | #include "dateentryimpl.h" |
31 | 31 | ||
32 | #include <qpe/datebookmonth.h> | 32 | #include <qpe/datebookmonth.h> |
33 | #include <qpe/qpeapplication.h> | 33 | #include <qpe/qpeapplication.h> |
34 | #include <qpe/config.h> | 34 | #include <qpe/config.h> |
35 | #include <qpe/qpedebug.h> | 35 | #include <qpe/qpedebug.h> |
36 | #include <qpe/event.h> | 36 | #include <qpe/event.h> |
37 | #include <qpe/finddialog.h> | 37 | #include <qpe/finddialog.h> |
38 | #include <qpe/ir.h> | 38 | #include <qpe/ir.h> |
39 | #include <qpe/qpemenubar.h> | 39 | #include <qpe/qpemenubar.h> |
40 | #include <qpe/qpemessagebox.h> | 40 | #include <qpe/qpemessagebox.h> |
41 | #include <qpe/resource.h> | 41 | #include <qpe/resource.h> |
42 | #include <qpe/sound.h> | 42 | #include <qpe/sound.h> |
43 | #include <qpe/timestring.h> | 43 | #include <qpe/timestring.h> |
44 | #include <qpe/qpetoolbar.h> | 44 | #include <qpe/qpetoolbar.h> |
45 | #include <qpe/tzselect.h> | 45 | #include <qpe/tzselect.h> |
46 | #include <qpe/xmlreader.h> | 46 | #include <qpe/xmlreader.h> |
47 | 47 | ||
48 | #include <qaction.h> | 48 | #include <qaction.h> |
49 | #include <qcopchannel_qws.h> | 49 | #include <qcopchannel_qws.h> |
50 | #include <qdatetime.h> | 50 | #include <qdatetime.h> |
51 | #include <qdialog.h> | 51 | #include <qdialog.h> |
52 | #include <qfile.h> | 52 | #include <qfile.h> |
53 | #include <qlabel.h> | 53 | #include <qlabel.h> |
54 | #include <qlayout.h> | 54 | #include <qlayout.h> |
55 | #include <qmessagebox.h> | 55 | #include <qmessagebox.h> |
56 | #include <qpopupmenu.h> | 56 | #include <qpopupmenu.h> |
57 | #include <qpushbutton.h> | 57 | #include <qpushbutton.h> |
58 | #include <qregexp.h> | 58 | #include <qregexp.h> |
59 | #include <qtextcodec.h> | 59 | #include <qtextcodec.h> |
60 | #include <qtextstream.h> | 60 | #include <qtextstream.h> |
61 | #include <qtl.h> | 61 | #include <qtl.h> |
62 | #include <qwidgetstack.h> | 62 | #include <qwidgetstack.h> |
63 | #include <qwindowsystem_qws.h> | 63 | #include <qwindowsystem_qws.h> |
64 | 64 | ||
65 | #include <sys/stat.h> | 65 | #include <sys/stat.h> |
66 | #include <sys/types.h> | 66 | #include <sys/types.h> |
67 | #include <fcntl.h> | 67 | #include <fcntl.h> |
68 | #include <unistd.h> | 68 | #include <unistd.h> |
69 | 69 | ||
70 | #include <stdlib.h> | 70 | #include <stdlib.h> |
71 | 71 | ||
72 | #define DAY 1 | 72 | #define DAY 1 |
73 | #define WEEK 2 | 73 | #define WEEK 2 |
74 | #define WEEKLST 4 | 74 | #define WEEKLST 4 |
75 | #define MONTH 3 | 75 | #define MONTH 3 |
76 | 76 | ||
77 | 77 | ||
78 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | 78 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) |
79 | : QMainWindow( parent, "datebook", f ), | 79 | : QMainWindow( parent, "datebook", f ), |
80 | aPreset( FALSE ), | 80 | aPreset( FALSE ), |
81 | presetTime( -1 ), | 81 | presetTime( -1 ), |
82 | startTime( 8 ), // an acceptable default | 82 | startTime( 8 ), // an acceptable default |
83 | syncing(FALSE), | 83 | syncing(FALSE), |
84 | inSearch(FALSE) | 84 | inSearch(FALSE), |
85 | alarmCounter(0) | ||
85 | { | 86 | { |
86 | QTime t; | 87 | QTime t; |
87 | t.start(); | 88 | t.start(); |
88 | db = new DateBookDBHack; | 89 | db = new DateBookDBHack; |
89 | qDebug("loading db t=%d", t.elapsed() ); | 90 | qDebug("loading db t=%d", t.elapsed() ); |
90 | loadSettings(); | 91 | loadSettings(); |
91 | setCaption( tr("Calendar") ); | 92 | setCaption( tr("Calendar") ); |
92 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); | 93 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); |
93 | 94 | ||
94 | setToolBarsMovable( FALSE ); | 95 | setToolBarsMovable( FALSE ); |
95 | 96 | ||
96 | views = new QWidgetStack( this ); | 97 | views = new QWidgetStack( this ); |
97 | setCentralWidget( views ); | 98 | setCentralWidget( views ); |
98 | 99 | ||
99 | dayView = 0; | 100 | dayView = 0; |
100 | weekView = 0; | 101 | weekView = 0; |
101 | weekLstView = 0; | 102 | weekLstView = 0; |
102 | monthView = 0; | 103 | monthView = 0; |
103 | 104 | ||
104 | QPEToolBar *bar = new QPEToolBar( this ); | 105 | QPEToolBar *bar = new QPEToolBar( this ); |
105 | bar->setHorizontalStretchable( TRUE ); | 106 | bar->setHorizontalStretchable( TRUE ); |
106 | 107 | ||
107 | QPEMenuBar *mb = new QPEMenuBar( bar ); | 108 | QPEMenuBar *mb = new QPEMenuBar( bar ); |
108 | mb->setMargin( 0 ); | 109 | mb->setMargin( 0 ); |
109 | 110 | ||
110 | QPEToolBar *sub_bar = new QPEToolBar(this); | 111 | QPEToolBar *sub_bar = new QPEToolBar(this); |
111 | 112 | ||
112 | QPopupMenu *view = new QPopupMenu( this ); | 113 | QPopupMenu *view = new QPopupMenu( this ); |
113 | QPopupMenu *settings = new QPopupMenu( this ); | 114 | QPopupMenu *settings = new QPopupMenu( this ); |
114 | 115 | ||
115 | mb->insertItem( tr( "View" ), view ); | 116 | mb->insertItem( tr( "View" ), view ); |
116 | mb->insertItem( tr( "Settings" ), settings ); | 117 | mb->insertItem( tr( "Settings" ), settings ); |
117 | 118 | ||
118 | QActionGroup *g = new QActionGroup( this ); | 119 | QActionGroup *g = new QActionGroup( this ); |
119 | g->setExclusive( TRUE ); | 120 | g->setExclusive( TRUE ); |
120 | 121 | ||
121 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), | 122 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), |
122 | QString::null, 0, this, 0 ); | 123 | QString::null, 0, this, 0 ); |
123 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); | 124 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); |
124 | a->addTo( sub_bar ); | 125 | a->addTo( sub_bar ); |
125 | 126 | ||
126 | a = new QAction( tr( "Today" ), Resource::loadPixmap( "to_day" ), QString::null, 0, g, 0 ); | 127 | a = new QAction( tr( "Today" ), Resource::loadPixmap( "to_day" ), QString::null, 0, g, 0 ); |
127 | connect( a, SIGNAL( activated() ), this, SLOT( slotToday() ) ); | 128 | connect( a, SIGNAL( activated() ), this, SLOT( slotToday() ) ); |
128 | a->addTo( sub_bar ); | 129 | a->addTo( sub_bar ); |
129 | a->addTo( view ); | 130 | a->addTo( view ); |
130 | 131 | ||
131 | a = new QAction( tr( "Day" ), Resource::loadPixmap( "day" ), QString::null, 0, g, 0 ); | 132 | a = new QAction( tr( "Day" ), Resource::loadPixmap( "day" ), QString::null, 0, g, 0 ); |
132 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); | 133 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); |
133 | a->addTo( sub_bar ); | 134 | a->addTo( sub_bar ); |
134 | a->addTo( view ); | 135 | a->addTo( view ); |
135 | a->setToggleAction( TRUE ); | 136 | a->setToggleAction( TRUE ); |
136 | a->setOn( TRUE ); | 137 | a->setOn( TRUE ); |
137 | dayAction = a; | 138 | dayAction = a; |
138 | 139 | ||
139 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); | 140 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); |
140 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); | 141 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); |
141 | a->addTo( sub_bar ); | 142 | a->addTo( sub_bar ); |
142 | a->addTo( view ); | 143 | a->addTo( view ); |
143 | a->setToggleAction( TRUE ); | 144 | a->setToggleAction( TRUE ); |
144 | weekAction = a; | 145 | weekAction = a; |
145 | 146 | ||
146 | a = new QAction( tr( "WeekLst" ), Resource::loadPixmap( "weeklst" ), QString::null, 0, g, 0 ); | 147 | a = new QAction( tr( "WeekLst" ), Resource::loadPixmap( "weeklst" ), QString::null, 0, g, 0 ); |
147 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeekLst() ) ); | 148 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeekLst() ) ); |
148 | a->addTo( sub_bar ); | 149 | a->addTo( sub_bar ); |
@@ -553,205 +554,204 @@ void DateBook::saveSettings() | |||
553 | { | 554 | { |
554 | Config config( "qpe" ); | 555 | Config config( "qpe" ); |
555 | Config configDB( "DateBook" ); | 556 | Config configDB( "DateBook" ); |
556 | configDB.setGroup( "Main" ); | 557 | configDB.setGroup( "Main" ); |
557 | configDB.writeEntry("startviewtime",startTime); | 558 | configDB.writeEntry("startviewtime",startTime); |
558 | configDB.writeEntry("alarmpreset",aPreset); | 559 | configDB.writeEntry("alarmpreset",aPreset); |
559 | configDB.writeEntry("presettime",presetTime); | 560 | configDB.writeEntry("presettime",presetTime); |
560 | } | 561 | } |
561 | 562 | ||
562 | void DateBook::newDefaultView(QAction *a) { | 563 | void DateBook::newDefaultView(QAction *a) { |
563 | int val=DAY; | 564 | int val=DAY; |
564 | if (a->text() == "Day") val=DAY; | 565 | if (a->text() == "Day") val=DAY; |
565 | if (a->text() == "Week") val=WEEK; | 566 | if (a->text() == "Week") val=WEEK; |
566 | if (a->text() == "WeekLst") val=WEEKLST; | 567 | if (a->text() == "WeekLst") val=WEEKLST; |
567 | if (a->text() == "Month") val=MONTH; | 568 | if (a->text() == "Month") val=MONTH; |
568 | 569 | ||
569 | Config configDB( "DateBook" ); | 570 | Config configDB( "DateBook" ); |
570 | configDB.setGroup( "Main" ); | 571 | configDB.setGroup( "Main" ); |
571 | configDB.writeEntry("defaultview",val); | 572 | configDB.writeEntry("defaultview",val); |
572 | } | 573 | } |
573 | 574 | ||
574 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) | 575 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) |
575 | { | 576 | { |
576 | bool needShow = FALSE; | 577 | bool needShow = FALSE; |
577 | if ( msg == "alarm(QDateTime,int)" ) { | 578 | if ( msg == "alarm(QDateTime,int)" ) { |
578 | QDataStream ds(data,IO_ReadOnly); | 579 | QDataStream ds(data,IO_ReadOnly); |
579 | QDateTime when; int warn; | 580 | QDateTime when; int warn; |
580 | ds >> when >> warn; | 581 | ds >> when >> warn; |
581 | 582 | ||
582 | // check to make it's okay to continue, | 583 | // check to make it's okay to continue, |
583 | // this is the case that the time was set ahead, and | 584 | // this is the case that the time was set ahead, and |
584 | // we are forced given a stale alarm... | 585 | // we are forced given a stale alarm... |
585 | QDateTime current = QDateTime::currentDateTime(); | 586 | QDateTime current = QDateTime::currentDateTime(); |
586 | if ( current.time().hour() != when.time().hour() | 587 | if ( current.time().hour() != when.time().hour() |
587 | && current.time().minute() != when.time().minute() ) | 588 | && current.time().minute() != when.time().minute() ) |
588 | return; | 589 | return; |
589 | 590 | ||
590 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); | 591 | QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); |
591 | if ( list.count() > 0 ) { | 592 | if ( list.count() > 0 ) { |
592 | QString msg; | 593 | QString msg; |
593 | bool bSound = FALSE; | 594 | bool bSound = FALSE; |
594 | int stopTimer = 0; | 595 | int stopTimer = 0; |
595 | bool found = FALSE; | 596 | bool found = FALSE; |
596 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); | 597 | for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); |
597 | it!=list.end(); ++it ) { | 598 | it!=list.end(); ++it ) { |
598 | if ( (*it).event().hasAlarm() ) { | 599 | if ( (*it).event().hasAlarm() ) { |
599 | found = TRUE; | 600 | found = TRUE; |
600 | msg += "<CENTER><B>" + (*it).description() + "</B>" | 601 | msg += "<CENTER><B>" + (*it).description() + "</B>" |
601 | + "<BR>" + (*it).location() + "<BR>" | 602 | + "<BR>" + (*it).location() + "<BR>" |
602 | + TimeString::dateString((*it).event().start(),ampm) | 603 | + TimeString::dateString((*it).event().start(),ampm) |
603 | + (warn | 604 | + (warn |
604 | ? tr(" (in " + QString::number(warn) | 605 | ? tr(" (in " + QString::number(warn) |
605 | + tr(" minutes)")) | 606 | + tr(" minutes)")) |
606 | : QString("")) | 607 | : QString("")) |
607 | + "<BR>" | 608 | + "<BR>" |
608 | + (*it).notes() + "</CENTER>"; | 609 | + (*it).notes() + "</CENTER>"; |
609 | if ( (*it).event().alarmSound() != Event::Silent ) { | 610 | if ( (*it).event().alarmSound() != Event::Silent ) { |
610 | bSound = TRUE; | 611 | bSound = TRUE; |
611 | } | 612 | } |
612 | } | 613 | } |
613 | } | 614 | } |
614 | if ( found ) { | 615 | if ( found ) { |
615 | if ( bSound ) { | 616 | if ( bSound ) { |
616 | Sound::soundAlarm(); | 617 | Sound::soundAlarm(); |
618 | alarmCounter = 0; | ||
617 | stopTimer = startTimer( 5000 ); | 619 | stopTimer = startTimer( 5000 ); |
618 | } | 620 | } |
619 | 621 | ||
620 | QDialog dlg( this, 0, TRUE ); | 622 | QDialog dlg( this, 0, TRUE ); |
621 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); | 623 | QVBoxLayout *vb = new QVBoxLayout( &dlg ); |
622 | QScrollView *view = new QScrollView( &dlg, "scrollView"); | 624 | QScrollView *view = new QScrollView( &dlg, "scrollView"); |
623 | view->setResizePolicy( QScrollView::AutoOneFit ); | 625 | view->setResizePolicy( QScrollView::AutoOneFit ); |
624 | vb->addWidget( view ); | 626 | vb->addWidget( view ); |
625 | QLabel *lblMsg = new QLabel( msg, &dlg ); | 627 | QLabel *lblMsg = new QLabel( msg, &dlg ); |
626 | view->addChild( lblMsg ); | 628 | view->addChild( lblMsg ); |
627 | QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg ); | 629 | QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg ); |
628 | connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) ); | 630 | connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) ); |
629 | vb->addWidget( cmdOk ); | 631 | vb->addWidget( cmdOk ); |
630 | 632 | ||
631 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 633 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
632 | dlg.showMaximized(); | 634 | dlg.showMaximized(); |
633 | #endif | 635 | #endif |
634 | needShow = dlg.exec(); | 636 | needShow = dlg.exec(); |
635 | 637 | ||
636 | if ( bSound ) | 638 | if ( bSound ) |
637 | killTimer( stopTimer ); | 639 | killTimer( stopTimer ); |
638 | } | 640 | } |
639 | } | 641 | } |
640 | } else if ( msg == "nextView()" ) { | 642 | } else if ( msg == "nextView()" ) { |
641 | QWidget* cur = views->visibleWidget(); | 643 | QWidget* cur = views->visibleWidget(); |
642 | if ( cur ) { | 644 | if ( cur ) { |
643 | if ( cur == dayView ) | 645 | if ( cur == dayView ) |
644 | viewWeek(); | 646 | viewWeek(); |
645 | else if ( cur == weekView ) | 647 | else if ( cur == weekView ) |
646 | viewWeekLst(); | 648 | viewWeekLst(); |
647 | else if ( cur == weekLstView ) | 649 | else if ( cur == weekLstView ) |
648 | viewMonth(); | 650 | viewMonth(); |
649 | else if ( cur == monthView ) | 651 | else if ( cur == monthView ) |
650 | viewDay(); | 652 | viewDay(); |
651 | needShow = TRUE; | 653 | needShow = TRUE; |
652 | } | 654 | } |
653 | } | 655 | } |
654 | if ( needShow ) { | 656 | if ( needShow ) { |
655 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 657 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
656 | showMaximized(); | 658 | showMaximized(); |
657 | #else | 659 | #else |
658 | show(); | 660 | show(); |
659 | #endif | 661 | #endif |
660 | raise(); | 662 | raise(); |
661 | QPEApplication::setKeepRunning(); | 663 | QPEApplication::setKeepRunning(); |
662 | setActiveWindow(); | 664 | setActiveWindow(); |
663 | } | 665 | } |
664 | } | 666 | } |
665 | 667 | ||
666 | void DateBook::reload() | 668 | void DateBook::reload() |
667 | { | 669 | { |
668 | db->reload(); | 670 | db->reload(); |
669 | if ( dayAction->isOn() ) | 671 | if ( dayAction->isOn() ) |
670 | viewDay(); | 672 | viewDay(); |
671 | else if ( weekAction->isOn() ) | 673 | else if ( weekAction->isOn() ) |
672 | viewWeek(); | 674 | viewWeek(); |
673 | else if ( monthAction->isOn() ) | 675 | else if ( monthAction->isOn() ) |
674 | viewMonth(); | 676 | viewMonth(); |
675 | syncing = FALSE; | 677 | syncing = FALSE; |
676 | } | 678 | } |
677 | 679 | ||
678 | void DateBook::flush() | 680 | void DateBook::flush() |
679 | { | 681 | { |
680 | syncing = TRUE; | 682 | syncing = TRUE; |
681 | db->save(); | 683 | db->save(); |
682 | } | 684 | } |
683 | 685 | ||
684 | void DateBook::timerEvent( QTimerEvent *e ) | 686 | void DateBook::timerEvent( QTimerEvent *e ) |
685 | { | 687 | { |
686 | static int stop = 0; | 688 | if ( alarmCounter < 10 ) { |
687 | if ( stop < 10 ) { | 689 | alarmCounter++; |
688 | Sound::soundAlarm(); | 690 | Sound::soundAlarm(); |
689 | stop++; | 691 | } |
690 | } else { | 692 | else |
691 | stop = 0; | ||
692 | killTimer( e->timerId() ); | 693 | killTimer( e->timerId() ); |
693 | } | ||
694 | } | 694 | } |
695 | 695 | ||
696 | void DateBook::changeClock( bool newClock ) | 696 | void DateBook::changeClock( bool newClock ) |
697 | { | 697 | { |
698 | ampm = newClock; | 698 | ampm = newClock; |
699 | // repaint the affected objects... | 699 | // repaint the affected objects... |
700 | if (dayView) dayView->redraw(); | 700 | if (dayView) dayView->redraw(); |
701 | if (weekView) weekView->redraw(); | 701 | if (weekView) weekView->redraw(); |
702 | if (weekLstView) weekLstView->redraw(); | 702 | if (weekLstView) weekLstView->redraw(); |
703 | } | 703 | } |
704 | 704 | ||
705 | void DateBook::changeWeek( bool m ) | 705 | void DateBook::changeWeek( bool m ) |
706 | { | 706 | { |
707 | /* no need to redraw, each widget catches. Do need to | 707 | /* no need to redraw, each widget catches. Do need to |
708 | store though for widgets we haven't made yet */ | 708 | store though for widgets we haven't made yet */ |
709 | onMonday = m; | 709 | onMonday = m; |
710 | } | 710 | } |
711 | 711 | ||
712 | void DateBook::slotToday() | 712 | void DateBook::slotToday() |
713 | { | 713 | { |
714 | // we need to view today using default view | 714 | // we need to view today using default view |
715 | viewDefault(QDate::currentDate()); | 715 | viewDefault(QDate::currentDate()); |
716 | } | 716 | } |
717 | 717 | ||
718 | void DateBook::closeEvent( QCloseEvent *e ) | 718 | void DateBook::closeEvent( QCloseEvent *e ) |
719 | { | 719 | { |
720 | if(syncing) { | 720 | if(syncing) { |
721 | /* no need to save, did that at flush */ | 721 | /* no need to save, did that at flush */ |
722 | e->accept(); | 722 | e->accept(); |
723 | return; | 723 | return; |
724 | } | 724 | } |
725 | 725 | ||
726 | // save settings will generate it's own error messages, no | 726 | // save settings will generate it's own error messages, no |
727 | // need to do checking ourselves. | 727 | // need to do checking ourselves. |
728 | saveSettings(); | 728 | saveSettings(); |
729 | if ( db->save() ) | 729 | if ( db->save() ) |
730 | e->accept(); | 730 | e->accept(); |
731 | else { | 731 | else { |
732 | if ( QMessageBox::critical( this, tr( "Out of space" ), | 732 | if ( QMessageBox::critical( this, tr( "Out of space" ), |
733 | tr("Calendar was unable to save\n" | 733 | tr("Calendar was unable to save\n" |
734 | "your changes.\n" | 734 | "your changes.\n" |
735 | "Free up some space and try again.\n" | 735 | "Free up some space and try again.\n" |
736 | "\nQuit anyway?"), | 736 | "\nQuit anyway?"), |
737 | QMessageBox::Yes|QMessageBox::Escape, | 737 | QMessageBox::Yes|QMessageBox::Escape, |
738 | QMessageBox::No|QMessageBox::Default ) | 738 | QMessageBox::No|QMessageBox::Default ) |
739 | != QMessageBox::No ) | 739 | != QMessageBox::No ) |
740 | e->accept(); | 740 | e->accept(); |
741 | else | 741 | else |
742 | e->ignore(); | 742 | e->ignore(); |
743 | } | 743 | } |
744 | } | 744 | } |
745 | 745 | ||
746 | // Entering directly from the "keyboard" | 746 | // Entering directly from the "keyboard" |
747 | void DateBook::slotNewEventFromKey( const QString &str ) | 747 | void DateBook::slotNewEventFromKey( const QString &str ) |
748 | { | 748 | { |
749 | if (syncing) { | 749 | if (syncing) { |
750 | QMessageBox::warning( this, tr("Calendar"), | 750 | QMessageBox::warning( this, tr("Calendar"), |
751 | tr( "Can not edit data, currently syncing") ); | 751 | tr( "Can not edit data, currently syncing") ); |
752 | return; | 752 | return; |
753 | } | 753 | } |
754 | 754 | ||
755 | // We get to here from a key pressed in the Day View | 755 | // We get to here from a key pressed in the Day View |
756 | // So we can assume some things. We want the string | 756 | // So we can assume some things. We want the string |
757 | // passed in to be part of the description. | 757 | // passed in to be part of the description. |
diff --git a/core/pim/datebook/datebook.h b/core/pim/datebook/datebook.h index d1fe90d..e7be0dd 100644 --- a/core/pim/datebook/datebook.h +++ b/core/pim/datebook/datebook.h | |||
@@ -59,68 +59,70 @@ protected: | |||
59 | 59 | ||
60 | void view(int v, const QDate &d); | 60 | void view(int v, const QDate &d); |
61 | 61 | ||
62 | public slots: | 62 | public slots: |
63 | void flush(); | 63 | void flush(); |
64 | void reload(); | 64 | void reload(); |
65 | 65 | ||
66 | private slots: | 66 | private slots: |
67 | void fileNew(); | 67 | void fileNew(); |
68 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str); | 68 | void slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str); |
69 | void slotSettings(); | 69 | void slotSettings(); |
70 | void newDefaultView(QAction *a); | 70 | void newDefaultView(QAction *a); |
71 | void slotToday();// view today | 71 | void slotToday();// view today |
72 | void changeClock( bool newClock ); | 72 | void changeClock( bool newClock ); |
73 | void changeWeek( bool newDay ); | 73 | void changeWeek( bool newDay ); |
74 | void appMessage(const QCString& msg, const QByteArray& data); | 74 | void appMessage(const QCString& msg, const QByteArray& data); |
75 | // handle key events in the day view... | 75 | // handle key events in the day view... |
76 | void slotNewEventFromKey( const QString &str ); | 76 | void slotNewEventFromKey( const QString &str ); |
77 | void slotFind(); | 77 | void slotFind(); |
78 | void slotDoFind( const QString &, const QDate &, bool, bool, int ); | 78 | void slotDoFind( const QString &, const QDate &, bool, bool, int ); |
79 | 79 | ||
80 | void viewDefault(const QDate &d); | 80 | void viewDefault(const QDate &d); |
81 | 81 | ||
82 | void viewDay(); | 82 | void viewDay(); |
83 | void viewWeek(); | 83 | void viewWeek(); |
84 | void viewWeekLst(); | 84 | void viewWeekLst(); |
85 | void viewMonth(); | 85 | void viewMonth(); |
86 | 86 | ||
87 | void showDay( int y, int m, int d ); | 87 | void showDay( int y, int m, int d ); |
88 | 88 | ||
89 | void editEvent( const Event &e ); | 89 | void editEvent( const Event &e ); |
90 | void removeEvent( const Event &e ); | 90 | void removeEvent( const Event &e ); |
91 | 91 | ||
92 | void receive( const QCString &msg, const QByteArray &data ); | 92 | void receive( const QCString &msg, const QByteArray &data ); |
93 | void setDocument( const QString & ); | 93 | void setDocument( const QString & ); |
94 | void beamEvent( const Event &e ); | 94 | void beamEvent( const Event &e ); |
95 | void beamDone( Ir *ir ); | 95 | void beamDone( Ir *ir ); |
96 | 96 | ||
97 | private: | 97 | private: |
98 | void addEvent( const Event &e ); | 98 | void addEvent( const Event &e ); |
99 | void initDay(); | 99 | void initDay(); |
100 | void initWeek(); | 100 | void initWeek(); |
101 | void initWeekLst(); | 101 | void initWeekLst(); |
102 | void initMonth(); | 102 | void initMonth(); |
103 | void loadSettings(); | 103 | void loadSettings(); |
104 | void saveSettings(); | 104 | void saveSettings(); |
105 | 105 | ||
106 | private: | 106 | private: |
107 | DateBookDBHack *db; | 107 | DateBookDBHack *db; |
108 | QWidgetStack *views; | 108 | QWidgetStack *views; |
109 | DateBookDay *dayView; | 109 | DateBookDay *dayView; |
110 | DateBookWeek *weekView; | 110 | DateBookWeek *weekView; |
111 | DateBookMonth *monthView; | 111 | DateBookMonth *monthView; |
112 | DateBookWeekLst *weekLstView; | 112 | DateBookWeekLst *weekLstView; |
113 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; | 113 | QAction *dayAction, *weekAction, *weekLstAction, *monthAction; |
114 | bool aPreset; // have everything set to alarm? | 114 | bool aPreset; // have everything set to alarm? |
115 | int presetTime; // the standard time for the alarm | 115 | int presetTime; // the standard time for the alarm |
116 | int startTime; | 116 | int startTime; |
117 | bool ampm; | 117 | bool ampm; |
118 | bool onMonday; | 118 | bool onMonday; |
119 | 119 | ||
120 | bool syncing; | 120 | bool syncing; |
121 | bool inSearch; | 121 | bool inSearch; |
122 | 122 | ||
123 | int alarmCounter; | ||
124 | |||
123 | QString checkEvent(const Event &); | 125 | QString checkEvent(const Event &); |
124 | }; | 126 | }; |
125 | 127 | ||
126 | #endif | 128 | #endif |