X-Git-Url: https://git.llucax.com/z.facultad/75.52/sercom.git/blobdiff_plain/afff8c7758418e6756f604f32c89a1a2588f955c..6efac10c91053504d0f2e60e408db484ee66aa6d:/sercom/subcontrollers/curso/__init__.py diff --git a/sercom/subcontrollers/curso/__init__.py b/sercom/subcontrollers/curso/__init__.py index 2ee0815..b9ce585 100644 --- a/sercom/subcontrollers/curso/__init__.py +++ b/sercom/subcontrollers/curso/__init__.py @@ -10,7 +10,15 @@ from turbogears import identity from turbogears import paginate from docutils.core import publish_parts from sercom.subcontrollers import validate as val -from sercom.model import Curso, Ejercicio, Alumno, Docente, Grupo +from sercom.model import Curso, Correccion, Ejercicio, Alumno, Docente, Grupo, DocenteInscripto, Rol +from curso_alumno import * +from sqlobject import * +from sqlobject.dberrors import * +from sercom.widgets import * +from alumno import AlumnoInscriptoController +from grupo import GrupoController +from ejercicio import EjercicioController +from docente import DocenteInscriptoController #}}} #{{{ Configuración @@ -19,6 +27,71 @@ name = 'curso' namepl = name + 's' #}}} +ajax = u""" + function alumnos_agregar_a_la_lista(texto, lista) + { + t = MochiKit.DOM.getElement(texto); + + url = "/alumno/get_alumno?padron="+t.value; + t.value = ""; + return url; + } + + function err (err) + { + alert("The metadata for MochiKit.Async could not be fetched :("); + } + + function procesar(result) + { + l = MochiKit.DOM.getElement('form_responsable_info'); + if (result.error) + l.innerHTML = result.msg; + else + l.innerHTML = result.msg.value; + } + + function buscar_alumno() + { + /* Obtengo el curso */ + l = MochiKit.DOM.getElement('form_cursoID'); + cursoid = l.options[l.selectedIndex].value; + if (cursoid <= 0) { + alert('Debe seleccionar un curso'); + return; + } + /* Obtengo el padron ingresado */ + p = MochiKit.DOM.getElement('form_responsable'); + padron = p.value; + if (padron == '') { + alert('Debe ingresar el padrón del alumno responsable'); + return; + } + url = "/grupo/get_inscripto?cursoid="+cursoid+'&padron='+padron; + var d = loadJSONDoc(url); + d.addCallbacks(procesar, err); + } + + function doSubmit() + { + /* TODO : Validar datos y evitar el submit si no esta completo */ + + /* Selecciono todos los miembros si no, no llegan al controllere*/ + l = MochiKit.DOM.getElement('form_alumnos'); + for (i=0; i 0: + col["Grupo"] = miembro[0].grupo.shortrepr() + else: + col["Grupo"] = "" + correctas = 0 + for ej in r.ejercicios: + for ins in ej.instancias: + if ej.grupal: + # Busco la correccion del grupo + g = Grupo.selectByAlumno(i.alumno).getOne() + c = Correccion.selectBy(instancia=ins, entregador=g.grupo) + else: + # Busco la correccion del alumno + c = Correccion.selectBy(instancia=ins, entregador=i) + if c.count() > 0: + col["E"+str(ej.numero)+str(ins.numero)] = c[0].nota + if c[0].nota >= 4: + correctas += 1 + else: + col["E"+str(ej.numero)+str(ins.numero)] = "" + col["EA"] = correctas + col["NP"] = i.nota_practica + col["NF"] = i.nota_final + col["NL"] = i.nota_libreta + rows.append(col) + return dict(curso=r, rows=rows, cols=cols) + + @expose() + def notascsv(self, cursoid): + r = validate_get(cursoid) + # Armo las columnas del listado + cols = ["Padron", "Nombre", "Grupo"] + # Ejercicios + for ej in r.ejercicios: + for ins in ej.instancias: + print "E"+str(ej.numero)+str(ins.numero) + cols.append("E"+str(ej.numero)+str(ins.numero)) + cols.append("EA") + cols.append("NP") + cols.append("NF") + cols.append("NL") + + rows = [] + for i in r.alumnos: + col = [] + col.append(i.alumno.padron) + col.append(i.alumno.nombre) + miembro = Grupo.selectByAlumno(i.alumno) + if miembro.count() > 0: + col.append(miembro[0].grupo.shortrepr()) + else: + col.append("") + correctas = 0 + for ej in r.ejercicios: + for ins in ej.instancias: + if ej.grupal: + # Busco la correccion del grupo + g = Grupo.selectByAlumno(i.alumno).getOne() + c = Correccion.selectBy(instancia=ins, entregador=g.grupo) + else: + # Busco la correccion del alumno + c = Correccion.selectBy(instancia=ins, entregador=i) + if c.count() > 0: + col.append(str(c[0].nota)) + if c[0].nota > 4: + correctas += 1 + else: + col.append("") + col.append(str(correctas)) + col.append(str(i.nota_practica)) + col.append(str(i.nota_final)) + col.append(str(i.nota_libreta)) + rows.append(col) + s = ",".join(cols) + "\n" + for i in rows: + s = s + ",".join(i) + "\n" + return s #}}}