#define _WX_COLLAPSABLE_PANE_H_GENERIC_
// forward declared
-class WXDLLEXPORT wxButton;
-class WXDLLEXPORT wxStaticLine;
-
-// class name
-extern WXDLLEXPORT_DATA(const wxChar) wxGenericCollapsiblePaneNameStr[];
+class WXDLLIMPEXP_FWD_CORE wxButton;
+class WXDLLIMPEXP_FWD_CORE wxStaticLine;
+#if defined( __WXMAC__ ) && !defined(__WXUNIVERSAL__)
+class WXDLLIMPEXP_FWD_CORE wxDisclosureTriangle;
+#endif
+#include "wx/containr.h"
// ----------------------------------------------------------------------------
// wxGenericCollapsiblePane
// ----------------------------------------------------------------------------
-class WXDLLEXPORT wxGenericCollapsiblePane : public wxCollapsiblePaneBase
+class WXDLLIMPEXP_CORE wxGenericCollapsiblePane :
+ public wxNavigationEnabled<wxCollapsiblePaneBase>
{
public:
wxGenericCollapsiblePane() { Init(); }
const wxString& label,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
- long style = wxTAB_TRAVERSAL | wxNO_BORDER,
+ long style = wxCP_DEFAULT_STYLE,
const wxValidator& val = wxDefaultValidator,
- const wxString& name = wxGenericCollapsiblePaneNameStr)
+ const wxString& name = wxCollapsiblePaneNameStr)
{
Init();
Create(parent, winid, label, pos, size, style, val, name);
}
- void Init()
- {
- m_pButton = NULL;
- m_pStatLine = NULL;
- m_pPane = NULL;
- }
+ virtual ~wxGenericCollapsiblePane();
bool Create(wxWindow *parent,
wxWindowID winid,
const wxString& label,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
- long style = wxTAB_TRAVERSAL | wxNO_BORDER,
+ long style = wxCP_DEFAULT_STYLE,
const wxValidator& val = wxDefaultValidator,
- const wxString& name = wxGenericCollapsiblePaneNameStr);
-
+ const wxString& name = wxCollapsiblePaneNameStr);
// public wxCollapsiblePane API
virtual void Collapse(bool collapse = true);
virtual wxString GetLabel() const
{ return m_strLabel; }
+ virtual bool Layout();
+
+
+ // for the generic collapsible pane only:
+ wxControl* GetControlWidget() const
+ { return (wxControl*)m_pButton; }
// implementation only, don't use
void OnStateChange(const wxSize& sizeNew);
-protected:
+protected:
// overridden methods
virtual wxSize DoGetBestSize() const;
- // internal helpers
- void LayoutChildren();
-
wxString GetBtnLabel() const;
-
+ int GetBorder() const;
// child controls
+#if defined( __WXMAC__ ) && !defined(__WXUNIVERSAL__)
+ wxDisclosureTriangle *m_pButton;
+#else
wxButton *m_pButton;
- wxStaticLine *m_pStatLine;
+#endif
+ wxStaticLine *m_pStaticLine;
wxWindow *m_pPane;
+ wxSizer *m_sz;
// the button label without ">>" or "<<"
wxString m_strLabel;
private:
+ void Init();
+
// event handlers
void OnButton(wxCommandEvent &ev);
void OnSize(wxSizeEvent &ev);
DECLARE_EVENT_TABLE()
};
-
#endif // _WX_COLLAPSABLE_PANE_H_GENERIC_
-