summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/datebook/datebook.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/core/pim/datebook/datebook.cpp b/core/pim/datebook/datebook.cpp
index 832b2f8..24affd0 100644
--- a/core/pim/datebook/datebook.cpp
+++ b/core/pim/datebook/datebook.cpp
@@ -232,844 +232,856 @@ void DateBook::receive( const QCString &msg, const QByteArray &data )
232 }else if (msg == "viewDefault(QDate)"){ 232 }else if (msg == "viewDefault(QDate)"){
233 QDate day; 233 QDate day;
234 stream >> day; 234 stream >> day;
235 viewDefault(day); 235 viewDefault(day);
236 } 236 }
237} 237}
238 238
239DateBook::~DateBook() 239DateBook::~DateBook()
240{ 240{
241} 241}
242 242
243void DateBook::slotSettings() 243void DateBook::slotSettings()
244{ 244{
245 DateBookSettings frmSettings( ampm, this ); 245 DateBookSettings frmSettings( ampm, this );
246 frmSettings.setStartTime( startTime ); 246 frmSettings.setStartTime( startTime );
247 frmSettings.setAlarmPreset( aPreset, presetTime ); 247 frmSettings.setAlarmPreset( aPreset, presetTime );
248 frmSettings.setJumpToCurTime( bJumpToCurTime ); 248 frmSettings.setJumpToCurTime( bJumpToCurTime );
249 frmSettings.setRowStyle( rowStyle ); 249 frmSettings.setRowStyle( rowStyle );
250 frmSettings.comboDefaultView->setCurrentItem(defaultView-1); 250 frmSettings.comboDefaultView->setCurrentItem(defaultView-1);
251 frmSettings.comboWeekListView->setCurrentItem(weeklistviewconfig); 251 frmSettings.comboWeekListView->setCurrentItem(weeklistviewconfig);
252 252
253 bool found=false; 253 bool found=false;
254 for (int i=0; i<(frmSettings.comboLocation->count()); i++) { 254 for (int i=0; i<(frmSettings.comboLocation->count()); i++) {
255 if ( frmSettings.comboLocation->text(i) == defaultLocation ) { 255 if ( frmSettings.comboLocation->text(i) == defaultLocation ) {
256 frmSettings.comboLocation->setCurrentItem(i); 256 frmSettings.comboLocation->setCurrentItem(i);
257 found=true; 257 found=true;
258 break; 258 break;
259 } 259 }
260 } 260 }
261 if(!found) { 261 if(!found) {
262 frmSettings.comboLocation->insertItem(defaultLocation); 262 frmSettings.comboLocation->insertItem(defaultLocation);
263 frmSettings.comboLocation->setCurrentItem(frmSettings.comboLocation->count()-1); 263 frmSettings.comboLocation->setCurrentItem(frmSettings.comboLocation->count()-1);
264 } 264 }
265 frmSettings.comboCategory->setCategories(defaultCategories,"Calendar", tr("Calendar")); 265 frmSettings.comboCategory->setCategories(defaultCategories,"Calendar", tr("Calendar"));
266 266
267 if ( QPEApplication::execDialog( &frmSettings ) ) { 267 if ( QPEApplication::execDialog( &frmSettings ) ) {
268 aPreset = frmSettings.alarmPreset(); 268 aPreset = frmSettings.alarmPreset();
269 presetTime = frmSettings.presetTime(); 269 presetTime = frmSettings.presetTime();
270 startTime = frmSettings.startTime(); 270 startTime = frmSettings.startTime();
271 bJumpToCurTime = frmSettings.jumpToCurTime(); 271 bJumpToCurTime = frmSettings.jumpToCurTime();
272 rowStyle = frmSettings.rowStyle(); 272 rowStyle = frmSettings.rowStyle();
273 defaultView=frmSettings.comboDefaultView->currentItem()+1; 273 defaultView=frmSettings.comboDefaultView->currentItem()+1;
274 weeklistviewconfig=frmSettings.comboWeekListView->currentItem(); 274 weeklistviewconfig=frmSettings.comboWeekListView->currentItem();
275 defaultLocation=frmSettings.comboLocation->currentText(); 275 defaultLocation=frmSettings.comboLocation->currentText();
276 defaultCategories=frmSettings.comboCategory->currentCategories(); 276 defaultCategories=frmSettings.comboCategory->currentCategories();
277 277
278 if ( dayView ) { 278 if ( dayView ) {
279 dayView->setStartViewTime( startTime ); 279 dayView->setStartViewTime( startTime );
280 dayView->setJumpToCurTime( bJumpToCurTime ); 280 dayView->setJumpToCurTime( bJumpToCurTime );
281 dayView->setRowStyle( rowStyle ); 281 dayView->setRowStyle( rowStyle );
282 } 282 }
283 if ( weekView ) { 283 if ( weekView ) {
284 weekView->setStartViewTime( startTime ); 284 weekView->setStartViewTime( startTime );
285 } 285 }
286 saveSettings(); 286 saveSettings();
287 287
288 // make the change obvious 288 // make the change obvious
289 if ( views->visibleWidget() ) { 289 if ( views->visibleWidget() ) {
290 if ( views->visibleWidget() == dayView ) 290 if ( views->visibleWidget() == dayView )
291 dayView->redraw(); 291 dayView->redraw();
292 else if ( views->visibleWidget() == weekView ) 292 else if ( views->visibleWidget() == weekView )
293 weekView->redraw(); 293 weekView->redraw();
294 else if ( views->visibleWidget() == weekLstView ) 294 else if ( views->visibleWidget() == weekLstView )
295 weekLstView->redraw(); 295 weekLstView->redraw();
296 } 296 }
297 } 297 }
298} 298}
299 299
300void DateBook::fileNew() 300void DateBook::fileNew()
301{ 301{
302 slotNewEventFromKey(""); 302 slotNewEventFromKey("");
303} 303}
304 304
305QString DateBook::checkEvent(const Event &e) 305QString DateBook::checkEvent(const Event &e)
306{ 306{
307 /* check if overlaps with itself */ 307 /* check if overlaps with itself */
308 bool checkFailed = FALSE; 308 bool checkFailed = FALSE;
309 309
310 /* check the next 12 repeats. should catch most problems */ 310 /* check the next 12 repeats. should catch most problems */
311 QDate current_date = e.start().date(); 311 QDate current_date = e.start().date();
312 Event previous = e; 312 Event previous = e;
313 for(int i = 0; i < 12; i++) 313 for(int i = 0; i < 12; i++)
314 { 314 {
315 QDateTime next; 315 QDateTime next;
316 if (!nextOccurance(previous, current_date.addDays(1), next)) { 316 if (!nextOccurance(previous, current_date.addDays(1), next)) {
317 break; // no more repeats 317 break; // no more repeats
318 } 318 }
319 if(next < previous.end()) { 319 if(next < previous.end()) {
320 checkFailed = TRUE; 320 checkFailed = TRUE;
321 break; 321 break;
322 } 322 }
323 current_date = next.date(); 323 current_date = next.date();
324 } 324 }
325 325
326 if(checkFailed) 326 if(checkFailed)
327 return tr("Event duration is potentially longer\n" 327 return tr("Event duration is potentially longer\n"
328 "than interval between repeats."); 328 "than interval between repeats.");
329 329
330 return QString::null; 330 return QString::null;
331} 331}
332 332
333QDate DateBook::currentDate() 333QDate DateBook::currentDate()
334{ 334{
335 QDate d = QDate::currentDate(); 335 QDate d = QDate::currentDate();
336 336
337 if ( dayView && views->visibleWidget() == dayView ) { 337 if ( dayView && views->visibleWidget() == dayView ) {
338 d = dayView->date(); 338 d = dayView->date();
339 } else if ( weekView && views->visibleWidget() == weekView ) { 339 } else if ( weekView && views->visibleWidget() == weekView ) {
340 d = weekView->date(); 340 d = weekView->date();
341 } else if ( weekLstView && views->visibleWidget() == weekLstView ) { 341 } else if ( weekLstView && views->visibleWidget() == weekLstView ) {
342 d = weekLstView->date(); 342 d = weekLstView->date();
343 } else if ( monthView && views->visibleWidget() == monthView ) { 343 } else if ( monthView && views->visibleWidget() == monthView ) {
344 d = monthView->selectedDate(); 344 d = monthView->selectedDate();
345 } 345 }
346 346
347 return d; 347 return d;
348} 348}
349 349
350void DateBook::view(int v, const QDate &d) { 350void DateBook::view(int v, const QDate &d) {
351 if (v==DAY) { 351 if (v==DAY) {
352 initDay(); 352 initDay();
353 dayAction->setOn( TRUE ); 353 dayAction->setOn( TRUE );
354 dayView->setDate( d ); 354 dayView->setDate( d );
355 views->raiseWidget( dayView ); 355 views->raiseWidget( dayView );
356 dayView->redraw(); 356 dayView->redraw();
357 } else if (v==WEEK) { 357 } else if (v==WEEK) {
358 initWeek(); 358 initWeek();
359 weekAction->setOn( TRUE ); 359 weekAction->setOn( TRUE );
360 weekView->setDate( d ); 360 weekView->setDate( d );
361 views->raiseWidget( weekView ); 361 views->raiseWidget( weekView );
362 weekView->redraw(); 362 weekView->redraw();
363 } else if (v==WEEKLST) { 363 } else if (v==WEEKLST) {
364 initWeekLst(); 364 initWeekLst();
365 weekLstAction->setOn( TRUE ); 365 weekLstAction->setOn( TRUE );
366 weekLstView->setDate(d); 366 weekLstView->setDate(d);
367 views->raiseWidget( weekLstView ); 367 views->raiseWidget( weekLstView );
368 weekLstView->redraw(); 368 weekLstView->redraw();
369 } else if (v==MONTH) { 369 } else if (v==MONTH) {
370 initMonth(); 370 initMonth();
371 monthAction->setOn( TRUE ); 371 monthAction->setOn( TRUE );
372 monthView->setDate( d.year(), d.month(), d.day() ); 372 monthView->setDate( d.year(), d.month(), d.day() );
373 views->raiseWidget( monthView ); 373 views->raiseWidget( monthView );
374 monthView->redraw(); 374 monthView->redraw();
375 } 375 }
376} 376}
377 377
378void DateBook::viewDefault(const QDate &d) { 378void DateBook::viewDefault(const QDate &d) {
379 view(defaultView,d); 379 view(defaultView,d);
380} 380}
381 381
382void DateBook::viewDay() { 382void DateBook::viewDay() {
383 view(DAY,currentDate()); 383 view(DAY,currentDate());
384} 384}
385 385
386void DateBook::viewWeek() { 386void DateBook::viewWeek() {
387 view(WEEK,currentDate()); 387 view(WEEK,currentDate());
388} 388}
389 389
390void DateBook::viewWeekLst() { 390void DateBook::viewWeekLst() {
391 view(WEEKLST,currentDate()); 391 view(WEEKLST,currentDate());
392} 392}
393 393
394void DateBook::viewMonth() { 394void DateBook::viewMonth() {
395 view(MONTH,currentDate()); 395 view(MONTH,currentDate());
396} 396}
397 397
398void DateBook::insertEvent( const Event &e ) 398void DateBook::insertEvent( const Event &e )
399{ 399{
400 Event dupEvent=e; 400 Event dupEvent=e;
401 if(!dupEvent.isValidUid() ) // tkcRom seems to be different 401 if(!dupEvent.isValidUid() ) // tkcRom seems to be different
402 dupEvent.assignUid(); 402 dupEvent.assignUid();
403 dupEvent.setLocation(defaultLocation); 403 dupEvent.setLocation(defaultLocation);
404 dupEvent.setCategories(defaultCategories); 404 dupEvent.setCategories(defaultCategories);
405 db->addEvent(dupEvent); 405 db->addEvent(dupEvent);
406 emit newEvent(); 406 emit newEvent();
407} 407}
408 408
409void DateBook::duplicateEvent( const Event &e ) 409void DateBook::duplicateEvent( const Event &e )
410{ 410{
411 // Alot of code duplication, as this is almost like editEvent(); 411 // Alot of code duplication, as this is almost like editEvent();
412 if (syncing) { 412 if (syncing) {
413 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); 413 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") );
414 return; 414 return;
415 } 415 }
416 416
417 Event dupevent(e);// Make a duplicate. 417 Event dupevent(e);// Make a duplicate.
418 418
419 // workaround added for text input. 419 // workaround added for text input.
420 QDialog editDlg( this, 0, TRUE ); 420 QDialog editDlg( this, 0, TRUE );
421 DateEntry *entry; 421 DateEntry *entry;
422 editDlg.setCaption( tr("Duplicate Event") ); 422 editDlg.setCaption( tr("Duplicate Event") );
423 QVBoxLayout *vb = new QVBoxLayout( &editDlg ); 423 QVBoxLayout *vb = new QVBoxLayout( &editDlg );
424 QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); 424 QScrollView *sv = new QScrollView( &editDlg, "scrollview" );
425 sv->setResizePolicy( QScrollView::AutoOneFit ); 425 sv->setResizePolicy( QScrollView::AutoOneFit );
426 // KLUDGE!!! 426 // KLUDGE!!!
427 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 427 sv->setHScrollBarMode( QScrollView::AlwaysOff );
428 vb->addWidget( sv ); 428 vb->addWidget( sv );
429 entry = new DateEntry( onMonday, dupevent, ampm, &editDlg, "editor" ); 429 entry = new DateEntry( onMonday, dupevent, ampm, &editDlg, "editor" );
430 entry->timezone->setEnabled( FALSE ); 430 entry->timezone->setEnabled( FALSE );
431 sv->addChild( entry ); 431 sv->addChild( entry );
432 432
433 while ( QPEApplication::execDialog( &editDlg ) ) { 433 while ( QPEApplication::execDialog( &editDlg ) ) {
434 Event newEv = entry->event(); 434 Event newEv = entry->event();
435 QString error = checkEvent(newEv); 435 QString error = checkEvent(newEv);
436 if (!error.isNull()) { 436 if (!error.isNull()) {
437 if (QMessageBox::warning(this, tr("error box"), error, tr("Fix it"), tr("Continue"), 0, 0, 1) == 0) 437 if (QMessageBox::warning(this, tr("error box"), error, tr("Fix it"), tr("Continue"), 0, 0, 1) == 0)
438 continue; 438 continue;
439 } 439 }
440 /* 440 /*
441 * The problem: 441 * The problem:
442 * DateBookDB does remove repeating events not by uid but by the time 442 * DateBookDB does remove repeating events not by uid but by the time
443 * the recurrence was created 443 * the recurrence was created
444 * so we need to update that time as well 444 * so we need to update that time as well
445 */ 445 */
446 Event::RepeatPattern rp = newEv.repeatPattern(); 446 Event::RepeatPattern rp = newEv.repeatPattern();
447 rp.createTime = ::time( NULL ); 447 rp.createTime = ::time( NULL );
448 newEv.setRepeat( TRUE, rp ); // has repeat and repeatPattern... 448 newEv.setRepeat( TRUE, rp ); // has repeat and repeatPattern...
449 if( newEv.uid() == e.uid() || !newEv.isValidUid() ) 449 if( newEv.uid() == e.uid() || !newEv.isValidUid() )
450 newEv.assignUid(); 450 newEv.assignUid();
451 451
452 db->addEvent(newEv); 452 db->addEvent(newEv);
453 emit newEvent(); 453 emit newEvent();
454 break; 454 break;
455 } 455 }
456} 456}
457 457
458void DateBook::editEvent( const Event &e ) 458void DateBook::editEvent( const Event &e )
459{ 459{
460 if (syncing) { 460 if (syncing) {
461 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); 461 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") );
462 return; 462 return;
463 } 463 }
464 464
465 // workaround added for text input. 465 // workaround added for text input.
466 QDialog editDlg( this, 0, TRUE ); 466 QDialog editDlg( this, 0, TRUE );
467 DateEntry *entry; 467 DateEntry *entry;
468 editDlg.setCaption( tr("Edit Event") ); 468 editDlg.setCaption( tr("Edit Event") );
469 QVBoxLayout *vb = new QVBoxLayout( &editDlg ); 469 QVBoxLayout *vb = new QVBoxLayout( &editDlg );
470 QScrollView *sv = new QScrollView( &editDlg, "scrollview" ); 470 QScrollView *sv = new QScrollView( &editDlg, "scrollview" );
471 sv->setResizePolicy( QScrollView::AutoOneFit ); 471 sv->setResizePolicy( QScrollView::AutoOneFit );
472 // KLUDGE!!! 472 // KLUDGE!!!
473 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 473 sv->setHScrollBarMode( QScrollView::AlwaysOff );
474 vb->addWidget( sv ); 474 vb->addWidget( sv );
475 entry = new DateEntry( onMonday, e, ampm, &editDlg, "editor" ); 475 entry = new DateEntry( onMonday, e, ampm, &editDlg, "editor" );
476 entry->timezone->setEnabled( FALSE ); 476 entry->timezone->setEnabled( FALSE );
477 sv->addChild( entry ); 477 sv->addChild( entry );
478 478
479 while ( QPEApplication::execDialog( &editDlg ) ) { 479 while ( QPEApplication::execDialog( &editDlg ) ) {
480 Event newEv = entry->event(); 480 Event newEv = entry->event();
481 if(newEv.description().isEmpty() && newEv.notes().isEmpty() ) 481 if(newEv.description().isEmpty() && newEv.notes().isEmpty() )
482 break; 482 break;
483 newEv.setUid(e.uid()); // FIXME: Hack not to clear uid 483 newEv.setUid(e.uid()); // FIXME: Hack not to clear uid
484 QString error = checkEvent(newEv); 484 QString error = checkEvent(newEv);
485 if (!error.isNull()) { 485 if (!error.isNull()) {
486 if (QMessageBox::warning(this, tr("error box"), error, tr("Fix it"), tr("Continue"), 0, 0, 1) == 0) continue; 486 if (QMessageBox::warning(this, tr("error box"), error, tr("Fix it"), tr("Continue"), 0, 0, 1) == 0) continue;
487 } 487 }
488 db->editEvent(e, newEv); 488 db->editEvent(e, newEv);
489 emit newEvent(); 489 emit newEvent();
490 break; 490 break;
491 } 491 }
492} 492}
493 493
494void DateBook::removeEvent( const Event &e ) 494void DateBook::removeEvent( const Event &e )
495{ 495{
496 if (syncing) { 496 if (syncing) {
497 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") ); 497 QMessageBox::warning( this, tr("Calendar"), tr( "Can not edit data, currently syncing") );
498 return; 498 return;
499 } 499 }
500 500
501 QString strName = e.description(); 501 QString strName = e.description();
502 502
503 if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) ) 503 if ( !QPEMessageBox::confirmDelete( this, tr( "Calendar" ),strName ) )
504 return; 504 return;
505 505
506 db->removeEvent( e ); 506 db->removeEvent( e );
507 if ( views->visibleWidget() == dayView && dayView ) 507 if ( views->visibleWidget() == dayView && dayView )
508 dayView->redraw(); 508 dayView->redraw();
509 509
510} 510}
511 511
512void DateBook::addEvent( const Event &e ) 512void DateBook::addEvent( const Event &e )
513{ 513{
514 QDate d = e.start().date(); 514 QDate d = e.start().date();
515 initDay(); 515 initDay();
516 dayView->setDate( d ); 516 dayView->setDate( d );
517} 517}
518 518
519void DateBook::showDay( int year, int month, int day ) 519void DateBook::showDay( int year, int month, int day )
520{ 520{
521 QDate d(year, month, day); 521 QDate d(year, month, day);
522 view(DAY,d); 522 view(DAY,d);
523} 523}
524 524
525void DateBook::initDay() 525void DateBook::initDay()
526{ 526{
527 if ( !dayView ) { 527 if ( !dayView ) {
528 dayView = new DateBookDay( ampm, onMonday, db, views, "day view" ); 528 dayView = new DateBookDay( ampm, onMonday, db, views, "day view" );
529 views->addWidget( dayView, DAY ); 529 views->addWidget( dayView, DAY );
530 dayView->setJumpToCurTime( bJumpToCurTime ); 530 dayView->setJumpToCurTime( bJumpToCurTime );
531 dayView->setStartViewTime( startTime ); 531 dayView->setStartViewTime( startTime );
532 dayView->setRowStyle( rowStyle ); 532 dayView->setRowStyle( rowStyle );
533 connect( this, SIGNAL( newEvent() ), dayView, SLOT( redraw() ) ); 533 connect( this, SIGNAL( newEvent() ), dayView, SLOT( redraw() ) );
534 connect( dayView, SIGNAL( newEvent() ), this, SLOT( fileNew() ) ); 534 connect( dayView, SIGNAL( newEvent() ), this, SLOT( fileNew() ) );
535 connect( dayView, SIGNAL( removeEvent( const Event & ) ), this, SLOT( removeEvent( const Event & ) ) ); 535 connect( dayView, SIGNAL( removeEvent( const Event & ) ), this, SLOT( removeEvent( const Event & ) ) );
536 connect( dayView, SIGNAL( editEvent( const Event & ) ), this, SLOT( editEvent( const Event & ) ) ); 536 connect( dayView, SIGNAL( editEvent( const Event & ) ), this, SLOT( editEvent( const Event & ) ) );
537 connect( dayView, SIGNAL( duplicateEvent( const Event & ) ), this, SLOT( duplicateEvent( const Event & ) ) ); 537 connect( dayView, SIGNAL( duplicateEvent( const Event & ) ), this, SLOT( duplicateEvent( const Event & ) ) );
538 connect( dayView, SIGNAL( beamEvent( const Event & ) ), this, SLOT( beamEvent( const Event & ) ) ); 538 connect( dayView, SIGNAL( beamEvent( const Event & ) ), this, SLOT( beamEvent( const Event & ) ) );
539 connect( dayView, SIGNAL(sigNewEvent(const QString &)), this, SLOT(slotNewEventFromKey(const QString &)) ); 539 connect( dayView, SIGNAL(sigNewEvent(const QString &)), this, SLOT(slotNewEventFromKey(const QString &)) );
540 } 540 }
541} 541}
542 542
543void DateBook::initWeek() 543void DateBook::initWeek()
544{ 544{
545 if ( !weekView ) { 545 if ( !weekView ) {
546 weekView = new DateBookWeek( ampm, onMonday, db, views, "week view" ); 546 weekView = new DateBookWeek( ampm, onMonday, db, views, "week view" );
547 weekView->setStartViewTime( startTime ); 547 weekView->setStartViewTime( startTime );
548 views->addWidget( weekView, WEEK ); 548 views->addWidget( weekView, WEEK );
549 connect( weekView, SIGNAL( showDate( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) ); 549 connect( weekView, SIGNAL( showDate( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) );
550 connect( this, SIGNAL( newEvent() ), weekView, SLOT( redraw() ) ); 550 connect( this, SIGNAL( newEvent() ), weekView, SLOT( redraw() ) );
551 } 551 }
552 552
553 //But also get it right: the year that we display can be different 553 //But also get it right: the year that we display can be different
554 //from the year of the current date. So, first find the year 554 //from the year of the current date. So, first find the year
555 //number of the current week. 555 //number of the current week.
556 int yearNumber, totWeeks; 556 int yearNumber, totWeeks;
557 calcWeek( currentDate(), totWeeks, yearNumber, onMonday ); 557 calcWeek( currentDate(), totWeeks, yearNumber, onMonday );
558 558
559 QDate d = QDate( yearNumber, 12, 31 ); 559 QDate d = QDate( yearNumber, 12, 31 );
560 calcWeek( d, totWeeks, yearNumber, onMonday ); 560 calcWeek( d, totWeeks, yearNumber, onMonday );
561 561
562 while ( totWeeks == 1 ) { 562 while ( totWeeks == 1 ) {
563 d = d.addDays( -1 ); 563 d = d.addDays( -1 );
564 calcWeek( d, totWeeks, yearNumber, onMonday ); 564 calcWeek( d, totWeeks, yearNumber, onMonday );
565 } 565 }
566} 566}
567 567
568void DateBook::initWeekLst() { 568void DateBook::initWeekLst() {
569 if ( !weekLstView ) { 569 if ( !weekLstView ) {
570 weekLstView = new DateBookWeekLst( ampm, onMonday, db, views, "weeklst view" ); 570 weekLstView = new DateBookWeekLst( ampm, onMonday, db, views, "weeklst view" );
571 views->addWidget( weekLstView, WEEKLST ); 571 views->addWidget( weekLstView, WEEKLST );
572 572
573 //weekLstView->setStartViewTime( startTime ); 573 //weekLstView->setStartViewTime( startTime );
574 connect( weekLstView, SIGNAL( showDate( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) ); 574 connect( weekLstView, SIGNAL( showDate( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) );
575 connect( weekLstView, SIGNAL( addEvent( const QDateTime &, const QDateTime &, const QString & , const QString &) ), 575 connect( weekLstView, SIGNAL( addEvent( const QDateTime &, const QDateTime &, const QString & , const QString &) ),
576 this, SLOT( slotNewEntry( const QDateTime &, const QDateTime &, const QString & , const QString &) ) ); 576 this, SLOT( slotNewEntry( const QDateTime &, const QDateTime &, const QString & , const QString &) ) );
577 connect( this, SIGNAL( newEvent() ), weekLstView, SLOT( redraw() ) ); 577 connect( this, SIGNAL( newEvent() ), weekLstView, SLOT( redraw() ) );
578 connect( weekLstView, SIGNAL( editEvent( const Event & ) ), this, SLOT( editEvent( const Event & ) ) ); 578 connect( weekLstView, SIGNAL( editEvent( const Event & ) ), this, SLOT( editEvent( const Event & ) ) );
579 } 579 }
580} 580}
581 581
582 582
583void DateBook::initMonth() 583void DateBook::initMonth()
584{ 584{
585 if ( !monthView ) { 585 if ( !monthView ) {
586 monthView = new DateBookMonth( views, "month view", FALSE, db ); 586 monthView = new DateBookMonth( views, "month view", FALSE, db );
587 views->addWidget( monthView, MONTH ); 587 views->addWidget( monthView, MONTH );
588 connect( monthView, SIGNAL( dateClicked( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) ); 588 connect( monthView, SIGNAL( dateClicked( int, int, int ) ), this, SLOT( showDay( int, int, int ) ) );
589 connect( this, SIGNAL( newEvent() ), monthView, SLOT( redraw() ) ); 589 connect( this, SIGNAL( newEvent() ), monthView, SLOT( redraw() ) );
590 qApp->processEvents(); 590 qApp->processEvents();
591 } 591 }
592} 592}
593 593
594void DateBook::loadSettings() 594void DateBook::loadSettings()
595{ 595{
596 Config qpeconfig( "qpe" ); 596 Config qpeconfig( "qpe" );
597 qpeconfig.setGroup("Time"); 597 qpeconfig.setGroup("Time");
598 ampm = qpeconfig.readBoolEntry( "AMPM", TRUE ); 598 ampm = qpeconfig.readBoolEntry( "AMPM", TRUE );
599 onMonday = qpeconfig.readBoolEntry( "MONDAY" ); 599 onMonday = qpeconfig.readBoolEntry( "MONDAY" );
600 600
601 Config config("DateBook"); 601 Config config("DateBook");
602 config.setGroup("Main"); 602 config.setGroup("Main");
603 startTime = config.readNumEntry("startviewtime", 8); 603 startTime = config.readNumEntry("startviewtime", 8);
604 aPreset = config.readBoolEntry("alarmpreset"); 604 aPreset = config.readBoolEntry("alarmpreset");
605 presetTime = config.readNumEntry("presettime"); 605 presetTime = config.readNumEntry("presettime");
606 bJumpToCurTime = config.readBoolEntry("jumptocurtime"); 606 bJumpToCurTime = config.readBoolEntry("jumptocurtime");
607 rowStyle = config.readNumEntry("rowstyle"); 607 rowStyle = config.readNumEntry("rowstyle");
608 defaultView = config.readNumEntry("defaultview",DAY); 608 defaultView = config.readNumEntry("defaultview",DAY);
609 weeklistviewconfig = config.readNumEntry("weeklistviewconfig",NORMAL); 609 weeklistviewconfig = config.readNumEntry("weeklistviewconfig",NORMAL);
610 610
611 defaultLocation=config.readEntry("defaultLocation"); 611 defaultLocation=config.readEntry("defaultLocation");
612 QString tmpString=config.readEntry("defaultCategories"); 612 QString tmpString=config.readEntry("defaultCategories");
613 QStringList tmpStringList=QStringList::split(",",tmpString); 613 QStringList tmpStringList=QStringList::split(",",tmpString);
614 defaultCategories.truncate(0); 614 defaultCategories.truncate(0);
615 615
616 for( QStringList::Iterator i=tmpStringList.begin(); i!=tmpStringList.end(); i++) { 616 for( QStringList::Iterator i=tmpStringList.begin(); i!=tmpStringList.end(); i++) {
617 defaultCategories.resize(defaultCategories.count()+1); 617 defaultCategories.resize(defaultCategories.count()+1);
618 defaultCategories[defaultCategories.count()-1]=(*i).toInt(); 618 defaultCategories[defaultCategories.count()-1]=(*i).toInt();
619 } 619 }
620} 620}
621 621
622void DateBook::saveSettings() 622void DateBook::saveSettings()
623{ 623{
624 Config config( "qpe" ); 624 Config config( "qpe" );
625 Config configDB( "DateBook" ); 625 Config configDB( "DateBook" );
626 configDB.setGroup( "Main" ); 626 configDB.setGroup( "Main" );
627 configDB.writeEntry("startviewtime",startTime); 627 configDB.writeEntry("startviewtime",startTime);
628 configDB.writeEntry("alarmpreset",aPreset); 628 configDB.writeEntry("alarmpreset",aPreset);
629 configDB.writeEntry("presettime",presetTime); 629 configDB.writeEntry("presettime",presetTime);
630 configDB.writeEntry("jumptocurtime", bJumpToCurTime); 630 configDB.writeEntry("jumptocurtime", bJumpToCurTime);
631 configDB.writeEntry("rowstyle", rowStyle); 631 configDB.writeEntry("rowstyle", rowStyle);
632 configDB.writeEntry("defaultview",defaultView); 632 configDB.writeEntry("defaultview",defaultView);
633 configDB.writeEntry("weeklistviewconfig",weeklistviewconfig); 633 configDB.writeEntry("weeklistviewconfig",weeklistviewconfig);
634 634
635 configDB.writeEntry("defaultLocation",defaultLocation); 635 configDB.writeEntry("defaultLocation",defaultLocation);
636 QStringList tmpStringList; 636 QStringList tmpStringList;
637 for( uint i=0; i<defaultCategories.count(); i++) { 637 for( uint i=0; i<defaultCategories.count(); i++) {
638 tmpStringList << QString::number(defaultCategories[i]); 638 tmpStringList << QString::number(defaultCategories[i]);
639 } 639 }
640 configDB.writeEntry("defaultCategories",tmpStringList.join(",")); 640 configDB.writeEntry("defaultCategories",tmpStringList.join(","));
641} 641}
642 642
643void DateBook::appMessage(const QCString& msg, const QByteArray& data) 643void DateBook::appMessage(const QCString& msg, const QByteArray& data)
644{ 644{
645 bool needShow = FALSE; 645 bool needShow = FALSE;
646 if ( msg == "alarm(QDateTime,int)" ) { 646 if ( msg == "alarm(QDateTime,int)" ) {
647 QDataStream ds(data,IO_ReadOnly); 647 QDataStream ds(data,IO_ReadOnly);
648 QDateTime when; int warn; 648 QDateTime when; int warn;
649 ds >> when >> warn; 649 ds >> when >> warn;
650 650
651 // check to make it's okay to continue, 651 // check to make it's okay to continue,
652 // this is the case that the time was set ahead, and 652 // this is the case that the time was set ahead, and
653 // we are forced given a stale alarm... 653 // we are forced given a stale alarm...
654 QDateTime current = QDateTime::currentDateTime(); 654 QDateTime current = QDateTime::currentDateTime();
655 if ( current.time().hour() != when.time().hour() && current.time().minute() != when.time().minute() ) 655 if ( current.time().hour() != when.time().hour() && current.time().minute() != when.time().minute() )
656 return; 656 return;
657 657
658 QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60)); 658 QValueList<EffectiveEvent> list = db->getEffectiveEvents(when.addSecs(warn*60));
659 if ( list.count() > 0 ) { 659 if ( list.count() > 0 ) {
660 QString msg; 660 QString msg;
661 bool bSound = FALSE; 661 bool bSound = FALSE;
662 int stopTimer = 0; 662 int stopTimer = 0;
663 bool found = FALSE; 663 bool found = FALSE;
664 for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); it!=list.end(); ++it ) { 664 for ( QValueList<EffectiveEvent>::ConstIterator it=list.begin(); it!=list.end(); ++it ) {
665 if ( (*it).event().hasAlarm() ) { 665 if ( (*it).event().hasAlarm() ) {
666 found = TRUE; 666 found = TRUE;
667 msg += "<CENTER><B>" + (*it).description() + "</B>" 667 msg += "<CENTER><B>" + (*it).description() + "</B>"
668 + "<BR>" + (*it).location() + "<BR>" 668 + "<BR>" + (*it).location() + "<BR>"
669 + TimeString::dateString((*it).event().start(),ampm) 669 + TimeString::dateString((*it).event().start(),ampm)
670 + (warn 670 + (warn
671 ? tr(" (in " + QString::number(warn) 671 ? tr(" (in " + QString::number(warn)
672 + tr(" minutes)")) 672 + tr(" minutes)"))
673 : QString("")) 673 : QString(""))
674 + "<BR>" 674 + "<BR>"
675 + (*it).notes() + "</CENTER>"; 675 + (*it).notes() + "</CENTER>";
676 if ( (*it).event().alarmSound() != Event::Silent ) { 676 if ( (*it).event().alarmSound() != Event::Silent ) {
677 bSound = TRUE; 677 bSound = TRUE;
678 } 678 }
679 } 679 }
680 } 680 }
681 if ( found ) { 681 if ( found ) {
682 if ( bSound ) { 682 if ( bSound ) {
683 Sound::soundAlarm(); 683 Sound::soundAlarm();
684 alarmCounter = 0; 684 alarmCounter = 0;
685 stopTimer = startTimer( 5000 ); 685 stopTimer = startTimer( 5000 );
686 } 686 }
687 QDialog dlg( this, 0, TRUE ); 687 QDialog dlg( this, 0, TRUE );
688 QVBoxLayout *vb = new QVBoxLayout( &dlg ); 688 QVBoxLayout *vb = new QVBoxLayout( &dlg );
689 QScrollView *view = new QScrollView( &dlg, "scrollView"); 689 QScrollView *view = new QScrollView( &dlg, "scrollView");
690 view->setResizePolicy( QScrollView::AutoOneFit ); 690 view->setResizePolicy( QScrollView::AutoOneFit );
691 vb->addWidget( view ); 691 vb->addWidget( view );
692 QLabel *lblMsg = new QLabel( msg, &dlg ); 692 QLabel *lblMsg = new QLabel( msg, &dlg );
693 view->addChild( lblMsg ); 693 view->addChild( lblMsg );
694 QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg ); 694 QPushButton *cmdOk = new QPushButton( tr("OK"), &dlg );
695 connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) ); 695 connect( cmdOk, SIGNAL(clicked()), &dlg, SLOT(accept()) );
696 vb->addWidget( cmdOk ); 696 vb->addWidget( cmdOk );
697 697
698 needShow = QPEApplication::execDialog( &dlg ); 698 needShow = QPEApplication::execDialog( &dlg );
699 699
700 if ( bSound ) 700 if ( bSound )
701 killTimer( stopTimer ); 701 killTimer( stopTimer );
702 } 702 }
703 } 703 }
704 } else if ( msg == "nextView()" ) { 704 } else if ( msg == "nextView()" ) {
705 needShow = true; 705 needShow = true;
706 if ( !qApp-> activeWindow ( )) { 706 if ( !qApp-> activeWindow ( )) {
707 needShow = TRUE; 707 needShow = TRUE;
708 } else { 708 } else {
709 QWidget* cur = views->visibleWidget(); 709 QWidget* cur = views->visibleWidget();
710 if ( cur ) { 710 if ( cur ) {
711 if ( cur == dayView ) 711 if ( cur == dayView )
712 viewWeek(); 712 viewWeek();
713 else if ( cur == weekView ) 713 else if ( cur == weekView )
714 viewWeekLst(); 714 viewWeekLst();
715 else if ( cur == weekLstView ) 715 else if ( cur == weekLstView )
716 viewMonth(); 716 viewMonth();
717 else if ( cur == monthView ) 717 else if ( cur == monthView )
718 viewDay(); 718 viewDay();
719 needShow = TRUE; 719 needShow = TRUE;
720 } 720 }
721 } 721 }
722 } else if (msg == "editEvent(int)") { 722 } else if (msg == "editEvent(int)") {
723 /* simple copy from receive */ 723 /* simple copy from receive */
724 QDataStream stream(data,IO_ReadOnly); 724 QDataStream stream(data,IO_ReadOnly);
725 int uid; 725 int uid;
726 stream >> uid; 726 stream >> uid;
727 Event e=db->eventByUID(uid); 727 Event e=db->eventByUID(uid);
728 editEvent(e); 728 editEvent(e);
729 } else if (msg == "viewDefault(QDate)"){ 729 } else if (msg == "viewDefault(QDate)"){
730 /* simple copy from receive */ 730 /* simple copy from receive */
731 QDataStream stream(data,IO_ReadOnly); 731 QDataStream stream(data,IO_ReadOnly);
732 QDate day; 732 QDate day;
733 stream >> day; 733 stream >> day;
734 viewDefault(day); 734 viewDefault(day);
735 needShow = true; 735 needShow = true;
736 } 736 }
737 737
738 if ( needShow ) { 738 if ( needShow ) {
739#if defined(Q_WS_QWS) || defined(_WS_QWS_) 739#if defined(Q_WS_QWS) || defined(_WS_QWS_)
740 // showMaximized(); 740 // showMaximized();
741#else 741#else
742 // show(); 742 // show();
743#endif 743#endif
744 // raise(); 744 // raise();
745 QPEApplication::setKeepRunning(); 745 QPEApplication::setKeepRunning();
746 // setActiveWindow(); 746 // setActiveWindow();
747 } 747 }
748} 748}
749 749
750void DateBook::reload() 750void DateBook::reload()
751{ 751{
752 db->reload(); 752 db->reload();
753 if ( dayAction->isOn() ) viewDay(); 753 if ( dayAction->isOn() ) viewDay();
754 else if ( weekAction->isOn() ) viewWeek(); 754 else if ( weekAction->isOn() ) viewWeek();
755 else if ( monthAction->isOn() ) viewMonth(); 755 else if ( monthAction->isOn() ) viewMonth();
756 syncing = FALSE; 756 syncing = FALSE;
757} 757}
758 758
759void DateBook::flush() 759void DateBook::flush()
760{ 760{
761 syncing = TRUE; 761 syncing = TRUE;
762 db->save(); 762 db->save();
763} 763}
764 764
765void DateBook::timerEvent( QTimerEvent *e ) 765void DateBook::timerEvent( QTimerEvent *e )
766{ 766{
767 if ( alarmCounter < 10 ) { 767 if ( alarmCounter < 10 ) {
768 alarmCounter++; 768 alarmCounter++;
769 Sound::soundAlarm(); 769 Sound::soundAlarm();
770 } else { 770 } else {
771 killTimer( e->timerId() ); 771 killTimer( e->timerId() );
772 } 772 }
773} 773}
774 774
775void DateBook::changeClock( bool newClock ) 775void DateBook::changeClock( bool newClock )
776{ 776{
777 ampm = newClock; 777 ampm = newClock;
778 // repaint the affected objects... 778 // repaint the affected objects...
779 if (dayView) dayView->redraw(); 779 if (dayView) dayView->redraw();
780 if (weekView) weekView->redraw(); 780 if (weekView) weekView->redraw();
781 if (weekLstView) weekLstView->redraw(); 781 if (weekLstView) weekLstView->redraw();
782} 782}
783 783
784void DateBook::changeWeek( bool m ) 784void DateBook::changeWeek( bool m )
785{ 785{
786 /* no need to redraw, each widget catches. Do need to 786 /* no need to redraw, each widget catches. Do need to
787 store though for widgets we haven't made yet */ 787 store though for widgets we haven't made yet */
788 onMonday = m; 788 onMonday = m;
789} 789}
790 790
791void DateBook::slotToday() 791void DateBook::slotToday()
792{ 792{
793 // we need to view today using default view 793 // we need to view today using default view
794 view(defaultView,QDate::currentDate()); 794 view(defaultView,QDate::currentDate());
795} 795}
796 796
797void DateBook::closeEvent( QCloseEvent *e ) 797void DateBook::closeEvent( QCloseEvent *e )
798{ 798{
799 if(syncing) { 799 if(syncing) {
800 /* no need to save, did that at flush */ 800 /* no need to save, did that at flush */
801 e->accept(); 801 e->accept();
802 return; 802 return;
803 } 803 }
804 804
805 // save settings will generate it's own error messages, no 805 // save settings will generate it's own error messages, no
806 // need to do checking ourselves. 806 // need to do checking ourselves.
807 saveSettings(); 807 saveSettings();
808 if ( db->save() ) { 808 if ( db->save() ) {
809 e->accept(); 809 e->accept();
810 } else { 810 } else {
811 if ( QMessageBox::critical( this, tr( "Out of space" ), 811 if ( QMessageBox::critical( this, tr( "Out of space" ),
812 tr("Calendar was unable to save\n" 812 tr("Calendar was unable to save\n"
813 "your changes.\n" 813 "your changes.\n"
814 "Free up some space and try again.\n" 814 "Free up some space and try again.\n"
815 "\nQuit anyway?"), 815 "\nQuit anyway?"),
816 QMessageBox::Yes|QMessageBox::Escape, 816 QMessageBox::Yes|QMessageBox::Escape,
817 QMessageBox::No|QMessageBox::Default ) 817 QMessageBox::No|QMessageBox::Default )
818 != QMessageBox::No ) 818 != QMessageBox::No )
819 e->accept(); 819 e->accept();
820 else 820 else
821 e->ignore(); 821 e->ignore();
822 } 822 }
823} 823}
824 824
825// Entering directly from the "keyboard" 825// Entering directly from the "keyboard"
826void DateBook::slotNewEventFromKey( const QString &str ) 826void DateBook::slotNewEventFromKey( const QString &str )
827{ 827{
828 if (syncing) { 828 if (syncing) {
829 QMessageBox::warning( this, tr("Calendar"), 829 QMessageBox::warning( this, tr("Calendar"),
830 tr( "Can not edit data, currently syncing") ); 830 tr( "Can not edit data, currently syncing") );
831 return; 831 return;
832 } 832 }
833 833
834 // We get to here from a key pressed in the Day View 834 // We get to here from a key pressed in the Day View
835 // So we can assume some things. We want the string 835 // So we can assume some things. We want the string
836 // passed in to be part of the description. 836 // passed in to be part of the description.
837 QDateTime start, end; 837 QDateTime start, end;
838 if ( views->visibleWidget() == dayView ) { 838 if ( views->visibleWidget() == dayView ) {
839 dayView->selectedDates( start, end ); 839 dayView->selectedDates( start, end );
840 } else if ( views->visibleWidget() == monthView ) { 840 } else if ( views->visibleWidget() == monthView ) {
841 QDate d = monthView->selectedDate(); 841 QDate d = monthView->selectedDate();
842 start = end = d; 842 start = end = d;
843 start.setTime( QTime( 10, 0 ) ); 843 start.setTime( QTime( 10, 0 ) );
844 end.setTime( QTime( 12, 0 ) ); 844 end.setTime( QTime( 12, 0 ) );
845 } else if ( views->visibleWidget() == weekView ) { 845 } else if ( views->visibleWidget() == weekView ) {
846 QDate d = weekView->date(); 846 QDate d = weekView->date();
847 start = end = d; 847 start = end = d;
848 start.setTime( QTime( 10, 0 ) ); 848 start.setTime( QTime( 10, 0 ) );
849 end.setTime( QTime( 12, 0 ) ); 849 end.setTime( QTime( 12, 0 ) );
850 } else if ( views->visibleWidget() == weekLstView ) { 850 } else if ( views->visibleWidget() == weekLstView ) {
851 QDate d = weekLstView->date(); 851 QDate d = weekLstView->date();
852 start = end = d; 852 start = end = d;
853 start.setTime( QTime( 10, 0 ) ); 853 start.setTime( QTime( 10, 0 ) );
854 end.setTime( QTime( 12, 0 ) ); 854 end.setTime( QTime( 12, 0 ) );
855 } 855 }
856 slotNewEntry(start, end, str); 856 slotNewEntry(start, end, str);
857} 857}
858void DateBook::slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str, const QString &location) { 858void DateBook::slotNewEntry(const QDateTime &start, const QDateTime &end, const QString &str, const QString &location) {
859 // argh! This really needs to be encapsulated in a class 859 // argh! This really needs to be encapsulated in a class
860 // or function. 860 // or function.
861 QDialog newDlg( this, 0, TRUE ); 861 QDialog newDlg( this, 0, TRUE );
862 newDlg.setCaption( DateEntryBase::tr("New Event") ); 862 newDlg.setCaption( DateEntryBase::tr("New Event") );
863 DateEntry *e; 863 DateEntry *e;
864 QVBoxLayout *vb = new QVBoxLayout( &newDlg ); 864 QVBoxLayout *vb = new QVBoxLayout( &newDlg );
865 QScrollView *sv = new QScrollView( &newDlg ); 865 QScrollView *sv = new QScrollView( &newDlg );
866 sv->setResizePolicy( QScrollView::AutoOneFit ); 866 sv->setResizePolicy( QScrollView::AutoOneFit );
867 sv->setFrameStyle( QFrame::NoFrame ); 867 sv->setFrameStyle( QFrame::NoFrame );
868 sv->setHScrollBarMode( QScrollView::AlwaysOff ); 868 sv->setHScrollBarMode( QScrollView::AlwaysOff );
869 vb->addWidget( sv ); 869 vb->addWidget( sv );
870 870
871 Event ev; 871 Event ev;
872 ev.setDescription( str ); 872 ev.setDescription( str );
873 // When the new gui comes in, change this... 873 // When the new gui comes in, change this...
874 if(location==0) { 874 if(location==0) {
875 if(defaultLocation.isEmpty()) { 875 if(defaultLocation.isEmpty()) {
876 ev.setLocation(tr("(Unknown)")); 876 ev.setLocation(tr("(Unknown)"));
877 } else { 877 } else {
878 ev.setLocation( defaultLocation ); 878 ev.setLocation( defaultLocation );
879 } 879 }
880 } else { 880 } else {
881 ev.setLocation(location); 881 ev.setLocation(location);
882 } 882 }
883 ev.setCategories(defaultCategories); 883 ev.setCategories(defaultCategories);
884 ev.setStart( start ); 884 ev.setStart( start );
885 ev.setEnd( end ); 885 ev.setEnd( end );
886 886
887 e = new DateEntry( onMonday, ev, ampm, &newDlg ); 887 e = new DateEntry( onMonday, ev, ampm, &newDlg );
888 e->setAlarmEnabled( aPreset, presetTime, Event::Loud ); 888 e->setAlarmEnabled( aPreset, presetTime, Event::Loud );
889 sv->addChild( e ); 889 sv->addChild( e );
890 while ( QPEApplication::execDialog( &newDlg ) ) { 890 while ( QPEApplication::execDialog( &newDlg ) ) {
891 ev = e->event(); 891 ev = e->event();
892 ev.assignUid(); 892 ev.assignUid();
893 QString error = checkEvent( ev ); 893 QString error = checkEvent( ev );
894 if ( !error.isNull() ) { 894 if ( !error.isNull() ) {
895 if ( QMessageBox::warning( this, tr("Error!"), error, tr("Fix it"), tr("Continue"), 0, 0, 1 ) == 0 ) 895 if ( QMessageBox::warning( this, tr("Error!"), error, tr("Fix it"), tr("Continue"), 0, 0, 1 ) == 0 )
896 continue; 896 continue;
897 } 897 }
898 db->addEvent( ev ); 898 db->addEvent( ev );
899 emit newEvent(); 899 emit newEvent();
900 break; 900 break;
901 } 901 }
902} 902}
903 903
904void DateBook::setDocument( const QString &filename ) 904void DateBook::setDocument( const QString &filename )
905{ 905{
906 if ( filename.find(".vcs") != int(filename.length()) - 4 ) return; 906 if ( filename.find(".vcs") != int(filename.length()) - 4 ) return;
907 907
908 QValueList<Event> tl = Event::readVCalendar( filename ); 908 QValueList<Event> tl = Event::readVCalendar( filename );
909 for( QValueList<Event>::Iterator it = tl.begin(); it != tl.end(); ++it ) { 909 for( QValueList<Event>::Iterator it = tl.begin(); it != tl.end(); ++it ) {
910 db->addEvent( *it ); 910 db->addEvent( *it );
911 } 911 }
912} 912}
913 913
914static const char * beamfile = "/tmp/obex/event.vcs"; 914static const char * beamfile = "/tmp/obex/event.vcs";
915 915
916void DateBook::beamEvent( const Event &e ) 916void DateBook::beamEvent( const Event &e )
917{ 917{
918 qDebug("trying to beamn"); 918 qDebug("trying to beamn");
919 unlink( beamfile ); // delete if exists 919 unlink( beamfile ); // delete if exists
920 mkdir("/tmp/obex/", 0755); 920 mkdir("/tmp/obex/", 0755);
921 Event::writeVCalendar( beamfile, e ); 921 Event::writeVCalendar( beamfile, e );
922 Ir *ir = new Ir( this ); 922 Ir *ir = new Ir( this );
923 connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); 923 connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) );
924 QString description = e.description(); 924 QString description = e.description();
925 ir->send( beamfile, description, "text/x-vCalendar" ); 925 ir->send( beamfile, description, "text/x-vCalendar" );
926} 926}
927 927
928void DateBook::beamDone( Ir *ir ) 928void DateBook::beamDone( Ir *ir )
929{ 929{
930 delete ir; 930 delete ir;
931 unlink( beamfile ); 931 unlink( beamfile );
932} 932}
933 933
934void DateBook::slotFind() 934void DateBook::slotFind()
935{ 935{
936 // move it to the day view... 936 // move it to the day view...
937 viewDay(); 937 viewDay();
938 FindDialog frmFind( "Calendar", this ); // no tr needed 938 FindDialog frmFind( "Calendar", this ); // no tr needed
939 frmFind.setUseDate( true ); 939 frmFind.setUseDate( true );
940 frmFind.setDate( currentDate() ); 940 frmFind.setDate( currentDate() );
941 QObject::connect( &frmFind, 941 QObject::connect( &frmFind,
942 SIGNAL(signalFindClicked(const QString&, const QDate&, 942 SIGNAL(signalFindClicked(const QString&, const QDate&,
943 bool, bool, int)), 943 bool, bool, int)),
944 this, 944 this,
945 SLOT(slotDoFind(const QString&, const QDate&, 945 SLOT(slotDoFind(const QString&, const QDate&,
946 bool, bool, int)) ); 946 bool, bool, int)) );
947 QObject::connect( this, 947 QObject::connect( this,
948 SIGNAL(signalNotFound()), 948 SIGNAL(signalNotFound()),
949 &frmFind, 949 &frmFind,
950 SLOT(slotNotFound()) ); 950 SLOT(slotNotFound()) );
951 QObject::connect( this, 951 QObject::connect( this,
952 SIGNAL(signalWrapAround()), 952 SIGNAL(signalWrapAround()),
953 &frmFind, 953 &frmFind,
954 SLOT(slotWrapAround()) ); 954 SLOT(slotWrapAround()) );
955 frmFind.move(0,0); 955 frmFind.move(0,0);
956 frmFind.exec(); 956 frmFind.exec();
957 inSearch = false; 957 inSearch = false;
958} 958}
959 959
960bool catComp( QArray<int> cats, int category ) 960bool catComp( QArray<int> cats, int category )
961{ 961{
962 bool returnMe; 962 bool returnMe;
963 int i, 963 int i,
964 count; 964 count;
965 965
966 count = int(cats.count()); 966 count = int(cats.count());
967 returnMe = false; 967 returnMe = false;
968 if ( (category == -1 && count == 0) || category == -2 ) 968 if ( (category == -1 && count == 0) || category == -2 )
969 returnMe = true; 969 returnMe = true;
970 else { 970 else {
971 for ( i = 0; i < count; i++ ) { 971 for ( i = 0; i < count; i++ ) {
972 if ( category == cats[i] ) { 972 if ( category == cats[i] ) {
973 returnMe = true; 973 returnMe = true;
974 break; 974 break;
975 } 975 }
976 } 976 }
977 } 977 }
978 return returnMe; 978 return returnMe;
979} 979}
980 980
981 981
982void DateBook::slotDoFind( const QString& txt, const QDate &dt, 982void DateBook::slotDoFind( const QString& txt, const QDate &dt,
983 bool caseSensitive, bool /*backwards*/, 983 bool caseSensitive, bool /*backwards*/,
984 int category ) 984 int category )
985{ 985{
986 QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ), 986 QDateTime dtEnd( QDate(3001, 1, 1), QTime(0, 0, 0) ),
987 next; 987 next;
988 988
989 QRegExp r( txt ); 989 QRegExp r( txt );
990 r.setCaseSensitive( caseSensitive ); 990 r.setCaseSensitive( caseSensitive );
991 991
992 992
993 static Event rev, nonrev; 993 static Event rev, nonrev;
994 if ( !inSearch ) { 994 if ( !inSearch ) {
995 rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); 995 rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) );
996 nonrev.setStart( rev.start() ); 996 nonrev.setStart( rev.start() );
997 inSearch = true; 997 inSearch = true;
998 } 998 }
999 static QDate searchDate = dt; 999 static QDate searchDate = dt;
1000 // if true at the end we will start at the begin again and afterwards
1001 // we will emit string not found
1000 static bool wrapAround = true; 1002 static bool wrapAround = true;
1001 bool candidtate; 1003 bool candidtate;
1002 candidtate = false; 1004 candidtate = false;
1003 1005
1004 QValueList<Event> repeats = db->getRawRepeats(); 1006 QValueList<Event> repeats = db->getRawRepeats();
1005 1007
1006 // find the candidate for the first repeat that matches... 1008 // find the candidate for the first repeat that matches...
1009 // first check if there can ever be a match and then compute
1010 // the next occurence from start. See if this event is closer
1011 // to the beginning (start. next < dtEnd) and not smaller then the last
1012 // result. If we find a canditate we set the dtEnd to the time
1013 // of the ocurrence and rev to this occurence.
1014 // set wrap around to true because there might be more events coming
1015 // and we're not at the end.
1007 QValueListConstIterator<Event> it; 1016 QValueListConstIterator<Event> it;
1008 QDate start = dt; 1017 QDate start = dt;
1009 for ( it = repeats.begin(); it != repeats.end(); ++it ) { 1018 for ( it = repeats.begin(); it != repeats.end(); ++it ) {
1010 if ( catComp( (*it).categories(), category ) ) { 1019 if ( catComp( (*it).categories(), category ) ) {
1011 if ( (*it).match( r ) ) { 1020 if ( (*it).match( r ) ) {
1012 if ( nextOccurance( *it, start, next ) ) { 1021 if ( nextOccurance( *it, start, next ) ) {
1013 if ( next < dtEnd && !(next <= rev.start() ) ) { 1022 if ( next < dtEnd && !(next <= rev.start() ) ) {
1014 rev = *it; 1023 rev = *it;
1015 dtEnd = next; 1024 dtEnd = next;
1016 rev.setStart( next ); 1025 rev.setStart( next );
1017 candidtate = true; 1026 candidtate = true;
1018 wrapAround = true; 1027 wrapAround = true;
1019 } 1028 }
1020 } 1029 }
1021 } 1030 }
1022 } 1031 }
1023 } 1032 }
1024 1033
1025 // now the for first non repeat... 1034 // now the for first non repeat...
1035 // dtEnd is set by the previous iteration of repeatingEvents
1036 // check if we find a closer item. Also set dtEnd to find even
1037 // more close occurrence
1026 QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() ); 1038 QValueList<Event> nonRepeats = db->getNonRepeatingEvents( dt, dtEnd.date() );
1027 qHeapSort( nonRepeats.begin(), nonRepeats.end() ); 1039 qHeapSort( nonRepeats.begin(), nonRepeats.end() );
1028 for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) { 1040 for ( it = nonRepeats.begin(); it != nonRepeats.end(); ++it ) {
1029 if ( catComp( (*it).categories(), category ) ) { 1041 if ( catComp( (*it).categories(), category ) ) {
1030 if ( (*it).start() < dtEnd ) { 1042 if ( (*it).start() < dtEnd ) {
1031 if ( (*it).match( r ) && !(*it <= nonrev) ) { 1043 if ( (*it).match( r ) && !(*it <= nonrev) ) {
1032 nonrev = *it; 1044 nonrev = *it;
1033 dtEnd = nonrev.start(); 1045 dtEnd = nonrev.start();
1034 candidtate = true; 1046 candidtate = true;
1035 wrapAround = true; 1047 wrapAround = true;
1036 break; 1048 break;
1037 } 1049 }
1038 } 1050 }
1039 } 1051 }
1040 } 1052 }
1041 if ( candidtate ) { 1053 if ( candidtate ) {
1042 dayView->setStartViewTime( dtEnd.time().hour() ); 1054 dayView->setStartViewTime( dtEnd.time().hour() );
1043 dayView->setDate( dtEnd.date().year(), dtEnd.date().month(), 1055 dayView->setDate( dtEnd.date().year(), dtEnd.date().month(),
1044 dtEnd.date().day() ); 1056 dtEnd.date().day() );
1045 } else { 1057 } else {
1046 if ( wrapAround ) { 1058 if ( wrapAround ) {
1047 emit signalWrapAround(); 1059 emit signalWrapAround();
1048 rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) ); 1060 rev.setStart( QDateTime(QDate(1960, 1, 1), QTime(0, 0, 0)) );
1049 nonrev.setStart( rev.start() ); 1061 nonrev.setStart( rev.start() );
1050 } else 1062 } else
1051 emit signalNotFound(); 1063 emit signalNotFound();
1052 wrapAround = !wrapAround; 1064 wrapAround = !wrapAround;
1053 } 1065 }
1054} 1066}
1055 1067
1056Event DateBookDBHack::eventByUID(int uid) { 1068Event DateBookDBHack::eventByUID(int uid) {
1057 1069
1058 // FIXME: Dirty Hacks to get hold of the private event lists 1070 // FIXME: Dirty Hacks to get hold of the private event lists
1059 QDate start; 1071 QDate start;
1060 QDate end=start.addDays(-1); 1072 QDate end=start.addDays(-1);
1061 QValueList<Event> myEventList=getNonRepeatingEvents(start,end); 1073 QValueList<Event> myEventList=getNonRepeatingEvents(start,end);
1062 QValueList<Event> myRepeatEvents=getRawRepeats(); 1074 QValueList<Event> myRepeatEvents=getRawRepeats();
1063 1075
1064 QValueList<Event>::ConstIterator it; 1076 QValueList<Event>::ConstIterator it;
1065 1077
1066 for (it = myEventList.begin(); it != myEventList.end(); it++) { 1078 for (it = myEventList.begin(); it != myEventList.end(); it++) {
1067 if ((*it).uid() == uid) return *it; 1079 if ((*it).uid() == uid) return *it;
1068 } 1080 }
1069 for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) { 1081 for (it = myRepeatEvents.begin(); it != myRepeatEvents.end(); it++) {
1070 if ((*it).uid() == uid) return *it; 1082 if ((*it).uid() == uid) return *it;
1071 } 1083 }
1072 1084
1073 Event ev; 1085 Event ev;
1074 return ev; // return at least 1086 return ev; // return at least
1075} 1087}