1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
5 from turbogears import controllers, expose, redirect
6 from turbogears import validate, flash, error_handler
7 from turbogears import validators as V
8 from turbogears import widgets as W
9 from turbogears import identity
10 from turbogears import paginate
11 from docutils.core import publish_parts
12 from sercom.subcontrollers import validate as val
13 from sercom.model import Alumno
24 return val.validate_get(cls, name, id)
26 def validate_set(id, data):
27 return val.validate_set(cls, name, id, data)
29 def validate_new(data):
30 return val.validate_new(cls, name, data)
34 class AlumnoForm(W.TableForm):
35 class Fields(W.WidgetsList):
36 padron = W.TextField(label=_(u'Padrón'),
37 help_text=_(u'Requerido y único.'),
38 validator=V.UnicodeString(min=3, max=10, strip=True))
39 nombre = W.TextField(label=_(u'Nombre'),
40 help_text=_(u'Requerido.'),
41 validator=V.UnicodeString(min=10, max=255, strip=True))
42 email = W.TextField(label=_(u'E-Mail'),
43 #help_text=_(u'Dirección de e-mail.'),
45 V.Email(not_empty=False, resolve_domain=True),
46 V.UnicodeString(not_empty=False, max=255, strip=True)))
47 telefono = W.TextField(label=_(u'Teléfono'),
48 #help_text=_(u'Texto libre para teléfono, se puede incluir '
49 # 'horarios o varias entradas.'),
50 validator=V.UnicodeString(not_empty=False, min=7, max=255,
52 nota = W.TextField(label=_(u'Nota'),
53 #help_text=_(u'Texto libre para teléfono, se puede incluir '
54 # 'horarios o varias entradas.'),
55 validator=V.Number(not_empty=False, strip=True))
56 observaciones = W.TextArea(label=_(u'Observaciones'),
57 #help_text=_(u'Observaciones.'),
58 validator=V.UnicodeString(not_empty=False, strip=True))
59 activo = W.CheckBox(label=_(u'Activo'), default=1,
60 #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
61 validator=V.Bool(if_empty=1))
63 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_padron');")]
69 class AlumnoController(controllers.Controller, identity.SecureResource):
70 """Basic model admin interface"""
71 require = identity.has_permission('admin')
74 def default(self, tg_errors=None):
75 """handle non exist urls"""
76 raise redirect('list')
80 raise redirect('list')
82 @expose(template='kid:%s.templates.list' % __name__)
85 """List records in model"""
87 return dict(records=r, name=name, namepl=namepl)
90 def activate(self, id, activo):
91 """Save or create record to model"""
94 r.activo = bool(int(activo))
96 raise cherrypy.NotFound
97 raise redirect('../../list')
99 @expose(template='kid:%s.templates.new' % __name__)
101 """Create new records in model"""
102 return dict(name=name, namepl=namepl, form=form, values=kw)
107 def create(self, **kw):
108 """Save or create record to model"""
110 flash(_(u'Se creó un nuevo %s.') % name)
111 raise redirect('list')
113 @expose(template='kid:%s.templates.edit' % __name__)
114 def edit(self, id, **kw):
115 """Edit record in model"""
117 return dict(name=name, namepl=namepl, record=r, form=form)
122 def update(self, id, **kw):
123 """Save or create record to model"""
124 r = validate_set(id, kw)
125 flash(_(u'El %s fue actualizado.') % name)
126 raise redirect('../list')
128 @expose(template='kid:%s.templates.show' % __name__)
129 def show(self,id, **kw):
130 """Show record in model"""
132 if r.observaciones is None:
135 r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
136 return dict(name=name, namepl=namepl, record=r)
139 def delete(self, id):
140 """Destroy record in model"""
143 flash(_(u'El %s fue eliminado permanentemente.') % name)
144 raise redirect('../list')
146 @expose(template='kid:%s.templates.from_file' % __name__)
150 @expose(template='kid:%s.templates.import_results' % __name__)
151 def from_file_add(self, archivo):
153 padron,nombre,email,telefono
156 lines = archivo.file.read().split('\n')
160 for row in csv.reader([line]):
164 u = Alumno(row[0], nombre=row[1])
167 u.contrasenia = row[0]
173 return dict(ok=ok, fail=fail)