-rw-r--r-- | korganizer/koagenda.cpp | 133 | ||||
-rw-r--r-- | korganizer/koagenda.h | 1 |
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 | ||
693 | void KOAgenda::startItemAction(QPoint viewportPos) | 686 | void 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; |