]> git.saurik.com Git - wxWidgets.git/blob - wxPython/demo/wxFindReplaceDialog.py
Reworked how stock objects are initialized. They now have an
[wxWidgets.git] / wxPython / demo / wxFindReplaceDialog.py
1 # 11/17/2003 - Jeff Grimmett (grimmtooth@softhome.net)
2 #
3 # o Updated for wx namespace
4 #
5 # 11/28/2003 - Jeff Grimmett (grimmtooth@softhome.net)
6 #
7 # o Changed the event binding slightly.
8 # o There are issues with the GetReplaceText() method of the
9 # FindDialogEvent. Must be retested when this is fixed.
10 #
11
12 import wx
13
14 #---------------------------------------------------------------------------
15
16 class TestPanel(wx.Panel):
17 def __init__(self, parent, log):
18 wx.Panel.__init__(self, parent, -1)
19 self.log = log
20
21 b = wx.Button(self, -1, "Show Find Dialog", (25, 50))
22 self.Bind(wx.EVT_BUTTON, self.OnShowFind, b)
23
24 b = wx.Button(self, -1, "Show Find && Replace Dialog", (25, 90))
25 self.Bind(wx.EVT_BUTTON, self.OnShowFindReplace, b)
26
27
28 # jg - 11/28/03 - corrected a long standing issue here where
29 # EVT_COMMAND_FIND_* was being used for these event binders
30 # instead of the actual event IDs shown below. As a result,
31 # onFind() was never showing the appropriate type. I guess
32 # nobody really paid much attention to that little
33 # debugging window :-)
34 #
35 self.Bind(wx.EVT_FIND, self.OnFind)
36 self.Bind(wx.EVT_FIND_NEXT, self.OnFind)
37 self.Bind(wx.EVT_FIND_REPLACE, self.OnFind)
38 self.Bind(wx.EVT_FIND_REPLACE_ALL, self.OnFind)
39 self.Bind(wx.EVT_FIND_CLOSE, self.OnFindClose)
40
41
42 def OnShowFind(self, evt):
43 data = wx.FindReplaceData()
44 dlg = wx.FindReplaceDialog(self, data, "Find")
45 dlg.data = data # save a reference to it...
46 dlg.Show(True)
47
48
49 def OnShowFindReplace(self, evt):
50 data = wx.FindReplaceData()
51 dlg = wx.FindReplaceDialog(self, data, "Find & Replace", wx.FR_REPLACEDIALOG)
52 dlg.data = data # save a reference to it...
53 dlg.Show(True)
54
55
56 def OnFind(self, evt):
57 map = {
58 wx.wxEVT_COMMAND_FIND : "FIND",
59 wx.wxEVT_COMMAND_FIND_NEXT : "FIND_NEXT",
60 wx.wxEVT_COMMAND_FIND_REPLACE : "REPLACE",
61 wx.wxEVT_COMMAND_FIND_REPLACE_ALL : "REPLACE_ALL",
62 }
63
64 et = evt.GetEventType()
65
66 #print evt.GetReplaceString()
67
68 if et in map:
69 evtType = map[et]
70 else:
71 evtType = "**Unknown Event Type**"
72
73 #>> Todo: the GetReplaceString() method is broken. Has to be
74 # fixed.
75 if et == wx.EVT_COMMAND_FIND_REPLACE or et == wx.EVT_COMMAND_FIND_REPLACE_ALL:
76 replaceTxt = "Replace text: %s" % evt.GetReplaceString()
77 else:
78 replaceTxt = ""
79
80 self.log.write("%s -- Find text: %s %s Flags: %d \n" %
81 (evtType, evt.GetFindString(), replaceTxt, evt.GetFlags()))
82
83
84 def OnFindClose(self, evt):
85 self.log.write("FindReplaceDialog closing...\n")
86 evt.GetDialog().Destroy()
87
88 #---------------------------------------------------------------------------
89
90 def runTest(frame, nb, log):
91 win = TestPanel(nb, log)
92 return win
93
94 #---------------------------------------------------------------------------
95
96
97
98
99 overview = """\
100 FindReplaceDialog is a standard modeless dialog which is used to allow the user
101 to search for some text (and possibly replace it with something else). The actual
102 searching is supposed to be done in the owner window which is the parent of this
103 dialog. Note that it means that unlike for the other standard dialogs this one
104 <u>must have a parent window</u>. Also note that there is no way to use this
105 dialog in a modal way; <b>it is always, by design and implementation, modeless</b>.
106
107 FileReplaceDialog requires the use of <b>FindReplaceData</b>. This holds the
108 data for the dialog. It is used to initialize the dialog with the default values
109 and will keep the last values from the dialog when it is closed. It is also
110 updated each time a FindDialogEvent is generated so instead of using the
111 FindDialogEvent methods you can also directly query this object. <b>Care must be
112 taken not to use this object after the dialog is destroyed.</b> The data within
113 will be invalid after the parent dialog is destroyed.
114 """
115
116
117
118
119 if __name__ == '__main__':
120 import sys,os
121 import run
122 run.main(['', os.path.basename(sys.argv[0])])
123