]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/FileBrowseButton.py
Add a utility function that can calculate word-wrap line breaks, and
[wxWidgets.git] / wxPython / demo / FileBrowseButton.py
index 2746101ea23c8cae9fa80a114f43c44e52c32f9d..2af110a9f8eb81d9b63fd429f0acf1c64cc43d07 100644 (file)
@@ -16,18 +16,27 @@ class TestPanel(wx.Panel):
         self.log = log
 
         self.fbb = filebrowse.FileBrowseButton(
-            self, -1, (20, 20), (450, -1), changeCallback = self.fbbCallback
+            self, -1, size=(450, -1), changeCallback = self.fbbCallback
             )
 
         self.fbbh = filebrowse.FileBrowseButtonWithHistory(
-            self, -1, (20, 50), (450, -1),  changeCallback = self.fbbhCallback
+            self, -1, size=(450, -1),  changeCallback = self.fbbhCallback
             )
-
+            
         self.dbb = filebrowse.DirBrowseButton(
-            self, -1, (20, 80), (450, -1), changeCallback = self.dbbCallback
+            self, -1, size=(450, -1), changeCallback = self.dbbCallback
             )
 
-        self.fbbh.SetHistory(['You', 'can', 'put', 'some', 'file', 'names', 'here'])
+        self.fbbh.callCallback = False
+        self.fbbh.SetHistory(['You', 'can', 'put', 'some', 'filenames', 'here'], 4)
+
+        sizer = wx.BoxSizer(wx.VERTICAL)
+        sizer.Add(self.fbb, 0, wx.ALL, 5)
+        sizer.Add(self.fbbh, 0, wx.ALL, 5)
+        sizer.Add(self.dbb, 0, wx.ALL, 5)
+        box = wx.BoxSizer()
+        box.Add(sizer, 0, wx.ALL, 20)
+        self.SetSizer(box)
 
 
     def fbbCallback(self, evt):
@@ -37,10 +46,14 @@ class TestPanel(wx.Panel):
     def fbbhCallback(self, evt):
         if hasattr(self, 'fbbh'):
             value = evt.GetString()
+            if not value:
+                return
             self.log.write('FileBrowseButtonWithHistory: %s\n' % value)
             history = self.fbbh.GetHistory()
-            history.append(value)
-            self.fbbh.SetHistory(history)
+            if value not in history:
+                history.append(value)
+                self.fbbh.SetHistory(history)
+                self.fbbh.GetHistoryControl().SetStringSelection(value)
 
 
     def dbbCallback(self, evt):
@@ -82,5 +95,5 @@ overview = """<html><body>
 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:])