X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c7426f4ca3ca80554c6360f7385741e971a96af3..1efad474fdc991183054287762e93756c5084e6c:/wxPython/wx/lib/filebrowsebutton.py?ds=sidebyside diff --git a/wxPython/wx/lib/filebrowsebutton.py b/wxPython/wx/lib/filebrowsebutton.py index c731be2b6e..e2e829da02 100644 --- a/wxPython/wx/lib/filebrowsebutton.py +++ b/wxPython/wx/lib/filebrowsebutton.py @@ -42,7 +42,8 @@ class FileBrowseButton(wx.Panel): fileMask = "*.*", fileMode = wx.OPEN, # callback for when value changes (optional) - changeCallback= lambda x:x + changeCallback= lambda x:x, + labelWidth = 0 ): """ :param labelText: Text for label to left of text field @@ -53,6 +54,7 @@ class FileBrowseButton(wx.Panel): :param fileMask: File mask (glob pattern, such as *.*) to use in file dialog :param fileMode: wx.OPEN or wx.SAVE, indicates type of file dialog to use :param changeCallback: Optional callback called for all changes in value of the control + :param labelWidth: Width of the label """ # store variables @@ -66,7 +68,7 @@ class FileBrowseButton(wx.Panel): self.fileMode = fileMode self.changeCallback = changeCallback self.callCallback = True - + self.labelWidth = labelWidth # create the dialog self.createDialog(parent, id, pos, size, style ) @@ -117,7 +119,10 @@ class FileBrowseButton(wx.Panel): label = wx.StaticText(self, -1, self.labelText, style =wx.ALIGN_RIGHT ) font = label.GetFont() w, h, d, e = self.GetFullTextExtent(self.labelText, font) - label.SetSize((w+5, h)) + if self.labelWidth > 0: + label.SetSize((self.labelWidth+5, h)) + else: + label.SetSize((w+5, h)) return label def createTextControl( self): @@ -242,8 +247,8 @@ class FileBrowseButtonWithHistory( FileBrowseButton ): textControl.SetToolTipString( self.toolTip ) textControl.Bind(wx.EVT_SET_FOCUS, self.OnSetFocus) if self.changeCallback: - textControl.Bind(wx.EVT_TEXT, self.changeCallback) - textControl.Bind(wx.EVT_COMBOBOX, self.changeCallback) + textControl.Bind(wx.EVT_TEXT, self.OnChanged) + textControl.Bind(wx.EVT_COMBOBOX, self.OnChanged) if self.history: history=self.history self.history=None @@ -289,8 +294,10 @@ class FileBrowseButtonWithHistory( FileBrowseButton ): """Return the current history list""" if self.historyCallBack != None: return self.historyCallBack() - else: + elif self.history: return list( self.history ) + else: + return [] def OnSetFocus(self, event):