]> git.llucax.com Git - z.facultad/75.52/sercom.git/blob - sercom/subcontrollers/curso/ejercicio/__init__.py
Listar curso en un orden más útil.
[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()
83     def default(self, tg_errors=None):
84         """handle non exist urls"""
85         raise redirect('../list')
86
87     @expose()
88     def index(self):
89         raise redirect('../list')
90
91     @expose(template='kid:%s.templates.list' % __name__)
92     @validate(validators=dict(curso=V.Int))
93     @paginate('records')
94     def list(self, curso):
95         """List records in model"""
96         r = cls.selectBy(cursoID=curso)
97         return dict(records=r, name=name, namepl=namepl, curso=curso)
98
99     @expose(template='kid:%s.templates.new' % __name__)
100     @validate(validators=dict(curso=V.Int))
101     @identity.require(identity.has_permission('admin'))
102     def new(self, curso, **kw):
103         """Create new records in model"""
104         kw['cursoID'] = curso
105         curso = Curso.get(curso)
106         options = { fkname+'ID': [(fk.id, fk.shortrepr()) for fk in
107             Enunciado.selectBy(anio=curso.anio,
108                 cuatrimestre=curso.cuatrimestre)] }
109         return dict(name=name, namepl=namepl, form=form, values=kw, options=options)
110
111     @validate(form=form)
112     @error_handler(new)
113     @identity.require(identity.has_permission('admin'))
114     @expose()
115     def create(self, **kw):
116         """Save or create record to model"""
117         validate_new(kw)
118         flash(_(u'Se creó un nuevo %s.') % name)
119         raise redirect('list/%s' % kw['cursoID'])
120
121     @expose(template='kid:%s.templates.edit' % __name__)
122     @identity.require(identity.has_permission('admin'))
123     def edit(self, id, **kw):
124         """Edit record in model"""
125         r = validate_get(id)
126         curso = Curso.get(r.cursoID)
127         options = { fkname+'ID': [(fk.id, fk.shortrepr()) for fk in
128             Enunciado.selectBy(anio=curso.anio,
129                 cuatrimestre=curso.cuatrimestre)] }
130         return dict(name=name, namepl=namepl, record=r, form=form, options=options)
131
132     @validate(form=form)
133     @error_handler(edit)
134     @expose()
135     @identity.require(identity.has_permission('admin'))
136     def update(self, id, **kw):
137         """Save or create record to model"""
138         r = validate_set(id, kw)
139         flash(_(u'El %s fue actualizado.') % name)
140         raise redirect('../list/%s' % r.cursoID)
141
142     @expose(template='kid:%s.templates.show' % __name__)
143     def show(self,id, **kw):
144         """Show record in model"""
145         r = validate_get(id)
146         return dict(name=name, namepl=namepl, record=r)
147
148     @expose()
149     @identity.require(identity.has_permission('admin'))
150     def delete(self, id):
151         """Destroy record in model"""
152         validate_del(id)
153         flash(_(u'El %s fue eliminado permanentemente.') % name)
154         raise redirect('../list')
155
156     @expose()
157     def files(self, id):
158         r = validate_get(id)
159         response.headers["Content-Type"] = r.archivo_type
160         response.headers["Content-disposition"] = "attachment;filename=%s" % (r.archivo_name)
161         flash(_(u'El %s fue eliminado permanentemente.') % name)
162         return r.archivo
163 #}}}
164