#ifndef _WX_COLLAPSABLE_PANE_H_GENERIC_
#define _WX_COLLAPSABLE_PANE_H_GENERIC_
-#include "wx/button.h"
-
-
-// the ID of the wxButton used to collapse/expand the panel
-#define wxCP_BUTTON_ID 12356
-
-// the number of pixels to leave between the button and the static line and
-// between the button and the pane
-#define wxCP_MARGIN 10
-
// forward declared
+class WXDLLEXPORT wxButton;
class WXDLLEXPORT wxStaticLine;
// class name
extern WXDLLEXPORT_DATA(const wxChar) wxGenericCollapsiblePaneNameStr[];
-
// ----------------------------------------------------------------------------
// wxGenericCollapsiblePane
// ----------------------------------------------------------------------------
const wxString& name = wxGenericCollapsiblePaneNameStr);
-public: // public API
+ // public wxCollapsiblePane API
+ virtual void Collapse(bool collapse = true);
+ virtual void SetLabel(const wxString &label);
- void Collapse(bool collapse = true);
- void SetLabel(const wxString &label);
-
- bool IsCollapsed() const
+ virtual bool IsCollapsed() const
{ return m_pPane==NULL || !m_pPane->IsShown(); }
- wxWindow *GetPane() const
+ virtual wxWindow *GetPane() const
{ return m_pPane; }
- wxString GetLabel() const
+ virtual wxString GetLabel() const
{ return m_strLabel; }
- wxWindow *GetTopLevelParent();
-
-public: // event handlers
-
- void OnButton(wxCommandEvent &ev);
- void OnSize(wxSizeEvent &ev);
-
-protected: // internal utils
+protected:
+ // overridden methods
+ virtual wxSize DoGetBestSize() const;
+ // internal helpers
void LayoutChildren();
wxString GetBtnLabel() const;
- virtual wxSize DoGetBestSize() const;
-protected:
+ // child controls
wxButton *m_pButton;
wxStaticLine *m_pStatLine;
wxWindow *m_pPane;
wxString m_strLabel;
private:
+ // event handlers
+ void OnButton(wxCommandEvent &ev);
+ void OnSize(wxSizeEvent &ev);
+
DECLARE_DYNAMIC_CLASS(wxGenericCollapsiblePane)
DECLARE_EVENT_TABLE()
};
-#endif
- // _WX_COLLAPSABLE_PANE_H_GENERIC_
+#endif // _WX_COLLAPSABLE_PANE_H_GENERIC_
+
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
+
+#ifndef WX_PRECOMP
+ #include "wx/button.h"
+#endif // !WX_PRECOMP
+
#include "wx/collpane.h"
#include "wx/statline.h"
+// ----------------------------------------------------------------------------
+// constants
+// ----------------------------------------------------------------------------
+
+// the number of pixels to leave between the button and the static line and
+// between the button and the pane
+#define wxCP_MARGIN 10
+
// ============================================================================
// implementation
// ============================================================================
IMPLEMENT_DYNAMIC_CLASS(wxCollapsiblePaneEvent, wxCommandEvent)
BEGIN_EVENT_TABLE(wxGenericCollapsiblePane, wxControl)
- EVT_BUTTON(wxCP_BUTTON_ID, wxGenericCollapsiblePane::OnButton)
+ EVT_BUTTON(wxID_ANY, wxGenericCollapsiblePane::OnButton)
EVT_SIZE(wxGenericCollapsiblePane::OnSize)
END_EVENT_TABLE()
-bool wxGenericCollapsiblePane::Create( wxWindow *parent, wxWindowID id,
- const wxString& label,
- const wxPoint& pos,
- const wxSize& size,
- long style,
- const wxValidator& val,
- const wxString& name)
+bool wxGenericCollapsiblePane::Create(wxWindow *parent,
+ wxWindowID id,
+ const wxString& label,
+ const wxPoint& pos,
+ const wxSize& size,
+ long style,
+ const wxValidator& val,
+ const wxString& name)
{
if ( !wxControl::Create(parent, id, pos, size, style, val, name) )
return false;
m_strLabel = label;
// create children; their size & position is set in OnSize()
- m_pButton = new wxButton(this, wxCP_BUTTON_ID, GetBtnLabel(), wxPoint(0, 0),
+ m_pButton = new wxButton(this, wxID_ANY, GetBtnLabel(), wxPoint(0, 0),
wxDefaultSize, wxBU_EXACTFIT);
m_pStatLine = new wxStaticLine(this, wxID_ANY);
m_pPane = new wxWindow(this, wxID_ANY, wxDefaultPosition, wxDefaultSize,
SetMinSize(sz);
SetSize(sz);
- wxWindow *top = GetTopLevelParent();
+ wxWindow *top = wxGetTopLevelParent(this);
if (top)
{
// we've changed our size, thus our top level parent needs to relayout
}
}
-wxWindow *wxGenericCollapsiblePane::GetTopLevelParent()
-{
- wxWindow *parent = GetParent();
- while (parent && !parent->IsTopLevel())
- parent = parent->GetParent();
-
- return parent;
-}
-
void wxGenericCollapsiblePane::SetLabel(const wxString &label)
{
m_strLabel = label;
// wxGenericCollapsiblePane - event handlers
//-----------------------------------------------------------------------------
-void wxGenericCollapsiblePane::OnButton(wxCommandEvent &WXUNUSED(event))
+void wxGenericCollapsiblePane::OnButton(wxCommandEvent& event)
{
+ if ( event.GetEventObject() != m_pButton )
+ {
+ event.Skip();
+ return;
+ }
+
Collapse(!IsCollapsed());
// this change was generated by the user - send the event