1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
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 *
16 from sercom.widgets import *
27 fknamepl = fkname + 's'
31 def validate_fk(data):
32 fk = data.get(fkname + 'ID', None)
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)
46 return val.validate_get(cls, name, id)
48 def validate_set(id, data):
50 return val.validate_set(cls, name, id, data)
52 def validate_new(data):
54 return val.validate_new(cls, name, data)
59 return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
62 return [(0, u'---')] + [(fk1.id, fk1.shortrepr()) for fk1 in Curso.select()]
65 function alumnos_agregar_a_la_lista(texto, lista)
67 t = MochiKit.DOM.getElement(texto);
69 curso = MochiKit.DOM.getElement('form_cursoID');
71 alert("No deberias ver esto, y quiere decir que tu form esta roto.\\nTe falta un combo de curso");
74 if (curso.options[curso.selectedIndex].value <= 0) {
75 alert('Debes seleccionar un curso primero');
78 url = "/grupo/get_inscripto?cursoid="+curso.options[curso.selectedIndex].value+"&padron="+t.value;
85 alert("The metadata for MochiKit.Async could not be fetched :(");
88 function procesar(result)
90 l = MochiKit.DOM.getElement('form_responsable_info');
92 l.innerHTML = result.msg;
94 l.innerHTML = result.msg.value;
97 function buscar_alumno()
99 /* Obtengo el curso */
100 l = MochiKit.DOM.getElement('form_cursoID');
101 cursoid = l.options[l.selectedIndex].value;
103 alert('Debe seleccionar un curso');
106 /* Obtengo el padron ingresado */
107 p = MochiKit.DOM.getElement('form_responsable');
110 alert('Debe ingresar el padrón del alumno responsable');
113 url = "/grupo/get_inscripto?cursoid="+cursoid+'&padron='+padron;
114 var d = loadJSONDoc(url);
115 d.addCallbacks(procesar, err);
120 connect('form_responsable', 'onblur', buscar_alumno);
125 /* TODO : Validar datos y evitar el submit si no esta completo */
127 /* Selecciono todos los miembros si no, no llegan al controllere*/
128 l = MochiKit.DOM.getElement('form_miembros');
129 for (i=0; i<l.options.length; i++) {
130 l.options[i].selected = true;
132 return true; // Dejo hacer el submit
135 MochiKit.DOM.addLoadEvent(prepare)
139 return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
141 class GrupoForm(W.TableForm):
142 class Fields(W.WidgetsList):
143 cursoID = W.SingleSelectField(label=_(u'Curso'), options = get_cursos, validator = V.Int(not_empty=True))
144 nombre = W.TextField(label=_(u'Nombre'), validator=V.UnicodeString(not_empty=True,strip=True))
145 responsable = CustomTextField(label=_(u'Responsable'), validator=V.UnicodeString(not_empty=True), attrs=dict(size='8'))
146 miembros = AjaxMultiSelect(label=_(u'Miembros'), validator=V.Int(), on_add="alumnos_agregar_a_la_lista")
147 tutores = W.MultipleSelectField(label=_(u'Tutores'), validator=V.Int(), options=get_docentes)
150 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)]
151 form_attrs = dict(onsubmit='return onsubmit()')
158 class GrupoController(controllers.Controller, identity.SecureResource):
159 """Basic model admin interface"""
160 require = identity.has_permission('admin')
163 def default(self, tg_errors=None):
164 """handle non exist urls"""
165 raise redirect('list')
169 raise redirect('list')
171 @expose(template='kid:%s.templates.list' % __name__)
174 """List records in model"""
176 return dict(records=r, name=name, namepl=namepl)
179 def activate(self, id, activo):
180 """Save or create record to model"""
182 raise redirect('../../list')
184 @expose(template='kid:%s.templates.new' % __name__)
186 """Create new records in model"""
187 return dict(name=name, namepl=namepl, form=form, values=kw)
192 def create(self, **kw):
193 """Save or create record to model"""
194 resp = kw['responsable']
196 # Busco el alumno inscripto
197 resp = AlumnoInscripto.selectBy(cursoID=kw['cursoID'],
198 alumno=Alumno.byPadron(kw['responsable'])).getOne()
199 except SQLObjectNotFound:
200 flash(_(u'El responsable %s no existe') % resp)
201 raise redirect('list')
202 kw['responsable'] = resp
205 flash(_(u'Se creó un nuevo %s.') % name)
206 raise redirect('list')
208 @expose(template='kid:%s.templates.edit' % __name__)
209 def edit(self, id, **kw):
210 """Edit record in model"""
212 # TODO : No encontre mejor forma de pasar cosas al form
213 # de manera comoda y facil de formatear segun lo que espera la UI (que
214 # en este caso es super particular). Ese EmptyClass no se si hay algo estandar
215 # en python que usar, puse {} y [] pero cuando quiero hacer values.id = XX explota.
218 values = EmptyClass()
220 values.cursoID = r.cursoID
221 values.nombre = r.nombre
222 # TODO : Ver como llenar la lista primero :S
224 values.responsable = r.responsable.alumno.padron
225 values.miembros = [{"id":i.alumno.id, "label":i.alumno.alumno.nombre} for i in r.miembros]
226 values.tutores = [a.docenteID for a in r.tutores]
227 return dict(name=name, namepl=namepl, record=values, form=form)
232 def update(self, id, **kw):
233 """Save or create record to model"""
234 responsable = kw['responsable']
235 curso = kw['cursoID']
236 resp = kw['responsable']
238 # Busco el alumno inscripto
239 resp = AlumnoInscripto.selectBy(cursoID=kw['cursoID'],
240 alumno=Alumno.byPadron(kw['responsable'])).getOne()
241 except SQLObjectNotFound:
242 flash(_(u'El responsable %s no existe') % resp)
243 raise redirect('list')
244 kw['responsable'] = resp
245 r = validate_set(id, kw)
246 flash(_(u'El %s fue actualizado.') % name)
247 raise redirect('../list')
249 @expose(template='kid:%s.templates.show' % __name__)
250 def show(self,id, **kw):
251 """Show record in model"""
253 return dict(name=name, namepl=namepl, record=r)
256 def delete(self, id):
257 """Destroy record in model"""
260 flash(_(u'El %s fue eliminado permanentemente.') % name)
261 raise redirect('../list')
264 def get_inscripto(self, cursoid, padron):
268 # Busco el alumno inscripto
269 alumno = AlumnoInscripto.selectBy(curso=cursoid, alumno=Alumno.byUsuario(padron)).getOne()
271 msg['id'] = alumno.id
272 msg['value'] = alumno.alumno.nombre
273 except SQLObjectNotFound:
274 msg = 'No existe el alumno %s en el curso seleccionado.' % padron
276 except Exception, (inst):
277 msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst)
279 return dict(msg=msg, error=error)