[GRASS-SVN] r36995 - grass/branches/releasebranch_6_4/gui/wxpython/gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Mon May 4 14:16:38 EDT 2009


Author: martinl
Date: 2009-05-04 14:16:38 -0400 (Mon, 04 May 2009)
New Revision: 36995

Modified:
   grass/branches/releasebranch_6_4/gui/wxpython/gui_modules/menuform.py
Log:
wxGUI: show option name/type in dialog
	(merge from devbr6, r36261)


Modified: grass/branches/releasebranch_6_4/gui/wxpython/gui_modules/menuform.py
===================================================================
--- grass/branches/releasebranch_6_4/gui/wxpython/gui_modules/menuform.py	2009-05-04 18:09:34 UTC (rev 36994)
+++ grass/branches/releasebranch_6_4/gui/wxpython/gui_modules/menuform.py	2009-05-04 18:16:38 UTC (rev 36995)
@@ -1004,6 +1004,25 @@
             else:
                 text_style = wx.FONTWEIGHT_BOLD
 
+            # title sizer (description, name, type)
+            if (len(p.get('values', []) ) > 0) and \
+                    p.get('multiple', 'no') == 'yes' and \
+                    p.get('gisprompt',False) == False and \
+                    p.get('type', '') == 'string':
+                title_txt = wx.StaticBox (parent=which_panel, id=wx.ID_ANY)
+            else:
+                title_sizer = wx.BoxSizer(wx.HORIZONTAL)
+                title_txt = wx.StaticText(parent=which_panel)
+                rtitle_txt = wx.StaticText(parent=which_panel,
+                                           label = '(' + p['name'] + ', ' + p['type'] + ')')
+                title_sizer.Add(item=title_txt, proportion=1,
+                                flag=wx.LEFT | wx.TOP | wx.EXPAND, border=5)
+                title_sizer.Add(item=rtitle_txt, proportion=0,
+                                flag=wx.ALIGN_RIGHT | wx.RIGHT | wx.TOP, border=5)
+                which_sizer.Add(item=title_sizer, proportion=0,
+                                flag=wx.EXPAND)
+            self.label_id.append(title_txt.GetId())
+
             # title expansion
             if p.get('multiple','no') == 'yes' and len( p.get('values','') ) == 0:
                 title = _("[multiple]") + " " + title
@@ -1017,12 +1036,11 @@
                 if p.get('multiple', 'no') == 'yes' and \
                         p.get('gisprompt',False) == False and \
                         p.get('type', '') == 'string':
-                    txt = wx.StaticBox (parent=which_panel, id=0, label=" " + title + ": ")
-                    self.label_id.append(txt.GetId())
+                    title_txt.SetLabel(" " + title + ": ")
                     if len(valuelist) > 6:
-                        hSizer=wx.StaticBoxSizer ( box=txt, orient=wx.VERTICAL )
+                        hSizer=wx.StaticBoxSizer ( box=title_txt, orient=wx.VERTICAL )
                     else:
-                        hSizer=wx.StaticBoxSizer ( box=txt, orient=wx.HORIZONTAL )
+                        hSizer=wx.StaticBoxSizer ( box=title_txt, orient=wx.HORIZONTAL )
                     isEnabled = {}
                     # copy default values
                     if p['value'] == '':
@@ -1052,15 +1070,11 @@
                         
                     which_sizer.Add( item=hSizer, proportion=0,
                                      flag=wx.EXPAND | wx.TOP | wx.RIGHT | wx.LEFT, border=5 )
-                elif p.get('gisprompt',False) == False:
+                elif p.get('gisprompt', False) == False:
                     if len(valuelist) == 1: # -> textctrl
-                        txt = wx.StaticText(parent=which_panel,
-                                            label = "%s. %s %s" % (title, _('Valid range'),
-                                                                   str(valuelist[0]) + ':'))
-                        self.label_id.append(txt.GetId())
-                        which_sizer.Add(item=txt, proportion=0,
-                                        flag=wx.ADJUST_MINSIZE | wx.TOP | wx.RIGHT | wx.LEFT, border=5)
-
+                        title_txt.SetLabel("%s. %s %s" % (title, _('Valid range'),
+                                                          str(valuelist[0]) + ':'))
+                        
                         if p.get('type','') == 'integer' and \
                                 p.get('multiple','no') == 'no':
 
@@ -1076,7 +1090,7 @@
                             style = wx.BOTTOM | wx.LEFT
                         else:
                             txt2 = wx.TextCtrl(parent=which_panel, value = p.get('default',''))
-                            txt.SetName("TextCtrl")
+                            txt2.SetName("TextCtrl")
                             style = wx.EXPAND | wx.BOTTOM | wx.LEFT
                         
                         if p.get('value', '') != '':
@@ -1093,10 +1107,7 @@
                         txt2.Bind(wx.EVT_TEXT, self.OnSetValue)
                     else:
                         # list of values (combo)
-                        txt = wx.StaticText(parent=which_panel, label = title + ':' )
-                        self.label_id.append(txt.GetId())
-                        which_sizer.Add(item=txt, proportion=0,
-                                        flag=wx.ADJUST_MINSIZE | wx.TOP | wx.RIGHT | wx.LEFT, border=5)
+                        title_txt.SetLabel(title + ':')
                         cb = wx.ComboBox(parent=which_panel, id=wx.ID_ANY, value=p.get('default',''),
                                          size=globalvar.DIALOG_COMBOBOX_SIZE,
                                          choices=valuelist, style=wx.CB_DROPDOWN | wx.CB_READONLY)
@@ -1113,11 +1124,7 @@
                 and p.get('gisprompt',False) == False
                 and p.get('prompt','') != 'color'):
 
-                txt = wx.StaticText(parent=which_panel, label = title + ':' )
-                self.label_id.append(txt.GetId())
-                which_sizer.Add(item=txt, proportion=0,
-                                flag=wx.EXPAND | wx.RIGHT | wx.LEFT | wx.TOP, border=5)
-
+                title_txt.SetLabel(title + ':' )
                 if p.get('multiple','yes') == 'yes' or \
                         p.get('type', 'string') in ('string', 'float') or \
                         len(p.get('key_desc', [])) > 1:
@@ -1149,10 +1156,7 @@
             # element selection tree combobox (maps, icons, regions, etc.)
             #
             if p.get('gisprompt', False) == True:
-                txt = wx.StaticText(parent=which_panel, label = title + ':')
-                self.label_id.append(txt.GetId())
-                which_sizer.Add(item=txt, proportion=0,
-                                flag=wx.ADJUST_MINSIZE | wx.RIGHT | wx.LEFT | wx.TOP, border=5)
+                title_txt.SetLabel(title + ':')
                 # GIS element entry
                 if p.get('prompt','') not in ('color',
                                               'color_none',
@@ -1309,8 +1313,7 @@
                     # we have to target the button here
                     p['wxId'] = fbb.GetChildren()[1].GetId()
 
-            if txt is not None:
-                # txt.SetFont( wx.Font( fontsize, wx.FONTFAMILY_DEFAULT, wx.NORMAL, text_style, 0, ''))
+            if title_txt is not None:
                 # create tooltip if given
                 if len(p['values_desc']) > 0:
                     if tooltip:
@@ -1322,7 +1325,7 @@
                             tooltip += p['values'][i] + ': ' + p['values_desc'][i] + os.linesep
                     tooltip.strip(os.linesep)
                 if tooltip:
-                    txt.SetToolTipString(tooltip)
+                    title_txt.SetToolTipString(tooltip)
 
             if p == first_param:
                 if type(p['wxId']) == type(1):



More information about the grass-commit mailing list