]> Creatis software - crea.git/blobdiff - lib/creaDevManagerLib/wxCDMLibDescriptionPanel.cpp
Feature #1711
[crea.git] / lib / creaDevManagerLib / wxCDMLibDescriptionPanel.cpp
index 07f9cc153557c44250cb6d4ed375d95009df57f7..88d598bc6141a0cc585a30a426c198735bee3c95 100644 (file)
@@ -108,6 +108,8 @@ void wxCDMLibDescriptionPanel::CreateControls()
       std::string tt = "Name: " + libraries[i]->GetName() + "\n";
       tt += "Location: " + libraries[i]->GetPath();
       pLibrarylk->SetToolTip(crea::std2wx(tt.c_str()));
+      pLibrarylk->Connect(wxEVT_ENTER_WINDOW, (wxObjectEventFunction)(wxEventFunction)(wxMouseEventFunction)&wxCDMLibDescriptionPanel::OnMouseEnter,NULL,this);
+      pLibrarylk->Connect(wxEVT_LEAVE_WINDOW, (wxObjectEventFunction)(wxEventFunction)(wxMouseEventFunction)&wxCDMLibDescriptionPanel::OnMouseExit,NULL,this);
       propertiesPanelSizer -> Add(pLibrarylk, 0, wxALIGN_LEFT | wxALL, 5);
     }
 
@@ -216,3 +218,43 @@ void wxCDMLibDescriptionPanel::OnBtnOpenFolder(wxCommandEvent& event)
   std::cerr << "Event OnBtnOpenFolder not implemented" << std::endl;
   event.Skip();
 }
+
+void wxCDMLibDescriptionPanel::OnMouseEnter(wxMouseEvent& event)
+{
+  wxCommandEvent* newEvent = new wxCommandEvent(wxEVT_COMMAND_LIST_ITEM_SELECTED);
+  std::string LibName = crea::wx2std(((wxHyperlinkCtrl*)event.GetEventObject())->GetURL());
+  int lbId = 0;
+  std::vector<modelCDMLibrary*> libraries = this->lib->GetLibraries();
+  for (int i = 0; i < libraries.size(); i++)
+    {
+      if(libraries[i]->GetName() == LibName)
+        {
+          lbId = libraries[i]->GetId();
+          break;
+        }
+    }
+  newEvent->SetInt(lbId);
+  newEvent->SetId(0);
+  wxPostEvent(this->GetParent(), *newEvent);
+  event.Skip();
+}
+
+void wxCDMLibDescriptionPanel::OnMouseExit(wxMouseEvent& event)
+{
+  wxCommandEvent* newEvent = new wxCommandEvent(wxEVT_COMMAND_LIST_ITEM_DESELECTED);
+  std::string LibName = crea::wx2std(((wxHyperlinkCtrl*)event.GetEventObject())->GetURL());
+  int lbId = 0;
+  std::vector<modelCDMLibrary*> libraries = this->lib->GetLibraries();
+  for (int i = 0; i < libraries.size(); i++)
+    {
+      if(libraries[i]->GetName() == LibName)
+        {
+          lbId = libraries[i]->GetId();
+          break;
+        }
+    }
+  newEvent->SetInt(lbId);
+  newEvent->SetId(0);
+  wxPostEvent(this->GetParent(), *newEvent);
+  event.Skip();
+}