1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
|
"""
"""
from . import widget
class Form(widget.Widget):
"""A form that automatically will contain all named widgets.
After a form is created, all named widget that are subsequently created are
added to that form. You may use dict style access to access named widgets.
Example:
f = gui.Form()
w = gui.Input("Phil",name="firstname")
w = gui.Input("Hassey",name="lastname")
print f.results()
print ''
print f.items()
print ''
print f['firstname'].value
print f['lastname'].value
"""
# The current form instance
form = None
# The list of PGU widgets that are tracked by this form
_elist = None
# A mapping of PGU widgets tracked by this form (name -> instance)
_emap = None
# The dirty flag is set when a new widget is added to the form
_dirty = 0
def __init__(self):
widget.Widget.__init__(self,decorate=False)
self._elist = []
self._emap = {}
self._dirty = 0
# Register this form as the one used by new widgets
Form.form = self
def add(self,e,name=None,value=None):
"""Adds a PGU widget to this form"""
if name != None: e.name = name
if value != None: e.value = value
self._elist.append(e)
self._dirty = 1
def _clean(self):
# Remove elements from our list if they no longer have an assigned name
for e in self._elist[:]:
if not hasattr(e,'name') or e.name == None:
self._elist.remove(e)
# Update the name-to-widget mapping
self._emap = {}
for e in self._elist:
self._emap[e.name] = e
self._dirty = 0
def __getitem__(self,k):
"""Returns the widget instance given the name of the widget"""
if self._dirty: self._clean()
return self._emap[k]
def __contains__(self,k):
"""Returns true if this form contains the named widget"""
if self._dirty: self._clean()
if k in self._emap: return True
return False
def results(self):
"""Return a dict of name, widget-value pairs."""
if self._dirty: self._clean()
r = {}
for e in self._elist:
# Make sure the widget has a 'value' (eg tables do not)
if (hasattr(e, "value")):
r[e.name] = e.value
else:
r[e.name] = None
return r
def items(self):
"""Return a list of name, widget pairs."""
return self.results().items()
|