]> git.saurik.com Git - wxWidgets.git/blob - wxPython/wx/lib/dialogs.py
Docsrings for wxSplitterWindow
[wxWidgets.git] / wxPython / wx / lib / dialogs.py
1 #----------------------------------------------------------------------
2 # Name: wx.lib.dialogs
3 # Purpose: ScrolledMessageDialog, MultipleChoiceDialog and
4 # function wrappers for the common dialogs by Kevin Altis.
5 #
6 # Author: Various
7 #
8 # Created: 3-January-2002
9 # RCS-ID: $Id$
10 # Copyright: (c) 2002 by Total Control Software
11 # Licence: wxWindows license
12 #----------------------------------------------------------------------
13 # 12/01/2003 - Jeff Grimmett (grimmtooth@softhome.net)
14 #
15 # o Updated for 2.5 compatability.
16 #
17 # 12/18/2003 - Jeff Grimmett (grimmtooth@softhome.net)
18 #
19 # o wxScrolledMessageDialog -> ScrolledMessageDialog
20 # o wxMultipleChoiceDialog -> MultipleChoiceDialog
21 #
22
23 import wx
24 import layoutf
25
26 #----------------------------------------------------------------------
27
28 class ScrolledMessageDialog(wx.Dialog):
29 def __init__(self, parent, msg, caption, pos = wx.DefaultPosition,
30 size = (500,300)):
31 wx.Dialog.__init__(self, parent, -1, caption, pos, size)
32 x, y = pos
33 if x == -1 and y == -1:
34 self.CenterOnScreen(wx.BOTH)
35
36 text = wx.TextCtrl(self, -1, msg, wx.DefaultPosition, wx.DefaultSize,
37 wx.TE_MULTILINE | wx.TE_READONLY)
38
39 ok = wx.Button(self, wx.ID_OK, "OK")
40 lc = layoutf.Layoutf('t=t5#1;b=t5#2;l=l5#1;r=r5#1', (self,ok))
41 text.SetConstraints(lc)
42
43 lc = layoutf.Layoutf('b=b5#1;x%w50#1;w!80;h!25', (self,))
44 ok.SetConstraints(lc)
45 self.SetAutoLayout(1)
46 self.Layout()
47
48
49 class MultipleChoiceDialog(wx.Dialog):
50 def __init__(self, parent, msg, title, lst, pos = wx.DefaultPosition,
51 size = (200,200), style = wx.DEFAULT_DIALOG_STYLE):
52 wx.Dialog.__init__(self, parent, -1, title, pos, size, style)
53
54 x, y = pos
55 if x == -1 and y == -1:
56 self.CenterOnScreen(wx.BOTH)
57
58 dc = wx.ClientDC(self)
59 height = 0
60 for line in msg.splitlines():
61 height = height + dc.GetTextExtent(line)[1] + 2
62
63 stat = wx.StaticText(self, -1, msg)
64 self.lbox = wx.ListBox(self, 100, wx.DefaultPosition, wx.DefaultSize,
65 lst, wx.LB_MULTIPLE)
66
67 ok = wx.Button(self, wx.ID_OK, "OK")
68 cancel = wx.Button(self, wx.ID_CANCEL, "Cancel")
69 lc = layoutf.Layoutf('t=t10#1;l=l5#1;r=r5#1;h!%d' % (height,), (self,))
70 stat.SetConstraints(lc)
71
72 lc = layoutf.Layoutf('t=b10#2;l=l5#1;r=r5#1;b=t5#3', (self, stat, ok))
73 self.lbox.SetConstraints(lc)
74
75 lc = layoutf.Layoutf('b=b5#1;x%w25#1;w!80;h!25', (self,))
76 ok.SetConstraints(lc)
77
78 lc = layoutf.Layoutf('b=b5#1;x%w75#1;w!80;h!25', (self,))
79 cancel.SetConstraints(lc)
80
81 self.SetAutoLayout(1)
82 self.lst = lst
83 self.Layout()
84
85 def GetValue(self):
86 return self.lbox.GetSelections()
87
88 def GetValueString(self):
89 sel = self.lbox.GetSelections()
90 val = []
91
92 for i in sel:
93 val.append(self.lst[i])
94
95 return tuple(val)
96
97
98 #----------------------------------------------------------------------
99 """
100 function wrappers for wxPython system dialogs
101 Author: Kevin Altis
102 Date: 2003-1-2
103 Rev: 3
104
105 This is the third refactor of the PythonCard dialog.py module
106 for inclusion in the main wxPython distribution. There are a number of
107 design decisions and subsequent code refactoring to be done, so I'm
108 releasing this just to get some feedback.
109
110 rev 3:
111 - result dictionary replaced by DialogResults class instance
112 - should message arg be replaced with msg? most wxWindows dialogs
113 seem to use the abbreviation?
114
115 rev 2:
116 - All dialog classes have been replaced by function wrappers
117 - Changed arg lists to more closely match wxWindows docs and wxPython.lib.dialogs
118 - changed 'returned' value to the actual button id the user clicked on
119 - added a returnedString value for the string version of the return value
120 - reworked colorDialog and fontDialog so you can pass in just a color or font
121 for the most common usage case
122 - probably need to use colour instead of color to match the English English
123 spelling in wxWindows (sigh)
124 - I still think we could lose the parent arg and just always use None
125 """
126
127 class DialogResults:
128 def __init__(self, returned):
129 self.returned = returned
130 self.accepted = returned in (wx.ID_OK, wx.ID_YES)
131 self.returnedString = returnedString(returned)
132
133 def __repr__(self):
134 return str(self.__dict__)
135
136 def returnedString(ret):
137 if ret == wx.ID_OK:
138 return "Ok"
139 elif ret == wx.ID_CANCEL:
140 return "Cancel"
141 elif ret == wx.ID_YES:
142 return "Yes"
143 elif ret == wx.ID_NO:
144 return "No"
145
146
147 ## findDialog was created before wxPython got a Find/Replace dialog
148 ## but it may be instructive as to how a function wrapper can
149 ## be added for your own custom dialogs
150 ## this dialog is always modal, while wxFindReplaceDialog is
151 ## modeless and so doesn't lend itself to a function wrapper
152 def findDialog(parent=None, searchText='', wholeWordsOnly=0, caseSensitive=0):
153 dlg = wx.Dialog(parent, -1, "Find", wx.DefaultPosition, (370, 120))
154
155 wx.StaticText(dlg, -1, 'Find what:', (7, 10))
156 wSearchText = wx.TextCtrl(dlg, -1, searchText, (70, 7), (195, -1))
157 wSearchText.SetValue(searchText)
158 wx.Button(dlg, wx.ID_OK, "Find Next", (280, 5), wx.DefaultSize).SetDefault()
159 wx.Button(dlg, wx.ID_CANCEL, "Cancel", (280, 35), wx.DefaultSize)
160 wWholeWord = wx.CheckBox(dlg, -1, 'Match whole word only',
161 (7, 35), wx.DefaultSize, wx.NO_BORDER)
162
163 if wholeWordsOnly:
164 wWholeWord.SetValue(1)
165
166 wCase = wx.CheckBox(dlg, -1, 'Match case', (7, 55), wx.DefaultSize, wx.NO_BORDER)
167
168 if caseSensitive:
169 wCase.SetValue(1)
170
171 wSearchText.SetSelection(0, len(wSearchText.GetValue()))
172 wSearchText.SetFocus()
173
174 result = DialogResults(dlg.ShowModal())
175 result.text = wSearchText.GetValue()
176 result.wholeword = wWholeWord.GetValue()
177 result.casesensitive = wCase.GetValue()
178 dlg.Destroy()
179 return result
180
181
182 def colorDialog(parent=None, colorData=None, color=None):
183 if colorData:
184 dialog = wx.ColourDialog(parent, colorData)
185 else:
186 dialog = wx.ColourDialog(parent)
187 dialog.GetColourData().SetChooseFull(1)
188
189 if color is not None:
190 dialog.GetColourData().SetColour(color)
191
192 result = DialogResults(dialog.ShowModal())
193 result.colorData = dialog.GetColourData()
194 result.color = result.colorData.GetColour().Get()
195 dialog.Destroy()
196 return result
197
198
199 ## it is easier to just duplicate the code than
200 ## try and replace color with colour in the result
201 def colourDialog(parent=None, colourData=None, colour=None):
202 if colourData:
203 dialog = wx.ColourDialog(parent, colourData)
204 else:
205 dialog = wx.ColourDialog(parent)
206 dialog.GetColourData().SetChooseFull(1)
207
208 if colour is not None:
209 dialog.GetColourData().SetColour(color)
210
211 result = DialogResults(dialog.ShowModal())
212 result.colourData = dialog.GetColourData()
213 result.colour = result.colourData.GetColour().Get()
214 dialog.Destroy()
215 return result
216
217
218 def fontDialog(parent=None, fontData=None, font=None):
219 if fontData is None:
220 fontData = wx.FontData()
221 fontData.SetColour(wx.BLACK)
222 fontData.SetInitialFont(wx.SystemSettings.GetFont(wx.SYS_DEFAULT_GUI_FONT))
223
224 if font is not None:
225 aFontData.SetInitialFont(font)
226
227 dialog = wx.FontDialog(parent, fontData)
228 result = DialogResults(dialog.ShowModal())
229
230 if result.accepted:
231 fontData = dialog.GetFontData()
232 result.fontData = fontData
233 result.color = fontData.GetColour().Get()
234 result.colour = result.color
235 result.font = fontData.GetChosenFont()
236 else:
237 result.color = None
238 result.colour = None
239 result.font = None
240
241 dialog.Destroy()
242 return result
243
244
245 def textEntryDialog(parent=None, message='', title='', defaultText='',
246 style=wx.OK | wx.CANCEL):
247 dialog = wx.TextEntryDialog(parent, message, title, defaultText, style)
248 result = DialogResults(dialog.ShowModal())
249 result.text = dialog.GetValue()
250 dialog.Destroy()
251 return result
252
253
254 def messageDialog(parent=None, message='', title='Message box',
255 aStyle = wx.OK | wx.CANCEL | wx.CENTRE,
256 pos=wx.DefaultPosition):
257 dialog = wx.MessageDialog(parent, message, title, aStyle, pos)
258 result = DialogResults(dialog.ShowModal())
259 dialog.Destroy()
260 return result
261
262
263 ## KEA: alerts are common, so I'm providing a class rather than
264 ## requiring the user code to set up the right icons and buttons
265 ## the with messageDialog function
266 def alertDialog(parent=None, message='', title='Alert', pos=wx.DefaultPosition):
267 return messageDialog(parent, message, title, wx.ICON_EXCLAMATION | wx.OK, pos)
268
269
270 def scrolledMessageDialog(parent=None, message='', title='', pos=wx.DefaultPosition,
271 size=(500,300)):
272
273 dialog = ScrolledMessageDialog(parent, message, title, pos, size)
274 result = DialogResults(dialog.ShowModal())
275 dialog.Destroy()
276 return result
277
278
279 def fileDialog(parent=None, title='Open', directory='', filename='', wildcard='*.*',
280 style=wx.OPEN | wx.MULTIPLE):
281
282 dialog = wx.FileDialog(parent, title, directory, filename, wildcard, style)
283 result = DialogResults(dialog.ShowModal())
284 if result.accepted:
285 result.paths = dialog.GetPaths()
286 else:
287 result.paths = None
288 dialog.Destroy()
289 return result
290
291
292 ## openFileDialog and saveFileDialog are convenience functions
293 ## they represent the most common usages of the fileDialog
294 ## with the most common style options
295 def openFileDialog(parent=None, title='Open', directory='', filename='',
296 wildcard='All Files (*.*)|*.*',
297 style=wx.OPEN | wx.MULTIPLE):
298 return fileDialog(parent, title, directory, filename, wildcard, style)
299
300
301 def saveFileDialog(parent=None, title='Save', directory='', filename='',
302 wildcard='All Files (*.*)|*.*',
303 style=wx.SAVE | wx.HIDE_READONLY | wx.OVERWRITE_PROMPT):
304 return fileDialog(parent, title, directory, filename, wildcard, style)
305
306
307 def dirDialog(parent=None, message='Choose a directory', path='', style=0,
308 pos=wx.DefaultPosition, size=wx.DefaultSize):
309
310 dialog = wx.DirDialog(parent, message, path, style, pos, size)
311 result = DialogResults(dialog.ShowModal())
312 if result.accepted:
313 result.path = dialog.GetPath()
314 else:
315 result.path = None
316 dialog.Destroy()
317 return result
318
319 directoryDialog = dirDialog
320
321
322 def singleChoiceDialog(parent=None, message='', title='', lst=[],
323 style=wx.OK | wx.CANCEL | wx.CENTRE):
324 dialog = wx.SingleChoiceDialog(parent, message, title, lst, style)
325 result = DialogResults(dialog.ShowModal())
326 result.selection = dialog.GetStringSelection()
327 dialog.Destroy()
328 return result
329
330
331 def multipleChoiceDialog(parent=None, message='', title='', lst=[], pos=wx.DefaultPosition,
332 size=(200,200)):
333
334 dialog = MultipleChoiceDialog(parent, message, title, lst, pos, size)
335 result = DialogResults(dialog.ShowModal())
336 result.selection = dialog.GetValueString()
337 dialog.Destroy()
338 return result
339
340
341 if __name__ == '__main__':
342 #import os
343 #print os.getpid()
344
345 class MyApp(wx.App):
346
347 def OnInit(self):
348 self.frame = frame = wx.Frame(None, -1, "Dialogs", size=(400, 200))
349 panel = wx.Panel(frame, -1)
350 self.panel = panel
351
352
353 dialogNames = [
354 'alertDialog',
355 'colorDialog',
356 'directoryDialog',
357 'fileDialog',
358 'findDialog',
359 'fontDialog',
360 'messageDialog',
361 'multipleChoiceDialog',
362 'openFileDialog',
363 'saveFileDialog',
364 'scrolledMessageDialog',
365 'singleChoiceDialog',
366 'textEntryDialog',
367 ]
368
369 self.nameList = wx.ListBox(panel, -1,
370 size=(130, 180),
371 choices=dialogNames,
372 style=wx.LB_SINGLE)
373 self.Bind(wx.EVT_LISTBOX, self.OnNameListSelected, self.nameList)
374
375 tstyle = wx.TE_RICH2 | wx.TE_PROCESS_TAB | wx.TE_MULTILINE
376 self.text1 = wx.TextCtrl(panel, -1, size=(200, 180), style=tstyle)
377
378 sizer = wx.BoxSizer(wx.HORIZONTAL)
379 sizer.Add(self.nameList, 0, wx.EXPAND|wx.ALL, 20)
380 sizer.Add(self.text1, 1, wx.EXPAND|wx.ALL, 20)
381
382 panel.SetSizer(sizer)
383
384 self.SetTopWindow(frame)
385 frame.Show(1)
386 return 1
387
388
389 def OnNameListSelected(self, evt):
390 import pprint
391 sel = evt.GetString()
392 result = None
393 if sel == 'alertDialog':
394 result = alertDialog(message='Danger Will Robinson')
395 elif sel == 'colorDialog':
396 result = colorDialog()
397 elif sel == 'directoryDialog':
398 result = directoryDialog()
399 elif sel == 'fileDialog':
400 wildcard = "JPG files (*.jpg;*.jpeg)|*.jpeg;*.JPG;*.JPEG;*.jpg|GIF files (*.gif)|*.GIF;*.gif|All Files (*.*)|*.*"
401 result = fileDialog(None, 'Open', '', '', wildcard)
402 elif sel == 'findDialog':
403 result = findDialog()
404 elif sel == 'fontDialog':
405 result = fontDialog()
406 elif sel == 'messageDialog':
407 result = messageDialog(None, 'Hello from Python and wxPython!',
408 'A Message Box', wx.OK | wx.ICON_INFORMATION)
409 #wx.YES_NO | wx.NO_DEFAULT | wx.CANCEL | wx.ICON_INFORMATION)
410 #result = messageDialog(None, 'message', 'title')
411 elif sel == 'multipleChoiceDialog':
412 result = multipleChoiceDialog(None, "message", "title", ['one', 'two', 'three'])
413 elif sel == 'openFileDialog':
414 result = openFileDialog()
415 elif sel == 'saveFileDialog':
416 result = saveFileDialog()
417 elif sel == 'scrolledMessageDialog':
418 msg = "Can't find the file dialog.py"
419 try:
420 # read this source file and then display it
421 import sys
422 filename = sys.argv[-1]
423 fp = open(filename)
424 message = fp.read()
425 fp.close()
426 except:
427 pass
428 result = scrolledMessageDialog(None, message, filename)
429 elif sel == 'singleChoiceDialog':
430 result = singleChoiceDialog(None, "message", "title", ['one', 'two', 'three'])
431 elif sel == 'textEntryDialog':
432 result = textEntryDialog(None, "message", "title", "text")
433
434 if result:
435 #self.text1.SetValue(pprint.pformat(result.__dict__))
436 self.text1.SetValue(str(result))
437
438 app = MyApp(True)
439 app.MainLoop()
440
441