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, validators, flash, error_handler
7 from turbogears.widgets import *
8 from turbogears import identity
9 from turbogears import paginate
10 from docutils.core import publish_parts
11 from sercom.subcontrollers import validate as val
12 from sercom.model import Docente
22 def validate_get(id): return val.validate_get(cls, name, id)
23 def validate_set(id, data): return val.validate_set(cls, name, id, data)
24 def validate_new(data): return val.validate_new(cls, name, data)
28 form = TableForm(fields=[
29 TextField(name='usuario', label=_(u'Usuario'),
30 help_text=_(u'Requerido y único.'),
31 validator=validators.UnicodeString(min=3, max=10, strip=True)),
32 TextField(name='nombre', label=_(u'Nombre'),
33 help_text=_(u'Requerido.'),
34 validator=validators.UnicodeString(min=10, max=255, strip=True)),
35 TextField(name='email', label=_(u'E-Mail'),
36 #help_text=_(u'Dirección de e-mail.'),
37 validator=validators.All(
38 validators.Email(not_empty=False, resolve_domain=True),
39 validators.UnicodeString(not_empty=False, max=255, strip=True))),
40 TextField(name='telefono', label=_(u'Teléfono'),
41 #help_text=_(u'Texto libre para teléfono, se puede incluir horarios o varias entradas.'),
42 validator=validators.UnicodeString(not_empty=False, min=7, max=255, strip=True)),
43 TextArea(name='observaciones', label=_(u'Observaciones'),
44 #help_text=_(u'Observaciones.'),
45 validator=validators.UnicodeString(not_empty=False, strip=True)),
46 CheckBox(name='nombrado', label=_(u'Nombrado'), default=1,
47 #help_text=_(u'Indica si tiene cargo.'),
48 validator=validators.Bool(if_empty=1)),
49 CheckBox(name='activo', label=_(u'Activo'), default=1,
50 #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
51 validator=validators.Bool(if_empty=1)),
53 form.javascript.append(JSSource("MochiKit.DOM.focusOnLoad('form_usuario');"))
57 class DocenteController(controllers.Controller, identity.SecureResource):
58 """Basic model admin interface"""
59 require = identity.has_permission('admin')
62 def default(self, tg_errors=None):
63 """handle non exist urls"""
64 raise redirect('list')
68 raise redirect('list')
70 @expose(template='kid:%s.templates.list' % __name__)
73 """List records in model"""
75 return dict(records=r, name=name, namepl=namepl)
78 def activate(self, id, activo):
79 """Save or create record to model"""
82 r.activo = bool(int(activo))
84 raise cherrypy.NotFound
85 raise redirect('../../list')
87 @expose(template='kid:%s.templates.new' % __name__)
89 """Create new records in model"""
90 return dict(name=name, namepl=namepl, form=form, values=kw)
95 def create(self, **kw):
96 """Save or create record to model"""
98 flash(_(u'Se creó un nuevo %s.') % name)
99 raise redirect('list')
101 @expose(template='kid:%s.templates.edit' % __name__)
102 def edit(self, id, **kw):
103 """Edit record in model"""
105 return dict(name=name, namepl=namepl, record=r, form=form)
110 def update(self, id, **kw):
111 """Save or create record to model"""
112 r = validate_set(id, kw)
113 flash(_(u'El %s fue actualizado.') % name)
114 raise redirect('../list')
116 @expose(template='kid:%s.templates.show' % __name__)
117 def show(self,id, **kw):
118 """Show record in model"""
120 if r.observaciones is None:
123 r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
124 return dict(name=name, namepl=namepl, record=r)
127 def delete(self, id):
128 """Destroy record in model"""
131 flash(_(u'El %s fue eliminado permanentemente.') % name)
132 raise redirect('../list')