X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcreaDevManagerLib%2FwxCDMMainFrame.cpp;h=9565b8a37858d75e7e8b0713d573e1c0fabab5c4;hb=94511d0d24fe76a082b14afeab79bcaf0d1ecf13;hp=5017c440ee1b368bd25f15208535ffd2be61fc61;hpb=741b9c1d03c7984f7ac4a39188e2bb114471f579;p=crea.git diff --git a/lib/creaDevManagerLib/wxCDMMainFrame.cpp b/lib/creaDevManagerLib/wxCDMMainFrame.cpp index 5017c44..9565b8a 100755 --- a/lib/creaDevManagerLib/wxCDMMainFrame.cpp +++ b/lib/creaDevManagerLib/wxCDMMainFrame.cpp @@ -219,6 +219,7 @@ void wxCDMMainFrame::CreateControls() wxSize(200,400), wxTR_HAS_BUTTONS | wxTR_AQUA_BUTTONS ); + this->actualTreeItem.Unset(); panel_Properties = new wxCDMMainDescriptionPanel( this, @@ -298,8 +299,9 @@ void wxCDMMainFrame::OnMenuNewProject(wxCommandEvent& event) auiManager.Update(); //populate tree control - tree_Projects->BuildTree(this->model->GetModelElements(),this->model->GetProject()); tree_Projects->Unselect(); + this->actualTreeItem.Unset(); + tree_Projects->BuildTree(this->model->GetModelElements(),this->model->GetProject()); tree_Projects->SelectItem(this->model->GetProject()->GetId().GetWxId()); wxMessageBox(wxT("ProjectSelected") ,_T("New Project - Success!"),wxOK | wxICON_ERROR); } @@ -344,12 +346,12 @@ void wxCDMMainFrame::OnMenuOpenProject(wxCommandEvent& event) std::cout << "building ui" << std::endl; //populate tree control + tree_Projects->Unselect(); + this->actualTreeItem.Unset(); tree_Projects->BuildTree(this->model->GetModelElements(), this->model->GetProject()); - tree_Projects->Unselect(); tree_Projects->SelectItem(this->model->GetProject()->GetId().GetWxId(), true); - //change project's actions panel if(this->panel_ProjectActions!= NULL) { @@ -374,8 +376,6 @@ void wxCDMMainFrame::OnMenuOpenProject(wxCommandEvent& event) auiManager.Update(); } - - event.Skip(); } void wxCDMMainFrame::OnMenuCloseProject(wxCommandEvent& event) @@ -389,18 +389,16 @@ void wxCDMMainFrame::OnMenuCloseProject(wxCommandEvent& event) } tree_Projects->BuildTree(this->model->GetModelElements(), this->model->GetProject()); - + this->actualTreeItem.Unset(); if(this->panel_Properties != NULL) { auiManager.DetachPane(this->panel_Properties); - this->panel_Properties->Destroy(); - this->panel_Properties = NULL; + this->panel_Properties->Hide(); } if(this->panel_ProjectActions != NULL) { auiManager.DetachPane(this->panel_ProjectActions); - this->panel_ProjectActions->Destroy(); - this->panel_ProjectActions = NULL; + this->panel_ProjectActions->Hide(); } this->panel_Properties = new wxCDMMainDescriptionPanel( @@ -415,7 +413,6 @@ void wxCDMMainFrame::OnMenuCloseProject(wxCommandEvent& event) auiManager.AddPane(panel_Properties, wxAuiPaneInfo().Center().Name(wxT("panel_Properties")).Caption(wxT("")).BestSize(600,400).CloseButton(false)); auiManager.Update(); - event.Skip(); } void wxCDMMainFrame::OnMenuExportHierarchy(wxCommandEvent& event) @@ -590,17 +587,24 @@ void wxCDMMainFrame::OnTreeSelectionChanged(wxTreeEvent& event) //get selected element wxTreeItemId elementId = event.GetItem(); - if(elementId.IsOk() && this->tree_Projects->IsSelected(elementId)) + //elementId.IsOk() && this->tree_Projects->IsSelected(elementId) + if(elementId.IsOk() && this->actualTreeItem != elementId) { - std::cout << "Tree Selection id: " << elementId << std::endl; + + std::cout << "Tree Selection id: " << elementId.m_pItem << std::endl; //get element from model modelCDMIProjectTreeNode* element = this->model->GetModelElements()[elementId]; if (element == NULL) return; std::cout << "Tree Selection: " << element->GetName() << std::endl; - - //TODO get element type + + //std::stringstream ss; + //ss << this->actualTreeItem.m_pItem << ":" << event.GetOldItem().m_pItem << " --> " << elementId.m_pItem; + //wxMessageBox( wxT("Tree Selection id: " + ss.str() + " by " + element->GetName()), wxT("Refresh Project - Error"), wxICON_ERROR); + this->actualTreeItem = elementId; + + //get element type //project modelCDMProject* elementProject = dynamic_cast(element); wxPanel* description; @@ -801,16 +805,19 @@ void wxCDMMainFrame::OnTreeSelectionChanged(wxTreeEvent& event) { this->panel_Properties->Hide(); auiManager.DetachPane(this->panel_Properties); - this->panel_Properties->Destroy(); - this->panel_Properties = NULL; + //this->panel_Properties->Destroy(); + //this->panel_Properties = NULL; } //set new view auiManager.AddPane(description, wxAuiPaneInfo().Center().Name(wxT("panel_Properties")).Caption(wxT("")).BestSize(600,400).CloseButton(false)); this->panel_Properties = description; auiManager.Update(); - event.Skip(); } + else + { + event.Skip(); + } return; @@ -819,22 +826,24 @@ void wxCDMMainFrame::OnTreeSelectionChanged(wxTreeEvent& event) void wxCDMMainFrame::OnChangeView(wxCommandEvent& event) { modelCDMIProjectTreeNode* myItem = NULL; + wxPanel* description = NULL; switch(event.GetId()) { case 0: myItem = ((modelCDMIProjectTreeNode*)event.GetClientData()); //select out old one to generate selection event this->tree_Projects->Unselect(); - this->tree_Projects->SelectItem(myItem->GetId().GetWxId(), true); + this->tree_Projects->SelectItem(myItem->GetId().GetWxId()); this->tree_Projects->Expand(myItem->GetId().GetWxId()); break; case 1: - wxPanel* description = NULL; + if(event.GetString() == wxT("manage_packages")) { //this->tree_Projects->Expand(this->model->GetProject()->GetId()); //this->tree_Projects->Unselect(); - description = new wxCDMPackageManagerPanel( + this->actualTreeItem.Unset(); + description = new wxCDMPackageManagerPanel( this, this->model->GetProject(), ID_WINDOW_PROPERTIES, @@ -846,19 +855,20 @@ void wxCDMMainFrame::OnChangeView(wxCommandEvent& event) } else if(event.GetString() == wxT("manage_libraries")) { - this->tree_Projects->SelectItem(this->model->GetProject()->GetLib()->GetId().GetWxId(), true); + this->tree_Projects->SelectItem(this->model->GetProject()->GetLib()->GetId().GetWxId()); this->tree_Projects->Expand(this->model->GetProject()->GetLib()->GetId().GetWxId()); break; } else if(event.GetString() == wxT("manage_applications")) { - this->tree_Projects->SelectItem(this->model->GetProject()->GetAppli()->GetId().GetWxId(), true); + this->tree_Projects->SelectItem(this->model->GetProject()->GetAppli()->GetId().GetWxId()); this->tree_Projects->Expand(this->model->GetProject()->GetAppli()->GetId().GetWxId()); break; } else if(event.GetString() == wxT("blackbox")) { modelCDMBlackBox* bb = (modelCDMBlackBox*)event.GetClientData(); + this->actualTreeItem.Unset(); description = new wxCDMBlackBoxDescriptionPanel( this, bb, @@ -868,6 +878,7 @@ void wxCDMMainFrame::OnChangeView(wxCommandEvent& event) wxSize(600, 400), 0 ); + } //delete old view @@ -882,10 +893,11 @@ void wxCDMMainFrame::OnChangeView(wxCommandEvent& event) auiManager.AddPane(description, wxAuiPaneInfo().Center().Name(wxT("panel_Properties")).Caption(wxT("")).BestSize(600,400).CloseButton(false)); this->panel_Properties = description; auiManager.Update(); - break; + default: + event.Skip(); } - event.Skip(); + } void wxCDMMainFrame::OnElementSelected(wxCommandEvent& event)