summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--korganizer/koagenda.cpp133
-rw-r--r--korganizer/koagenda.h1
2 files changed, 63 insertions, 71 deletions
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp
index ec81d44..e8b7c94 100644
--- a/korganizer/koagenda.cpp
+++ b/korganizer/koagenda.cpp
@@ -395,20 +395,26 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
395 } 395 }
396 static int startX = 0; 396 static int startX = 0;
397 static int startY = 0; 397 static int startY = 0;
398 static bool block = true; 398 static int blockmoveDist = ( QApplication::desktop()->width() < 480 ? 15 : 20 );
399 static bool blockMoving = true;
400 static bool leftMouseDown = false;
401 static bool rightMouseDown = false;
399 switch (me->type()) { 402 switch (me->type()) {
400 case QEvent::MouseButtonPress: 403 case QEvent::MouseButtonPress:
401 //qDebug("QEvent::MouseButtonPress: "); 404 if (me->button() == LeftButton)
402 // kdDebug() << "koagenda: filtered button press" << endl; 405 leftMouseDown = true;
406 else if (me->button() == RightButton)
407 rightMouseDown = true;
408 blockMoving = true;
409 startX = viewportPos.x();
410 startY = viewportPos.y();
403 if (object != viewport()) { 411 if (object != viewport()) {
404 if (me->button() == RightButton) { 412 if (me->button() == RightButton) {
405 mClickedItem = (KOAgendaItem *)object; 413 mClickedItem = (KOAgendaItem *)object;
406 if (mClickedItem) { 414 if (mClickedItem) {
407 selectItem(mClickedItem); 415 selectItem(mClickedItem);
408 // emit showIncidencePopupSignal(mClickedItem->incidence());
409 } 416 }
410 //mItemPopup->popup(QCursor::pos()); 417 } else if (me->button() == LeftButton) {
411 } else {
412 mActionItem = (KOAgendaItem *)object; 418 mActionItem = (KOAgendaItem *)object;
413 if (mActionItem) { 419 if (mActionItem) {
414 if ( mSelectionHeight > 0 ) { 420 if ( mSelectionHeight > 0 ) {
@@ -426,20 +432,13 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
426 mActionItem = 0; 432 mActionItem = 0;
427 } else { 433 } else {
428 startItemAction(viewportPos); 434 startItemAction(viewportPos);
429 startX = viewportPos.x();
430 startY = viewportPos.y();
431 block = true;
432 } 435 }
433 } 436 }
434 } 437 }
435 } else { 438 } else { // ---------- viewport()
436 selectItem(0); 439 selectItem(0);
437 mActionItem = 0; 440 mActionItem = 0;
438 if (me->button() == RightButton ) { 441 if (me->button() == LeftButton ) {
439 blockNewEvent = true;
440 block = false;
441 } else {
442 blockNewEvent = false;
443 setCursor(arrowCursor); 442 setCursor(arrowCursor);
444 startSelectAction(viewportPos); 443 startSelectAction(viewportPos);
445 } 444 }
@@ -447,48 +446,20 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
447 break; 446 break;
448 447
449 case QEvent::MouseButtonRelease: 448 case QEvent::MouseButtonRelease:
450 //qDebug("QEvent::MouseButtonRelease: %d",blockNewEvent );
451 if (me->button() == RightButton && blockNewEvent && !block) {
452 int x,y;
453 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
454 int gx,gy;
455 contentsToGrid(x,y,gx,gy);
456 if ( object == viewport() ) {
457 if ( mCurrentCellY < mStartCellY +1 ) {
458 //qDebug("mCurrentCellY %d mStartCellY %d ", mCurrentCellY,mStartCellY);
459 mCurrentCellX = gx;
460 mCurrentCellY = gy;
461 mStartCellX = gx;
462 mStartCellY = gy;
463 mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) );
464 break;
465 } else {
466 blockNewEvent = false;
467 }
468 } else {
469 mClickedItem = (KOAgendaItem *)object;
470 if (mActionItem ) {
471 endItemAction();
472 }
473 if (mClickedItem) {
474 selectItem(mClickedItem);
475 emit showIncidencePopupSignal(mClickedItem->incidence());
476 }
477 }
478 } else if (me->button() == RightButton && block ) {
479 if (object != viewport()) { 449 if (object != viewport()) {
450 if (me->button() == RightButton) {
451 if ( blockMoving ) {
480 mClickedItem = (KOAgendaItem *)object; 452 mClickedItem = (KOAgendaItem *)object;
481 if (mActionItem ) { 453 if (mActionItem ) {
482 endItemAction(); 454 endItemAction();
483 } 455 }
456 leftMouseDown = false; // no more leftMouse computation
484 if (mClickedItem) { 457 if (mClickedItem) {
485 selectItem(mClickedItem); 458 selectItem(mClickedItem);
486 emit showIncidencePopupSignal(mClickedItem->incidence()); 459 emit showIncidencePopupSignal(mClickedItem->incidence());
487 } 460 }
488 } 461 }
489 break; 462 } else if (me->button() == LeftButton && leftMouseDown) {
490 }
491 block = true;
492 if (mActionItem) { 463 if (mActionItem) {
493 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); 464 QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos));
494 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); 465 //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 );
@@ -505,24 +476,41 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
505 return true; 476 return true;
506 } 477 }
507 endItemAction(); 478 endItemAction();
508 } else if ( mActionType == SELECT ) {
509 if (me->button() == RightButton ) {
510 } else {
511 endSelectAction( !blockNewEvent );
512 } 479 }
513 } 480 }
481
482 } else { // ---------- viewport()
483 if (me->button() == RightButton) { //right click
484 if ( blockMoving ) { // we did mot moved the mouse much - popup menu
485 if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action
486 endSelectAction( false ); // do not emit new event signal
487 leftMouseDown = false; // no more leftMouse computation
488 }
489 int x,y;
490 viewportToContents(viewportPos.x(),viewportPos.y(),x,y);
491 int gx,gy;
492 contentsToGrid(x,y,gx,gy);
493 mCurrentCellX = gx;
494 mCurrentCellY = gy;
495 mStartCellX = gx;
496 mStartCellY = gy;
497 mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) );
498 }
499 }
500 else if (me->button() == LeftButton && leftMouseDown ) { //left click
501 endSelectAction( true ); // emit new event signal
502 }
503 }
504 if (me->button() == LeftButton)
505 leftMouseDown = false;
506 else if (me->button() == RightButton)
507 rightMouseDown = false;
514 break; 508 break;
515 509
516 case QEvent::MouseMove: 510 case QEvent::MouseMove:
517 if (object != viewport()) { 511 if ( !rightMouseDown && !leftMouseDown )
518 KOAgendaItem *moveItem = (KOAgendaItem *)object; 512 return true;
519 //qDebug("moveItem %d ",moveItem ); 513 if ( blockMoving ) {
520 if (!moveItem->incidence()->isReadOnly() /*&&
521 !moveItem->incidence()->recurrence()->doesRecur()*/ )
522 if (!mActionItem)
523 setNoActionCursor(moveItem,viewportPos);
524 else {
525 if ( block ) {
526 int dX, dY; 514 int dX, dY;
527 dX = startX - viewportPos.x(); 515 dX = startX - viewportPos.x();
528 if ( dX < 0 ) 516 if ( dX < 0 )
@@ -530,18 +518,22 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
530 dY = viewportPos.y() - startY; 518 dY = viewportPos.y() - startY;
531 if ( dY < 0 ) 519 if ( dY < 0 )
532 dY = -dY; 520 dY = -dY;
533 int diff = 30; 521 //qDebug("%d %d %d ", dX, dY , blockmoveDist );
534 if ( QApplication::desktop()->width() < 480 ) 522 if ( dX > blockmoveDist || dY > blockmoveDist ) {
535 diff = 15; 523 blockMoving = false;
536 // qDebug(" %d %d ",dX, dY );
537 if ( dX > diff || dY > diff ) {
538 block = false;
539 } 524 }
540 } 525 }
541 if ( !block ) 526 if (object != viewport()) {
527 KOAgendaItem *moveItem = (KOAgendaItem *)object;
528 if (!moveItem->incidence()->isReadOnly() ) {
529 if (!mActionItem)
530 setNoActionCursor(moveItem,viewportPos);
531 else {
532 if ( !blockMoving )
542 performItemAction(viewportPos); 533 performItemAction(viewportPos);
543 } 534 }
544 } else { 535 }
536 } else { // ---------- viewport()
545 if ( mActionType == SELECT ) { 537 if ( mActionType == SELECT ) {
546 performSelectAction( viewportPos ); 538 performSelectAction( viewportPos );
547 } 539 }
@@ -569,7 +561,6 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me)
569 default: 561 default:
570 break; 562 break;
571 } 563 }
572
573 return true; 564 return true;
574} 565}
575 566
@@ -686,9 +677,11 @@ void KOAgenda::endSelectAction( bool emitNewEvent )
686 mScrollDownTimer.stop(); 677 mScrollDownTimer.stop();
687 678
688 emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); 679 emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY);
689 if ( emitNewEvent && mStartCellY < mCurrentCellY ) 680 if ( emitNewEvent && mStartCellY < mCurrentCellY ) {
681 qDebug("ew event signal ");
690 emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); 682 emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY);
691} 683}
684}
692 685
693void KOAgenda::startItemAction(QPoint viewportPos) 686void KOAgenda::startItemAction(QPoint viewportPos)
694{ 687{
diff --git a/korganizer/koagenda.h b/korganizer/koagenda.h
index 2069b22..f3f1772 100644
--- a/korganizer/koagenda.h
+++ b/korganizer/koagenda.h
@@ -210,7 +210,6 @@ class KOAgenda : public QScrollView
210 virtual void contentsMousePressEvent ( QMouseEvent * ); 210 virtual void contentsMousePressEvent ( QMouseEvent * );
211 211
212 private: 212 private:
213 bool blockNewEvent;
214 void init(); 213 void init();
215 void marcus_bains(); 214 void marcus_bains();
216 bool mAllDayMode; 215 bool mAllDayMode;