]> git.llucax.com Git - z.facultad/75.52/sercom.git/blob - sercom/subcontrollers/curso/ejercicio/__init__.py
Ordenar mejor ejercicios.
[z.facultad/75.52/sercom.git] / sercom / subcontrollers / curso / ejercicio / __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
13 from cherrypy import request, response
14
15 from entrega import  *
16
17 #}}}
18
19 #{{{ Configuración
20 cls = Ejercicio
21 name = 'ejercicio'
22 namepl = name + 's'
23
24 fkcls = Enunciado
25 fkname = 'enunciado'
26 fknamepl = fkname + 's'
27 #}}}
28
29 #{{{ Validación
30 def validate_fk(data):
31     fk = data.get(fkname + 'ID', None)
32     if fk == 0: fk = None
33     if fk is not None:
34         try:
35             fk = fkcls.get(fk)
36         except LookupError:
37             flash(_(u'No se pudo crear el nuevo %s porque el %s con '
38                 'identificador %d no existe.' % (name, fkname, fk)))
39             raise redirect('new', **data)
40     data.pop(fkname + 'ID', None)
41     data[fkname] = fk
42     return fk
43
44 def validate_get(id):
45     return val.validate_get(cls, name, id)
46
47 def validate_set(id, data):
48     validate_fk(data)
49     return val.validate_set(cls, name, id, data)
50
51 def validate_new(data):
52     validate_fk(data)
53     return val.validate_new(cls, name, data)
54
55 def validate_del(id):
56     return val.validate_del(cls, name, id)
57 #}}}
58
59 #{{{ Formulario
60 class EjercicioForm(W.TableForm):
61     class Fields(W.WidgetsList):
62         cursoID = W.HiddenField(validator=V.Int)
63         numero = W.TextField(name="numero",label=_(u'Nro'),
64             help_text=_(u'Requerido.'),
65             validator=V.Int(not_empty=True))
66         fk = W.SingleSelectField(name=fkname+'ID', label=_(fkname.capitalize()),
67             validator=V.Int(not_empty=True))
68         grupal = W.CheckBox(name='grupal', label=_(u"Grupal?"), validator=V.Bool(if_empty=0), default=0)
69     fields = Fields()
70     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_numero');")]
71
72 form = EjercicioForm()
73 #}}}
74
75 #{{{ Controlador
76 class EjercicioController(controllers.Controller, identity.SecureResource):
77     """Basic model admin interface"""
78     require = identity.has_permission('entregar')
79
80     entrega = EntregaController()
81
82     @expose(template='kid:%s.templates.list' % __name__)
83     @validate(validators=dict(curso=V.Int))
84     @paginate('records')
85     def list(self, curso):
86         """List records in model"""
87         r = cls.selectBy(cursoID=curso).orderBy(cls.q.numero)
88         return dict(records=r, name=name, namepl=namepl, curso=curso)
89
90     @expose(template='kid:%s.templates.new' % __name__)
91     @validate(validators=dict(curso=V.Int))
92     @identity.require(identity.has_permission('admin'))
93     def new(self, curso, **kw):
94         """Create new records in model"""
95         kw['cursoID'] = curso
96         curso = Curso.get(curso)
97         options = { fkname+'ID': [(fk.id, fk.shortrepr()) for fk in
98             Enunciado.selectBy(anio=curso.anio,
99                 cuatrimestre=curso.cuatrimestre)] }
100         return dict(name=name, namepl=namepl, form=form, values=kw, options=options)
101
102     @validate(form=form)
103     @error_handler(new)
104     @identity.require(identity.has_permission('admin'))
105     @expose()
106     def create(self, **kw):
107         """Save or create record to model"""
108         validate_new(kw)
109         flash(_(u'Se creó un nuevo %s.') % name)
110         raise redirect('list/%s' % kw['cursoID'])
111
112     @expose(template='kid:%s.templates.edit' % __name__)
113     @identity.require(identity.has_permission('admin'))
114     def edit(self, id, **kw):
115         """Edit record in model"""
116         r = validate_get(id)
117         curso = Curso.get(r.cursoID)
118         options = { fkname+'ID': [(fk.id, fk.shortrepr()) for fk in
119             Enunciado.selectBy(anio=curso.anio,
120                 cuatrimestre=curso.cuatrimestre)] }
121         return dict(name=name, namepl=namepl, record=r, form=form, options=options)
122
123     @validate(form=form)
124     @error_handler(edit)
125     @expose()
126     @identity.require(identity.has_permission('admin'))
127     def update(self, id, **kw):
128         """Save or create record to model"""
129         r = validate_set(id, kw)
130         flash(_(u'El %s fue actualizado.') % name)
131         raise redirect('../list/%s' % r.cursoID)
132
133     @expose(template='kid:%s.templates.show' % __name__)
134     def show(self,id, **kw):
135         """Show record in model"""
136         r = validate_get(id)
137         return dict(name=name, namepl=namepl, record=r)
138
139     @expose()
140     @identity.require(identity.has_permission('admin'))
141     def delete(self, id):
142         """Destroy record in model"""
143         validate_del(id)
144         flash(_(u'El %s fue eliminado permanentemente.') % name)
145         raise redirect('../list')
146
147     @expose()
148     def files(self, id):
149         r = validate_get(id)
150         response.headers["Content-Type"] = r.archivo_type
151         response.headers["Content-disposition"] = "attachment;filename=%s" % (r.archivo_name)
152         flash(_(u'El %s fue eliminado permanentemente.') % name)
153         return r.archivo
154 #}}}
155