#ifndef _WX_GENERIC_DATECTRL_H_
#define _WX_GENERIC_DATECTRL_H_
-class WXDLLIMPEXP_ADV wxCalendarDateAttr;
-class WXDLLIMPEXP_ADV wxCalendarCtrl;
-class WXDLLIMPEXP_ADV wxCalendarEvent;
-class WXDLLIMPEXP_ADV wxPopupWindow;
+#include "wx/calctrl.h"
+#include "wx/combo.h"
-class WXDLLIMPEXP_ADV wxDatePickerCtrl : public wxDatePickerCtrlBase
+class WXDLLIMPEXP_FWD_ADV wxCalendarComboPopup;
+
+class WXDLLIMPEXP_ADV wxDatePickerCtrlGeneric : public wxDatePickerCtrlBase
{
public:
// creating the control
- wxDatePickerCtrl() { Init(); }
- wxDatePickerCtrl(wxWindow *parent,
- wxWindowID id,
- const wxDateTime& date = wxDefaultDateTime,
- const wxPoint& pos = wxDefaultPosition,
- const wxSize& size = wxDefaultSize,
- long style = wxDP_DEFAULT | wxDP_SHOWCENTURY,
- const wxString& name = wxDatePickerCtrlNameStr);
+ wxDatePickerCtrlGeneric() { Init(); }
+ virtual ~wxDatePickerCtrlGeneric();
+ wxDatePickerCtrlGeneric(wxWindow *parent,
+ wxWindowID id,
+ const wxDateTime& date = wxDefaultDateTime,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxDP_DEFAULT | wxDP_SHOWCENTURY,
+ const wxValidator& validator = wxDefaultValidator,
+ const wxString& name = wxDatePickerCtrlNameStr)
+ {
+ Init();
+
+ (void)Create(parent, id, date, pos, size, style, validator, name);
+ }
bool Create(wxWindow *parent,
wxWindowID id,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
long style = wxDP_DEFAULT | wxDP_SHOWCENTURY,
+ const wxValidator& validator = wxDefaultValidator,
const wxString& name = wxDatePickerCtrlNameStr);
// wxDatePickerCtrl methods
const wxDateTime& upperdate = wxDefaultDateTime);
// extra methods available only in this (generic) implementation
- bool SetFormat(const wxChar *fmt);
- wxCalendarCtrl *GetCalendar() const { return m_cal; }
+ bool SetFormat(const wxString& fmt);
+ wxCalendarCtrl *GetCalendar() const;
// implementation only from now on
// overridden base class methods
virtual bool Destroy();
- virtual bool Enable(bool enable = TRUE);
- virtual bool Show(bool show = TRUE);
-
protected:
virtual wxSize DoGetBestSize() const;
- virtual void DoMoveWindow(int x, int y, int width, int height);
private:
- wxPopupWindow *m_popup;
- wxTextCtrl *m_txt;
- wxCalendarCtrl *m_cal;
- wxButton *m_btn;
- wxString m_format;
+ void Init();
- bool m_dropped, m_ignoreDrop;
+ void OnText(wxCommandEvent &event);
+ void OnSize(wxSizeEvent& event);
+ void OnFocus(wxFocusEvent& event);
+
+ wxComboCtrl* m_combo;
+ wxCalendarComboPopup* m_popup;
- void Init();
- void DropDown(bool down=true);
-
- void OnText(wxCommandEvent &ev);
- void OnEditKey(wxKeyEvent & event);
- void OnCalKey(wxKeyEvent & event);
- void OnClick(wxCommandEvent &ev);
- void OnSelChange(wxCalendarEvent &ev);
- void OnSetFocus(wxFocusEvent &ev);
- void OnKillFocus(wxFocusEvent &ev);
- void OnChildSetFocus(wxChildFocusEvent &ev);
-
- DECLARE_DYNAMIC_CLASS(wxDatePickerCtrl)
DECLARE_EVENT_TABLE()
- DECLARE_NO_COPY_CLASS(wxDatePickerCtrl)
+ wxDECLARE_NO_COPY_CLASS(wxDatePickerCtrlGeneric);
};
#endif // _WX_GENERIC_DATECTRL_H_