From 3373bc801aa5114fab30396b8fe0d6d18242ec26 Mon Sep 17 00:00:00 2001 From: Charlie Fenton Date: Sat, 22 Oct 2011 11:12:30 +0000 Subject: [PATCH] MGR: Bug fix: if currently selected task in Simple View deleted, change selection svn path=/trunk/boinc/; revision=24463 --- checkin_notes | 7 +++++++ clientgui/sg_TaskPanel.cpp | 21 ++++++++++++++++++--- 2 files changed, 25 insertions(+), 3 deletions(-) diff --git a/checkin_notes b/checkin_notes index 24eb7e5352..6a11e46970 100644 --- a/checkin_notes +++ b/checkin_notes @@ -7672,3 +7672,10 @@ Charlie 21 Oct 2011 clientgui/ sg_TaskPanel.cpp + +Charlie 21 Oct 2011 + - MGR: Bug fix: when the task currently selected in Simple View + is deleted, change selection to a different task. + + clientgui/ + sg_TaskPanel.cpp diff --git a/clientgui/sg_TaskPanel.cpp b/clientgui/sg_TaskPanel.cpp index f9fe4c44c1..12fe5cf0df 100755 --- a/clientgui/sg_TaskPanel.cpp +++ b/clientgui/sg_TaskPanel.cpp @@ -82,7 +82,7 @@ void CSlideShowPanel::AdvanceSlideShow(bool changeSlide) { TaskSelectionData* selData = ((CSimpleTaskPanel*)GetParent())->GetTaskSelectionData(); if (selData == NULL) return; - int numSlides = selData->slideShowFileNames.size(); + int numSlides = (int)selData->slideShowFileNames.size(); if (numSlides <= 0) { if (m_bCurrentSlideIsDefault) return; @@ -691,6 +691,7 @@ void CSimpleTaskPanel::UpdateTaskSelectionList(bool reskin) { RESULT* ctrlResult; PROJECT* project; std::vectoris_alive; + bool needRefresh = false; CMainDocument* pDoc = wxGetApp().GetDocument(); CSkinSimple* pSkinSimple = wxGetApp().GetSkinManager()->GetSimple(); @@ -729,7 +730,7 @@ void CSimpleTaskPanel::UpdateTaskSelectionList(bool reskin) { } } - // if it isn't currently one of the tabs then we have a new one! lets add it + // if it isn't currently in the list then we have a new one! lets add it if (!found) { #if SELECTBYRESULTNAME wxString resname(result->name, wxConvUTF8); @@ -761,7 +762,18 @@ void CSimpleTaskPanel::UpdateTaskSelectionList(bool reskin) { delete selData; m_TaskSelectionCtrl->Delete(j); if (j == m_CurrentTaskSelection) { + int newCount = m_TaskSelectionCtrl->GetCount(); + if (m_CurrentTaskSelection < newCount) { + // Select the next item if one exists + m_TaskSelectionCtrl->SetSelection(m_CurrentTaskSelection); + } else if (newCount > 0) { + // Select the previous item if one exists + m_TaskSelectionCtrl->SetSelection(newCount-1); + } else { + m_TaskSelectionCtrl->SetSelection(wxNOT_FOUND); + } m_bStableTaskInfoChanged = true; + needRefresh = true; } } } @@ -802,9 +814,12 @@ void CSimpleTaskPanel::UpdateTaskSelectionList(bool reskin) { break; } selData->dotColor = newColor; - m_TaskSelectionCtrl->Refresh(); + needRefresh = true; } } + if (needRefresh) { + m_TaskSelectionCtrl->Refresh(); + } }