X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f8105809ef8f7cb0d1a9933f3f790b7b446c7cfa..08b97268061292f7c3794dae243a6490b23a42f1:/utils/configtool/src/custompropertydialog.cpp diff --git a/utils/configtool/src/custompropertydialog.cpp b/utils/configtool/src/custompropertydialog.cpp index 9bf09e750a..b2e227f7ab 100644 --- a/utils/configtool/src/custompropertydialog.cpp +++ b/utils/configtool/src/custompropertydialog.cpp @@ -9,19 +9,26 @@ // Licence: ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "custompropertydialog.h" +// For compilers that support precompilation, includes "wx/wx.h". +#include "wx/wxprec.h" + +#ifdef __BORLANDC__ +#pragma hdrstop #endif -#include -#include -#include -#include -#include -#include -#include -#include +#ifndef WX_PRECOMP + +#include "wx/wx.h" +#include "wx/statline.h" +#include "wx/splitter.h" +#include "wx/scrolwin.h" +#include "wx/spinctrl.h" +#include "wx/spinbutt.h" + +#endif +#include "wx/cshelp.h" +#include "wx/valgen.h" #include "custompropertydialog.h" ////@begin XPM images @@ -56,11 +63,11 @@ END_EVENT_TABLE() * ctCustomPropertyDialog constructor */ -ctCustomPropertyDialog::ctCustomPropertyDialog( wxWindow* parent, wxWindowID id, const wxString& caption, const wxPoint& pos, const wxSize& size, long style ) +ctCustomPropertyDialog::ctCustomPropertyDialog( wxWindow* parent, wxWindowID id, const wxString& caption) { m_type = wxT("string"); - wxDialog::Create( parent, id, caption, pos, size, style ); + wxDialog::Create( parent, id, caption); CreateControls(); } @@ -70,14 +77,15 @@ ctCustomPropertyDialog::ctCustomPropertyDialog( wxWindow* parent, wxWindowID id, */ void ctCustomPropertyDialog::CreateControls() -{ +{ ////@begin ctCustomPropertyDialog content construction + wxArrayString items; + ctCustomPropertyDialog* item1 = this; wxBoxSizer* item2 = new wxBoxSizer(wxVERTICAL); item1->SetSizer(item2); - item1->SetAutoLayout(TRUE); wxBoxSizer* item3 = new wxBoxSizer(wxVERTICAL); item2->Add(item3, 1, wxGROW|wxALL, 5); @@ -88,8 +96,8 @@ void ctCustomPropertyDialog::CreateControls() wxStaticText* item5 = new wxStaticText(item1, wxID_STATIC, _("&Name:"), wxDefaultPosition, wxDefaultSize, 0); item3->Add(item5, 0, wxALIGN_LEFT|wxALL|wxADJUST_MINSIZE, 5); - wxTextCtrl* item6 = new wxTextCtrl(item1, ID_CUSTOMPROPERTYNAME, _(""), wxDefaultPosition, wxDefaultSize, 0); - item3->Add(item6, 0, wxGROW|wxALL, 5); + m_customPropertyName = new wxTextCtrl(item1, wxID_ANY); + item3->Add(m_customPropertyName, 0, wxGROW|wxALL, 5); wxBoxSizer* item7 = new wxBoxSizer(wxHORIZONTAL); item3->Add(item7, 0, wxGROW, 5); @@ -100,15 +108,14 @@ void ctCustomPropertyDialog::CreateControls() wxStaticText* item9 = new wxStaticText(item1, wxID_STATIC, _("&Data type:"), wxDefaultPosition, wxDefaultSize, 0); item8->Add(item9, 0, wxALIGN_LEFT|wxALL|wxADJUST_MINSIZE, 5); - wxString item10Strings[] = { - _("string"), - _("bool"), - _("double"), - _("long") - }; - wxChoice* item10 = new wxChoice(item1, ID_CUSTOMPROPERTYTYPE, wxDefaultPosition, wxDefaultSize, 4, item10Strings, 0); - item10->SetStringSelection(_("string")); - item8->Add(item10, 1, wxGROW|wxALL, 5); + items.Empty(); + items.Add(_("string")); + items.Add(_("bool")); + items.Add(_("double")); + items.Add(_("long")); + m_customPrototype = new wxChoice(item1, wxID_ANY, wxDefaultPosition, wxDefaultSize, items); + m_customPrototype->SetStringSelection(_("string")); + item8->Add(m_customPrototype, 1, wxGROW|wxALL, 5); wxBoxSizer* item11 = new wxBoxSizer(wxVERTICAL); item7->Add(item11, 0, wxALIGN_CENTER_VERTICAL, 5); @@ -116,25 +123,24 @@ void ctCustomPropertyDialog::CreateControls() wxStaticText* item12 = new wxStaticText(item1, wxID_STATIC, _("&Editor type:"), wxDefaultPosition, wxDefaultSize, 0); item11->Add(item12, 0, wxALIGN_LEFT|wxALL|wxADJUST_MINSIZE, 5); - wxString item13Strings[] = { - _("string"), - _("choice"), - _("bool"), - _("float"), - _("integer"), - _("configitems") - }; - wxChoice* item13 = new wxChoice(item1, ID_CUSTOMPROPERTYEDITORTYPE, wxDefaultPosition, wxDefaultSize, 6, item13Strings, 0); - item13->SetStringSelection(_("string")); - item11->Add(item13, 1, wxGROW|wxALL, 5); - - wxStaticBox* item14Static = new wxStaticBox(item1, -1, _("Choices")); + items.Empty(); + items.Add(_("string")); + items.Add(_("choice")); + items.Add(_("bool")); + items.Add(_("float")); + items.Add(_("integer")); + items.Add(_("configitems")); + m_customPropertyEditorType = new wxChoice(item1, wxID_ANY, wxDefaultPosition, wxDefaultSize, items); + m_customPropertyEditorType->SetStringSelection(_("string")); + item11->Add(m_customPropertyEditorType, 1, wxGROW|wxALL, 5); + + wxStaticBox* item14Static = new wxStaticBox(item1, wxID_ANY, _("Choices")); wxStaticBoxSizer* item14 = new wxStaticBoxSizer(item14Static, wxHORIZONTAL); item3->Add(item14, 0, wxGROW|wxALL, 5); wxString* item15Strings = NULL; - wxListBox* item15 = new wxListBox(item1, ID_PROPERTY_CHOICES, wxDefaultPosition, wxDefaultSize, 0, item15Strings, wxLB_SINGLE); - item14->Add(item15, 1, wxALIGN_CENTER_VERTICAL|wxALL, 5); + m_propertyChoices = new wxListBox(item1, ID_PROPERTY_CHOICES, wxDefaultPosition, wxDefaultSize, 0, item15Strings, wxLB_SINGLE); + item14->Add(m_propertyChoices, 1, wxALIGN_CENTER_VERTICAL|wxALL, 5); wxBoxSizer* item16 = new wxBoxSizer(wxVERTICAL); item14->Add(item16, 0, wxALIGN_CENTER_VERTICAL, 5); @@ -148,21 +154,21 @@ void ctCustomPropertyDialog::CreateControls() wxStaticText* item19 = new wxStaticText(item1, wxID_STATIC, _("&Description:"), wxDefaultPosition, wxDefaultSize, 0); item3->Add(item19, 0, wxALIGN_LEFT|wxALL|wxADJUST_MINSIZE, 5); - wxTextCtrl* item20 = new wxTextCtrl(item1, ID_CUSTOMPROPERTYDESCRIPTION, _(""), wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxTE_RICH); - item3->Add(item20, 1, wxGROW|wxALL, 5); + m_customPropertyDescription = new wxTextCtrl(item1, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE|wxTE_RICH); + item3->Add(m_customPropertyDescription, 1, wxGROW|wxALL, 5); wxBoxSizer* item21 = new wxBoxSizer(wxHORIZONTAL); item3->Add(item21, 0, wxGROW|wxALL, 5); item21->Add(5, 5, 1, wxALIGN_CENTER_VERTICAL|wxALL, 5); - wxButton* item23 = new wxButton(item1, wxID_OK, _("&OK"), wxDefaultPosition, wxDefaultSize, 0); + wxButton* item23 = new wxButton(item1, wxID_OK); item21->Add(item23, 0, wxALIGN_CENTER_VERTICAL|wxALL, 5); - wxButton* item24 = new wxButton(item1, wxID_CANCEL, _("&Cancel"), wxDefaultPosition, wxDefaultSize, 0); + wxButton* item24 = new wxButton(item1, wxID_CANCEL); item21->Add(item24, 0, wxALIGN_CENTER_VERTICAL|wxALL, 5); - wxButton* item25 = new wxButton(item1, wxID_HELP, _("&Help"), wxDefaultPosition, wxDefaultSize, 0); + wxButton* item25 = new wxButton(item1, wxID_HELP); item21->Add(item25, 0, wxALIGN_CENTER_VERTICAL|wxALL, 5); GetSizer()->Fit(this); @@ -171,10 +177,10 @@ void ctCustomPropertyDialog::CreateControls() ////@end ctCustomPropertyDialog content construction // Add validators - FindWindow(ID_CUSTOMPROPERTYNAME)->SetValidator(wxGenericValidator(& m_name)); - FindWindow(ID_CUSTOMPROPERTYTYPE)->SetValidator(wxGenericValidator(& m_type)); - FindWindow(ID_CUSTOMPROPERTYEDITORTYPE)->SetValidator(wxGenericValidator(& m_editorType)); - FindWindow(ID_CUSTOMPROPERTYDESCRIPTION)->SetValidator(wxGenericValidator(& m_description)); + m_customPropertyName->SetValidator(wxGenericValidator(& m_name)); + m_customPrototype->SetValidator(wxGenericValidator(& m_type)); + m_customPropertyEditorType->SetValidator(wxGenericValidator(& m_editorType)); + m_customPropertyDescription->SetValidator(wxGenericValidator(& m_description)); } /*! @@ -183,7 +189,7 @@ void ctCustomPropertyDialog::CreateControls() bool ctCustomPropertyDialog::ShowToolTips() { - return TRUE; + return true; } /*! @@ -192,25 +198,26 @@ bool ctCustomPropertyDialog::ShowToolTips() void ctCustomPropertyDialog::OnUpdatePropertyChoices( wxUpdateUIEvent& event ) { - wxChoice* choice = (wxChoice* ) FindWindow(ID_CUSTOMPROPERTYTYPE); - event.Enable( choice->GetSelection() > -1 && choice->GetStringSelection() == wxT("choice") ); + if(m_customPrototype) + event.Enable( m_customPrototype->GetSelection() > -1 && m_customPrototype->GetStringSelection() == wxT("choice") ); } /*! * Event handler for ID_PROPERTY_CHOICE_ADD */ -void ctCustomPropertyDialog::OnPropertyChoiceAdd( wxCommandEvent& event ) +void ctCustomPropertyDialog::OnPropertyChoiceAdd( wxCommandEvent& WXUNUSED(event) ) { - wxChoice* choice = (wxChoice* ) FindWindow(ID_CUSTOMPROPERTYTYPE); - if ( choice->GetSelection() > -1 && choice->GetStringSelection() == wxT("choice") ) + if(m_customPrototype) { - wxString str = wxGetTextFromUser(_T("New choice"), _("Add choice")); - if (!str.IsEmpty()) + if ( m_customPropertyEditorType->GetSelection() > -1 && m_customPropertyEditorType->GetStringSelection() == wxT("choice") ) { - wxListBox* listBox = (wxListBox* ) FindWindow(ID_PROPERTY_CHOICES); - listBox->Append(str); - m_choices.Add(str); + wxString str = wxGetTextFromUser(_T("New choice"), _("Add choice")); + if (!str.empty() && m_propertyChoices) + { + m_propertyChoices->Append(str); + m_choices.Add(str); + } } } } @@ -221,22 +228,21 @@ void ctCustomPropertyDialog::OnPropertyChoiceAdd( wxCommandEvent& event ) void ctCustomPropertyDialog::OnUpdatePropertyChoiceAdd( wxUpdateUIEvent& event ) { - wxChoice* choice = (wxChoice* ) FindWindow(ID_CUSTOMPROPERTYEDITORTYPE); - event.Enable( choice->GetSelection() > -1 && choice->GetStringSelection() == wxT("choice") ); + if(m_customPropertyEditorType) + event.Enable( m_customPropertyEditorType->GetSelection() > -1 && + m_customPropertyEditorType->GetStringSelection() == wxT("choice") ); } /*! * Event handler for ID_PROPERTY_CHOICE_REMOVE */ -void ctCustomPropertyDialog::OnPropertyChoiceRemove( wxCommandEvent& event ) +void ctCustomPropertyDialog::OnPropertyChoiceRemove( wxCommandEvent& WXUNUSED(event) ) { - wxChoice* choice = (wxChoice* ) FindWindow(ID_CUSTOMPROPERTYEDITORTYPE); - wxListBox* listBox = (wxListBox* ) FindWindow(ID_PROPERTY_CHOICES); - if (listBox->GetSelection() > -1) + if (m_propertyChoices && m_propertyChoices->GetSelection() > -1) { - listBox->Delete(listBox->GetSelection()); - m_choices.Remove(listBox->GetSelection()); + m_propertyChoices->Delete(m_propertyChoices->GetSelection()); + m_choices.RemoveAt(m_propertyChoices->GetSelection()); } } @@ -246,16 +252,16 @@ void ctCustomPropertyDialog::OnPropertyChoiceRemove( wxCommandEvent& event ) void ctCustomPropertyDialog::OnUpdatePropertyChoiceRemove( wxUpdateUIEvent& event ) { - wxChoice* choice = (wxChoice* ) FindWindow(ID_CUSTOMPROPERTYEDITORTYPE); - wxListBox* listBox = (wxListBox* ) FindWindow(ID_PROPERTY_CHOICES); - event.Enable( choice->GetSelection() > -1 && choice->GetStringSelection() == wxT("choice") && - listBox->GetSelection() > -1 ); + if (m_customPropertyEditorType && m_propertyChoices) + event.Enable( m_customPropertyEditorType->GetSelection() > -1 && + m_customPropertyEditorType->GetStringSelection() == wxT("choice") && + m_propertyChoices->GetSelection() > -1 ); } void ctCustomPropertyDialog::SetChoices(const wxArrayString& choices) { - wxListBox* listBox = (wxListBox* ) FindWindow(ID_PROPERTY_CHOICES); size_t i, len = choices.GetCount(); - for (i = 0; i < len; i++) - listBox->Append(m_choices[i]); + if (m_propertyChoices) + for (i = 0; i < len; i++) + m_propertyChoices->Append(m_choices[i]); }