[GRASS-SVN] r43285 - grass/trunk/gui/wxpython/gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Thu Aug 26 16:47:49 EDT 2010


Author: martinl
Date: 2010-08-26 20:47:49 +0000 (Thu, 26 Aug 2010)
New Revision: 43285

Modified:
   grass/trunk/gui/wxpython/gui_modules/gmodeler.py
Log:
wxGUI/modeler: if-else condition properties in progress


Modified: grass/trunk/gui/wxpython/gui_modules/gmodeler.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/gmodeler.py	2010-08-26 14:19:28 UTC (rev 43284)
+++ grass/trunk/gui/wxpython/gui_modules/gmodeler.py	2010-08-26 20:47:49 UTC (rev 43285)
@@ -1,7 +1,7 @@
 """!
 @package gmodeler.py
 
- at brief Graphical modeler to create, edit, and manage models
+ at brief wxGUI Graphical Modeler for creating, editing, and managing models
 
 Classes:
  - Model
@@ -22,12 +22,14 @@
  - VariablePanel
  - ValiableListCtrl
  - ModelItem
+ - ModelItemDialog
  - ModelLoop
  - ModelLoopDialog
  - ItemPanel
  - ItemListCtrl
  - ItemCheckListCtrl
  - ModelCondition
+ - ModelConditionDialog
 
 (C) 2010 by the GRASS Development Team
 This program is free software under the GNU General Public License
@@ -210,7 +212,7 @@
         for data in self.GetData():
             if data.GetValue() == value and \
                     data.GetPrompt() == prompt:
-                return dataItem
+                return data
         
         return None
                 
@@ -332,7 +334,7 @@
             loopItem.SetItems(alist)
             
             for action in loopItem.GetItems():
-                action.SetLoop(loopItem)
+                action.SetBlock(loopItem)
         
     def AddItem(self, newItem):
         """!Add item to the list"""
@@ -1645,7 +1647,7 @@
         self.rels = list() # list of ModelRelations
         
         self.isEnabled = True
-        self.inLoop = None
+        self.inBlock   = None
         
     def GetId(self):
         """!Get id"""
@@ -1658,7 +1660,7 @@
 
     def GetRelations(self, fdir = None):
         """!Get list of relations
-
+        
         @param fdir True for 'from'
         """
         if fdir is None:
@@ -1687,29 +1689,29 @@
     def Update(self):
         pass
 
-    def SetLoop(self, loop = None):
+    def SetBlock(self, item = None):
         """!Register loop
 
-        @param loop reference to loop (None to unset)
+        @param item reference to ModelObject which defines block of ModelObject (None to unset)
         """
-        self.inLoop = loop
+        self.inBlock = item
 
-    def GetLoop(self):
-        """!Get related loop
+    def GetBlock(self):
+        """!Get related ModelObject which defines block
 
-        @return ModelLoop instance
-        @return None if no loop defined
+        @return ModelLoop/ModelCondition instance
+        @return None if no block defined for this item
         """
-        return self.inLoop
+        return self.inBlock
     
-    def GetLoopId(self):
-        """!Get id of the loop
+    def GetBlockId(self):
+        """!Get id of ModelObject which defines block
 
-        @return loop id 
-        @return None if action is not in the loop
+        @return item id 
+        @return None if action is not in the block
         """
-        if self.inLoop:
-            return self.inLoop.GetId()
+        if self.inBlock:
+            return self.inBlock.GetId()
         
         return None
     
@@ -2200,7 +2202,6 @@
         
         elif isinstance(shape, ModelLoop):
             dlg = ModelLoopDialog(parent = self.frame, shape = shape)
-            ### shape.SetPropDialog(dlg)
             dlg.CentreOnParent()
             if dlg.ShowModal() == wx.ID_OK:
                 shape.SetText(dlg.GetCondition())
@@ -2208,10 +2209,10 @@
                 ids = dlg.GetItems()
                 for aId in ids['unchecked']:
                     action = self.frame.GetModel().GetItem(aId)
-                    action.SetLoop()
+                    action.SetBlock()
                 for aId in ids['checked']:
                     action = self.frame.GetModel().GetItem(aId)
-                    action.SetLoop(shape)
+                    action.SetBlock(shape)
                     if action:
                         alist.append(action)
                 shape.SetItems(alist)
@@ -2220,6 +2221,14 @@
             
             dlg.Destroy()
         
+        elif isinstance(shape, ModelCondition):
+            dlg = ModelConditionDialog(parent = self.frame, shape = shape)
+            dlg.CentreOnParent()
+            if dlg.ShowModal() == wx.ID_OK:
+                shape.SetText(dlg.GetCondition())
+            
+            dlg.Destroy()
+                   
     def OnBeginDragLeft(self, x, y, keys = 0, attachment = 0):
         """!Drag shape (begining)"""
         self.frame.ModelChanged()
@@ -2234,7 +2243,7 @@
         shape = self.GetShape()
         if isinstance(shape, ModelLoop):
             self.frame.DefineLoop(shape)
-        loop = shape.GetLoop()
+        loop = shape.GetBlock()
         if loop:
             self.frame.DefineLoop(loop)
         
@@ -3852,6 +3861,45 @@
         """!Clear object, remove rels"""
         self.rels = list()
         
+class ModelItemDialog(wx.Dialog):
+    """!Abstract item properties dialog"""
+    def __init__(self, parent, shape, title, id = wx.ID_ANY,
+                 style = wx.DEFAULT_DIALOG_STYLE | wx.RESIZE_BORDER, **kwargs):
+        self.parent = parent
+        self.shape = shape
+        
+        wx.Dialog.__init__(self, parent, id, title = title, style = style, **kwargs)
+        
+        self.panel = wx.Panel(parent = self, id = wx.ID_ANY)
+        
+        self.condBox = wx.StaticBox(parent = self.panel, id = wx.ID_ANY,
+                                    label=" %s " % _("Condition"))
+        self.condText = wx.TextCtrl(parent = self.panel, id = wx.ID_ANY,
+                                    value = shape.GetText())
+        
+        self.itemList = ItemCheckListCtrl(parent = self.panel,
+                                          window = self,
+                                          columns = [_("ID"), _("Name"),
+                                                     _("Command")],
+                                          excludeId = [shape.GetId()])
+        self.itemList.Populate(self.parent.GetModel().GetItems())
+        
+        self.btnCancel = wx.Button(parent = self.panel, id = wx.ID_CANCEL)
+        self.btnOk     = wx.Button(parent = self.panel, id = wx.ID_OK)
+        self.btnOk.SetDefault()
+        
+    def _layout(self):
+        """!Do layout (virtual method)"""
+        pass
+    
+    def GetItems(self):
+        """!Get list of selected actions"""
+        return self.itemList.GetItems()
+    
+    def GetCondition(self):
+        """!Get loop condition"""
+        return self.condText.GetValue()
+    
 class ModelLoop(ModelItem, ogl.RectangleShape):
     def __init__(self, parent, x, y, id = -1, width = None, height = None, text = '', items = []):
         """!Defines a loop"""
@@ -3879,33 +3927,16 @@
         """!Get name"""
         return _("loop")
 
-class ModelLoopDialog(wx.Dialog):
+class ModelLoopDialog(ModelItemDialog):
     """!Loop properties dialog"""
     def __init__(self, parent, shape, id = wx.ID_ANY, title = _("Loop properties"),
                  style = wx.DEFAULT_DIALOG_STYLE | wx.RESIZE_BORDER, **kwargs):
-        self.parent = parent
-        self.shape = shape
+        ModelItemDialog.__init__(self, parent, shape, title,
+                                 style = style, **kwargs)
         
-        wx.Dialog.__init__(self, parent, id, title = title, style = style, **kwargs)
-        
-        self.panel = wx.Panel(parent = self, id = wx.ID_ANY)
-        
-        self.condBox = wx.StaticBox(parent = self.panel, id = wx.ID_ANY,
-                                    label=" %s " % _("Condition"))
-        self.condText = wx.TextCtrl(parent = self.panel, id = wx.ID_ANY,
-                                    value = shape.GetText())
         self.listBox = wx.StaticBox(parent = self.panel, id = wx.ID_ANY,
                                     label=" %s " % _("List of items in loop"))
-        self.itemList = ItemCheckListCtrl(parent = self.panel,
-                                          columns = [_("ID"), _("Name"),
-                                                     _("Command")],
-                                          excludeId = [shape.GetId()])
-        self.itemList.Populate(self.parent.GetModel().GetItems())
         
-        self.btnCancel = wx.Button(parent = self.panel, id = wx.ID_CANCEL)
-        self.btnOk     = wx.Button(parent = self.panel, id = wx.ID_OK)
-        self.btnOk.SetDefault()
-        
         self._layout()
         self.SetMinSize(self.GetSize())
         self.SetSize((500, 400))
@@ -3939,23 +3970,6 @@
         
         self.Layout()
 
-    def GetItems(self):
-        """!Get list of selected actions"""
-        ids = { 'checked'   : list(),
-                'unchecked' : list() }
-        for i in range(self.itemList.GetItemCount()):
-            iId = int(self.itemList.GetItem(i, 0).GetText())
-            if self.itemList.IsChecked(i):
-                ids['checked'].append(iId)
-            else:
-                ids['unchecked'].append(iId)
-        
-        return ids
-        
-    def GetCondition(self):
-        """!Get loop condition"""
-        return self.condText.GetValue()
-    
 class ItemPanel(wx.Panel):
     def __init__(self, parent, id = wx.ID_ANY,
                  **kwargs):
@@ -3969,8 +3983,8 @@
                                     label=" %s " % _("List of items - right-click to delete"))
         
         self.list = ItemListCtrl(parent = self,
-                                 columns = [_("ID"), _("Name"), _("In item"),
-                                            _("Command / condition")])
+                                 columns = [_("ID"), _("Name"), _("In block"),
+                                            _("Command / Condition")])
         
         self._layout()
 
@@ -4013,7 +4027,7 @@
         """!Populate the list"""
         self.itemDataMap = dict()
         i = 0
-        if len(self.columns) == 3:
+        if len(self.columns) == 3: # ItemCheckList
             checked = list()
         for action in data:
             if action.GetId() in self.excludeId:
@@ -4022,11 +4036,17 @@
                 self.itemDataMap[i] = [str(action.GetId()),
                                        action.GetName(),
                                        action.GetLog()]
-                checked.append(action.GetLoopId())
+                aId = action.GetBlockId()
+                if aId not in self.excludeId:
+                    aId = None
+                checked.append(aId)
             else:
+                bId = action.GetBlockId()
+                if not bId:
+                    bId = ''
                 self.itemDataMap[i] = [str(action.GetId()),
                                        action.GetName(),
-                                       str(action.GetLoopId()),
+                                       str(bId),
                                        action.GetLog()]
             
             i += 1
@@ -4160,7 +4180,10 @@
         self.frame.ModelChanged()
 
 class ItemCheckListCtrl(ItemListCtrl, listmix.CheckListCtrlMixin):
-    def __init__(self, parent, columns, excludeId = [], **kwargs):
+    def __init__(self, parent, columns, window = None, excludeId = [], **kwargs):
+        self.parent = parent
+        self.window = window
+        
         ItemListCtrl.__init__(self, parent, columns, excludeId, disablePopup = True, **kwargs)
         listmix.CheckListCtrlMixin.__init__(self)
         self.SetColumnWidth(0, 50)
@@ -4168,7 +4191,36 @@
     def OnBeginEdit(self, event):
         """!Disable editing"""
         event.Veto()
+        
+    def OnCheckItem(self, index, flag):
+        """!Item checked/unchecked"""
+        name = self.GetName()
+        if name == 'IfBlockList' and self.window:
+            self.window.OnCheckItemIf(index, flag)
+        elif name == 'ElseBlockList' and self.window:
+            self.window.OnCheckItemElse(index, flag)
+        
+    def GetItems(self):
+        """!Get list of selected actions"""
+        ids = { 'checked'   : list(),
+                'unchecked' : list() }
+        for i in range(self.GetItemCount()):
+            iId = int(self.GetItem(i, 0).GetText())
+            if self.IsChecked(i):
+                ids['checked'].append(iId)
+            else:
+                ids['unchecked'].append(iId)
+            
+        return ids
 
+    def CheckItemById(self, aId, flag):
+        """!Check/uncheck given item by id"""
+        for i in range(self.GetItemCount()):
+            iId = int(self.GetItem(i, 0).GetText())
+            if iId == aId:
+                self.CheckItem(i, flag)
+                break
+        
 class ModelCondition(ModelItem, ogl.PolygonShape):
     def __init__(self, parent, x, y, id = -1, width = None, height = None, text = '', items = []):
         """!Defines a condition"""
@@ -4214,6 +4266,84 @@
         """!Get object height"""
         return self.height
 
+class ModelConditionDialog(ModelItemDialog):
+    """!Condition properties dialog"""
+    def __init__(self, parent, shape, id = wx.ID_ANY, title = _("If-else properties"),
+                 style = wx.DEFAULT_DIALOG_STYLE | wx.RESIZE_BORDER, **kwargs):
+        ModelItemDialog.__init__(self, parent, shape, title,
+                                 style = style, **kwargs)
+        
+        self.listBoxIf = wx.StaticBox(parent = self.panel, id = wx.ID_ANY,
+                                      label=" %s " % _("List of items in 'if' block"))
+        self.itemListIf = self.itemList
+        self.itemListIf.SetName('IfBlockList')
+        
+        self.listBoxElse = wx.StaticBox(parent = self.panel, id = wx.ID_ANY,
+                                        label=" %s " % _("List of items in 'else' block"))
+        self.itemListElse = ItemCheckListCtrl(parent = self.panel,
+                                              window = self,
+                                              columns = [_("ID"), _("Name"),
+                                                         _("Command")],
+                                              excludeId = [shape.GetId()])
+        self.itemListElse.SetName('ElseBlockList')
+        self.itemListElse.Populate(self.parent.GetModel().GetItems())
+        
+        self._layout()
+        self.SetMinSize(self.GetSize())
+        self.SetSize((500, 400))
+        
+    def _layout(self):
+        """!Do layout"""
+        sizer = wx.BoxSizer(wx.VERTICAL)
+        
+        condSizer = wx.StaticBoxSizer(self.condBox, wx.VERTICAL)
+        condSizer.Add(item = self.condText, proportion = 1,
+                      flag = wx.EXPAND)
+        
+        listIfSizer = wx.StaticBoxSizer(self.listBoxIf, wx.VERTICAL)
+        listIfSizer.Add(item = self.itemListIf, proportion = 1,
+                        flag = wx.EXPAND)
+        listElseSizer = wx.StaticBoxSizer(self.listBoxElse, wx.VERTICAL)
+        listElseSizer.Add(item = self.itemListElse, proportion = 1,
+                          flag = wx.EXPAND)
+        
+        btnSizer = wx.StdDialogButtonSizer()
+        btnSizer.AddButton(self.btnCancel)
+        btnSizer.AddButton(self.btnOk)
+        btnSizer.Realize()
+
+        sizer.Add(item = condSizer, proportion = 0,
+                  flag = wx.EXPAND | wx.ALL, border = 3)
+        sizer.Add(item = listIfSizer, proportion = 1,
+                  flag = wx.EXPAND | wx.LEFT | wx.RIGHT, border = 3)
+        sizer.Add(item = listElseSizer, proportion = 1,
+                  flag = wx.EXPAND | wx.LEFT | wx.RIGHT, border = 3)
+        sizer.Add(item = btnSizer, proportion=0,
+                  flag = wx.EXPAND | wx.ALL | wx.ALIGN_CENTER, border=5)
+        
+        self.panel.SetSizer(sizer)
+        sizer.Fit(self.panel)
+        
+        self.Layout()
+
+    def OnCheckItemIf(self, index, flag):
+        """!Item in if-block checked/unchecked"""
+        if flag is False:
+            return
+        
+        aId = int(self.itemListIf.GetItem(index, 0).GetText())
+        if aId in self.itemListElse.GetItems()['checked']:
+            self.itemListElse.CheckItemById(aId, False)
+            
+    def OnCheckItemElse(self, index, flag):
+        """!Item in else-block checked/unchecked"""
+        if flag is False:
+            return
+        
+        aId = int(self.itemListElse.GetItem(index, 0).GetText())
+        if aId in self.itemListIf.GetItems()['checked']:
+            self.itemListIf.CheckItemById(aId, False)
+        
 def main():
     app = wx.PySimpleApp()
     wx.InitAllImageHandlers()



More information about the grass-commit mailing list