1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
5 from turbogears import controllers, expose, redirect
6 from turbogears import validate, flash, error_handler
7 from turbogears import validators as V
8 from turbogears import widgets as W
9 from turbogears import identity
10 from turbogears import paginate
11 from docutils.core import publish_parts
12 from sercom.subcontrollers import validate as val
13 from sercom.model import Curso, AlumnoInscripto, Docente, Grupo, Alumno
14 from sqlobject import AND
16 from sercom.widgets import *
27 fknamepl = fkname + 's'
31 def validate_fk(data):
32 fk = data.get(fkname + 'ID', None)
38 flash(_(u'No se pudo crear el nuevo %s porque el %s con '
39 'identificador %d no existe.' % (name, fkname, fk)))
40 raise redirect('new', **data)
41 data.pop(fkname + 'ID', None)
46 return val.validate_get(cls, name, id)
48 def validate_set(id, data):
50 return val.validate_set(cls, name, id, data)
52 def validate_new(data):
54 return val.validate_new(cls, name, data)
59 return [(fk1.id, fk1.shortrepr()) for fk1 in Docente.select()]
62 return [(0, u'---')] + [(fk1.id, fk1.shortrepr()) for fk1 in Curso.select()]
67 alert("The metadata for MochiKit.Async could not be fetched :(");
70 function procesar(result)
72 l = MochiKit.DOM.getElement('form_responsable_info');
73 l.innerHTML = result.msg;
76 function buscar_alumno()
78 /* Obtengo el curso */
79 l = MochiKit.DOM.getElement('form_cursoID');
80 cursoid = l.options[l.selectedIndex].value;
82 alert('Debe seleccionar un curso');
85 /* Obtengo el padron ingresado */
86 p = MochiKit.DOM.getElement('form_responsable');
89 alert('Debe ingresar el padrón del alumno responsable');
92 url = "/grupo/get_inscripto?cursoid="+cursoid+'&padron='+padron;
93 var d = loadJSONDoc(url);
94 d.addCallbacks(procesar, err);
99 connect('form_responsable', 'onblur', buscar_alumno);
102 MochiKit.DOM.addLoadEvent(prepare)
106 class GrupoForm(W.TableForm):
107 class Fields(W.WidgetsList):
108 curso = W.SingleSelectField(name='cursoID', label=_(u'Curso'), options = get_cursos,
109 validator = V.Int(not_empty=True))
110 nombre = W.TextField(label=_(u'Nombre'), validator=V.UnicodeString(not_empty=True,strip=True))
111 responsable = CustomTextField(label=_(u'Responsable'), validator=V.Int(not_empty=True), attrs=dict(size='8'))
114 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('curso');"), W.JSSource(ajax)]
121 class GrupoController(controllers.Controller, identity.SecureResource):
122 """Basic model admin interface"""
123 require = identity.has_permission('admin')
126 def default(self, tg_errors=None):
127 """handle non exist urls"""
128 raise redirect('list')
132 raise redirect('list')
134 @expose(template='kid:%s.templates.list' % __name__)
137 """List records in model"""
139 return dict(records=r, name=name, namepl=namepl)
142 def activate(self, id, activo):
143 """Save or create record to model"""
145 raise redirect('../../list')
147 @expose(template='kid:%s.templates.new' % __name__)
149 """Create new records in model"""
150 return dict(name=name, namepl=namepl, form=form, values=kw)
155 def create(self, **kw):
156 """Save or create record to model"""
158 flash(_(u'Se creó un nuevo %s.') % name)
159 raise redirect('list')
161 @expose(template='kid:%s.templates.edit' % __name__)
162 def edit(self, id, **kw):
163 """Edit record in model"""
165 return dict(name=name, namepl=namepl, record=r, form=form)
170 def update(self, id, **kw):
171 """Save or create record to model"""
172 r = validate_set(id, kw)
173 flash(_(u'El %s fue actualizado.') % name)
174 raise redirect('../list')
176 @expose(template='kid:%s.templates.show' % __name__)
177 def show(self,id, **kw):
178 """Show record in model"""
180 return dict(name=name, namepl=namepl, record=r)
183 def delete(self, id):
184 """Destroy record in model"""
187 flash(_(u'El %s fue eliminado permanentemente.') % name)
188 raise redirect('../list')
191 def get_inscripto(self, cursoid, padron):
192 msg = 'No existe el alumno %s en el curso seleccionado.' % padron
194 # Busco el alumno inscripto
195 alumno = AlumnoInscripto.select(AND(Curso.q.id==cursoid, Alumno.q.usuario==padron))
196 if alumno.count() > 0:
197 msg = alumno[0].alumno.nombre
198 except Exception, (inst):
199 msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst)