X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkWxBrowser.cxx;h=874f7f61dec955acccf199639731bff0d31e4f89;hb=372f03317f05d4a436b0f9c39b98558ec4810b78;hp=3776e1f4f949c60680025516d6cb1de3a05d387c;hpb=7eba604321498f7ed6333b7cbe9bf2aceb4ec30e;p=bbtk.git diff --git a/kernel/src/bbtkWxBrowser.cxx b/kernel/src/bbtkWxBrowser.cxx index 3776e1f..874f7f6 100644 --- a/kernel/src/bbtkWxBrowser.cxx +++ b/kernel/src/bbtkWxBrowser.cxx @@ -1,17 +1,34 @@ #ifdef _USE_WXWIDGETS_ + #include "bbtkWxBrowser.h" #include "bbtkWxBlackBox.h" +#include "bbtkWxConsole.h" #include "bbtkConfigurationFile.h" +#include "bbtkUtilities.h" namespace bbtk { + //======================================================================== + enum + { + bwd_id, + fwd_id, + home_id, + reload_id, + include_id, + url_id , + html_id + }; + + +/*EED //======================================================================== void WxHtmlWindow::OnLinkClicked(const wxHtmlLinkInfo& e) { - // std::cout << "WxHtmlWindow::OnLink"<UpdateURL(); - - } //======================================================================== +*/ + - //======================================================================== - enum - { - bwd_id, - fwd_id, - home_id, - reload_id, - index_id, - url_id, - html_id - }; //======================================================================== BEGIN_EVENT_TABLE(WxBrowser, wxPanel) @@ -43,7 +49,7 @@ namespace bbtk EVT_BUTTON(fwd_id, WxBrowser::OnForwardButton ) EVT_BUTTON(home_id, WxBrowser::OnHomeButton ) EVT_BUTTON(reload_id, WxBrowser::OnReloadButton ) - EVT_BUTTON(index_id, WxBrowser::OnMakeIndexButton ) + EVT_BUTTON(include_id, WxBrowser::OnIncludeFileButton ) EVT_TEXT_ENTER(url_id, WxBrowser::OnURLEnter ) EVT_HTML_LINK_CLICKED(html_id, WxBrowser::OnLinkClicked) END_EVENT_TABLE() @@ -53,7 +59,8 @@ namespace bbtk //======================================================================== WxBrowser::WxBrowser ( wxWindow *parent, wxSize size ) : - wxPanel ( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL) + wxPanel ( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL), + mWxConsole(0) { wxPanel* panel = this; @@ -62,45 +69,38 @@ namespace bbtk wxBoxSizer *bsizer = new wxBoxSizer(wxHORIZONTAL); - - sizer->Add ( bsizer, 0, wxGROW ); - - + mwxBackButton = new wxButton( panel, bwd_id,_T("<"),wxDefaultPosition, wxDefaultSize,wxBU_EXACTFIT); - bsizer->Add ( mwxBackButton, 0, wxALIGN_CENTRE | - wxLEFT | wxTOP | wxBOTTOM , 10 ); + bsizer->Add ( mwxBackButton , 0, wxALIGN_CENTRE | wxLEFT | wxTOP | wxBOTTOM , 10 ); mwxForwardButton = new wxButton( panel, fwd_id,_T(">"),wxDefaultPosition, wxDefaultSize,wxBU_EXACTFIT); - bsizer->Add ( mwxForwardButton, 0, wxALIGN_CENTRE | - wxTOP | wxBOTTOM , 10); + bsizer->Add ( mwxForwardButton , 0, wxALIGN_CENTRE | wxTOP | wxBOTTOM , 10); - mwxHomeButton = new wxButton( panel, home_id,_T("~"),wxDefaultPosition, + mwxHomeButton = new wxButton( panel, home_id,_T("Home"),wxDefaultPosition, wxDefaultSize,wxBU_EXACTFIT); - bsizer->Add ( mwxHomeButton, 0, wxALIGN_CENTRE | - wxLEFT | wxTOP | wxBOTTOM , 10 ); + bsizer->Add ( mwxHomeButton , 0, wxALIGN_CENTRE | wxLEFT | wxTOP | wxBOTTOM , 10 ); - mwxReloadButton = new wxButton( panel, reload_id,_T("."),wxDefaultPosition, + mwxReloadButton = new wxButton( panel, reload_id,_T("Reload"),wxDefaultPosition, wxDefaultSize,wxBU_EXACTFIT); - bsizer->Add ( mwxReloadButton, 0, wxALIGN_CENTRE | - wxTOP | wxBOTTOM , 10 ); + bsizer->Add ( mwxReloadButton , 0, wxALIGN_CENTRE | wxTOP | wxBOTTOM , 10 ); - mwxMakeIndexButton = new wxButton( panel, index_id, - _T("*"),wxDefaultPosition, + mwxIncludeFileButton = new wxButton( panel, include_id, + _T("RUN"),wxDefaultPosition, wxDefaultSize,wxBU_EXACTFIT); - bsizer->Add ( mwxMakeIndexButton, 0, wxALIGN_CENTRE | - wxLEFT | wxTOP | wxBOTTOM , 10 ); + bsizer->Add ( mwxIncludeFileButton , 0, wxALIGN_CENTRE | wxLEFT | wxTOP | wxBOTTOM , 10 ); mwxURL = new wxTextCtrl(panel,url_id,_T(""), wxDefaultPosition, wxDefaultSize, wxTE_PROCESS_ENTER); mwxURL->SetLabel(_T("URL")); - bsizer->Add(mwxURL, 1, wxGROW | wxALL, 10); + bsizer->Add(mwxURL, 1, wxEXPAND | wxALL, 10); - mwxHtmlWindow = new WxHtmlWindow(parent,html_id,this,size); +// mwxHtmlWindow = new WxHtmlWindow(parent,html_id,this,size); + mwxHtmlWindow = new WxHtmlWindow(this,html_id,this,size); /* @@ -112,23 +112,32 @@ namespace bbtk */ mwxHtmlWindow->SetBorders(5); // mwxHtmlWindow->FitInside(); + wxStaticBoxSizer* hw = new wxStaticBoxSizer( new wxStaticBox( this, -1, _T(""), wxDefaultPosition, size ), wxVERTICAL ); - hw->Add ( mwxHtmlWindow, 1, wxGROW ); +//EED hw->Add ( mwxHtmlWindow, 1, wxGROW ); + hw->Add ( mwxHtmlWindow, 1, wxEXPAND ); + + + + + //sizer->Add ( mwxHtmlWindow, 1, wxGROW ); +//EED sizer->Add ( hw, 1, wxGROW ); // | wxLEFT | wxRIGHT | wxBOTTOM, 10 ); + sizer->Add ( bsizer , 0, wxEXPAND ); sizer->Add ( hw, 1, wxGROW ); // | wxLEFT | wxRIGHT | wxBOTTOM, 10 ); - - + + panel -> SetSizer(sizer); panel -> SetAutoLayout(true); panel -> Layout(); - GoHome(); +// GoHome(); /* Connect( mwxBackButton->GetId(), @@ -165,6 +174,7 @@ namespace bbtk bool WxBrowser::GoTo(std::string& file) { // std::cout << "goto"<LoadPage(std2wx(file)); UpdateURL(); return r; @@ -192,9 +202,24 @@ namespace bbtk //======================================================================== void WxBrowser::GoHome() { - std::string url = ConfigurationFile::GetInstance().Get_url(); + std::string url = ConfigurationFile::GetInstance().Get_doc_path(); url += "/bbtkWebSite/menu.html"; - GoTo(url); + GoTo(url); + + mwxURL->Clear(); + mwxURL->AppendText(std2wx(url)); + + +/*EED + if (Utilities::FileExists(url)) + { + GoTo(url); + } + else + { + // what ? + } +*/ } //======================================================================== @@ -206,16 +231,39 @@ namespace bbtk //======================================================================== //======================================================================== - void WxBrowser::OnReloadButton(wxCommandEvent& ) + void WxBrowser::OnReloadButton(wxCommandEvent& e) { - std::string s = wx2std(mwxHtmlWindow->GetOpenedPage()); - GoTo(s); + OnURLEnter(e); } //======================================================================== //======================================================================== - void WxBrowser::OnMakeIndexButton(wxCommandEvent& ) + void WxBrowser::OnIncludeFileButton(wxCommandEvent& ) { + std::string filename = wx2std(mwxURL->GetValue()); + size_t s = filename.length(); + + WxConsole* C = mWxConsole; //::GetInstance(); + // MessageManager::SetMessageLevel("All",9); + Interpreter* I = new Interpreter; + + if ((s>3) && (filename[s-1]=='s') + && (filename[s-2]=='b') + && (filename[s-3]=='b') + && (filename[s-4]=='.')) + { + std::cout << "stat"<SetStatusText(_T("Executing ")+mwxURL->GetValue()); + std::cout << "int"<InterpretFile(filename); + std::cout << "eoint"<SetStatusText(_T("The current page is not a bbs file : cannot execute it")); + } + + delete I; /* std::string bbdoc = ConfigurationFile::GetInstance().Get_url(); bbdoc += "/bbdoc"; @@ -230,21 +278,21 @@ namespace bbtk //======================================================================== void WxBrowser::OnURLEnter( wxCommandEvent&) { - //std::cout << "OnURL"<LoadPage(mwxURL->GetValue()); } //======================================================================== + //======================================================================== void WxBrowser::OnLinkClicked(wxHtmlLinkEvent& e) { - std::cout << "WxBrowser::OnLinkClicked"<LoadPage(e.GetLinkInfo().GetHref()); + mwxHtmlWindow->LoadPage( e.GetLinkInfo().GetHref() ); UpdateURL(); + mwxHtmlWindow->LoadPage( mwxURL->GetValue() ); } //======================================================================== + /* void WxBrowser::OnCell(wxHtmlCellEvent& ) {