]> Creatis software - bbtkGEditor.git/blobdiff - lib/EditorGraphicBBS/bbsWxGUIEditorGraphic/wxBlackBoxEditionDialog.cxx
v1.1.0
[bbtkGEditor.git] / lib / EditorGraphicBBS / bbsWxGUIEditorGraphic / wxBlackBoxEditionDialog.cxx
index 053d0a659eb8a8c32f95f5ec7184654fa62aea92..8ee617b4c8e51891aee2c8add70c2406c25395fa 100644 (file)
@@ -8,35 +8,34 @@ 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
- *  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.
- *
- *  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.
- * ------------------------------------------------------------------------ */
+* 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
+*  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.
+*
+*  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::wxBlackBoxEditionDialog .
- */
+*  \file
+*  \brief Class bbtk::wxBlackBoxEditionDialog .
+*/
 
 #include "wxBlackBoxEditionDialog.h"
 #include "creaWx.h"
 
-
 namespace bbtk
 {
        //=========================================================================
@@ -66,16 +65,36 @@ namespace bbtk
 
        //=========================================================================
 
+       bool wxBlackBoxEditionDialog::isValidNameForABox(std::string boxname) {
+
+               int i=0;
+               for (i = 0; i < boxname.size() ; i++) {
+                       if ( (isalnum(boxname[i])==0) && (boxname.compare(i, 1, "-") != 0) && ( boxname.compare(i, 1, "_") != 0) ){
+                               return false;
+                       }
+               } // for
+               return true;
+       }
+
+       //=========================================================================
+
        void wxBlackBoxEditionDialog::constructBlackBoxEditionDialog()
        {
                wxBoxSizer *sizerDialog = new wxBoxSizer(wxVERTICAL);
 
         wxScrolledWindow *scrollWin = new wxScrolledWindow( this, -1, wxDefaultPosition,  wxSize(200,200), wxVSCROLL);
 
+               wxStaticText *textBoxName = new wxStaticText(scrollWin, -1, wxT("Box Name"));
+               wxTextCtrl *valueBoxName  = new wxTextCtrl(scrollWin, -1, _T(""), wxDefaultPosition,wxSize(300,25));
+               _initBoxName = _model->getBBTKName();
+               valueBoxName->SetValue(crea::std2wx(_initBoxName));
+               _boxName = valueBoxName ;
+
                wxStaticText *text = new wxStaticText(scrollWin, -1, wxT("Input Ports"));
                wxFont font(11, wxDEFAULT, wxNORMAL, wxBOLD);
                text->SetFont(font);
-
+               textBoxName->SetFont(font);
 
 
                std::vector<GPortModel*> lstInputs = _model->getInputPorts();
@@ -95,7 +114,10 @@ namespace bbtk
 
                        if(port->getValue()!="")
                        {
-                               txtValue->SetValue(crea::std2wx(port->getValue()));
+                               std::string text = port->getValue();
+                               if(text.length()>0)
+                                       addDoubleQuotes(text);
+                               txtValue->SetValue(crea::std2wx(text));
                        }
 
                        if(port->isConnected())
@@ -135,6 +157,10 @@ namespace bbtk
                buts->Add(closeButton,0,wxCENTRE|wxEXPAND,5);
 
                sizerDialog->AddSpacer(10);
+               sizerDialog->Add(textBoxName,0,wxALIGN_TOP|wxALIGN_CENTER);
+               sizerDialog->AddSpacer(10);
+               sizerDialog->Add(valueBoxName, wxSizerFlags(0).Align(0).Border(wxLEFT, 100));
+               sizerDialog->AddSpacer(10);
                sizerDialog->Add(text,0,wxALIGN_TOP|wxALIGN_CENTER);
                sizerDialog->AddSpacer(15);
                sizerDialog->Add(sizer,0,wxALIGN_CENTER| wxEXPAND);
@@ -159,17 +185,45 @@ namespace bbtk
 
        void wxBlackBoxEditionDialog::onClickOk(wxCommandEvent& event)
        {
+               int closeok = 1;
                for(int i=0;i<(int)_lstValues.size();i++)
                {
                        std::string text = wx2std(_lstValues[i]->GetValue());
                        //TOFIX Search a better alternative
                        if(text!="--No editable--" && text!="--Port Connected--")
                        {
+                               //JPRG: When executing, add double quotes if necessary
+                               if(text.length()>0)
+                               {
+                                       addDoubleQuotes(text);
+                               }
                                _model->setValueToInputPort(i,text);
                        }
                }
-               _parent->SaveTempActualDiagram();
-               Close(true);
+               //handle box name
+               std::string boxname = wx2std(_boxName->GetValue());
+               if( boxname.compare(_initBoxName) != 0 ){
+                       if (isValidNameForABox(boxname) == true){
+                               if( _parent->boxNameExists(boxname) == true ){
+                                       closeok=0;
+                                       wxMessageDialog *dial = new wxMessageDialog(NULL,
+                         wxT("The name already exists. Please provide another name"),
+                         wxT("Change name: name already exists"), wxOK | wxICON_EXCLAMATION | wxSTAY_ON_TOP);
+                                       dial->ShowModal();
+                               }else{
+                                       _model->setBBTKName(boxname);
+                               }
+                       }else{
+                               closeok=0;
+                               wxMessageDialog *dial = new wxMessageDialog(NULL,  wxT("Please provide a valide name for your box (no spaces and only leters, digits, \"_\" or \"-\" allowed)"),  wxT("Change name: invalid name"), wxOK | wxICON_EXCLAMATION | wxSTAY_ON_TOP);
+                               dial->ShowModal();
+                       }
+               }
+               if( closeok==1 ){
+                       _parent->SaveTempActualDiagram("edit values");
+                       Close(true);
+               }
        }
 
        //=========================================================================
@@ -180,131 +234,37 @@ printf("EED wxBlackBoxEditionDialog::onClickClose\n");
                Close(true);
        }
 
+       //=========================================================================
 
-    wxBlackBoxEditionDialog::wxBlackBoxEditionDialog( wxGUIEditorGraphicBBS *parent , GBlackBoxModel *model ) : wxDialog( parent , wxID_ANY , _T( "" ) , wxDefaultPosition , wxSize( 480 , 640 ) , wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER ) {
-        _model = model ;
-        std::string title( "BlackBox Editing - " ) ;
-        title += _model->getBBTKPackage( ) ;
-        title += ":" ;
-        title += _model->getBBTKType( ) ;
-        title += ":" ;
-        title += _model->getBBTKName( ) ;
-        SetTitle( std2wx( title ) ) ;
-
-        constructBlackBoxEditionDialog( ) ;
-    }
-
-    //=========================================================================
-
-    wxBlackBoxEditionDialog::~wxBlackBoxEditionDialog( ) {
-
-    }
-
-    //=========================================================================
-
-    void wxBlackBoxEditionDialog::constructBlackBoxEditionDialog( ) {
-        wxBoxSizer *sizerDialog = new wxBoxSizer( wxVERTICAL ) ;
-
-        wxScrolledWindow *scrollWin = new wxScrolledWindow( this , -1 , wxDefaultPosition , wxSize( 200 , 200 ) , wxVSCROLL ) ;
-
-        wxStaticText *text = new wxStaticText( scrollWin , -1 , wxT( "Input Ports" ) ) ;
-        wxFont font( 11 , wxDEFAULT , wxNORMAL , wxBOLD ) ;
-        text->SetFont( font ) ;
-
-
-
-        std::vector<GPortModel*> lstInputs = _model->getInputPorts( ) ;
-        wxFlexGridSizer *sizer = new wxFlexGridSizer( lstInputs.size( ) , 3 , 5 , 5 ) ;
-        for ( int i = 0 ; i < ( int ) lstInputs.size( ) ; i++ ) {
-            GPortModel* port = lstInputs[i] ;
-            std::string type = port->getBBTKType( ) ;
-            wxStaticText *lblName = new wxStaticText( scrollWin , -1 , std2wx( port->getBBTKName( ) ) , wxDefaultPosition , wxSize( 100 , 25 ) ) ;
-            wxStaticText *lblType = new wxStaticText( scrollWin , -1 , std2wx( type ) , wxDefaultPosition , wxSize( 250 , 25 ) ) ;
-            wxTextCtrl *txtValue = new wxTextCtrl( scrollWin , -1 , _T( "" ) , wxDefaultPosition , wxSize( 90 , 25 ) ) ;
-
-            if ( port->getValue( ) != "" ) {
-                txtValue->SetValue( crea::std2wx( port->getValue( ) ) ) ;
-            }
-
-            if ( port->isConnected( ) ) {
-                std::string connected( "--CAN'T TOUCH THIS--" ) ;
-                txtValue->SetValue( crea::std2wx( connected ) ) ;
-                txtValue->SetEditable( false ) ;
-            }
-
-            char et = '*' ;
-            if ( type.find( et ) != -1 ) {
-                std::string noEditable( "--CAN'T TOUCH THIS--" ) ;
-                txtValue->SetValue( crea::std2wx( noEditable ) ) ;
-                txtValue->SetEditable( false ) ;
-            }
-
-            _lstNames.push_back( lblName ) ;
-            _lstValues.push_back( txtValue ) ;
-            _lstTypes.push_back( lblType ) ;
-
-            sizer->Add( lblName , 1 , wxEXPAND , 5 ) ;
-            sizer->Add( txtValue , 1 , wxEXPAND , 5 ) ;
-            sizer->Add( lblType , 1 , wxCENTRE | wxEXPAND , 5 ) ;
-        }
-
-
-        wxBoxSizer *buts = new wxBoxSizer( wxHORIZONTAL ) ;
-        wxButton *okButton = new wxButton( scrollWin , -1 , _T( "OK" ) , wxDefaultPosition , wxSize( 70 , 30 ) ) ;
-        wxButton *closeButton = new wxButton( scrollWin , -1 , _T( "CLOSE" ) , wxDefaultPosition , wxSize( 70 , 30 ) ) ;
-
-        // connect command event handlers
-        Connect( okButton->GetId( ) , wxEVT_COMMAND_BUTTON_CLICKED , wxCommandEventHandler( wxBlackBoxEditionDialog::onClickOk ) ) ;
-        Connect( closeButton->GetId( ) , wxEVT_COMMAND_BUTTON_CLICKED , wxCommandEventHandler( wxBlackBoxEditionDialog::onClickClose ) ) ;
-
-        buts->Add( okButton , 0 , wxCENTRE | wxEXPAND , 5 ) ;
-        buts->Add( closeButton , 0 , wxCENTRE | wxEXPAND , 5 ) ;
-
-        sizerDialog->AddSpacer( 10 ) ;
-        sizerDialog->Add( text , 0 , wxALIGN_TOP | wxALIGN_CENTER ) ;
-        sizerDialog->AddSpacer( 15 ) ;
-        sizerDialog->Add( sizer , 0 , wxALIGN_CENTER ) ;
-        sizerDialog->AddSpacer( 15 ) ;
-        sizerDialog->Add( buts , 0 , wxALIGN_CENTER | wxTOP | wxBOTTOM ) ;
-
-        scrollWin->SetSizer( sizerDialog ) ;
-        scrollWin->Centre( ) ;
-
-
-        scrollWin->SetVirtualSize( 400 , 400 ) ;
-        scrollWin->SetSize( 300 , 300 ) ;
-        scrollWin->SetScrollbars( 10 , 10 , 50 , 50 ) ;
-        //        scrollWin->SetSizer(sizer);
-
-
-        ShowModal( ) ;
-        Destroy( ) ;
-    }
-
-    //=========================================================================
-
-    void wxBlackBoxEditionDialog::onClickOk( wxCommandEvent& event ) {
-        for ( int i = 0 ; i < ( int ) _lstValues.size( ) ; i++ ) {
-            std::string text = wx2std( _lstValues[i]->GetValue( ) ) ;
-            //TOFIX Search a better alternative
-            if ( text != "--No editable--" && text != "--Port Connected--" ) {
-                _model->setValueToInputPort( i , text ) ;
-            }
-        }
-
-        Close( true ) ;
-    }
-
-    //=========================================================================
-
-    void wxBlackBoxEditionDialog::onClickClose( wxCommandEvent& event ) {
-        printf( "EED wxBlackBoxEditionDialog::onClickClose JGRR AND CM WERE HERE!!!\n" ) ;
-        Close( true ) ;
-    }
-
-    //=========================================================================
+       //=========================================================================
+       
+       void wxBlackBoxEditionDialog::addDoubleQuotes(std::string &text)
+       {
+               
+               //We add the double quotes at the beginning
+               if(text[0] != '"' )
+                       text = "\"" + text;
+               
+               //We add the double quotes at the end
+               if(text[text.length()-1] != '"')        
+                       text+= "\"";
+               
+       }
+       
 
-} // EO namespace bbtk
+       //=========================================================================
+       void wxBlackBoxEditionDialog::removeDoubleQuotes(std::string &text)
+       {
+               if(text[0]== '"' )
+                       text.replace(0, 1,"");
+               if(text[text.length()-1] == '"')        
+                       text.replace(text.length()-1, 1,"");
+               
+       }
+       
+       
+       
+}  // EO namespace bbtk
 
 // EOF
 /*     // remove * from the name