]> git.llucax.com Git - software/sercom.git/blobdiff - sercom/subcontrollers/alumno/__init__.py
Si el alumno no esta en ningun grupo pongo el campo en vacio para que no falle.
[software/sercom.git] / sercom / subcontrollers / alumno / __init__.py
index e54459cdc881a88ec9a1a524fc25a135bbfe3496..7dd7f015d9e553c79914f7385507aa26077ddaad 100644 (file)
@@ -10,7 +10,8 @@ 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 Alumno
+from sercom.model import Alumno, Rol
+from sqlobject import *
 #}}}
 
 #{{{ Configuración
@@ -32,34 +33,34 @@ def validate_new(data):
 
 #{{{ Formulario
 class AlumnoForm(W.TableForm):
-    fields = [
-        W.TextField(name='padron', label=_(u'Padrón'),
+    class Fields(W.WidgetsList):
+        padron = W.TextField(label=_(u'Padrón'),
             help_text=_(u'Requerido y único.'),
-            validator=V.UnicodeString(min=3, max=10, strip=True)),
-        W.TextField(name='nombre', label=_(u'Nombre'),
+            validator=V.UnicodeString(min=3, max=10, strip=True))
+        nombre = W.TextField(label=_(u'Nombre'),
             help_text=_(u'Requerido.'),
-            validator=V.UnicodeString(min=10, max=255, strip=True)),
-        W.TextField(name='email', label=_(u'E-Mail'),
+            validator=V.UnicodeString(min=10, max=255, strip=True))
+        email = W.TextField(label=_(u'E-Mail'),
             #help_text=_(u'Dirección de e-mail.'),
             validator=V.All(
                 V.Email(not_empty=False, resolve_domain=True),
-                V.UnicodeString(not_empty=False, max=255, strip=True))),
-        W.TextField(name='telefono', label=_(u'Teléfono'),
+                V.UnicodeString(not_empty=False, max=255, strip=True)))
+        telefono = W.TextField(label=_(u'Teléfono'),
             #help_text=_(u'Texto libre para teléfono, se puede incluir '
             #    'horarios o varias entradas.'),
             validator=V.UnicodeString(not_empty=False, min=7, max=255,
-                strip=True)),
-        W.TextField(name='nota', label=_(u'Nota'),
+                strip=True))
+        nota = W.TextField(label=_(u'Nota'),
             #help_text=_(u'Texto libre para teléfono, se puede incluir '
             #    'horarios o varias entradas.'),
-            validator=V.Number(not_empty=False, strip=True)),
-        W.TextArea(name='observaciones', label=_(u'Observaciones'),
+            validator=V.Number(not_empty=False, strip=True))
+        observaciones = W.TextArea(label=_(u'Observaciones'),
             #help_text=_(u'Observaciones.'),
-            validator=V.UnicodeString(not_empty=False, strip=True)),
-        W.CheckBox(name='activo', label=_(u'Activo'), default=1,
+            validator=V.UnicodeString(not_empty=False, strip=True))
+        activo = W.CheckBox(label=_(u'Activo'), default=1,
             #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
-            validator=V.Bool(if_empty=1)),
-    ]
+            validator=V.Bool(if_empty=1))
+    fields = Fields()
     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_padron');")]
 
 form = AlumnoForm()
@@ -106,6 +107,7 @@ class AlumnoController(controllers.Controller, identity.SecureResource):
     @expose()
     def create(self, **kw):
         """Save or create record to model"""
+        kw['roles'] = [Rol.by_nombre('alumno')]
         validate_new(kw)
         flash(_(u'Se creó un nuevo %s.') % name)
         raise redirect('list')
@@ -142,5 +144,56 @@ class AlumnoController(controllers.Controller, identity.SecureResource):
         r.destroySelf()
         flash(_(u'El %s fue eliminado permanentemente.') % name)
         raise redirect('../list')
+
+    @expose(template='kid:%s.templates.from_file' % __name__)
+    def from_file(self):
+        return dict()
+
+    @expose(template='kid:%s.templates.import_results' % __name__)
+    def from_file_add(self, archivo):
+        """ Se espera :
+             padron,nombre,email,telefono
+        """
+        import csv
+        lines = archivo.file.read().split('\n')
+        ok = []
+        fail = []
+        entregador = Rol.get(2)
+        for line in lines:
+            for row in csv.reader([line]):
+                if row == []:
+                    continue
+                try:
+                    u = Alumno(row[0], nombre=row[1], roles=[Rol.by_nombre('alumno')])
+                    u.email = row[2]
+                    u.telefono = row[3]
+                    u.password = row[0]
+                    u.activo = True
+                    u.add_rol(entregador)
+                    ok.append(row)
+                except Exception, e:
+                    row.append(str(e))
+                    fail.append(row)
+        return dict(ok=ok, fail=fail)
+    
+    @expose('json')
+    def get_alumno(self, padron):
+        msg = u''
+        error=False
+        try:
+            # Busco el alumno inscripto
+            alumno = Alumno.byPadron(padron=padron)
+            msg = {}
+            msg['id'] = alumno.id
+            msg['value'] = alumno.shortrepr()
+        except SQLObjectNotFound:
+            msg = 'No existe el alumno con padron: %s.' % padron
+            error=True
+        except Exception, (inst):
+            msg = u"""Se ha producido un error inesperado al buscar el registro:\n      %s""" % str(inst)
+            error = True
+        return dict(msg=msg, error=error)
+
+   
 #}}}