Adding support for using Networkedit et PLCOpenEditor in Beremiz
authorlbessard
Mon, 10 Sep 2007 18:19:53 +0200 (2007-09-10)
changeset 25 fa7503684c28
parent 24 585d5b387b6a
child 26 7bc11b005c8b
Adding support for using Networkedit et PLCOpenEditor in Beremiz
Beremiz.py
plugger.py
plugins/canfestival/canfestival.py
--- a/Beremiz.py	Mon Sep 10 18:12:03 2007 +0200
+++ b/Beremiz.py	Mon Sep 10 18:19:53 2007 +0200
@@ -32,9 +32,6 @@
 
 from plugger import PluginsRoot
 
-def CHECK_WX_VERSION(major, minor, release):
-    return not (wx.MAJOR_VERSION < major or wx.MINOR_VERSION < minor or wx.RELEASE_NUMBER < release)
-
 class LogPseudoFile:
     """ Base class for file like objects to facilitate StdOut for the Shell."""
     def __init__(self, output = None):
@@ -255,7 +252,7 @@
     def _init_ctrls(self, prnt):
         wx.Frame.__init__(self, id=ID_BEREMIZ, name=u'Beremiz',
               parent=prnt, pos=wx.Point(0, 0), size=wx.Size(1000, 600),
-              style=wx.DEFAULT_FRAME_STYLE, title=u'Beremiz')
+              style=wx.DEFAULT_FRAME_STYLE|wx.CLIP_CHILDREN, title=u'Beremiz')
         self._init_utils()
         self.SetClientSize(wx.Size(1000, 600))
         self.SetMenuBar(self.menuBar1)
@@ -440,8 +437,22 @@
             # Refresh ParamsPanel
             self.ParamsPanel.Show()
             infos = plugin.GetParamsAttributes()
-            self.RefreshSizerElement(self.ParamsPanelMainSizer, infos, None)
-            if len(plugin.PluginMethods) > 0:
+            if wx.VERSION >= (2, 7, 0):
+                self.ParamsPanelMainSizer.Clear(True)
+            else:
+                self.ClearSizer(self.ParamsPanelMainSizer)
+            if len(self.PluginRoot.PluginMethods) > 0:
+                boxsizer = wx.BoxSizer(wx.HORIZONTAL)
+                self.ParamsPanelMainSizer.AddSizer(boxsizer, 0, border=5, flag=wx.GROW|wx.ALL)
+                for name, method in self.PluginRoot.PluginMethods:
+                    if method:
+                        id = wx.NewId()
+                        button = wx.Button(id=id, label=name, name=name, parent=self.ParamsPanel, 
+                            pos=wx.Point(0, 0), style=wx.BU_EXACTFIT)
+                        button.Bind(wx.EVT_BUTTON, self.GetButtonCallBackFunction(self.PluginRoot, method), id=id)
+                        boxsizer.AddWindow(button, 0, border=5, flag=wx.GROW|wx.RIGHT)
+            self.RefreshSizerElement(self.ParamsPanelMainSizer, infos, None, False)
+            if plugin != self.PluginRoot and len(plugin.PluginMethods) > 0:
                 boxsizer = wx.BoxSizer(wx.HORIZONTAL)
                 self.ParamsPanelMainSizer.AddSizer(boxsizer, 0, border=5, flag=wx.GROW|wx.ALL)
                 for name, method in plugin.PluginMethods:
@@ -524,11 +535,12 @@
         for staticbox in staticboxes:
             staticbox.Destroy()
                 
-    def RefreshSizerElement(self, sizer, elements, path):
-        if wx.VERSION >= (2, 7, 0):
-            sizer.Clear(True)
-        else:
-            self.ClearSizer(sizer)
+    def RefreshSizerElement(self, sizer, elements, path, clean = True):
+        if clean:
+            if wx.VERSION >= (2, 7, 0):
+                sizer.Clear(True)
+            else:
+                self.ClearSizer(sizer)
         first = True
         for element_infos in elements:
             if path:
--- a/plugger.py	Mon Sep 10 18:12:03 2007 +0200
+++ b/plugger.py	Mon Sep 10 18:19:53 2007 +0200
@@ -565,6 +565,8 @@
     def SaveProject(self):
         if not self.PLCManager.SaveXMLFile():
             self.PLCManager.SaveXMLFile(os.path.join(self.ProjectPath, 'plc.xml'))
+        if self.PLCEditor:
+            self.PLCEditor.RefreshTitle()
         self.PlugRequestSave()
     
     def PlugPath(self, PlugName=None):
@@ -705,11 +707,17 @@
 
     def _EditPLC(self, logger):
         if not self.PLCEditor:
+            def _onclose():
+                self.PLCEditor = None
+            def _onsave():
+                self.SaveProject()
             self.PLCEditor = PLCOpenEditor(self.AppFrame, self.PLCManager)
             self.PLCEditor.RefreshProjectTree()
             self.PLCEditor.RefreshFileMenu()
             self.PLCEditor.RefreshEditMenu()
             self.PLCEditor.RefreshToolBar()
+            self.PLCEditor._onclose = _onclose
+            self.PLCEditor._onsave = _onsave
             self.PLCEditor.Show()
 
     def _Clean(self, logger):
--- a/plugins/canfestival/canfestival.py	Mon Sep 10 18:12:03 2007 +0200
+++ b/plugins/canfestival/canfestival.py	Mon Sep 10 18:19:53 2007 +0200
@@ -36,10 +36,13 @@
         if not self._View:
             def _onclose():
                 self.View = None
+            def _onsave():
+                self.GetPlugRoot().SaveProject()
             self._View = _NetworkEdit(self.GetPlugRoot().AppFrame, self)
             # TODO redefine BusId when IEC channel change
             self._View.SetBusId(self.GetCurrentLocation())
             self._View._onclose = _onclose
+            self._View._onsave = _onsave
             self._View.Show()
 
     PluginMethods = [("NetworkEdit",_OpenView)]