]> git.llucax.com Git - z.facultad/75.52/sercom.git/blobdiff - sercom/subcontrollers/grupo/__init__.py
Aceptar IDs en métodos add_xxx() donde tiene sentido.
[z.facultad/75.52/sercom.git] / sercom / subcontrollers / grupo / __init__.py
index 46422c72e582e65cb6a36e85c87d0d544db28b05..307cf4f3e1429038089ed3b0ff92c57e4cb571b3 100644 (file)
@@ -62,14 +62,10 @@ def get_cursos():
     return [(0, u'---')] + [(fk1.id, fk1.shortrepr()) for fk1 in Curso.select()]
 
 ajax = u"""
     return [(0, u'---')] + [(fk1.id, fk1.shortrepr()) for fk1 in Curso.select()]
 
 ajax = u"""
-    function alumnos_agregar_a_la_lista(texto, lista, loading)
+    function alumnos_agregar_a_la_lista(texto, lista)
     {
         t = MochiKit.DOM.getElement(texto);
 
     {
         t = MochiKit.DOM.getElement(texto);
 
-        /* Como no se si se puede hacer de otra manera, asumo que tengo en
-         * el form un Combo que se llama curso en el codigo, y tiro error si
-         * no existe
-         */
         curso = MochiKit.DOM.getElement('form_cursoID');
         if (!curso) {
             alert("No deberias ver esto, y quiere decir que tu form esta roto.\\nTe falta un combo de curso");
         curso = MochiKit.DOM.getElement('form_cursoID');
         if (!curso) {
             alert("No deberias ver esto, y quiere decir que tu form esta roto.\\nTe falta un combo de curso");
@@ -79,12 +75,9 @@ ajax = u"""
             alert('Debes seleccionar un curso primero');
             return;
         }
             alert('Debes seleccionar un curso primero');
             return;
         }
-        load = MochiKit.DOM.getElement(loading);
-        load.style.visibility = 'visible';
         url = "/grupo/get_inscripto?cursoid="+curso.options[curso.selectedIndex].value+"&padron="+t.value;
         url = "/grupo/get_inscripto?cursoid="+curso.options[curso.selectedIndex].value+"&padron="+t.value;
-        var d = loadJSONDoc(url);
-        d.addCallbacks(partial(_on_alumno_get_result, lista, loading), partial(_on_alumno_get_error, loading));
         t.value = "";
         t.value = "";
+        return url;
     }
 
     function err (err)
     }
 
     function err (err)
@@ -130,6 +123,8 @@ ajax = u"""
     MochiKit.DOM.addLoadEvent(prepare)
 
 """
     MochiKit.DOM.addLoadEvent(prepare)
 
 """
+def get_docentes():
+    return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
 
 class GrupoForm(W.TableForm):
     class Fields(W.WidgetsList):
 
 class GrupoForm(W.TableForm):
     class Fields(W.WidgetsList):
@@ -137,7 +132,8 @@ 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'))
         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 = AjaxMultiSelect(name='alumnos', label=_(u'Integrantes'), validator=V.Int(), on_add="alumnos_agregar_a_la_lista")
+        alumnos = AjaxMultiSelect(name='alumnos', label=_(u'Miembros'), validator=V.Int(), on_add="alumnos_agregar_a_la_lista")
+        docentes = W.MultipleSelectField(name='docentes', label=_(u'Tutores'), validator=V.Int(), options=get_docentes)
 
     fields = Fields()
     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)]
 
     fields = Fields()
     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)]
@@ -206,12 +202,23 @@ class GrupoController(controllers.Controller, identity.SecureResource):
         if alumnos == []:
             flash(_(u'No se pudo crear el grupo. No se han agregado integrantes.'))
             raise redirect('list')
         if alumnos == []:
             flash(_(u'No se pudo crear el grupo. No se han agregado integrantes.'))
             raise redirect('list')
-
         del(kw['alumnos'])
 
         del(kw['alumnos'])
 
+        # Busco los docentes
+        docentes = []
+        for docenteid in kw['docentes']:
+            docentes.append(Docente.get(docenteid))
+        # TODO : Puede no tener tutor ?
+        #if docentes == []:
+        #    flash(_(u'No se pudo crear el grupo. No se han agregado integrantes.'))
+        #    raise redirect('list')
+        del(kw['docentes'])
+
         r = validate_new(kw)
         for a in alumnos:
             r.add_miembro(a)
         r = validate_new(kw)
         for a in alumnos:
             r.add_miembro(a)
+        for a in docentes:
+            r.add_tutor(a)
         flash(_(u'Se creó un nuevo %s.') % name)
         raise redirect('list')
 
         flash(_(u'Se creó un nuevo %s.') % name)
         raise redirect('list')