X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7ae712f56622968fd7b23d14d22e076e3cb4c65a..c017416682938c39547836051c0fad74db45e8a0:/include/wx/datectrl.h diff --git a/include/wx/datectrl.h b/include/wx/datectrl.h index 834ec21a01..3bf46761c0 100644 --- a/include/wx/datectrl.h +++ b/include/wx/datectrl.h @@ -12,10 +12,13 @@ #ifndef _WX_DATECTRL_H_ #define _WX_DATECTRL_H_ -#include "wx/control.h" // the base class -#include "wx/datetime.h" +#include "wx/defs.h" -#define wxDatePickerCtrlNameStr _T("datectrl") +#if wxUSE_DATEPICKCTRL + +#include "wx/datetimectrl.h" // the base class + +#define wxDatePickerCtrlNameStr wxT("datectrl") // wxDatePickerCtrl styles enum @@ -31,14 +34,18 @@ enum // always show century in the default date display (otherwise it depends on // the system date format which may include the century or not) - wxDP_SHOWCENTURY = 4 + wxDP_SHOWCENTURY = 4, + + // allow not having any valid date in the control (by default it always has + // some date, today initially if no valid date specified in ctor) + wxDP_ALLOWNONE = 8 }; // ---------------------------------------------------------------------------- // wxDatePickerCtrl: allow the user to enter the date // ---------------------------------------------------------------------------- -class WXDLLIMPEXP_ADV wxDatePickerCtrlBase : public wxControl +class WXDLLIMPEXP_ADV wxDatePickerCtrlBase : public wxDateTimePickerCtrl { public: /* @@ -55,19 +62,28 @@ public: const wxString& name = wxDatePickerCtrlNameStr); */ - // set/get the date - virtual void SetValue(const wxDateTime& dt) = 0; - virtual wxDateTime GetValue() const = 0; + /* + We inherit the methods to set/get the date from the base class. + + virtual void SetValue(const wxDateTime& dt) = 0; + virtual wxDateTime GetValue() const = 0; + */ - // set/get the allowed valid range for the dates, if either/both of them - // are invalid, there is no corresponding limit and if neither is set - // GetRange() returns false + // And add methods to set/get the allowed valid range for the dates. If + // either/both of them are invalid, there is no corresponding limit and if + // neither is set, GetRange() returns false. virtual void SetRange(const wxDateTime& dt1, const wxDateTime& dt2) = 0; virtual bool GetRange(wxDateTime *dt1, wxDateTime *dt2) const = 0; }; #if defined(__WXMSW__) && !defined(__WXUNIVERSAL__) #include "wx/msw/datectrl.h" + + #define wxHAS_NATIVE_DATEPICKCTRL +#elif defined(__WXOSX_COCOA__) && !defined(__WXUNIVERSAL__) + #include "wx/osx/datectrl.h" + + #define wxHAS_NATIVE_DATEPICKCTRL #else #include "wx/generic/datectrl.h" @@ -81,16 +97,18 @@ public: const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxDP_DEFAULT | wxDP_SHOWCENTURY, + const wxValidator& validator = wxDefaultValidator, const wxString& name = wxDatePickerCtrlNameStr) - : wxDatePickerCtrlGeneric(parent, id, date, pos, size, style, name) + : wxDatePickerCtrlGeneric(parent, id, date, pos, size, style, validator, name) { } private: - DECLARE_DYNAMIC_CLASS(wxDatePickerCtrl) - DECLARE_NO_COPY_CLASS(wxDatePickerCtrl) + DECLARE_DYNAMIC_CLASS_NO_COPY(wxDatePickerCtrl) }; #endif +#endif // wxUSE_DATEPICKCTRL + #endif // _WX_DATECTRL_H_