Diffstat (limited to 'core/pim/datebook/datebook.cpp') (more/less context) (show whitespace changes)
-rw-r--r-- | core/pim/datebook/datebook.cpp | 106 |
1 files changed, 98 insertions, 8 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp index e8d808f..9880e2d 100644 --- a/core/pim/datebook/datebook.cpp +++ b/core/pim/datebook/datebook.cpp | |||
@@ -23,12 +23,13 @@ | |||
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 "dateentryimpl.h" | 30 | #include "dateentryimpl.h" |
30 | 31 | ||
31 | #include <qpe/datebookmonth.h> | 32 | #include <qpe/datebookmonth.h> |
32 | #include <qpe/qpeapplication.h> | 33 | #include <qpe/qpeapplication.h> |
33 | #include <qpe/config.h> | 34 | #include <qpe/config.h> |
34 | #include <qpe/qpedebug.h> | 35 | #include <qpe/qpedebug.h> |
@@ -66,12 +67,13 @@ | |||
66 | #include <unistd.h> | 67 | #include <unistd.h> |
67 | 68 | ||
68 | #include <stdlib.h> | 69 | #include <stdlib.h> |
69 | 70 | ||
70 | #define DAY 1 | 71 | #define DAY 1 |
71 | #define WEEK 2 | 72 | #define WEEK 2 |
73 | #define WEEKLST 4 | ||
72 | #define MONTH 3 | 74 | #define MONTH 3 |
73 | 75 | ||
74 | 76 | ||
75 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | 77 | DateBook::DateBook( QWidget *parent, const char *, WFlags f ) |
76 | : QMainWindow( parent, "datebook", f ), | 78 | : QMainWindow( parent, "datebook", f ), |
77 | aPreset( FALSE ), | 79 | aPreset( FALSE ), |
@@ -87,12 +89,20 @@ DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | |||
87 | loadSettings(); | 89 | loadSettings(); |
88 | setCaption( tr("Calendar") ); | 90 | setCaption( tr("Calendar") ); |
89 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); | 91 | setIcon( Resource::loadPixmap( "datebook_icon" ) ); |
90 | 92 | ||
91 | setToolBarsMovable( FALSE ); | 93 | setToolBarsMovable( FALSE ); |
92 | 94 | ||
95 | views = new QWidgetStack( this ); | ||
96 | setCentralWidget( views ); | ||
97 | |||
98 | dayView = 0; | ||
99 | weekView = 0; | ||
100 | weekLstView = 0; | ||
101 | monthView = 0; | ||
102 | |||
93 | QPEToolBar *bar = new QPEToolBar( this ); | 103 | QPEToolBar *bar = new QPEToolBar( this ); |
94 | bar->setHorizontalStretchable( TRUE ); | 104 | bar->setHorizontalStretchable( TRUE ); |
95 | 105 | ||
96 | QPEMenuBar *mb = new QPEMenuBar( bar ); | 106 | QPEMenuBar *mb = new QPEMenuBar( bar ); |
97 | mb->setMargin( 0 ); | 107 | mb->setMargin( 0 ); |
98 | 108 | ||
@@ -121,18 +131,27 @@ DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | |||
121 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); | 131 | connect( a, SIGNAL( activated() ), this, SLOT( viewDay() ) ); |
122 | a->addTo( sub_bar ); | 132 | a->addTo( sub_bar ); |
123 | a->addTo( view ); | 133 | a->addTo( view ); |
124 | a->setToggleAction( TRUE ); | 134 | a->setToggleAction( TRUE ); |
125 | a->setOn( TRUE ); | 135 | a->setOn( TRUE ); |
126 | dayAction = a; | 136 | dayAction = a; |
137 | |||
127 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); | 138 | a = new QAction( tr( "Week" ), Resource::loadPixmap( "week" ), QString::null, 0, g, 0 ); |
128 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); | 139 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeek() ) ); |
129 | a->addTo( sub_bar ); | 140 | a->addTo( sub_bar ); |
130 | a->addTo( view ); | 141 | a->addTo( view ); |
131 | a->setToggleAction( TRUE ); | 142 | a->setToggleAction( TRUE ); |
132 | weekAction = a; | 143 | weekAction = a; |
144 | |||
145 | a = new QAction( tr( "WeekLst" ), Resource::loadPixmap( "weeklst" ), QString::null, 0, g, 0 ); | ||
146 | connect( a, SIGNAL( activated() ), this, SLOT( viewWeekLst() ) ); | ||
147 | a->addTo( sub_bar ); | ||
148 | a->addTo( view ); | ||
149 | a->setToggleAction( TRUE ); | ||
150 | weekLstAction = a; | ||
151 | |||
133 | a = new QAction( tr( "Month" ), Resource::loadPixmap( "month" ), QString::null, 0, g, 0 ); | 152 | a = new QAction( tr( "Month" ), Resource::loadPixmap( "month" ), QString::null, 0, g, 0 ); |
134 | connect( a, SIGNAL( activated() ), this, SLOT( viewMonth() ) ); | 153 | connect( a, SIGNAL( activated() ), this, SLOT( viewMonth() ) ); |
135 | a->addTo( sub_bar ); | 154 | a->addTo( sub_bar ); |
136 | a->addTo( view ); | 155 | a->addTo( view ); |
137 | a->setToggleAction( TRUE ); | 156 | a->setToggleAction( TRUE ); |
138 | monthAction = a; | 157 | monthAction = a; |
@@ -142,20 +161,40 @@ DateBook::DateBook( QWidget *parent, const char *, WFlags f ) | |||
142 | a->addTo( sub_bar ); | 161 | a->addTo( sub_bar ); |
143 | 162 | ||
144 | a = new QAction( tr( "Alarm and Start Time..." ), QString::null, 0, 0 ); | 163 | a = new QAction( tr( "Alarm and Start Time..." ), QString::null, 0, 0 ); |
145 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); | 164 | connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); |
146 | a->addTo( settings ); | 165 | a->addTo( settings ); |
147 | 166 | ||
148 | views = new QWidgetStack( this ); | 167 | QPopupMenu *default_view = new QPopupMenu(this); |
149 | setCentralWidget( views ); | 168 | settings->insertItem( tr( "Default View" ),default_view ); |
169 | default_view->setCheckable(TRUE); | ||
150 | 170 | ||
151 | dayView = 0; | ||
152 | weekView = 0; | ||
153 | monthView = 0; | ||
154 | 171 | ||
155 | viewDay(); | 172 | Config config("DateBook"); |
173 | config.setGroup("Main"); | ||
174 | int current=config.readNumEntry("defaultview", DAY); | ||
175 | |||
176 | QActionGroup *ag = new QActionGroup(this); | ||
177 | a = new QAction( tr( "Day" ), QString::null, 0, 0, 0, true ); | ||
178 | if (current==DAY) a->setOn(true), viewDay(); | ||
179 | ag->insert(a); | ||
180 | a = new QAction( tr( "Week" ), QString::null, 0, 0, 0, true ); | ||
181 | if (current==WEEK) a->setOn(true), viewWeek(); | ||
182 | ag->insert(a); | ||
183 | a = new QAction( tr( "WeekLst" ), QString::null, 0, 0, 0, true ); | ||
184 | if (current==WEEKLST) a->setOn(true), viewWeekLst(); | ||
185 | ag->insert(a); | ||
186 | a = new QAction( tr( "Month" ), QString::null, 0, 0, 0, true ); | ||
187 | if (current==MONTH) a->setOn(true), viewMonth(); | ||
188 | ag->insert(a); | ||
189 | |||
190 | ag->addTo(default_view); | ||
191 | connect(ag, SIGNAL( selected ( QAction * ) ), | ||
192 | this, SLOT( newDefaultView(QAction *) ) | ||
193 | ); | ||
194 | |||
156 | connect( qApp, SIGNAL(clockChanged(bool)), | 195 | connect( qApp, SIGNAL(clockChanged(bool)), |
157 | this, SLOT(changeClock(bool)) ); | 196 | this, SLOT(changeClock(bool)) ); |
158 | connect( qApp, SIGNAL(weekChanged(bool)), | 197 | connect( qApp, SIGNAL(weekChanged(bool)), |
159 | this, SLOT(changeWeek(bool)) ); | 198 | this, SLOT(changeWeek(bool)) ); |
160 | 199 | ||
161 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 200 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
@@ -261,12 +300,14 @@ QDate DateBook::currentDate() | |||
261 | QDate d = QDate::currentDate(); | 300 | QDate d = QDate::currentDate(); |
262 | 301 | ||
263 | if ( dayView && views->visibleWidget() == dayView ) { | 302 | if ( dayView && views->visibleWidget() == dayView ) { |
264 | d = dayView->date(); | 303 | d = dayView->date(); |
265 | } else if ( weekView && views->visibleWidget() == weekView ) { | 304 | } else if ( weekView && views->visibleWidget() == weekView ) { |
266 | d = weekView->date(); | 305 | d = weekView->date(); |
306 | } else if ( weekLstView && views->visibleWidget() == weekLstView ) { | ||
307 | d = weekLstView->date(); | ||
267 | } else if ( monthView && views->visibleWidget() == monthView ) { | 308 | } else if ( monthView && views->visibleWidget() == monthView ) { |
268 | d = monthView->selectedDate(); | 309 | d = monthView->selectedDate(); |
269 | } | 310 | } |
270 | 311 | ||
271 | return d; | 312 | return d; |
272 | } | 313 | } |
@@ -288,12 +329,21 @@ void DateBook::viewWeek() | |||
288 | QDate d = currentDate(); | 329 | QDate d = currentDate(); |
289 | weekView->setDate( d ); | 330 | weekView->setDate( d ); |
290 | views->raiseWidget( weekView ); | 331 | views->raiseWidget( weekView ); |
291 | weekView->redraw(); | 332 | weekView->redraw(); |
292 | } | 333 | } |
293 | 334 | ||
335 | void DateBook::viewWeekLst() { | ||
336 | initWeekLst(); | ||
337 | weekLstAction->setOn( TRUE ); | ||
338 | QDate d=currentDate(); | ||
339 | weekLstView->setDate(d); | ||
340 | views->raiseWidget( weekLstView ); | ||
341 | weekLstView->redraw(); | ||
342 | } | ||
343 | |||
294 | void DateBook::viewMonth() | 344 | void DateBook::viewMonth() |
295 | { | 345 | { |
296 | initMonth(); | 346 | initMonth(); |
297 | monthAction->setOn( TRUE ); | 347 | monthAction->setOn( TRUE ); |
298 | QDate d = currentDate(); | 348 | QDate d = currentDate(); |
299 | monthView->setDate( d.year(), d.month(), d.day() ); | 349 | monthView->setDate( d.year(), d.month(), d.day() ); |
@@ -328,13 +378,14 @@ void DateBook::editEvent( const Event &e ) | |||
328 | #endif | 378 | #endif |
329 | while (editDlg.exec() ) { | 379 | while (editDlg.exec() ) { |
330 | Event newEv = entry->event(); | 380 | Event newEv = entry->event(); |
331 | QString error = checkEvent(newEv); | 381 | QString error = checkEvent(newEv); |
332 | if (!error.isNull()) { | 382 | if (!error.isNull()) { |
333 | if (QMessageBox::warning(this, "error box", | 383 | if (QMessageBox::warning(this, "error box", |
334 | error, "Fix it", "Continue", 0, 0, 1) == 0) | 384 | error, "Fix it", "Continue", |
385 | 0, 0, 1) == 0) | ||
335 | continue; | 386 | continue; |
336 | } | 387 | } |
337 | db->editEvent(e, newEv); | 388 | db->editEvent(e, newEv); |
338 | emit newEvent(); | 389 | emit newEvent(); |
339 | break; | 390 | break; |
340 | } | 391 | } |
@@ -419,12 +470,34 @@ void DateBook::initWeek() | |||
419 | d = d.addDays( -1 ); | 470 | d = d.addDays( -1 ); |
420 | calcWeek( d, totWeeks, yearNumber, onMonday ); | 471 | calcWeek( d, totWeeks, yearNumber, onMonday ); |
421 | } | 472 | } |
422 | if ( totWeeks != weekView->totalWeeks() ) | 473 | if ( totWeeks != weekView->totalWeeks() ) |
423 | weekView->setTotalWeeks( totWeeks ); | 474 | weekView->setTotalWeeks( totWeeks ); |
424 | } | 475 | } |
476 | void DateBook::initWeekLst() { | ||
477 | if ( !weekLstView ) { | ||
478 | weekLstView = new DateBookWeekLst( ampm, onMonday, db, | ||
479 | views, "weeklst view" ); | ||
480 | views->addWidget( weekLstView, WEEKLST ); | ||
481 | |||
482 | //weekLstView->setStartViewTime( startTime ); | ||
483 | connect( weekLstView, SIGNAL( showDate( int, int, int ) ), | ||
484 | this, SLOT( showDay( int, int, int ) ) ); | ||
485 | connect( weekLstView, SIGNAL( addEvent( const QDateTime &, | ||
486 | const QDateTime &, | ||
487 | const QString & ) ), | ||
488 | this, SLOT( slotNewEntry( const QDateTime &, | ||
489 | const QDateTime &, | ||
490 | const QString & ) ) ); | ||
491 | connect( this, SIGNAL( newEvent() ), | ||
492 | weekLstView, SLOT( redraw() ) ); | ||
493 | connect( weekLstView, SIGNAL( editEvent( const Event & ) ), | ||
494 | this, SLOT( editEvent( const Event & ) ) ); | ||
495 | } | ||
496 | } | ||
497 | |||
425 | 498 | ||
426 | void DateBook::initMonth() | 499 | void DateBook::initMonth() |
427 | { | 500 | { |
428 | if ( !monthView ) { | 501 | if ( !monthView ) { |
429 | monthView = new DateBookMonth( views, "month view", FALSE, db ); | 502 | monthView = new DateBookMonth( views, "month view", FALSE, db ); |
430 | views->addWidget( monthView, MONTH ); | 503 | views->addWidget( monthView, MONTH ); |
@@ -461,12 +534,24 @@ void DateBook::saveSettings() | |||
461 | configDB.setGroup( "Main" ); | 534 | configDB.setGroup( "Main" ); |
462 | configDB.writeEntry("startviewtime",startTime); | 535 | configDB.writeEntry("startviewtime",startTime); |
463 | configDB.writeEntry("alarmpreset",aPreset); | 536 | configDB.writeEntry("alarmpreset",aPreset); |
464 | configDB.writeEntry("presettime",presetTime); | 537 | configDB.writeEntry("presettime",presetTime); |
465 | } | 538 | } |
466 | 539 | ||
540 | void DateBook::newDefaultView(QAction *a) { | ||
541 | int val=DAY; | ||
542 | if (a->text() == "Day") val=DAY; | ||
543 | if (a->text() == "Week") val=WEEK; | ||
544 | if (a->text() == "WeekLst") val=WEEKLST; | ||
545 | if (a->text() == "Month") val=MONTH; | ||
546 | |||
547 | Config configDB( "DateBook" ); | ||
548 | configDB.setGroup( "Main" ); | ||
549 | configDB.writeEntry("defaultview",val); | ||
550 | } | ||
551 | |||
467 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) | 552 | void DateBook::appMessage(const QCString& msg, const QByteArray& data) |
468 | { | 553 | { |
469 | bool needShow = FALSE; | 554 | bool needShow = FALSE; |
470 | if ( msg == "alarm(QDateTime,int)" ) { | 555 | if ( msg == "alarm(QDateTime,int)" ) { |
471 | QDataStream ds(data,IO_ReadOnly); | 556 | QDataStream ds(data,IO_ReadOnly); |
472 | QDateTime when; int warn; | 557 | QDateTime when; int warn; |
@@ -533,12 +618,14 @@ void DateBook::appMessage(const QCString& msg, const QByteArray& data) | |||
533 | } else if ( msg == "nextView()" ) { | 618 | } else if ( msg == "nextView()" ) { |
534 | QWidget* cur = views->visibleWidget(); | 619 | QWidget* cur = views->visibleWidget(); |
535 | if ( cur ) { | 620 | if ( cur ) { |
536 | if ( cur == dayView ) | 621 | if ( cur == dayView ) |
537 | viewWeek(); | 622 | viewWeek(); |
538 | else if ( cur == weekView ) | 623 | else if ( cur == weekView ) |
624 | viewWeekLst(); | ||
625 | else if ( cur == weekLstView ) | ||
539 | viewMonth(); | 626 | viewMonth(); |
540 | else if ( cur == monthView ) | 627 | else if ( cur == monthView ) |
541 | viewDay(); | 628 | viewDay(); |
542 | needShow = TRUE; | 629 | needShow = TRUE; |
543 | } | 630 | } |
544 | } | 631 | } |
@@ -587,12 +674,13 @@ void DateBook::timerEvent( QTimerEvent *e ) | |||
587 | void DateBook::changeClock( bool newClock ) | 674 | void DateBook::changeClock( bool newClock ) |
588 | { | 675 | { |
589 | ampm = newClock; | 676 | ampm = newClock; |
590 | // repaint the affected objects... | 677 | // repaint the affected objects... |
591 | if (dayView) dayView->redraw(); | 678 | if (dayView) dayView->redraw(); |
592 | if (weekView) weekView->redraw(); | 679 | if (weekView) weekView->redraw(); |
680 | if (weekLstView) weekLstView->redraw(); | ||
593 | } | 681 | } |
594 | 682 | ||
595 | void DateBook::changeWeek( bool m ) | 683 | void DateBook::changeWeek( bool m ) |
596 | { | 684 | { |
597 | /* no need to redraw, each widget catches. Do need to | 685 | /* no need to redraw, each widget catches. Do need to |
598 | store though for widgets we haven't made yet */ | 686 | store though for widgets we haven't made yet */ |
@@ -657,13 +745,15 @@ void DateBook::slotNewEventFromKey( const QString &str ) | |||
657 | } else if ( views->visibleWidget() == weekView ) { | 745 | } else if ( views->visibleWidget() == weekView ) { |
658 | QDate d = weekView->date(); | 746 | QDate d = weekView->date(); |
659 | start = end = d; | 747 | start = end = d; |
660 | start.setTime( QTime( 10, 0 ) ); | 748 | start.setTime( QTime( 10, 0 ) ); |
661 | end.setTime( QTime( 12, 0 ) ); | 749 | end.setTime( QTime( 12, 0 ) ); |
662 | } | 750 | } |
663 | 751 | slotNewEntry(start, end, str); | |
752 | } | ||
753 | void DateBook::slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str) { | ||
664 | // argh! This really needs to be encapsulated in a class | 754 | // argh! This really needs to be encapsulated in a class |
665 | // or function. | 755 | // or function. |
666 | QDialog newDlg( this, 0, TRUE ); | 756 | QDialog newDlg( this, 0, TRUE ); |
667 | newDlg.setCaption( DateEntryBase::tr("New Event") ); | 757 | newDlg.setCaption( DateEntryBase::tr("New Event") ); |
668 | DateEntry *e; | 758 | DateEntry *e; |
669 | QVBoxLayout *vb = new QVBoxLayout( &newDlg ); | 759 | QVBoxLayout *vb = new QVBoxLayout( &newDlg ); |