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 Curso
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 CursoForm(W.TableForm):
35 class Fields(W.WidgetsList):
36 anio = W.TextField(label=_(u'Anio'),
37 help_text=_(u'Requerido y único.'),
38 validator=V.Number(min=4, max=4, strip=True))
39 cuatrimestre = W.TextField(label=_(u'Cuatrimestre'),
40 help_text=_(u'Requerido.'),
41 validator=V.Number(min=1, max=1, strip=True))
42 numero = W.TextField(label=_(u'Numero'),
43 help_text=_(u'Requerido'),
44 validator=V.Number(min=1, max=2, strip=True))
46 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('anio');")]
47 # ver que otros campos agregar.
49 W.TextField(name='telefono', label=_(u'Teléfono'),
50 #help_text=_(u'Texto libre para teléfono, se puede incluir '
51 # 'horarios o varias entradas.'),
52 validator=V.UnicodeString(not_empty=False, min=7, max=255,
54 W.TextField(name='nota', label=_(u'Nota'),
55 #help_text=_(u'Texto libre para teléfono, se puede incluir '
56 # 'horarios o varias entradas.'),
57 validator=V.Number(not_empty=False, strip=True)),
58 W.TextArea(name='observaciones', label=_(u'Observaciones'),
59 #help_text=_(u'Observaciones.'),
60 validator=V.UnicodeString(not_empty=False, strip=True)),
61 W.CheckBox(name='activo', label=_(u'Activo'), default=1,
62 #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
63 validator=V.Bool(if_empty=1)),
70 class CursoController(controllers.Controller, identity.SecureResource):
71 """Basic model admin interface"""
72 require = identity.has_permission('admin')
75 def default(self, tg_errors=None):
76 """handle non exist urls"""
77 raise redirect('list')
81 raise redirect('list')
83 @expose(template='kid:%s.templates.list' % __name__)
86 """List records in model"""
88 return dict(records=r, name=name, namepl=namepl)
91 def activate(self, id, activo):
92 """Save or create record to model"""
95 r.activo = bool(int(activo))
97 raise cherrypy.NotFound
98 raise redirect('../../list')
100 @expose(template='kid:%s.templates.new' % __name__)
102 """Create new records in model"""
103 return dict(name=name, namepl=namepl, form=form, values=kw)
108 def create(self, **kw):
109 """Save or create record to model"""
111 flash(_(u'Se creó un nuevo %s.') % name)
112 raise redirect('list')
114 @expose(template='kid:%s.templates.edit' % __name__)
115 def edit(self, id, **kw):
116 """Edit record in model"""
118 return dict(name=name, namepl=namepl, record=r, form=form)
123 def update(self, id, **kw):
124 """Save or create record to model"""
125 r = validate_set(id, kw)
126 flash(_(u'El %s fue actualizado.') % name)
127 raise redirect('../list')
129 @expose(template='kid:%s.templates.show' % __name__)
130 def show(self,id, **kw):
131 """Show record in model"""
133 if r.observaciones is None:
136 r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
137 return dict(name=name, namepl=namepl, record=r)
140 def delete(self, id):
141 """Destroy record in model"""
144 flash(_(u'El %s fue eliminado permanentemente.') % name)
145 raise redirect('../list')