]> Creatis software - bbtkGEditor.git/blobdiff - lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxTabPanelsManager.cxx
Bug #1375
[bbtkGEditor.git] / lib / EditorGraphicBBS / bbsWxGUIEditorGraphic / wxTabPanelsManager.cxx
index 86750fc35833f4ee646b04e3a0d14805fe7a97fc..a7a705221f2adea8b959d8065d1d5ffd454b364c 100644 (file)
@@ -1,4 +1,4 @@
-/*=========================================================================                                                                               
+/*=========================================================================
 Program:   bbtk
 Module:    $RCSfile$
 Language:  C++
@@ -11,32 +11,31 @@ Version:   $Revision$
 * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale)
 * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux
 *
-*  This software is governed by the CeCILL-B license under French law and 
-*  abiding by the rules of distribution of free software. You can  use, 
-*  modify and/ or redistribute the software under the terms of the CeCILL-B 
-*  license as circulated by CEA, CNRS and INRIA at the following URL 
-*  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html 
+*  This software is governed by the CeCILL-B license under French law and
+*  abiding by the rules of distribution of free software. You can  use,
+*  modify and/ or redistribute the software under the terms of the CeCILL-B
+*  license as circulated by CEA, CNRS and INRIA at the following URL
+*  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
 *  or in the file LICENSE.txt.
 *
 *  As a counterpart to the access to the source code and  rights to copy,
 *  modify and redistribute granted by the license, users are provided only
 *  with a limited warranty  and the software's author,  the holder of the
 *  economic rights,  and the successive licensors  have only  limited
-*  liability. 
+*  liability.
 *
 *  The fact that you are presently reading this means that you have had
 *  knowledge of the CeCILL-B license and that you accept its terms.
-* ------------------------------------------------------------------------ */                                                                         
+* ------------------------------------------------------------------------ */
 
 /**
-*  \file 
-*  \brief Class bbtk::wxTabPanelsManager . 
+*  \file
+*  \brief Class bbtk::wxTabPanelsManager .
 */
 
 
 #include "wxTabPanelsManager.h"
 
-
 namespace bbtk
 {
 
@@ -44,37 +43,46 @@ namespace bbtk
        //=========================================================================
        wxTabPanelsManager::wxTabPanelsManager(wxGUIEditorGraphicBBS *parent)
        {
-               printf ("EED %p wxTabPanelsManager()\n" , this );
-               _parent = parent;
-               _lastId = 0;
-               _notebook = _parent->getAuiNotebook();
+               _parent         = parent;
+               _lastId         = 0;
+               _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);
+
        }
 
        //=========================================================================
        wxTabPanelsManager::~wxTabPanelsManager()
        {
-               printf ("EED %p ~wxTabPanelsManager()\n" , this );
        }
-       
+
        //=========================================================================
-       void wxTabPanelsManager::addNewTab()
+       void wxTabPanelsManager::addNewTab(wxString tabName)
        {
+printf("EED wxTabPanelsManager::addNewTab 0\n");
+
                _lastId++;
-               wxGEditorTabPanel *newPanel = new wxGEditorTabPanel(_notebook,_lastId);
+               wxGEditorTabPanel *newPanel         = new wxGEditorTabPanel(_notebook,_lastId);
                newPanel->setPanelsManager(this);
-               _panels[_lastId]=newPanel;
-               _actual = newPanel;
-               _notebook->AddPage(newPanel,_T("Diagram"),true);
+               _panels[_lastId]                    = newPanel;
+               _actual                             = newPanel;
+
+               _notebook->AddPage(newPanel, tabName  ,true);
+
+printf("EED wxTabPanelsManager::addNewTab 1\n");
        }
 
+
+
+
+
        //=========================================================================
        wxAuiNotebook* wxTabPanelsManager::getAuiNotebook()
        {
                return _notebook;
        }
-       
+
        //=========================================================================
        wxGEditorTabPanel* wxTabPanelsManager::getActualTabPanel()
        {
@@ -97,16 +105,16 @@ namespace bbtk
 
        //=========================================================================
 
-       std::string wxTabPanelsManager::getActualDiagramBBS()
+       std::string wxTabPanelsManager::getActualDiagramBBS(bool wln)
        {
-               return _actual->getDiagramBBS();
+               return _actual->getDiagramBBS(wln);
        }
 
        //=========================================================================
 
-       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();
        }
 
        //=========================================================================
@@ -132,18 +140,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() //FCY
+       {
+               _parent->SaveTempActualDiagram();
+       }
+       //=========================================================================
+       void wxTabPanelsManager::saveTempActualDiagram() //FCY
+       {
+               _actual->saveTempDiagram();
+       }
+       //=========================================================================
+       void wxTabPanelsManager::loadTempDiagram(unsigned short un) //FCY
+       {
+                _actual->loadTempDiagram(un);
+       }
+
+       //=========================================================================
+       unsigned short wxTabPanelsManager::getUndoState() //FCY
+       {
+                return _actual->getUndoState();
+       }
+               //=========================================================================
+       unsigned short wxTabPanelsManager::getRedoState() //FCY
+       {
+                return _actual->getRedoState();
+       }
        //=========================================================================
 
        bool wxTabPanelsManager::isActualDiagramComplexBox()
@@ -155,11 +189,11 @@ namespace bbtk
 
        void wxTabPanelsManager::setActualDiagramComplexBox(bool val)
        {
-               _actual->setComplexBox(val);    
+               _actual->setComplexBox(val);
        }
 
        //=========================================================================
-       
+
        void wxTabPanelsManager::addActualDiagramComplexInputPort(std::string portName)
        {
                _actual->addComplexInputPort(portName);
@@ -192,17 +226,152 @@ namespace bbtk
 
        //=========================================================================
 
+       void wxTabPanelsManager::VerifyLastTabPanel()
+       {
+printf("wxTabPanelsManager::VerifyActualTabPanel  %d \n", this->_notebook->GetPageCount() );
+            if (this->_notebook->GetPageCount()==0)
+            {
+                this->_actual=NULL;
+            }
+       }
+
+       //=========================================================================
+
        void wxTabPanelsManager::OnTabChanged(wxAuiNotebookEvent& event)
        {
-               int index = event.GetSelection();
-               wxGEditorTabPanel* tab =(wxGEditorTabPanel*)_notebook->GetPage(index);          
-               int id = tab->getPanelId();
-               _actual = _panels[id];
+               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 );
+    }
+
+
+
+
+
+
+
+
 
 
 }  // EO namespace bbtk