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