]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/msw/calendar.py
Fixed missing focus problem.
[wxWidgets.git] / wxPython / src / msw / calendar.py
CommitLineData
f6bcfd97 1# This file was created automatically by SWIG.
d14a1e28
RD
2# Don't modify this file, modify the SWIG interface instead.
3
caef1a4d
RD
4"""
5Classes for an interactive Calendar control.
6"""
7
d14a1e28
RD
8import _calendar
9
d55e5bfc
RD
10import _misc
11import _core
12wx = _core
c24da6d6 13__docfilter__ = wx.__DocFilter(globals())
d14a1e28
RD
14CAL_SUNDAY_FIRST = _calendar.CAL_SUNDAY_FIRST
15CAL_MONDAY_FIRST = _calendar.CAL_MONDAY_FIRST
16CAL_SHOW_HOLIDAYS = _calendar.CAL_SHOW_HOLIDAYS
17CAL_NO_YEAR_CHANGE = _calendar.CAL_NO_YEAR_CHANGE
18CAL_NO_MONTH_CHANGE = _calendar.CAL_NO_MONTH_CHANGE
19CAL_SEQUENTIAL_MONTH_SELECTION = _calendar.CAL_SEQUENTIAL_MONTH_SELECTION
20CAL_SHOW_SURROUNDING_WEEKS = _calendar.CAL_SHOW_SURROUNDING_WEEKS
21CAL_HITTEST_NOWHERE = _calendar.CAL_HITTEST_NOWHERE
22CAL_HITTEST_HEADER = _calendar.CAL_HITTEST_HEADER
23CAL_HITTEST_DAY = _calendar.CAL_HITTEST_DAY
24CAL_HITTEST_INCMONTH = _calendar.CAL_HITTEST_INCMONTH
25CAL_HITTEST_DECMONTH = _calendar.CAL_HITTEST_DECMONTH
26CAL_HITTEST_SURROUNDING_WEEK = _calendar.CAL_HITTEST_SURROUNDING_WEEK
27CAL_BORDER_NONE = _calendar.CAL_BORDER_NONE
28CAL_BORDER_SQUARE = _calendar.CAL_BORDER_SQUARE
29CAL_BORDER_ROUND = _calendar.CAL_BORDER_ROUND
30class CalendarDateAttr(object):
98e665d3 31 """
c24da6d6
RD
32 A set of customization attributes for a calendar date, which can be
33 used to control the look of the Calendar object.
98e665d3 34 """
423f194a
RD
35 def __repr__(self):
36 return "<%s.%s; proxy of C++ wxCalendarDateAttr instance at %s>" % (self.__class__.__module__, self.__class__.__name__, self.this,)
d14a1e28 37 def __init__(self, *args, **kwargs):
41f1cec7 38 """
a95a7133 39 __init__(self, Colour colText=wxNullColour, Colour colBack=wxNullColour,
98e665d3 40 Colour colBorder=wxNullColour, Font font=wxNullFont,
d03fd34d 41 int border=CAL_BORDER_NONE) -> CalendarDateAttr
98e665d3
RD
42
43 Create a CalendarDateAttr.
41f1cec7 44 """
d14a1e28
RD
45 newobj = _calendar.new_CalendarDateAttr(*args, **kwargs)
46 self.this = newobj.this
eedf876b 47 self.thisown = 1
d14a1e28 48 del newobj.thisown
423f194a 49 def SetTextColour(*args, **kwargs):
a95a7133 50 """SetTextColour(self, Colour colText)"""
423f194a
RD
51 return _calendar.CalendarDateAttr_SetTextColour(*args, **kwargs)
52
53 def SetBackgroundColour(*args, **kwargs):
a95a7133 54 """SetBackgroundColour(self, Colour colBack)"""
423f194a
RD
55 return _calendar.CalendarDateAttr_SetBackgroundColour(*args, **kwargs)
56
57 def SetBorderColour(*args, **kwargs):
a95a7133 58 """SetBorderColour(self, Colour col)"""
423f194a
RD
59 return _calendar.CalendarDateAttr_SetBorderColour(*args, **kwargs)
60
61 def SetFont(*args, **kwargs):
a95a7133 62 """SetFont(self, Font font)"""
423f194a
RD
63 return _calendar.CalendarDateAttr_SetFont(*args, **kwargs)
64
65 def SetBorder(*args, **kwargs):
a95a7133 66 """SetBorder(self, int border)"""
423f194a
RD
67 return _calendar.CalendarDateAttr_SetBorder(*args, **kwargs)
68
69 def SetHoliday(*args, **kwargs):
a95a7133 70 """SetHoliday(self, bool holiday)"""
423f194a
RD
71 return _calendar.CalendarDateAttr_SetHoliday(*args, **kwargs)
72
73 def HasTextColour(*args, **kwargs):
a95a7133 74 """HasTextColour(self) -> bool"""
423f194a
RD
75 return _calendar.CalendarDateAttr_HasTextColour(*args, **kwargs)
76
77 def HasBackgroundColour(*args, **kwargs):
a95a7133 78 """HasBackgroundColour(self) -> bool"""
423f194a
RD
79 return _calendar.CalendarDateAttr_HasBackgroundColour(*args, **kwargs)
80
81 def HasBorderColour(*args, **kwargs):
a95a7133 82 """HasBorderColour(self) -> bool"""
423f194a
RD
83 return _calendar.CalendarDateAttr_HasBorderColour(*args, **kwargs)
84
85 def HasFont(*args, **kwargs):
a95a7133 86 """HasFont(self) -> bool"""
423f194a
RD
87 return _calendar.CalendarDateAttr_HasFont(*args, **kwargs)
88
89 def HasBorder(*args, **kwargs):
a95a7133 90 """HasBorder(self) -> bool"""
423f194a
RD
91 return _calendar.CalendarDateAttr_HasBorder(*args, **kwargs)
92
93 def IsHoliday(*args, **kwargs):
a95a7133 94 """IsHoliday(self) -> bool"""
423f194a
RD
95 return _calendar.CalendarDateAttr_IsHoliday(*args, **kwargs)
96
97 def GetTextColour(*args, **kwargs):
a95a7133 98 """GetTextColour(self) -> Colour"""
423f194a
RD
99 return _calendar.CalendarDateAttr_GetTextColour(*args, **kwargs)
100
101 def GetBackgroundColour(*args, **kwargs):
a95a7133 102 """GetBackgroundColour(self) -> Colour"""
423f194a
RD
103 return _calendar.CalendarDateAttr_GetBackgroundColour(*args, **kwargs)
104
105 def GetBorderColour(*args, **kwargs):
a95a7133 106 """GetBorderColour(self) -> Colour"""
423f194a
RD
107 return _calendar.CalendarDateAttr_GetBorderColour(*args, **kwargs)
108
109 def GetFont(*args, **kwargs):
a95a7133 110 """GetFont(self) -> Font"""
423f194a
RD
111 return _calendar.CalendarDateAttr_GetFont(*args, **kwargs)
112
113 def GetBorder(*args, **kwargs):
a95a7133 114 """GetBorder(self) -> int"""
423f194a
RD
115 return _calendar.CalendarDateAttr_GetBorder(*args, **kwargs)
116
eedf876b 117
d14a1e28
RD
118class CalendarDateAttrPtr(CalendarDateAttr):
119 def __init__(self, this):
120 self.this = this
121 if not hasattr(self,"thisown"): self.thisown = 0
122 self.__class__ = CalendarDateAttr
123_calendar.CalendarDateAttr_swigregister(CalendarDateAttrPtr)
eedf876b 124
d55e5bfc 125class CalendarEvent(_core.CommandEvent):
423f194a
RD
126 def __repr__(self):
127 return "<%s.%s; proxy of C++ wxCalendarEvent instance at %s>" % (self.__class__.__module__, self.__class__.__name__, self.this,)
d14a1e28 128 def __init__(self, *args, **kwargs):
a95a7133 129 """__init__(self, CalendarCtrl cal, wxEventType type) -> CalendarEvent"""
d14a1e28
RD
130 newobj = _calendar.new_CalendarEvent(*args, **kwargs)
131 self.this = newobj.this
f6bcfd97 132 self.thisown = 1
d14a1e28 133 del newobj.thisown
423f194a 134 def GetDate(*args, **kwargs):
a95a7133 135 """GetDate(self) -> DateTime"""
423f194a
RD
136 return _calendar.CalendarEvent_GetDate(*args, **kwargs)
137
9fd4be55 138 def SetDate(*args, **kwargs):
a95a7133 139 """SetDate(self, DateTime date)"""
9fd4be55
RD
140 return _calendar.CalendarEvent_SetDate(*args, **kwargs)
141
142 def SetWeekDay(*args, **kwargs):
a95a7133 143 """SetWeekDay(self, int wd)"""
9fd4be55
RD
144 return _calendar.CalendarEvent_SetWeekDay(*args, **kwargs)
145
423f194a 146 def GetWeekDay(*args, **kwargs):
a95a7133 147 """GetWeekDay(self) -> int"""
423f194a
RD
148 return _calendar.CalendarEvent_GetWeekDay(*args, **kwargs)
149
1fbf26be
RD
150 def PySetDate(self, date):
151 """takes datetime.datetime or datetime.date object"""
629e65c2 152 self.SetDate(_pydate2wxdate(date))
1fbf26be
RD
153
154 def PyGetDate(self):
155 """returns datetime.date object"""
629e65c2 156 return _wxdate2pydate(self.GetDate())
1fbf26be 157
f6bcfd97 158
d14a1e28
RD
159class CalendarEventPtr(CalendarEvent):
160 def __init__(self, this):
f6bcfd97 161 self.this = this
d14a1e28
RD
162 if not hasattr(self,"thisown"): self.thisown = 0
163 self.__class__ = CalendarEvent
164_calendar.CalendarEvent_swigregister(CalendarEventPtr)
165
166wxEVT_CALENDAR_DOUBLECLICKED = _calendar.wxEVT_CALENDAR_DOUBLECLICKED
167wxEVT_CALENDAR_SEL_CHANGED = _calendar.wxEVT_CALENDAR_SEL_CHANGED
168wxEVT_CALENDAR_DAY_CHANGED = _calendar.wxEVT_CALENDAR_DAY_CHANGED
169wxEVT_CALENDAR_MONTH_CHANGED = _calendar.wxEVT_CALENDAR_MONTH_CHANGED
170wxEVT_CALENDAR_YEAR_CHANGED = _calendar.wxEVT_CALENDAR_YEAR_CHANGED
171wxEVT_CALENDAR_WEEKDAY_CLICKED = _calendar.wxEVT_CALENDAR_WEEKDAY_CLICKED
172EVT_CALENDAR = wx.PyEventBinder( wxEVT_CALENDAR_DOUBLECLICKED, 1)
173EVT_CALENDAR_SEL_CHANGED = wx.PyEventBinder( wxEVT_CALENDAR_SEL_CHANGED, 1)
174EVT_CALENDAR_DAY = wx.PyEventBinder( wxEVT_CALENDAR_DAY_CHANGED, 1)
175EVT_CALENDAR_MONTH = wx.PyEventBinder( wxEVT_CALENDAR_MONTH_CHANGED, 1)
176EVT_CALENDAR_YEAR = wx.PyEventBinder( wxEVT_CALENDAR_YEAR_CHANGED, 1)
177EVT_CALENDAR_WEEKDAY_CLICKED = wx.PyEventBinder( wxEVT_CALENDAR_WEEKDAY_CLICKED, 1)
178
d55e5bfc 179class CalendarCtrl(_core.Control):
c24da6d6
RD
180 """
181 The calendar control allows the user to pick a date interactively.
182
183 The CalendarCtrl displays a window containing several parts: the
184 control to pick the month and the year at the top (either or both of
185 them may be disabled) and a month area below them which shows all the
186 days in the month. The user can move the current selection using the
187 keyboard and select the date (generating EVT_CALENDAR event) by
188 pressing <Return> or double clicking it.
189
190 It has advanced possibilities for the customization of its
191 display. All global settings (such as colours and fonts used) can, of
192 course, be changed. But also, the display style for each day in the
193 month can be set independently using CalendarDateAttr class.
194
195 An item without custom attributes is drawn with the default colours
196 and font and without border, but setting custom attributes with
197 SetAttr allows to modify its appearance. Just create a custom
198 attribute object and set it for the day you want to be displayed
199 specially A day may be marked as being a holiday, (even if it is not
200 recognized as one by wx.DateTime) by using the SetHoliday method.
201
202 As the attributes are specified for each day, they may change when the
203 month is changed, so you will often want to update them in an
204 EVT_CALENDAR_MONTH event handler.
c24da6d6 205 """
423f194a
RD
206 def __repr__(self):
207 return "<%s.%s; proxy of C++ wxCalendarCtrl instance at %s>" % (self.__class__.__module__, self.__class__.__name__, self.this,)
d14a1e28 208 def __init__(self, *args, **kwargs):
41f1cec7 209 """
a95a7133 210 __init__(self, Window parent, int id=-1, DateTime date=DefaultDateTime,
41f1cec7
RD
211 Point pos=DefaultPosition, Size size=DefaultSize,
212 long style=wxCAL_SHOW_HOLIDAYS|wxWANTS_CHARS,
d03fd34d 213 String name=CalendarNameStr) -> CalendarCtrl
98e665d3
RD
214
215 Create and show a calendar control.
41f1cec7 216 """
d14a1e28
RD
217 newobj = _calendar.new_CalendarCtrl(*args, **kwargs)
218 self.this = newobj.this
f6bcfd97 219 self.thisown = 1
d14a1e28 220 del newobj.thisown
0122b7e3 221 self._setOORInfo(self)
423f194a
RD
222
223 def Create(*args, **kwargs):
41f1cec7 224 """
a95a7133 225 Create(self, Window parent, int id, DateTime date=DefaultDateTime,
41f1cec7
RD
226 Point pos=DefaultPosition, Size size=DefaultSize,
227 long style=wxCAL_SHOW_HOLIDAYS|wxWANTS_CHARS,
d03fd34d 228 String name=CalendarNameStr) -> bool
98e665d3 229
c24da6d6
RD
230 Acutally create the GUI portion of the CalendarCtrl for 2-phase
231 creation.
41f1cec7 232 """
423f194a
RD
233 return _calendar.CalendarCtrl_Create(*args, **kwargs)
234
235 def SetDate(*args, **kwargs):
98e665d3 236 """
a95a7133 237 SetDate(self, DateTime date)
98e665d3
RD
238
239 Sets the current date.
240 """
423f194a
RD
241 return _calendar.CalendarCtrl_SetDate(*args, **kwargs)
242
243 def GetDate(*args, **kwargs):
98e665d3 244 """
a95a7133 245 GetDate(self) -> DateTime
98e665d3
RD
246
247 Gets the currently selected date.
248 """
423f194a
RD
249 return _calendar.CalendarCtrl_GetDate(*args, **kwargs)
250
251 def SetLowerDateLimit(*args, **kwargs):
98e665d3 252 """
a95a7133 253 SetLowerDateLimit(self, DateTime date=DefaultDateTime) -> bool
423f194a 254
98e665d3
RD
255 set the range in which selection can occur
256 """
257 return _calendar.CalendarCtrl_SetLowerDateLimit(*args, **kwargs)
423f194a
RD
258
259 def SetUpperDateLimit(*args, **kwargs):
98e665d3 260 """
a95a7133 261 SetUpperDateLimit(self, DateTime date=DefaultDateTime) -> bool
98e665d3
RD
262
263 set the range in which selection can occur
264 """
423f194a
RD
265 return _calendar.CalendarCtrl_SetUpperDateLimit(*args, **kwargs)
266
98e665d3
RD
267 def GetLowerDateLimit(*args, **kwargs):
268 """
a95a7133 269 GetLowerDateLimit(self) -> DateTime
98e665d3
RD
270
271 get the range in which selection can occur
272 """
273 return _calendar.CalendarCtrl_GetLowerDateLimit(*args, **kwargs)
274
423f194a 275 def GetUpperDateLimit(*args, **kwargs):
98e665d3 276 """
a95a7133 277 GetUpperDateLimit(self) -> DateTime
98e665d3
RD
278
279 get the range in which selection can occur
280 """
423f194a
RD
281 return _calendar.CalendarCtrl_GetUpperDateLimit(*args, **kwargs)
282
283 def SetDateRange(*args, **kwargs):
98e665d3 284 """
a95a7133 285 SetDateRange(self, DateTime lowerdate=DefaultDateTime, DateTime upperdate=DefaultDateTime) -> bool
98e665d3
RD
286
287 set the range in which selection can occur
288 """
423f194a
RD
289 return _calendar.CalendarCtrl_SetDateRange(*args, **kwargs)
290
291 def EnableYearChange(*args, **kwargs):
98e665d3 292 """
a95a7133 293 EnableYearChange(self, bool enable=True)
98e665d3
RD
294
295 This function should be used instead of changing CAL_NO_YEAR_CHANGE
296 style bit directly. It allows or disallows the user to change the year
297 interactively.
298 """
423f194a
RD
299 return _calendar.CalendarCtrl_EnableYearChange(*args, **kwargs)
300
301 def EnableMonthChange(*args, **kwargs):
98e665d3 302 """
a95a7133 303 EnableMonthChange(self, bool enable=True)
98e665d3 304
c24da6d6
RD
305 This function should be used instead of changing CAL_NO_MONTH_CHANGE
306 style bit. It allows or disallows the user to change the month
307 interactively. Note that if the month can not be changed, the year can
308 not be changed either.
98e665d3 309 """
423f194a
RD
310 return _calendar.CalendarCtrl_EnableMonthChange(*args, **kwargs)
311
312 def EnableHolidayDisplay(*args, **kwargs):
98e665d3 313 """
a95a7133 314 EnableHolidayDisplay(self, bool display=True)
98e665d3 315
c24da6d6
RD
316 This function should be used instead of changing CAL_SHOW_HOLIDAYS
317 style bit directly. It enables or disables the special highlighting of
318 the holidays.
98e665d3 319 """
423f194a
RD
320 return _calendar.CalendarCtrl_EnableHolidayDisplay(*args, **kwargs)
321
322 def SetHeaderColours(*args, **kwargs):
98e665d3 323 """
a95a7133 324 SetHeaderColours(self, Colour colFg, Colour colBg)
98e665d3 325
c24da6d6 326 Header colours are used for painting the weekdays at the top.
98e665d3 327 """
423f194a
RD
328 return _calendar.CalendarCtrl_SetHeaderColours(*args, **kwargs)
329
330 def GetHeaderColourFg(*args, **kwargs):
98e665d3 331 """
a95a7133 332 GetHeaderColourFg(self) -> Colour
98e665d3 333
c24da6d6 334 Header colours are used for painting the weekdays at the top.
98e665d3 335 """
423f194a
RD
336 return _calendar.CalendarCtrl_GetHeaderColourFg(*args, **kwargs)
337
338 def GetHeaderColourBg(*args, **kwargs):
98e665d3 339 """
a95a7133 340 GetHeaderColourBg(self) -> Colour
98e665d3 341
c24da6d6 342 Header colours are used for painting the weekdays at the top.
98e665d3 343 """
423f194a
RD
344 return _calendar.CalendarCtrl_GetHeaderColourBg(*args, **kwargs)
345
346 def SetHighlightColours(*args, **kwargs):
98e665d3 347 """
a95a7133 348 SetHighlightColours(self, Colour colFg, Colour colBg)
98e665d3 349
c24da6d6 350 Highlight colour is used for the currently selected date.
98e665d3 351 """
423f194a
RD
352 return _calendar.CalendarCtrl_SetHighlightColours(*args, **kwargs)
353
354 def GetHighlightColourFg(*args, **kwargs):
98e665d3 355 """
a95a7133 356 GetHighlightColourFg(self) -> Colour
98e665d3 357
c24da6d6 358 Highlight colour is used for the currently selected date.
98e665d3 359 """
423f194a
RD
360 return _calendar.CalendarCtrl_GetHighlightColourFg(*args, **kwargs)
361
362 def GetHighlightColourBg(*args, **kwargs):
98e665d3 363 """
a95a7133 364 GetHighlightColourBg(self) -> Colour
98e665d3 365
c24da6d6 366 Highlight colour is used for the currently selected date.
98e665d3 367 """
423f194a
RD
368 return _calendar.CalendarCtrl_GetHighlightColourBg(*args, **kwargs)
369
370 def SetHolidayColours(*args, **kwargs):
98e665d3 371 """
a95a7133 372 SetHolidayColours(self, Colour colFg, Colour colBg)
98e665d3 373
c24da6d6
RD
374 Holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is
375 used).
98e665d3 376 """
423f194a
RD
377 return _calendar.CalendarCtrl_SetHolidayColours(*args, **kwargs)
378
379 def GetHolidayColourFg(*args, **kwargs):
98e665d3 380 """
a95a7133 381 GetHolidayColourFg(self) -> Colour
98e665d3 382
c24da6d6
RD
383 Holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is
384 used).
98e665d3 385 """
423f194a
RD
386 return _calendar.CalendarCtrl_GetHolidayColourFg(*args, **kwargs)
387
388 def GetHolidayColourBg(*args, **kwargs):
98e665d3 389 """
a95a7133 390 GetHolidayColourBg(self) -> Colour
98e665d3 391
c24da6d6
RD
392 Holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is
393 used).
98e665d3 394 """
423f194a
RD
395 return _calendar.CalendarCtrl_GetHolidayColourBg(*args, **kwargs)
396
397 def GetAttr(*args, **kwargs):
98e665d3 398 """
a95a7133 399 GetAttr(self, size_t day) -> CalendarDateAttr
98e665d3 400
c24da6d6
RD
401 Returns the attribute for the given date (should be in the range
402 1...31). The returned value may be None
98e665d3 403 """
423f194a
RD
404 return _calendar.CalendarCtrl_GetAttr(*args, **kwargs)
405
406 def SetAttr(*args, **kwargs):
98e665d3 407 """
a95a7133 408 SetAttr(self, size_t day, CalendarDateAttr attr)
98e665d3 409
c24da6d6
RD
410 Associates the attribute with the specified date (in the range
411 1...31). If the attribute passed is None, the items attribute is
412 cleared.
98e665d3 413 """
423f194a
RD
414 return _calendar.CalendarCtrl_SetAttr(*args, **kwargs)
415
416 def SetHoliday(*args, **kwargs):
98e665d3 417 """
a95a7133 418 SetHoliday(self, size_t day)
98e665d3
RD
419
420 Marks the specified day as being a holiday in the current month.
421 """
423f194a
RD
422 return _calendar.CalendarCtrl_SetHoliday(*args, **kwargs)
423
424 def ResetAttr(*args, **kwargs):
98e665d3 425 """
a95a7133 426 ResetAttr(self, size_t day)
98e665d3 427
c24da6d6
RD
428 Clears any attributes associated with the given day (in the range
429 1...31).
98e665d3 430 """
423f194a
RD
431 return _calendar.CalendarCtrl_ResetAttr(*args, **kwargs)
432
433 def HitTest(*args, **kwargs):
98e665d3
RD
434 """
435 HitTest(Point pos) -> (result, date, weekday)
436
c24da6d6
RD
437 Returns 3-tuple with information about the given position on the
438 calendar control. The first value of the tuple is a result code and
79fccf9d 439 determines the validity of the remaining two values.
98e665d3
RD
440 """
441 return _calendar.CalendarCtrl_HitTest(*args, **kwargs)
423f194a 442
9fd4be55 443 def GetMonthControl(*args, **kwargs):
98e665d3 444 """
a95a7133 445 GetMonthControl(self) -> Control
98e665d3 446
c24da6d6 447 Get the currently shown control for month.
98e665d3 448 """
9fd4be55
RD
449 return _calendar.CalendarCtrl_GetMonthControl(*args, **kwargs)
450
451 def GetYearControl(*args, **kwargs):
98e665d3 452 """
a95a7133 453 GetYearControl(self) -> Control
98e665d3 454
c24da6d6 455 Get the currently shown control for year.
98e665d3 456 """
9fd4be55
RD
457 return _calendar.CalendarCtrl_GetYearControl(*args, **kwargs)
458
f20a2e1f
RD
459 def GetClassDefaultAttributes(*args, **kwargs):
460 """
461 GetClassDefaultAttributes(int variant=WINDOW_VARIANT_NORMAL) -> VisualAttributes
462
79fccf9d
RD
463 Get the default attributes for this class. This is useful if you want
464 to use the same font or colour in your own control as in a standard
465 control -- which is a much better idea than hard coding specific
caef1a4d
RD
466 colours or fonts which might look completely out of place on the
467 user's system, especially if it uses themes.
f20a2e1f
RD
468
469 The variant parameter is only relevant under Mac currently and is
79fccf9d 470 ignore under other platforms. Under Mac, it will change the size of
caef1a4d
RD
471 the returned font. See `wx.Window.SetWindowVariant` for more about
472 this.
f20a2e1f
RD
473 """
474 return _calendar.CalendarCtrl_GetClassDefaultAttributes(*args, **kwargs)
475
476 GetClassDefaultAttributes = staticmethod(GetClassDefaultAttributes)
1fbf26be
RD
477 def PySetDate(self, date):
478 """takes datetime.datetime or datetime.date object"""
629e65c2 479 self.SetDate(_pydate2wxdate(date))
1fbf26be
RD
480
481 def PyGetDate(self):
482 """returns datetime.date object"""
629e65c2 483 return _wxdate2pydate(self.GetDate())
1fbf26be
RD
484
485 def PySetLowerDateLimit(self, date):
486 """takes datetime.datetime or datetime.date object"""
629e65c2 487 self.SetLowerDateLimit(_pydate2wxdate(date))
1fbf26be
RD
488
489 def PySetUpperDateLimit(self, date):
490 """takes datetime.datetime or datetime.date object"""
629e65c2 491 self.SetUpperDateLimit(_pydate2wxdate(date))
1fbf26be
RD
492
493 def PySetDateRange(self, lowerdate, upperdate):
494 """takes datetime.datetime or datetime.date objects"""
495 self.PySetLowerDateLimit(lowerdate)
496 self.PySetUpperDateLimit(upperdate)
497
498 def PyGetLowerDateLimit(self):
499 """returns datetime.date object"""
629e65c2 500 return _wxdate2pydate(self.GetLowerDateLimit())
1fbf26be
RD
501
502 def PyGetUpperDateLimit(self):
503 """returns datetime.date object"""
629e65c2 504 return _wxdate2pydate(self.GetUpperDateLimit())
1fbf26be 505
f6bcfd97 506
d14a1e28
RD
507class CalendarCtrlPtr(CalendarCtrl):
508 def __init__(self, this):
509 self.this = this
510 if not hasattr(self,"thisown"): self.thisown = 0
511 self.__class__ = CalendarCtrl
512_calendar.CalendarCtrl_swigregister(CalendarCtrlPtr)
d03fd34d
RD
513cvar = _calendar.cvar
514CalendarNameStr = cvar.CalendarNameStr
f6bcfd97 515
d14a1e28 516def PreCalendarCtrl(*args, **kwargs):
98e665d3
RD
517 """
518 PreCalendarCtrl() -> CalendarCtrl
519
520 Precreate a CalendarCtrl for 2-phase creation.
521 """
d14a1e28 522 val = _calendar.new_PreCalendarCtrl(*args, **kwargs)
09f3d4e6
RD
523 val.thisown = 1
524 return val
525
f20a2e1f
RD
526def CalendarCtrl_GetClassDefaultAttributes(*args, **kwargs):
527 """
528 CalendarCtrl_GetClassDefaultAttributes(int variant=WINDOW_VARIANT_NORMAL) -> VisualAttributes
529
79fccf9d
RD
530 Get the default attributes for this class. This is useful if you want
531 to use the same font or colour in your own control as in a standard
532 control -- which is a much better idea than hard coding specific
caef1a4d
RD
533 colours or fonts which might look completely out of place on the
534 user's system, especially if it uses themes.
f20a2e1f
RD
535
536 The variant parameter is only relevant under Mac currently and is
79fccf9d 537 ignore under other platforms. Under Mac, it will change the size of
caef1a4d
RD
538 the returned font. See `wx.Window.SetWindowVariant` for more about
539 this.
f20a2e1f
RD
540 """
541 return _calendar.CalendarCtrl_GetClassDefaultAttributes(*args, **kwargs)
542
629e65c2 543def _pydate2wxdate(date):
1fbf26be
RD
544 import datetime
545 assert isinstance(date, (datetime.datetime, datetime.date))
546 tt = date.timetuple()
547 dmy = (tt[2], tt[1]-1, tt[0])
548 return wx.DateTimeFromDMY(*dmy)
549
629e65c2 550def _wxdate2pydate(date):
1fbf26be
RD
551 import datetime
552 assert isinstance(date, wx.DateTime)
629e65c2
RD
553 if date.IsValid():
554 ymd = map(int, date.FormatISODate().split('-'))
555 return datetime.date(*ymd)
556 else:
557 return None
1fbf26be 558
f6bcfd97 559