]> Creatis software - bbtkGEditor.git/blobdiff - lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx
Bug #1689
[bbtkGEditor.git] / lib / EditorGraphicBBS / bbsWxGUIEditorGraphic / wxTabPanelsManager.cxx
index bca6b0b81f8396454147308d43ea481cb2b284e4..7c29eaefb1e94f887567146803e76d81cec6c4ba 100644 (file)
@@ -36,7 +36,6 @@ Version:   $Revision$
 
 #include "wxTabPanelsManager.h"
 
-
 namespace bbtk
 {
 
@@ -49,6 +48,8 @@ namespace bbtk
                _notebook       = _parent->getAuiNotebook();
                addNewTab();
                _notebook->Connect(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED,wxAuiNotebookEventHandler(wxTabPanelsManager::OnTabChanged),0,this);
+               _notebook->Connect(wxEVT_COMMAND_AUINOTEBOOK_PAGE_CLOSE,wxAuiNotebookEventHandler(wxTabPanelsManager::OnTabClose),0,this);
+
        }
 
        //=========================================================================
@@ -57,16 +58,23 @@ namespace bbtk
        }
 
        //=========================================================================
-       void wxTabPanelsManager::addNewTab()
+       void wxTabPanelsManager::addNewTab(wxString tabName)
        {
                _lastId++;
-               wxGEditorTabPanel *newPanel         = new wxGEditorTabPanel(_notebook,_lastId);
+
+               //EED 13/10/2012                wxGEditorTabPanel *newPanel         = new wxGEditorTabPanel( _notebook,_lastId );
+               wxGEditorTabPanel *newPanel         = new wxGEditorTabPanel( _notebook,_lastId, _parent->GetBBTKFactory() );
+
                newPanel->setPanelsManager(this);
                _panels[_lastId]                    = newPanel;
                _actual                             = newPanel;
-               _notebook->AddPage(newPanel,_T("Diagram"),true);
+               _notebook->AddPage(newPanel, tabName  ,true);
        }
 
+
+
+
+
        //=========================================================================
        wxAuiNotebook* wxTabPanelsManager::getAuiNotebook()
        {
@@ -102,9 +110,9 @@ namespace bbtk
 
        //=========================================================================
 
-       std::string wxTabPanelsManager::getActualComplexBoxBBS(std::string cbName,std::string cbAuthor,std::string cbCategory,std::string cbDescription)
+       std::string wxTabPanelsManager::getActualComplexBoxBBS()
        {
-               return _actual->saveComplexBoxBBS(cbName,cbAuthor,cbCategory,cbDescription);
+               return _actual->saveComplexBoxBBS();
        }
 
        //=========================================================================
@@ -130,18 +138,44 @@ namespace bbtk
 
        //=========================================================================
 
-       void wxTabPanelsManager::saveActualDiagram(std::string &content)
+       void wxTabPanelsManager::saveActualDiagram(std::string &content, const std::string &path) //DFCH
        {
-               _actual->saveDiagram(content);
+               _actual->saveDiagram(content, path);
        }
 
        //=========================================================================
 
-       void wxTabPanelsManager::loadDiagram(ifstream &inputStream)
+       void wxTabPanelsManager::loadDiagram(ifstream &inputStream, const std::string &path) //DFCH
        {
-               _actual->loadDiagram(inputStream);
+               _actual->loadDiagram(inputStream, path);
        }
 
+       //=========================================================================
+       void wxTabPanelsManager::saveTempandUpdate(const std::string &action) //FCY
+       {
+               _parent->SaveTempActualDiagram(action);
+       }
+       //=========================================================================
+       void wxTabPanelsManager::saveTempActualDiagram(const std::string &action) //FCY
+       {
+               _actual->saveTempDiagram(action);
+       }
+       //=========================================================================
+       void wxTabPanelsManager::loadTempDiagram(unsigned short un) //FCY
+       {
+                _actual->loadTempDiagram(un);
+       }
+
+       //=========================================================================
+       unsigned short wxTabPanelsManager::getUndoState( std::string &stun) //FCY
+       {
+                return _actual->getUndoState(stun);
+       }
+               //=========================================================================
+       unsigned short wxTabPanelsManager::getRedoState(std::string &stre) //FCY
+       {
+                return _actual->getRedoState(stre);
+       }
        //=========================================================================
 
        bool wxTabPanelsManager::isActualDiagramComplexBox()
@@ -203,15 +237,138 @@ printf("wxTabPanelsManager::VerifyActualTabPanel  %d \n", this->_notebook->GetPa
 
        void wxTabPanelsManager::OnTabChanged(wxAuiNotebookEvent& event)
        {
-printf("wxTabPanelsManager::OnTabChanged \n");
                int index                   = event.GetSelection();
                wxGEditorTabPanel* tab      = (wxGEditorTabPanel*)_notebook->GetPage(index);
                int id                      = tab->getPanelId();
                _actual                     = _panels[id];
                _parent->refreshGUIControls();
+
+       }
+
+       //=========================================================================
+
+       void wxTabPanelsManager::OnTabClose(wxAuiNotebookEvent& event)
+       {
+
+               std::cout<<"RaC wxTabPanelsManager::OnTabClose Start... "<<_panels.size()<<std::endl;
+               int index = event.GetSelection();
+
+               if(_panels.size()>0)
+               {
+                       wxGEditorTabPanel* tab      = (wxGEditorTabPanel*)_notebook->GetPage(index);
+                       int id                      = tab->getPanelId();
+                       tab->deleteAllBoxes();
+                       _panels.erase(id);
+
+                       _notebook->RemovePage(index);
+
+                       std::cout<<"RaC wxTabPanelsManager::OnTabClose  IMPORTANT. The complete tab is not erased from memory... "<<std::endl;
+                       //////////////////////////////
+                       // TO FIX . RaC May 2012 - IMPORTANT. The complete tab is not erased from memory.
+                       // Only the objects are deleted and the tab is hidden
+                       // Execution problems when a tab is deleted using delete or DeletePage
+                       // delete tab;
+
+                       map<int, wxGEditorTabPanel*>::iterator it = _panels.begin() ;
+                       _actual=(*it).second;
+
+                       std::cout<<"RaC wxTabPanelsManager::OnTabClose End..."<< std::endl;
+               }
+       }
+
+       //=========================================================================
+    std::string wxTabPanelsManager::GetCbName()
+       {
+           return _actual->GetCbName();
+       }
+       
+       //=========================================================================
+       void wxTabPanelsManager::SetNameTabPanel(wxString tabpanelname)
+       {
+           int id          = _notebook->GetSelection();
+           _notebook->SetPageText( id , tabpanelname );
        }
 
+       std::string wxTabPanelsManager::GetNameTabPanel() 
+       {
+                int id = _notebook->GetSelection();
+               return crea::wx2std(_notebook->GetPageText(id));
+       }
+
+       //=========================================================================
+       //DFCH
+       std::string wxTabPanelsManager::GetCurrentTabPanelPath( )
+       {
+               int id          = _notebook->GetSelection();
+               wxGEditorTabPanel* auxPanel = (wxGEditorTabPanel*) _notebook->GetPage(id);
+               return( auxPanel->GetFullPath( ) );
+           //return ( (wxGEditorTabPanel) _notebook->GetPage(id)->GetFullPath( ) );
+       }
+
+
+       //=========================================================================
+    std::string wxTabPanelsManager::GetCbPackageName()
+       {
+           return _actual->GetCbPackageName();
+       }
+
+       //=========================================================================
+    std::string wxTabPanelsManager::GetAuthor()
+       {
+           return _actual->GetAuthor();
+       }
+
+       //=========================================================================
+    std::string wxTabPanelsManager::GetDescription()
+       {
+           return _actual->GetDescription();
+       }
+
+       //=========================================================================
+    std::string wxTabPanelsManager::GetCategory()
+       {
+           return _actual->GetCategory();
+       }
+
+       //=========================================================================
+    void wxTabPanelsManager::SetCbName(std::string cbName)
+    {
+        _actual->SetCbName( cbName );
+    }
+
+       //=========================================================================
+    void wxTabPanelsManager::SetCbPackageName(std::string packagename)
+    {
+        _actual->SetCbPackageName( packagename );
+    }
+
+
+       //=========================================================================
+    void wxTabPanelsManager::SetAuthor(std::string author)
+    {
+        _actual->SetAuthor( author );
+    }
+
+
        //=========================================================================
+    void wxTabPanelsManager::SetCategory(std::string category)
+    {
+        _actual->SetCategory( category );
+    }
+
+
+       //=========================================================================
+    void wxTabPanelsManager::SetDescription(std::string description)
+    {
+        _actual->SetDescription( description );
+    }
+
+
+
+
+
+
+