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, DocenteInscripto, Grupo, Alumno, Miembro
14 from sqlobject import *
16 from sercom.widgets import *
28 return val.validate_get(cls, name, id)
30 def validate_set(id, data):
31 return val.validate_set(cls, name, id, data)
33 def validate_new(data):
34 return val.validate_new(cls, name, data)
37 return val.validate_del(cls, name, id)
42 return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
44 def get_docentes_inscriptos(id):
45 return [(fk1.id, fk1.shortrepr()) for fk1 in DocenteInscripto.select(DocenteInscripto.q.cursoID==id)]
48 function alumnos_agregar_a_la_lista(texto, lista)
50 t = MochiKit.DOM.getElement(texto);
52 curso = MochiKit.DOM.getElement('form_cursoID');
54 alert("No deberias ver esto, y quiere decir que tu form esta roto.\\nTe falta un combo de curso");
57 if (curso.value <= 0) {
58 alert('Debes seleccionar un curso primero');
61 url = "/curso/grupo/get_inscripto?cursoid="+curso.value+"&padron="+t.value;
68 alert("The metadata for MochiKit.Async could not be fetched :(");
71 function procesar(result)
73 l = MochiKit.DOM.getElement('form_responsable_info');
75 l.innerHTML = result.msg;
77 l.innerHTML = result.msg.value;
80 function buscar_alumno()
82 /* Obtengo el padron ingresado */
83 p = MochiKit.DOM.getElement('form_responsable');
88 /* Obtengo el curso */
89 l = MochiKit.DOM.getElement('form_cursoID');
92 alert('Debe seleccionar un curso');
95 url = "/curso/grupo/get_inscripto?cursoid="+cursoid+'&padron='+padron;
96 var d = loadJSONDoc(url);
97 d.addCallbacks(procesar, err);
102 connect('form_responsable', 'onblur', buscar_alumno);
107 /* TODO : Validar datos y evitar el submit si no esta completo */
109 /* Selecciono todos los miembros si no, no llegan al controllere*/
110 l = MochiKit.DOM.getElement('form_miembros');
111 for (i=0; i<l.options.length; i++) {
112 l.options[i].selected = true;
114 return true; // Dejo hacer el submit
117 MochiKit.DOM.addLoadEvent(prepare)
121 class GrupoForm(W.TableForm):
122 class Fields(W.WidgetsList):
123 cursoID = W.HiddenField()
124 nombre = W.TextField(label=_(u'Nombre'), validator=V.UnicodeString(not_empty=True,strip=True))
125 responsable = CustomTextField(label=_(u'Responsable'), validator=V.UnicodeString(), attrs=dict(size='8'))
126 miembros = AjaxMultiSelect(label=_(u'Miembros'), validator=V.Int(), on_add="alumnos_agregar_a_la_lista")
127 tutores = W.MultipleSelectField(label=_(u'Tutores'), validator=V.Int())
130 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_nombre');"), W.JSSource(ajax)]
131 form_attrs = dict(onsubmit='return doSubmit()')
138 class GrupoController(controllers.Controller, identity.SecureResource):
139 """Basic model admin interface"""
140 require = identity.has_permission('admin')
143 def default(self, tg_errors=None):
144 """handle non exist urls"""
145 raise redirect(tg.url('/curso/list'))
149 raise redirect(tg.url('/curso/list'))
151 @expose(template='kid:%s.templates.list' % __name__)
153 def list(self, cursoID):
154 """List records in model"""
155 r = cls.select(cls.q.cursoID == cursoID)
156 return dict(records=r, name=name, namepl=namepl, cursoID=int(cursoID))
158 @expose(template='kid:%s.templates.new' % __name__)
159 def new(self, cursoID, **kw):
160 """Create new records in model"""
161 form.fields[0].attrs['value'] = cursoID
162 options = dict(tutores=get_docentes_inscriptos(cursoID))
163 return dict(name=name, namepl=namepl, cursoID=int(cursoID), form=form, options=options, values=kw)
168 def create(self, **kw):
169 """Save or create record to model"""
170 resp = kw['responsable']
172 # Busco el alumno inscripto
173 resp = AlumnoInscripto.selectBy(cursoID=kw['cursoID'],
174 alumno=Alumno.byPadron(kw['responsable'])).getOne()
175 except SQLObjectNotFound:
177 kw['responsable'] = resp
180 flash(_(u'Se creó un nuevo %s.') % name)
181 raise redirect('list/%d' % int(kw['cursoID']))
183 @expose(template='kid:%s.templates.edit' % __name__)
184 def edit(self, id, **kw):
185 """Edit record in model"""
187 # TODO : No encontre mejor forma de pasar cosas al form
188 # de manera comoda y facil de formatear segun lo que espera la UI (que
189 # en este caso es super particular). Ese EmptyClass no se si hay algo estandar
190 # en python que usar, puse {} y [] pero cuando quiero hacer values.id = XX explota.
191 options = dict(tutores=get_docentes_inscriptos(r.curso.id))
194 values = EmptyClass()
196 values.cursoID = r.cursoID
197 values.nombre = r.nombre
198 # TODO : Ver como llenar la lista primero :S
200 values.responsable = r.responsable.alumno.padron
201 values.miembros = [{"id":i.alumno.id, "label":i.alumno.alumno.nombre} for i in filter(lambda x: x.baja is None, r.miembros)]
202 values.tutores = [a.docenteID for a in r.tutores]
203 return dict(name=name, namepl=namepl, record=values, options=options, form=form)
208 def update(self, id, **kw):
209 """Save or create record to model"""
210 responsable = kw['responsable']
211 curso = kw['cursoID']
212 resp = kw['responsable']
214 # Busco el alumno inscripto
215 resp = AlumnoInscripto.selectBy(cursoID=kw['cursoID'],
216 alumno=Alumno.byPadron(kw['responsable'])).getOne()
217 except SQLObjectNotFound:
219 kw['responsable'] = resp
220 r = validate_set(id, kw)
221 flash(_(u'El %s fue actualizado.') % name)
222 raise redirect('../list/%d' % r.curso.id)
224 @expose(template='kid:%s.templates.show' % __name__)
225 def show(self,id, **kw):
226 """Show record in model"""
228 return dict(name=name, namepl=namepl, record=r)
231 def delete(self, cursoID, id):
232 """Destroy record in model"""
234 flash(_(u'El %s fue eliminado permanentemente.') % name)
235 raise redirect('../../list/%d' % int(cursoID))
238 def get_inscripto(self, cursoid, padron):
242 # Busco el alumno inscripto
243 alumno = AlumnoInscripto.selectBy(curso=cursoid, alumno=Alumno.byUsuario(padron)).getOne()
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
250 except Exception, (inst):
251 msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst)
253 return dict(msg=msg, error=error)
256 def get_alumnos(self, grupoid):
260 # Busco los alumnos del grupo
261 grupo = Grupo.get(int(grupoid))
262 miembros = Miembro.selectBy(baja=None, grupo=grupo)
267 alumnoInscripto = AlumnoInscripto.get(m.alumno.id)
268 msg['id'] = alumnoInscripto.id
269 msg['label'] = alumnoInscripto.shortrepr()
270 integrantes.append(msg)
271 except Exception, (inst):
272 msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst)
275 integrantes.append(msg)
276 return dict(msg=integrantes, error=error)