1 # 11/17/2003 - Jeff Grimmett (grimmtooth@softhome.net) 
   3 # o Updated for wx namespace 
   5 # 11/28/2003 - Jeff Grimmett (grimmtooth@softhome.net) 
   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. 
  14 #--------------------------------------------------------------------------- 
  16 class TestPanel(wx
.Panel
): 
  17     def __init__(self
, parent
, log
): 
  18         wx
.Panel
.__init
__(self
, parent
, -1) 
  21         b 
= wx
.Button(self
, -1, "Show Find Dialog", (25, 50)) 
  22         self
.Bind(wx
.EVT_BUTTON
, self
.OnShowFind
, b
) 
  24         b 
= wx
.Button(self
, -1, "Show Find && Replace Dialog", (25, 90)) 
  25         self
.Bind(wx
.EVT_BUTTON
, self
.OnShowFindReplace
, b
) 
  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 :-) 
  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
) 
  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... 
  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... 
  56     def OnFind(self
, evt
): 
  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", 
  64         et 
= evt
.GetEventType() 
  69             evtType 
= "**Unknown Event Type**" 
  71         #>> Todo: the GetReplaceString() method is broken. Has to be 
  73         if et 
== wx
.EVT_COMMAND_FIND_REPLACE 
or et 
== wx
.EVT_COMMAND_FIND_REPLACE_ALL
: 
  74             replaceTxt 
= "Replace text: %s" % evt
.GetReplaceString() 
  78         self
.log
.write("%s -- Find text: %s   Replace text: %s  Flags: %d  \n" % 
  79                        (evtType
, evt
.GetFindString(), replaceTxt
, evt
.GetFlags())) 
  82     def OnFindClose(self
, evt
): 
  83         self
.log
.write("FindReplaceDialog closing...\n") 
  84         evt
.GetDialog().Destroy() 
  86 #--------------------------------------------------------------------------- 
  88 def runTest(frame
, nb
, log
): 
  89     win 
= TestPanel(nb
, log
) 
  92 #--------------------------------------------------------------------------- 
  98 FindReplaceDialog is a standard modeless dialog which is used to allow the user  
  99 to search for some text (and possibly replace it with something else). The actual  
 100 searching is supposed to be done in the owner window which is the parent of this  
 101 dialog. Note that it means that unlike for the other standard dialogs this one  
 102 <u>must have a parent window</u>. Also note that there is no way to use this  
 103 dialog in a modal way; <b>it is always, by design and implementation, modeless</b>. 
 105 FileReplaceDialog requires the use of <b>FindReplaceData</b>. This holds the  
 106 data for the dialog. It is used to initialize the dialog with the default values  
 107 and will keep the last values from the dialog when it is closed. It is also  
 108 updated each time a FindDialogEvent is generated so instead of using the  
 109 FindDialogEvent methods you can also directly query this object. <b>Care must be 
 110 taken not to use this object after the dialog is destroyed.</b> The data within 
 111 will be invalid after the parent dialog is destroyed. 
 117 if __name__ 
== '__main__': 
 120     run
.main(['', os
.path
.basename(sys
.argv
[0])] + sys
.argv
[1:])