]> git.llucax.com Git - software/sercom.git/blob - sercom/subcontrollers/entrega/__init__.py
fix shortrepr
[software/sercom.git] / sercom / subcontrollers / entrega / __init__.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
2
3 #{{{ Imports
4 from turbogears import controllers, expose, redirect
5 from turbogears import validate, flash, error_handler
6 from turbogears import validators as V
7 from turbogears import widgets as W
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 Ejercicio, Curso, Enunciado, InstanciaDeEntrega
13 from cherrypy import request, response
14 #}}}
15
16 #{{{ Configuración
17 cls = InstanciaDeEntrega
18 name = 'instancia de entrega'
19 namepl = 'instancias de entrega'
20
21 fkcls = Ejercicio
22 fkname = 'ejercicio'
23 fknamepl = fkname + 's'
24
25 #}}}
26
27 #{{{ Validación
28 def validate_fk(data):
29     fk = data.get(fkname + 'ID', None)
30     if fk == 0: fk = None
31     if fk is not None:
32         try:
33             fk = fkcls.get(fk)
34         except LookupError:
35             flash(_(u'No se pudo crear el nuevo %s porque el %s con '
36                 'identificador %d no existe.' % (name, fkname, fk)))
37             raise redirect('new', **data)
38     data.pop(fkname + 'ID', None)
39     data[fkname] = fk
40     return fk
41
42 def validate_get(id):
43     return val.validate_get(cls, name, id)
44
45 def validate_set(id, data):
46     validate_fk(data)
47     return val.validate_set(cls, name, id, data)
48
49 def validate_new(data):
50     validate_fk(data)
51     return val.validate_new(cls, name, data)
52 #}}}
53
54 #{{{ Formulario
55 def get_options():
56     return [(0, _(u'--'))] + [(fk.id, fk.shortrepr()) for fk in fkcls.select()]
57
58 class EntregaForm(W.TableForm):
59     class Fields(W.WidgetsList):
60         numero = W.TextField(name="numero",label=_(u'Nro'), help_text=_(u'Requerido.'),
61             validator=V.Int(not_empty=True))
62         inicio = W.CalendarDateTimePicker(label=_(u"Inicio"))
63         fin = W.CalendarDateTimePicker(label=_(u"Fin"))
64         procesada = W.CheckBox(label=_(u"Procesada?"))
65         activo = W.CheckBox(label=_(u"Activo?"))
66         observaciones = W.TextArea(rows="5", cols="40")
67         ejercicio_id= W.HiddenField()
68     fields = Fields()
69     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_nombre');")]
70
71 form = EntregaForm()
72 #}}}
73
74 #{{{ Controlador
75 class EntregaController(controllers.Controller, identity.SecureResource):
76     """Basic model admin interface"""
77     require = identity.has_permission('admin')
78
79     @expose(template='kid:%s.templates.list' % __name__)
80     @validate(validators=dict(ejercicio_id=V.Int))
81     @paginate('records')
82     def default(self, ejercicio_id):
83         e = Ejercicio.get(ejercicio_id)
84         r = e.instancias
85         return dict(records=r, name=name, namepl=namepl, parcial=str(ejercicio_id))
86
87     @expose(template='kid:%s.templates.new' % __name__)
88     def new(self, ejercicio_id, **kw):
89         """Create new records in model"""
90         form.fields[6].attrs['value'] = ejercicio_id
91         return dict(name=name, namepl=namepl, form=form, values=kw, partial=str(ejercicio_id))
92
93     @validate(form=form)
94     @error_handler(new)
95     @expose()
96     def create(self, ejercicio_id, **kw):
97         """Save or create record to model"""
98         e = Ejercicio.get(ejercicio_id)
99         e.add_instancia(**kw)
100         flash(_(u'Se creó un nuevo %s.') % name)
101         raise redirect('/entrega/'+str(e.id))
102
103     @expose()
104     def delete(self, id):
105         """Destroy record in model"""
106         r = validate_get(id)
107         r.destroySelf()
108         flash(_(u'El %s fue eliminado permanentemente.') % name)
109         raise redirect('../list')
110
111 #}}}
112