X-Git-Url: https://git.llucax.com/software/sercom.git/blobdiff_plain/86cda0b5747c356334877720dccb99fc9100f615..1ffc7414129c25c25452f371d1abe6345dfc5ad8:/sercom/subcontrollers/grupo/__init__.py diff --git a/sercom/subcontrollers/grupo/__init__.py b/sercom/subcontrollers/grupo/__init__.py index 628d1b7..8042b7c 100644 --- a/sercom/subcontrollers/grupo/__init__.py +++ b/sercom/subcontrollers/grupo/__init__.py @@ -11,7 +11,7 @@ from turbogears import paginate from docutils.core import publish_parts from sercom.subcontrollers import validate as val from sercom.model import Curso, AlumnoInscripto, Docente, Grupo, Alumno -from sqlobject import AND +from sqlobject import * from sercom.widgets import * @@ -70,7 +70,10 @@ ajax = u""" function procesar(result) { l = MochiKit.DOM.getElement('form_responsable_info'); - l.innerHTML = result.msg; + if (result.error) + l.innerHTML = result.msg; + else + l.innerHTML = result.msg.value; } function buscar_alumno() @@ -109,6 +112,7 @@ class GrupoForm(W.TableForm): validator = V.Int(not_empty=True)) nombre = W.TextField(label=_(u'Nombre'), validator=V.UnicodeString(not_empty=True,strip=True)) responsable = CustomTextField(label=_(u'Responsable'), validator=V.UnicodeString(not_empty=True), attrs=dict(size='8')) + alumnos = AlumnoMultiSelect(label=_(u'Integrantes'), validator=V.Int()) fields = Fields() javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)] @@ -219,14 +223,20 @@ class GrupoController(controllers.Controller, identity.SecureResource): @expose('json') def get_inscripto(self, cursoid, padron): - msg = 'No existe el alumno %s en el curso seleccionado.' % padron + msg = u'' + error=False try: # Busco el alumno inscripto - alumno = AlumnoInscripto.select(AND(Curso.q.id==cursoid, Alumno.q.usuario==padron)) - if alumno.count() > 0: - msg = alumno[0].alumno.nombre + alumno = AlumnoInscripto.selectBy(curso=cursoid, alumno=Alumno.byUsuario(padron)).getOne() + msg = {} + msg['id'] = alumno.id + msg['value'] = alumno.alumno.nombre + except SQLObjectNotFound: + msg = 'No existe el alumno %s en el curso seleccionado.' % padron + error=True except Exception, (inst): msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst) - return dict(msg=msg) + error = True + return dict(msg=msg, error=error) #}}}