X-Git-Url: https://git.llucax.com/z.facultad/75.52/sercom.git/blobdiff_plain/8a15f8fedd03ec178f5f50f33af3300529ddeff8..f0aafe47a832b36b3bb48d07cc0692c048056666:/sercom/subcontrollers/grupo/__init__.py diff --git a/sercom/subcontrollers/grupo/__init__.py b/sercom/subcontrollers/grupo/__init__.py index f919753..ab3c454 100644 --- a/sercom/subcontrollers/grupo/__init__.py +++ b/sercom/subcontrollers/grupo/__init__.py @@ -109,6 +109,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)] @@ -154,7 +155,22 @@ class GrupoController(controllers.Controller, identity.SecureResource): @expose() def create(self, **kw): """Save or create record to model""" - validate_new(kw) + responsable = kw['responsable'] + curso = kw['cursoID'] + alumno = None + try: + # Busco el alumno inscripto + alumno = AlumnoInscripto.select(AND(Curso.q.id==curso, Alumno.q.usuario==responsable)) + if alumno.count() > 0: + alumno = alumno[0] + else: + raise Exception + except Exception, (inst): + flash(_(u'El responsable %s no existe') % responsable) + raise redirect('list') + + kw['responsable'] = alumno + r = validate_new(kw) flash(_(u'Se creó un nuevo %s.') % name) raise redirect('list') @@ -177,6 +193,8 @@ class GrupoController(controllers.Controller, identity.SecureResource): alumno = AlumnoInscripto.select(AND(Curso.q.id==curso, Alumno.q.usuario==responsable)) if alumno.count() > 0: alumno = alumno[0] + else: + raise Exception except Exception, (inst): flash(_(u'El responsable %s no existe') % responsable) raise redirect('../list') @@ -203,13 +221,17 @@ 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 + 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 + else: + 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) #}}}