]> git.saurik.com Git - wxWidgets.git/blame - wxPython/demo/CalendarCtrl.py
further wxABI_VERSION fixes
[wxWidgets.git] / wxPython / demo / CalendarCtrl.py
CommitLineData
f6bcfd97 1
8fa876ca 2import wx
95bfd958 3import wx.calendar
f6bcfd97
BP
4
5#----------------------------------------------------------------------
6
8fa876ca 7class TestPanel(wx.Panel):
f6bcfd97 8 def __init__(self, parent, ID, log):
8fa876ca 9 wx.Panel.__init__(self, parent, ID)
f6bcfd97
BP
10 self.log = log
11
95bfd958
RD
12 cal = wx.calendar.CalendarCtrl(self, -1, wx.DateTime_Now(), pos = (25,50),
13 style = wx.calendar.CAL_SHOW_HOLIDAYS
14 | wx.calendar.CAL_SUNDAY_FIRST
15 | wx.calendar.CAL_SEQUENTIAL_MONTH_SELECTION
1fded56b 16 )
b96c7a38 17 self.cal = cal
a0415e12 18 self.Bind(wx.calendar.EVT_CALENDAR, self.OnCalSelected, id=cal.GetId())
b96c7a38 19
1e4a197e 20 # Set up control to display a set of holidays:
95bfd958 21 self.Bind(wx.calendar.EVT_CALENDAR_MONTH, self.OnChangeMonth, cal)
1e4a197e
RD
22 self.holidays = [(1,1), (10,31), (12,25) ] # (these don't move around)
23 self.OnChangeMonth()
24
a0415e12
RD
25 cal2 = wx.calendar.CalendarCtrl(self, -1, wx.DateTime_Now(), pos = (325,50))
26
f6bcfd97
BP
27
28 def OnCalSelected(self, evt):
29 self.log.write('OnCalSelected: %s\n' % evt.GetDate())
30
1e4a197e
RD
31 def OnChangeMonth(self, evt=None):
32 cur_month = self.cal.GetDate().GetMonth() + 1 # convert wxDateTime 0-11 => 1-12
33 for month, day in self.holidays:
34 if month == cur_month:
35 self.cal.SetHoliday(day)
f6bcfd97
BP
36
37#----------------------------------------------------------------------
38
39def runTest(frame, nb, log):
40 win = TestPanel(nb, -1, log)
41 return win
42
43#----------------------------------------------------------------------
44
45
46overview = """\
47<html><body>
95bfd958 48<h2>CalendarCtrl</h2>
f6bcfd97
BP
49
50Yet <i>another</i> calendar control. This one is a wrapper around the C++
51version described in the docs. This one will probably be a bit more efficient
52than the one in wxPython.lib.calendar, but I like a few things about it better,
53so I think both will stay in wxPython.
54"""
1fded56b
RD
55
56
1fded56b
RD
57if __name__ == '__main__':
58 import sys,os
59 import run
8eca4fef 60 run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
1fded56b 61