--- a/dialogs/FBDBlockDialog.py Thu Jun 06 23:48:25 2013 +0200
+++ b/dialogs/FBDBlockDialog.py Mon Jun 10 00:55:57 2013 +0200
@@ -22,19 +22,22 @@
#License along with this library; if not, write to the Free Software
#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+from graphics.FBD_Objects import FBD_Block from controls.LibraryPanel import LibraryPanel
+from BlockPreviewDialog import BlockPreviewDialog #-------------------------------------------------------------------------------
# Create New Block Dialog
#-------------------------------------------------------------------------------
-class FBDBlockDialog(wx.Dialog):
+class FBDBlockDialog(BlockPreviewDialog): - def __init__(self, parent, controller):
- wx.Dialog.__init__(self, parent,
+ def __init__(self, parent, controller, tagname): + BlockPreviewDialog.__init__(self, parent, controller, tagname, size=wx.Size(600, 450), title=_('Block Properties'))
main_sizer = wx.FlexGridSizer(cols=1, hgap=0, rows=4, vgap=10)
@@ -99,49 +102,22 @@
self.Bind(wx.EVT_CHECKBOX, self.OnExecutionOrderChanged, self.ExecutionControl)
top_right_gridsizer.AddWindow(self.ExecutionControl, flag=wx.GROW)
- preview_label = wx.StaticText(self, label=_('Preview:'))
- right_gridsizer.AddWindow(preview_label, flag=wx.GROW)
- self.Preview = wx.Panel(self,
- style=wx.TAB_TRAVERSAL|wx.SIMPLE_BORDER)
- self.Preview.SetBackgroundColour(wx.Colour(255,255,255))
- setattr(self.Preview, "GetDrawingMode", lambda:FREEDRAWING_MODE)
- setattr(self.Preview, "GetScaling", lambda:None)
- setattr(self.Preview, "GetBlockType", controller.GetBlockType)
- setattr(self.Preview, "IsOfType", controller.IsOfType)
- self.Preview.Bind(wx.EVT_PAINT, self.OnPaint)
+ right_gridsizer.AddWindow(self.PreviewLabel, flag=wx.GROW) right_gridsizer.AddWindow(self.Preview, flag=wx.GROW)
- button_sizer = self.CreateButtonSizer(wx.OK|wx.CANCEL|wx.CENTRE)
- self.Bind(wx.EVT_BUTTON, self.OnOK, button_sizer.GetAffirmativeButton())
- main_sizer.AddSizer(button_sizer, border=20,
+ main_sizer.AddSizer(self.ButtonSizer, border=20, flag=wx.ALIGN_RIGHT|wx.BOTTOM|wx.LEFT|wx.RIGHT)
self.SetSizer(main_sizer)
- self.Controller = controller
self.BlockName.SetValue("")
self.BlockName.Enable(False)
self.Inputs.Enable(False)
- self.MinBlockSize = None
+ self.CurrentBlockName = None
- self.PouElementNames = []
+ self.LibraryPanel.SetBlockList(controller.GetBlockTypes(tagname)) self.LibraryPanel.SetFocus()
- def SetBlockList(self, blocklist):
- self.LibraryPanel.SetBlockList(blocklist)
- def SetPreviewFont(self, font):
- self.Preview.SetFont(font)
selected = self.LibraryPanel.GetSelectedBlock()
@@ -151,37 +127,23 @@
message = _("Form isn't complete. Valid block type must be selected!")
elif name_enabled and block_name == "":
message = _("Form isn't complete. Name must be filled!")
- elif name_enabled and not TestIdentifier(block_name):
- message = _("\"%s\" is not a valid identifier!") % block_name
- elif name_enabled and block_name.upper() in IEC_KEYWORDS:
- message = _("\"%s\" is a keyword. It can't be used!") % block_name
- elif name_enabled and block_name.upper() in self.PouNames:
- message = _("\"%s\" pou already exists!") % block_name
- elif name_enabled and block_name.upper() in self.PouElementNames:
- message = _("\"%s\" element for this pou already exists!") % block_name
- dialog = wx.MessageDialog(self, message, _("Error"), wx.OK|wx.ICON_ERROR)
- self.EndModal(wx.ID_OK)
+ self.ShowMessage(message) + elif name_enabled and self.TestBlockName(block_name): + BlockPreviewDialog.OnOK(self, event) - def SetMinBlockSize(self, size):
- self.MinBlockSize = size
- def SetPouNames(self, pou_names):
- self.PouNames = [pou_name.upper() for pou_name in pou_names]
- def SetPouElementNames(self, element_names):
- self.PouElementNames = [element_name.upper() for element_name in element_names]
def SetValues(self, values):
blocktype = values.get("type", None)
+ default_name_model = re.compile("%s[0-9]+" % blocktype) if blocktype is not None:
- self.LibraryPanel.SelectTreeItem(blocktype, values.get("inputs", None))
+ self.LibraryPanel.SelectTreeItem(blocktype, + values.get("inputs", None)) for name, value in values.items():
- self.BlockName.SetValue(value)
+ self.DefaultBlockName = value + if default_name_model.match(value) is None: + self.CurrentBlockName = value + self.BlockName.ChangeValue(value) elif name == "extension":
self.Inputs.SetValue(value)
elif name == "executionOrder":
@@ -199,26 +161,36 @@
values["executionOrder"] = self.ExecutionOrder.GetValue()
values["executionControl"] = self.ExecutionControl.GetValue()
def OnLibraryTreeItemSelected(self, event):
values = self.LibraryPanel.GetSelectedBlock()
- blocktype = self.Controller.GetBlockType(values["type"], values["inputs"])
+ blocktype = (self.Controller.GetBlockType(values["type"], + if values is not None else None) if blocktype is not None:
self.Inputs.SetValue(len(blocktype["inputs"]))
self.Inputs.Enable(blocktype["extensible"])
- self.BlockName.Enable(blocktype["type"] != "function")
- wx.CallAfter(self.RefreshPreview)
+ self.Inputs.SetValue(2) + self.Inputs.Enable(False) + if blocktype is not None and blocktype["type"] != "function": + self.BlockName.Enable(True) + self.BlockName.ChangeValue( + if self.CurrentBlockName is not None + else self.Controller.GenerateNewName( + self.TagName, None, values["type"]+"%d", 0)) self.BlockName.Enable(False)
- self.Inputs.Enable(False)
- self.Inputs.SetValue(2)
- wx.CallAfter(self.ErasePreview)
+ self.BlockName.ChangeValue("") def OnNameChanged(self, event):
if self.BlockName.IsEnabled():
+ self.CurrentBlockName = self.BlockName.GetValue() @@ -235,15 +207,7 @@
- def ErasePreview(self):
- dc = wx.ClientDC(self.Preview)
def RefreshPreview(self):
- dc = wx.ClientDC(self.Preview)
- dc.SetFont(self.Preview.GetFont())
values = self.LibraryPanel.GetSelectedBlock()
if self.BlockName.IsEnabled():
@@ -256,19 +220,6 @@
inputs = values["inputs"],
executionControl = self.ExecutionControl.GetValue(),
executionOrder = self.ExecutionOrder.GetValue())
- width, height = self.MinBlockSize
- min_width, min_height = self.Block.GetMinSize()
- width, height = max(min_width, width), max(min_height, height)
- self.Block.SetSize(width, height)
- clientsize = self.Preview.GetClientSize()
- x = (clientsize.width - width) / 2
- y = (clientsize.height - height) / 2
- self.Block.SetPosition(x, y)
- def OnPaint(self, event):
- if self.Block is not None:
+ BlockPreviewDialog.RefreshPreview(self) --- a/editors/Viewer.py Thu Jun 06 23:48:25 2013 +0200
+++ b/editors/Viewer.py Mon Jun 10 00:55:57 2013 +0200
@@ -2197,11 +2197,8 @@
def AddNewBlock(self, bbox):
- dialog = FBDBlockDialog(self.ParentWindow, self.Controler)
+ dialog = FBDBlockDialog(self.ParentWindow, self.Controler, self.TagName) dialog.SetPreviewFont(self.GetFont())
- dialog.SetBlockList(self.Controler.GetBlockTypes(self.TagName, self.Debug))
- dialog.SetPouNames(self.Controler.GetProjectPouNames(self.Debug))
- dialog.SetPouElementNames(self.Controler.GetEditedElementVariables(self.TagName, self.Debug))
dialog.SetMinBlockSize((bbox.width, bbox.height))
if dialog.ShowModal() == wx.ID_OK:
@@ -2501,14 +2498,8 @@
#-------------------------------------------------------------------------------
def EditBlockContent(self, block):
- dialog = FBDBlockDialog(self.ParentWindow, self.Controler)
+ dialog = FBDBlockDialog(self.ParentWindow, self.Controler, self.TagName) dialog.SetPreviewFont(self.GetFont())
- dialog.SetBlockList(self.Controler.GetBlockTypes(self.TagName, self.Debug))
- dialog.SetPouNames(self.Controler.GetProjectPouNames(self.Debug))
- variable_names = self.Controler.GetEditedElementVariables(self.TagName, self.Debug)
- if block.GetName() != "":
- variable_names.remove(block.GetName())
- dialog.SetPouElementNames(variable_names)
dialog.SetMinBlockSize(block.GetSize())
old_values = {"name" : block.GetName(),
"type" : block.GetType(),