# 11/28/2003 - Jeff Grimmett (grimmtooth@softhome.net)
#
# o Changed the event binding slightly.
-# o There are issues with the GetReplaceText() method of the
-# FindDialogEvent. Must be retested when this is fixed.
-#
+
import wx
wx.Panel.__init__(self, parent, -1)
self.log = log
- b = wx.Button(self, -1, "Show Find Dialog", (25, 50))
- self.Bind(wx.EVT_BUTTON, self.OnShowFind, b)
-
- b = wx.Button(self, -1, "Show Find && Replace Dialog", (25, 90))
- self.Bind(wx.EVT_BUTTON, self.OnShowFindReplace, b)
+ self.fbtn = wx.Button(self, -1, "Show Find Dialog", (25, 50))
+ self.Bind(wx.EVT_BUTTON, self.OnShowFind, self.fbtn)
+ self.frbtn = wx.Button(self, -1, "Show Find && Replace Dialog", (25, 90))
+ self.Bind(wx.EVT_BUTTON, self.OnShowFindReplace, self.frbtn)
- # jg - 11/28/03 - corrected a long standing issue here where
- # EVT_COMMAND_FIND_* was being used for these event binders
- # instead of the actual event IDs shown below. As a result,
- # onFind() was never showing the appropriate type. I guess
- # nobody really paid much attention to that little
- # debugging window :-)
- #
self.Bind(wx.EVT_FIND, self.OnFind)
self.Bind(wx.EVT_FIND_NEXT, self.OnFind)
self.Bind(wx.EVT_FIND_REPLACE, self.OnFind)
self.Bind(wx.EVT_FIND_REPLACE_ALL, self.OnFind)
self.Bind(wx.EVT_FIND_CLOSE, self.OnFindClose)
+ def EnableButtons(self):
+ self.fbtn.Enable()
+ self.frbtn.Enable()
+
+ def DisableButtons(self):
+ self.fbtn.Disable()
+ self.frbtn.Disable()
def OnShowFind(self, evt):
+ self.DisableButtons()
data = wx.FindReplaceData()
dlg = wx.FindReplaceDialog(self, data, "Find")
dlg.data = data # save a reference to it...
def OnShowFindReplace(self, evt):
+ self.DisableButtons()
data = wx.FindReplaceData()
dlg = wx.FindReplaceDialog(self, data, "Find & Replace", wx.FR_REPLACEDIALOG)
dlg.data = data # save a reference to it...
et = evt.GetEventType()
- #print evt.GetReplaceString()
-
if et in map:
evtType = map[et]
else:
evtType = "**Unknown Event Type**"
- #>> Todo: the GetReplaceString() method is broken. Has to be
- # fixed.
- if et == wx.EVT_COMMAND_FIND_REPLACE or et == wx.EVT_COMMAND_FIND_REPLACE_ALL:
+ if et in [wx.wxEVT_COMMAND_FIND_REPLACE, wx.wxEVT_COMMAND_FIND_REPLACE_ALL]:
replaceTxt = "Replace text: %s" % evt.GetReplaceString()
else:
replaceTxt = ""
- self.log.write("%s -- Find text: %s %s Flags: %d \n" %
+ self.log.write("%s -- Find text: %s Replace text: %s Flags: %d \n" %
(evtType, evt.GetFindString(), replaceTxt, evt.GetFlags()))
def OnFindClose(self, evt):
self.log.write("FindReplaceDialog closing...\n")
evt.GetDialog().Destroy()
+ self.EnableButtons()
+
#---------------------------------------------------------------------------
if __name__ == '__main__':
import sys,os
import run
- run.main(['', os.path.basename(sys.argv[0])])
+ run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])