]> git.llucax.com Git - software/sercom.git/blob - sercom/subcontrollers/grupo/__init__.py
6e2899498a2d8da579cb055a78e4e2391f952400
[software/sercom.git] / sercom / subcontrollers / grupo / __init__.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
2
3 #{{{ Imports
4 import cherrypy
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, AlumnoInscripto, Docente, Grupo, Alumno
14 from sqlobject import *
15
16 from sercom.widgets import *
17
18 #}}}
19
20 #{{{ Configuración
21 cls = Grupo
22 name = 'grupo'
23 namepl = 'grupos'
24
25 fkcls = Curso
26 fkname = 'curso'
27 fknamepl = fkname + 's'
28 #}}}
29
30 #{{{ Validación
31 def validate_fk(data):
32     fk = data.get(fkname + 'ID', None)
33     if fk == 0: fk = None
34     if fk is not None:
35         try:
36             fk = fkcls.get(fk)
37         except LookupError:
38             flash(_(u'No se pudo crear el nuevo %s porque el %s con '
39                 'identificador %d no existe.' % (name, fkname, fk)))
40             raise redirect('new', **data)
41     data.pop(fkname + 'ID', None)
42     data[fkname] = fk
43     return fk
44
45 def validate_get(id):
46     return val.validate_get(cls, name, id)
47
48 def validate_set(id, data):
49     validate_fk(data)
50     return val.validate_set(cls, name, id, data)
51
52 def validate_new(data):
53     validate_fk(data)
54     return val.validate_new(cls, name, data)
55 #}}}
56
57 #{{{ Formulario
58 def get_docentes():
59     return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
60
61 def get_cursos():
62     return [(0, u'---')] + [(fk1.id, fk1.shortrepr()) for fk1 in Curso.select()]
63
64 ajax = u"""
65     function err (err)
66     {
67         alert("The metadata for MochiKit.Async could not be fetched :(");
68     }
69
70     function procesar(result)
71     {
72         l = MochiKit.DOM.getElement('form_responsable_info');
73         if (result.error)
74             l.innerHTML = result.msg;
75         else
76             l.innerHTML = result.msg.value;
77     }
78
79     function buscar_alumno()
80     {
81         /* Obtengo el curso */
82         l = MochiKit.DOM.getElement('form_cursoID');
83         cursoid = l.options[l.selectedIndex].value;
84         if (cursoid <= 0) {
85             alert('Debe seleccionar un curso');
86             return;
87         }
88         /* Obtengo el padron ingresado */
89         p = MochiKit.DOM.getElement('form_responsable');
90         padron = p.value;
91         if (padron == '') {
92             alert('Debe ingresar el padrón del alumno responsable');
93             return;
94         }
95         url = "/grupo/get_inscripto?cursoid="+cursoid+'&padron='+padron;
96         var d = loadJSONDoc(url);
97         d.addCallbacks(procesar, err);
98     }
99
100     function prepare()
101     {
102         connect('form_responsable', 'onblur', buscar_alumno);
103     }
104
105     MochiKit.DOM.addLoadEvent(prepare)
106
107 """
108
109 class GrupoForm(W.TableForm):
110     class Fields(W.WidgetsList):
111         curso = W.SingleSelectField(name='cursoID', label=_(u'Curso'), options = get_cursos,
112         validator = V.Int(not_empty=True))
113         nombre = W.TextField(label=_(u'Nombre'), validator=V.UnicodeString(not_empty=True,strip=True))
114         responsable = CustomTextField(label=_(u'Responsable'), validator=V.UnicodeString(not_empty=True), attrs=dict(size='8'))
115         alumnos = AlumnoMultiSelect(name='alumnos', label=_(u'Integrantes'), validator=V.Int())
116
117     fields = Fields()
118     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)]
119
120 form = GrupoForm()
121
122 #}}}
123
124 #{{{ Controlador
125 class GrupoController(controllers.Controller, identity.SecureResource):
126     """Basic model admin interface"""
127     require = identity.has_permission('admin')
128
129     @expose()
130     def default(self, tg_errors=None):
131         """handle non exist urls"""
132         raise redirect('list')
133
134     @expose()
135     def index(self):
136         raise redirect('list')
137
138     @expose(template='kid:%s.templates.list' % __name__)
139     @paginate('records')
140     def list(self):
141         """List records in model"""
142         r = cls.select()
143         return dict(records=r, name=name, namepl=namepl)
144
145     @expose()
146     def activate(self, id, activo):
147         """Save or create record to model"""
148         r = validate_get(id)
149         raise redirect('../../list')
150
151     @expose(template='kid:%s.templates.new' % __name__)
152     def new(self, **kw):
153         """Create new records in model"""
154         return dict(name=name, namepl=namepl, form=form, values=kw)
155
156     @validate(form=form)
157     @error_handler(new)
158     @expose()
159     def create(self, **kw):
160         """Save or create record to model"""
161         responsable = kw['responsable']
162         curso = kw['cursoID']
163         resp = None
164         try:
165             # Busco el alumno inscripto
166             resp = AlumnoInscripto.select(AND(Curso.q.id==curso, Alumno.q.usuario==responsable))
167             if resp.count() > 0:
168                 resp = resp[0]
169             else:
170                 raise Exception
171         except Exception, (inst):
172             flash(_(u'El responsable %s no existe') % responsable)
173             raise redirect('list')
174
175         kw['responsable'] = resp
176
177         # Busco los alumnos
178         alumnos = []
179         for alumnoid in kw['alumnos']:
180             alumnos.append(Alumno.get(alumnoid))
181         if alumnos == []:
182             flash(_(u'No se pudo crear el grupo. No se han agregado integrantes.'))
183             raise redirect('list')
184
185         del(kw['alumnos'])
186
187         r = validate_new(kw)
188         for a in alumnos:
189             r.add_miembro(a)
190         flash(_(u'Se creó un nuevo %s.') % name)
191         raise redirect('list')
192
193     @expose(template='kid:%s.templates.edit' % __name__)
194     def edit(self, id, **kw):
195         """Edit record in model"""
196         r = validate_get(id)
197         return dict(name=name, namepl=namepl, record=r, form=form)
198
199     @validate(form=form)
200     @error_handler(edit)
201     @expose()
202     def update(self, id, **kw):
203         """Save or create record to model"""
204         responsable = kw['responsable']
205         curso = kw['cursoID']
206         alumno = None
207         try:
208             # Busco el alumno inscripto
209             alumno = AlumnoInscripto.select(AND(Curso.q.id==curso, Alumno.q.usuario==responsable))
210             if alumno.count() > 0:
211                 alumno = alumno[0]
212             else:
213                 raise Exception
214         except Exception, (inst):
215             flash(_(u'El responsable %s no existe') % responsable)
216             raise redirect('../list')
217
218         r = validate_set(id, kw)
219         r.responsable = alumno
220         flash(_(u'El %s fue actualizado.') % name)
221         raise redirect('../list')
222
223     @expose(template='kid:%s.templates.show' % __name__)
224     def show(self,id, **kw):
225         """Show record in model"""
226         r = validate_get(id)
227         return dict(name=name, namepl=namepl, record=r)
228
229     @expose()
230     def delete(self, id):
231         """Destroy record in model"""
232         r = validate_get(id)
233         r.destroySelf()
234         flash(_(u'El %s fue eliminado permanentemente.') % name)
235         raise redirect('../list')
236
237     @expose('json')
238     def get_inscripto(self, cursoid, padron):
239         msg = u''
240         error=False
241         try:
242             # Busco el alumno inscripto
243             alumno = AlumnoInscripto.selectBy(curso=cursoid, alumno=Alumno.byUsuario(padron)).getOne()
244             msg = {}
245             msg['id'] = alumno.id
246             msg['value'] = alumno.alumno.nombre
247         except SQLObjectNotFound:
248             msg = 'No existe el alumno %s en el curso seleccionado.' % padron
249             error=True
250         except Exception, (inst):
251             msg = u"""Se ha producido un error inesperado al buscar el registro:\n      %s""" % str(inst)
252             error = True
253         return dict(msg=msg, error=error)
254 #}}}
255