some 'delegate' drawing optimizations
[toast/confclerk.git] / src / gui / eventdialog.cpp
index be98e29..12838a5 100644 (file)
@@ -45,6 +45,7 @@ void EventDialog::favouriteClicked()
 {
     Event event = Event::getById(mEventId,Conference::activeConference());
 
+    QList<Event> conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
     if(event.isFavourite())
     {
         event.setFavourite(false);
@@ -56,12 +57,22 @@ void EventDialog::favouriteClicked()
         favouriteButton->setIcon(QIcon(":/icons/favourite-onBig.png"));
     }
     event.update("favourite");
+
+    if(event.isFavourite())
+    {
+        // event has became 'favourite' and so 'conflicts' list may have changed
+        conflicts = Event::conflictEvents(event.id(),Conference::activeConference());
+    }
+
     qDebug() << " FAVOURITE [" << event.id() << "] -> " << event.isFavourite();
-    // update EVENT_CONFLICT table
-    event.updateConflicts();
+
     // since the Favourite icon has changed, update TreeViews accordingly
     // all TreeViews have to listen on this signal
     emit(eventHasChanged(event.id()));
+
+    // have to emit 'eventHasChanged' signal on all events in conflict
+    for(int i=0; i<conflicts.count(); i++)
+        emit(eventHasChanged(conflicts[i].id()));
 }
 
 void EventDialog::alarmClicked()