]> git.saurik.com Git - wxWidgets.git/blame - include/wx/calctrl.h
define wxHAS_ATOMIC_OPS only if native implementation is available; use fewer loop...
[wxWidgets.git] / include / wx / calctrl.h
CommitLineData
9d9b7755
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/calctrl.h
3// Purpose: date-picker control
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 29.12.99
7// RCS-ID: $Id$
8// Copyright: (c) 1999 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
65571936 9// Licence: wxWindows licence
9d9b7755
VZ
10///////////////////////////////////////////////////////////////////////////////
11
1e6feb95
VZ
12#ifndef _WX_CALCTRL_H_
13#define _WX_CALCTRL_H_
14
15#include "wx/defs.h"
16
17#if wxUSE_CALENDARCTRL
9d9b7755 18
feb72429 19#include "wx/dateevt.h"
b1ef887a
VS
20#include "wx/colour.h"
21#include "wx/font.h"
628e155d 22#include "wx/control.h"
4f6aed9c 23
37df1f33
VZ
24// ----------------------------------------------------------------------------
25// wxCalendarCtrl flags
26// ----------------------------------------------------------------------------
27
28enum
29{
30 // show Sunday as the first day of the week (default)
31 wxCAL_SUNDAY_FIRST = 0x0000,
32
33 // show Monder as the first day of the week
34 wxCAL_MONDAY_FIRST = 0x0001,
35
36 // highlight holidays
37 wxCAL_SHOW_HOLIDAYS = 0x0002,
38
39 // disable the year change control, show only the month change one
628e155d 40 // deprecated
37df1f33
VZ
41 wxCAL_NO_YEAR_CHANGE = 0x0004,
42
43 // don't allow changing neither month nor year (implies
44 // wxCAL_NO_YEAR_CHANGE)
45 wxCAL_NO_MONTH_CHANGE = 0x000c,
46
47 // use MS-style month-selection instead of combo-spin combination
48 wxCAL_SEQUENTIAL_MONTH_SELECTION = 0x0010,
49
50 // show the neighbouring weeks in the previous and next month
7b0ccb8a
RR
51 wxCAL_SHOW_SURROUNDING_WEEKS = 0x0020,
52
53 // show week numbers on the left side of the calendar.
54 wxCAL_SHOW_WEEK_NUMBERS = 0x0040
37df1f33
VZ
55};
56
0185cd09
VZ
57// ----------------------------------------------------------------------------
58// constants
59// ----------------------------------------------------------------------------
60
61// return values for the HitTest() method
62enum wxCalendarHitTestResult
63{
64 wxCAL_HITTEST_NOWHERE, // outside of anything
65 wxCAL_HITTEST_HEADER, // on the header (weekdays)
37df1f33
VZ
66 wxCAL_HITTEST_DAY, // on a day in the calendar
67 wxCAL_HITTEST_INCMONTH,
68 wxCAL_HITTEST_DECMONTH,
69 wxCAL_HITTEST_SURROUNDING_WEEK
0185cd09
VZ
70};
71
4f6aed9c
VZ
72// border types for a date
73enum wxCalendarDateBorder
74{
75 wxCAL_BORDER_NONE, // no border (default)
76 wxCAL_BORDER_SQUARE, // a rectangular border
77 wxCAL_BORDER_ROUND // a round border
78};
79
0185cd09 80// ----------------------------------------------------------------------------
4f6aed9c 81// wxCalendarDateAttr: custom attributes for a calendar date
0185cd09
VZ
82// ----------------------------------------------------------------------------
83
12f190b0 84class WXDLLIMPEXP_ADV wxCalendarDateAttr
4f6aed9c
VZ
85{
86public:
87 // ctors
628e155d 88 wxCalendarDateAttr(const wxColour& colText = wxNullColour,
4f6aed9c
VZ
89 const wxColour& colBack = wxNullColour,
90 const wxColour& colBorder = wxNullColour,
91 const wxFont& font = wxNullFont,
92 wxCalendarDateBorder border = wxCAL_BORDER_NONE)
93 : m_colText(colText), m_colBack(colBack),
94 m_colBorder(colBorder), m_font(font)
95 {
96 Init(border);
97 }
98 wxCalendarDateAttr(wxCalendarDateBorder border,
99 const wxColour& colBorder = wxNullColour)
100 : m_colBorder(colBorder)
101 {
102 Init(border);
103 }
104
105 // setters
106 void SetTextColour(const wxColour& colText) { m_colText = colText; }
107 void SetBackgroundColour(const wxColour& colBack) { m_colBack = colBack; }
108 void SetBorderColour(const wxColour& col) { m_colBorder = col; }
109 void SetFont(const wxFont& font) { m_font = font; }
110 void SetBorder(wxCalendarDateBorder border) { m_border = border; }
111 void SetHoliday(bool holiday) { m_holiday = holiday; }
112
113 // accessors
114 bool HasTextColour() const { return m_colText.Ok(); }
115 bool HasBackgroundColour() const { return m_colBack.Ok(); }
116 bool HasBorderColour() const { return m_colBorder.Ok(); }
117 bool HasFont() const { return m_font.Ok(); }
118 bool HasBorder() const { return m_border != wxCAL_BORDER_NONE; }
119
120 bool IsHoliday() const { return m_holiday; }
121
122 const wxColour& GetTextColour() const { return m_colText; }
123 const wxColour& GetBackgroundColour() const { return m_colBack; }
124 const wxColour& GetBorderColour() const { return m_colBorder; }
125 const wxFont& GetFont() const { return m_font; }
126 wxCalendarDateBorder GetBorder() const { return m_border; }
628e155d
VZ
127
128 // get or change the "mark" attribute, i.e. the one used for the items
129 // marked with wxCalendarCtrl::Mark()
130 static const wxCalendarDateAttr& GetMark() { return m_mark; }
131 static void SetMark(wxCalendarDateAttr const& m) { m_mark = m; }
132
006713a2 133protected:
006713a2
DW
134 void Init(wxCalendarDateBorder border = wxCAL_BORDER_NONE)
135 {
136 m_border = border;
68379eaf 137 m_holiday = false;
006713a2 138 }
628e155d 139
4f6aed9c 140private:
628e155d
VZ
141 static wxCalendarDateAttr m_mark;
142
4f6aed9c
VZ
143 wxColour m_colText,
144 m_colBack,
145 m_colBorder;
146 wxFont m_font;
147 wxCalendarDateBorder m_border;
148 bool m_holiday;
149};
9d9b7755
VZ
150
151// ----------------------------------------------------------------------------
152// wxCalendarCtrl events
153// ----------------------------------------------------------------------------
154
b5dbe15d 155class WXDLLIMPEXP_FWD_ADV wxCalendarCtrl;
4f6aed9c 156
feb72429 157class WXDLLIMPEXP_ADV wxCalendarEvent : public wxDateEvent
9d9b7755
VZ
158{
159public:
628e155d
VZ
160 wxCalendarEvent() : m_wday(wxDateTime::Inv_WeekDay) { }
161 wxCalendarEvent(wxWindow *win, const wxDateTime& dt, wxEventType type)
162 : wxDateEvent(win, dt, type),
163 m_wday(wxDateTime::Inv_WeekDay)
164 {
165 }
9d9b7755 166
12ac619f 167 void SetWeekDay(const wxDateTime::WeekDay wd) { m_wday = wd; }
0185cd09
VZ
168 wxDateTime::WeekDay GetWeekDay() const { return m_wday; }
169
9d9b7755 170private:
0185cd09 171 wxDateTime::WeekDay m_wday;
f6bcfd97 172
fc7a2a60 173 DECLARE_DYNAMIC_CLASS_NO_COPY(wxCalendarEvent)
9d9b7755
VZ
174};
175
628e155d
VZ
176// ----------------------------------------------------------------------------
177// wxCalendarCtrlBase
178// ----------------------------------------------------------------------------
179
180class WXDLLIMPEXP_ADV wxCalendarCtrlBase : public wxControl
181{
182public:
183 // do we allow changing the month/year?
184 bool AllowMonthChange() const { return !HasFlag(wxCAL_NO_MONTH_CHANGE); }
185
186 // get/set the current date
187 virtual wxDateTime GetDate() const = 0;
188 virtual bool SetDate(const wxDateTime& date) = 0;
189
190
51317496
VZ
191 // restricting the dates shown by the control to the specified range: only
192 // implemented in the generic and MSW versions for now
193
194 // if either date is set, the corresponding limit will be enforced and true
195 // returned; if none are set, the existing restrictions are removed and
196 // false is returned
197 virtual bool
198 SetDateRange(const wxDateTime& WXUNUSED(lowerdate) = wxDefaultDateTime,
199 const wxDateTime& WXUNUSED(upperdate) = wxDefaultDateTime)
200 {
201 return false;
202 }
203
204 // retrieves the limits currently in use (wxDefaultDateTime if none) in the
205 // provided pointers (which may be NULL) and returns true if there are any
206 // limits or false if none
207 virtual bool
208 GetDateRange(wxDateTime *lowerdate, wxDateTime *upperdate) const
209 {
210 if ( lowerdate )
211 *lowerdate = wxDefaultDateTime;
212 if ( upperdate )
213 *upperdate = wxDefaultDateTime;
214 return false;
215 }
216
628e155d
VZ
217 // returns one of wxCAL_HITTEST_XXX constants and fills either date or wd
218 // with the corresponding value (none for NOWHERE, the date for DAY and wd
219 // for HEADER)
220 //
221 // notice that this is not implemented in all versions
222 virtual wxCalendarHitTestResult
223 HitTest(const wxPoint& WXUNUSED(pos),
224 wxDateTime* WXUNUSED(date) = NULL,
225 wxDateTime::WeekDay* WXUNUSED(wd) = NULL)
226 {
227 return wxCAL_HITTEST_NOWHERE;
228 }
229
230 // allow or disable changing the current month (and year), return true if
231 // the value of this option really changed or false if it was already set
232 // to the required value
233 //
234 // NB: we provide implementation for this pure virtual function, derived
235 // classes should call it
236 virtual bool EnableMonthChange(bool enable) = 0;
237
238
239 // an item without custom attributes is drawn with the default colours and
240 // font and without border, setting custom attributes allows to modify this
241 //
242 // the day parameter should be in 1..31 range, for days 29, 30, 31 the
243 // corresponding attribute is just unused if there is no such day in the
244 // current month
245 //
246 // notice that currently arbitrary attributes are supported only in the
247 // generic version, the native controls only support Mark() which assigns
248 // some special appearance (which can be customized using SetMark() for the
249 // generic version) to the given day
250
251 virtual void Mark(size_t day, bool mark) = 0;
252
253 virtual wxCalendarDateAttr *GetAttr(size_t WXUNUSED(day)) const
254 { return NULL; }
255 virtual void SetAttr(size_t WXUNUSED(day), wxCalendarDateAttr *attr)
256 { delete attr; }
257 virtual void ResetAttr(size_t WXUNUSED(day)) { }
258
259
bf956fac
VZ
260 // holidays support
261 //
262 // currently all functions in this section are implemented in the generic
263 // version of the control only and are simply ignored by native ones
264
265 // equivalent to changing wxCAL_SHOW_HOLIDAYS flag but should be called
266 // instead of just changing it
267 virtual void EnableHolidayDisplay(bool WXUNUSED(display) = true) { }
268
269 // set/get the colours to use for holidays (if they're enabled)
270 virtual void SetHolidayColours(const wxColour& WXUNUSED(colFg),
271 const wxColour& WXUNUSED(colBg)) { }
272
273 virtual const wxColour& GetHolidayColourFg() const { return wxNullColour; }
274 virtual const wxColour& GetHolidayColourBg() const { return wxNullColour; }
275
276 // mark the given day of the current month as being a holiday
277 virtual void SetHoliday(size_t WXUNUSED(day)) { }
278
279
280 // customizing the colours of the controls
281 //
282 // most of the methods in this section are only implemented by the native
283 // version of the control and do nothing in the native ones
284
285 // set/get the colours to use for the display of the week day names at the
286 // top of the controls
287 virtual void SetHeaderColours(const wxColour& WXUNUSED(colFg),
288 const wxColour& WXUNUSED(colBg)) { }
289
290 virtual const wxColour& GetHeaderColourFg() const { return wxNullColour; }
291 virtual const wxColour& GetHeaderColourBg() const { return wxNullColour; }
292
293 // set/get the colours used for the currently selected date
294 virtual void SetHighlightColours(const wxColour& WXUNUSED(colFg),
295 const wxColour& WXUNUSED(colBg)) { }
296
297 virtual const wxColour& GetHighlightColourFg() const { return wxNullColour; }
298 virtual const wxColour& GetHighlightColourBg() const { return wxNullColour; }
299
300
628e155d
VZ
301 // implementation only from now on
302
b3ed7020 303 // generate the given calendar event, return true if it was processed
8354b47d
VZ
304 //
305 // NB: this is public because it's used from GTK+ callbacks
b3ed7020 306 bool GenerateEvent(wxEventType type)
628e155d
VZ
307 {
308 wxCalendarEvent event(this, GetDate(), type);
b3ed7020 309 return HandleWindowEvent(event);
628e155d 310 }
a4fcd589 311
8354b47d 312protected:
a4fcd589
VZ
313 // generate all the events for the selection change from dateOld to current
314 // date: SEL_CHANGED, PAGE_CHANGED if necessary and also one of (deprecated)
315 // YEAR/MONTH/DAY_CHANGED ones
316 void GenerateAllChangeEvents(const wxDateTime& dateOld);
628e155d
VZ
317};
318
4f6aed9c
VZ
319// ----------------------------------------------------------------------------
320// wxCalendarCtrl
321// ----------------------------------------------------------------------------
322
628e155d 323#define wxCalendarNameStr "CalendarCtrl"
4f6aed9c 324
51317496
VZ
325#ifndef __WXUNIVERSAL__
326 #if defined(__WXGTK20__)
327 #define wxHAS_NATIVE_CALENDARCTRL
328 #include "wx/gtk/calctrl.h"
329 #define wxCalendarCtrl wxGtkCalendarCtrl
330 #elif defined(__WXMSW__)
331 #define wxHAS_NATIVE_CALENDARCTRL
332 #include "wx/msw/calctrl.h"
333 #endif
334#endif // !__WXUNIVERSAL__
335
336#ifndef wxHAS_NATIVE_CALENDARCTRL
628e155d
VZ
337 #include "wx/generic/calctrlg.h"
338 #define wxCalendarCtrl wxGenericCalendarCtrl
339#endif
feb72429 340
4f6aed9c 341// ----------------------------------------------------------------------------
2e4df4bf 342// calendar event types and macros for handling them
4f6aed9c
VZ
343// ----------------------------------------------------------------------------
344
c058cafa 345extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_SEL_CHANGED;
628e155d
VZ
346extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_PAGE_CHANGED;
347extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_DOUBLECLICKED;
348extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_WEEKDAY_CLICKED;
349
350// deprecated events
c058cafa
VZ
351extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_DAY_CHANGED;
352extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_MONTH_CHANGED;
353extern WXDLLIMPEXP_ADV const wxEventType wxEVT_CALENDAR_YEAR_CHANGED;
2e4df4bf 354
457e6c54
JS
355typedef void (wxEvtHandler::*wxCalendarEventFunction)(wxCalendarEvent&);
356
7fa03f04 357#define wxCalendarEventHandler(func) \
8bc3ec1f 358 (wxObjectEventFunction)(wxEventFunction)wxStaticCastEvent(wxCalendarEventFunction, &func)
7fa03f04
VZ
359
360#define wx__DECLARE_CALEVT(evt, id, fn) \
361 wx__DECLARE_EVT1(wxEVT_CALENDAR_ ## evt, id, wxCalendarEventHandler(fn))
362
363#define EVT_CALENDAR(id, fn) wx__DECLARE_CALEVT(DOUBLECLICKED, id, fn)
364#define EVT_CALENDAR_SEL_CHANGED(id, fn) wx__DECLARE_CALEVT(SEL_CHANGED, id, fn)
628e155d
VZ
365#define EVT_CALENDAR_PAGE_CHANGED(id, fn) wx__DECLARE_CALEVT(PAGE_CHANGED, id, fn)
366#define EVT_CALENDAR_WEEKDAY_CLICKED(id, fn) wx__DECLARE_CALEVT(WEEKDAY_CLICKED, id, fn)
367
368// deprecated events
7fa03f04
VZ
369#define EVT_CALENDAR_DAY(id, fn) wx__DECLARE_CALEVT(DAY_CHANGED, id, fn)
370#define EVT_CALENDAR_MONTH(id, fn) wx__DECLARE_CALEVT(MONTH_CHANGED, id, fn)
371#define EVT_CALENDAR_YEAR(id, fn) wx__DECLARE_CALEVT(YEAR_CHANGED, id, fn)
9d9b7755 372
1e6feb95
VZ
373#endif // wxUSE_CALENDARCTRL
374
375#endif // _WX_CALCTRL_H_
376