// Created: 29.12.99
// RCS-ID: $Id$
// Copyright: (c) 1999 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
-// Licence: wxWindows license
+// Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(__APPLE__)
#pragma interface "calctrl.h"
#endif
#define _WX_GENERIC_CALCTRL_H
#include "wx/control.h" // the base class
-
-#include "wx/spinctrl.h" // for wxSpinEvent
+#include "wx/dcclient.h" // for wxPaintDC
class WXDLLEXPORT wxComboBox;
class WXDLLEXPORT wxStaticText;
+class WXDLLEXPORT wxSpinCtrl;
#define wxCalendarNameStr _T("CalendarCtrl")
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
long style = wxCAL_SHOW_HOLIDAYS | wxWANTS_CHARS,
- const wxString& name = wxCalendarNameStr)
- {
- Init();
-
- (void)Create(parent, id, date, pos, size, style, name);
- }
+ const wxString& name = wxCalendarNameStr);
bool Create(wxWindow *parent,
wxWindowID id,
virtual ~wxCalendarCtrl();
+ virtual bool Destroy();
+
// set/get the current date
// ------------------------
const wxDateTime& GetUpperDateLimit() const { return m_highdate; }
bool SetDateRange(const wxDateTime& lowerdate = wxDefaultDateTime, const wxDateTime& upperdate = wxDefaultDateTime);
-
+
// calendar mode
// -------------
void OnDClick(wxMouseEvent& event);
void OnChar(wxKeyEvent& event);
void OnMonthChange(wxCommandEvent& event);
- void OnYearChange(wxSpinEvent& event);
+ void OnYearChange(wxCommandEvent& event);
// override some base class virtuals
virtual wxSize DoGetBestSize() const;
// is this date in the given range?
bool IsDateInRange(const wxDateTime& date) const;
-
+
// range helpers
bool ChangeYear(wxDateTime* target) const;
bool ChangeMonth(wxDateTime* target) const;
wxControl *GetYearControl() const;
// OnPaint helper-methods
-
+
// Highlight the [fromdate : todate] range using pen and brush
void HighlightRange(wxPaintDC* dc, const wxDateTime& fromdate, const wxDateTime& todate, wxPen* pen, wxBrush* brush);
-
+
// Get the "coordinates" for the date relative to the month currently displayed.
// using (day, week): upper left coord is (1, 1), lower right coord is (7, 6)
// if the date isn't visible (-1, -1) is put in (day, week) and false is returned
m_rowOffset;
wxRect m_leftArrowRect,
- m_rightArrowRect;
+ m_rightArrowRect;
// the week day names
wxString m_weekdays[7];
+ // TRUE if SetDate() is being called as the result of changing the year in
+ // the year control
+ bool m_userChangedYear;
+
DECLARE_DYNAMIC_CLASS(wxCalendarCtrl)
DECLARE_EVENT_TABLE()
+ DECLARE_NO_COPY_CLASS(wxCalendarCtrl)
};
#endif // _WX_GENERIC_CALCTRL_H