From 315e5ed816332fbde28f9bd7a370439361407ed5 Mon Sep 17 00:00:00 2001 From: Ricardo Markiewicz Date: Sun, 25 Feb 2007 21:04:10 +0000 Subject: [PATCH] entregas Quise ponerlo como /ejercicio/entregas que tiene mas onda pero el puto kid se me queja y no tengo ganas de saber por que :) --- sercom/controllers.py | 2 + sercom/model.py | 7 +- sercom/subcontrollers/__init__.py | 1 + sercom/subcontrollers/ejercicio/__init__.py | 1 + .../ejercicio/templates/list.kid | 1 + sercom/subcontrollers/entrega/__init__.py | 112 ++++++++++++++++++ .../subcontrollers/entrega/templates/list.kid | 47 ++++++++ .../subcontrollers/entrega/templates/new.kid | 18 +++ 8 files changed, 186 insertions(+), 3 deletions(-) create mode 100644 sercom/subcontrollers/entrega/__init__.py create mode 100644 sercom/subcontrollers/entrega/templates/list.kid create mode 100644 sercom/subcontrollers/entrega/templates/new.kid diff --git a/sercom/controllers.py b/sercom/controllers.py index b1e8ed1..6132eb2 100644 --- a/sercom/controllers.py +++ b/sercom/controllers.py @@ -85,6 +85,8 @@ class Root(controllers.RootController): ejercicio = EjercicioController() + entrega = EntregaController() + caso_de_prueba = CasoDePruebaController() curso = CursoController() diff --git a/sercom/model.py b/sercom/model.py index 739bbd7..dec75ad 100644 --- a/sercom/model.py +++ b/sercom/model.py @@ -478,9 +478,10 @@ class InstanciaDeEntrega(SQLObject, ByObject): #{{{ def __init__(self, ejercicio=None, numero=None, inicio=None, fin=None, observaciones=None, activo=True, tareas=(), **kargs): - SQLObject.__init__(self, ejercicioID=ejercicio.id, numero=numero, - fin=fin, inicio=inicio, observaciones=observaciones, activo=activo, - **kargs) + if ejercicio: + SQLObject.__init__(self, ejercicioID=ejercicio.id, numero=numero, + fin=fin, inicio=inicio, observaciones=observaciones, activo=activo, + **kargs) if tareas: self.tareas = tareas diff --git a/sercom/subcontrollers/__init__.py b/sercom/subcontrollers/__init__.py index f650c14..97976ee 100644 --- a/sercom/subcontrollers/__init__.py +++ b/sercom/subcontrollers/__init__.py @@ -4,3 +4,4 @@ from curso import CursoController from enunciado import EnunciadoController from caso_de_prueba import CasoDePruebaController from ejercicio import EjercicioController +from entrega import EntregaController diff --git a/sercom/subcontrollers/ejercicio/__init__.py b/sercom/subcontrollers/ejercicio/__init__.py index 3abb82c..c533506 100644 --- a/sercom/subcontrollers/ejercicio/__init__.py +++ b/sercom/subcontrollers/ejercicio/__init__.py @@ -11,6 +11,7 @@ from docutils.core import publish_parts from sercom.subcontrollers import validate as val from sercom.model import Ejercicio, Curso, Enunciado from cherrypy import request, response + #}}} #{{{ Configuración diff --git a/sercom/subcontrollers/ejercicio/templates/list.kid b/sercom/subcontrollers/ejercicio/templates/list.kid index bd79196..035542a 100644 --- a/sercom/subcontrollers/ejercicio/templates/list.kid +++ b/sercom/subcontrollers/ejercicio/templates/list.kid @@ -27,6 +27,7 @@ grupal + Entregas Editar Eliminar diff --git a/sercom/subcontrollers/entrega/__init__.py b/sercom/subcontrollers/entrega/__init__.py new file mode 100644 index 0000000..9159f73 --- /dev/null +++ b/sercom/subcontrollers/entrega/__init__.py @@ -0,0 +1,112 @@ +# vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker : + +#{{{ Imports +from turbogears import controllers, expose, redirect +from turbogears import validate, flash, error_handler +from turbogears import validators as V +from turbogears import widgets as W +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 Ejercicio, Curso, Enunciado, InstanciaDeEntrega +from cherrypy import request, response +#}}} + +#{{{ Configuración +cls = InstanciaDeEntrega +name = 'instancia de entrega' +namepl = 'instancias de entrega' + +fkcls = Ejercicio +fkname = 'ejercicio' +fknamepl = fkname + 's' + +#}}} + +#{{{ Validación +def validate_fk(data): + fk = data.get(fkname + 'ID', None) + if fk == 0: fk = None + if fk is not None: + try: + fk = fkcls.get(fk) + except LookupError: + flash(_(u'No se pudo crear el nuevo %s porque el %s con ' + 'identificador %d no existe.' % (name, fkname, fk))) + raise redirect('new', **data) + data.pop(fkname + 'ID', None) + data[fkname] = fk + return fk + +def validate_get(id): + return val.validate_get(cls, name, id) + +def validate_set(id, data): + validate_fk(data) + return val.validate_set(cls, name, id, data) + +def validate_new(data): + validate_fk(data) + return val.validate_new(cls, name, data) +#}}} + +#{{{ Formulario +def get_options(): + return [(0, _(u'--'))] + [(fk.id, fk.shortrepr()) for fk in fkcls.select()] + +class EntregaForm(W.TableForm): + class Fields(W.WidgetsList): + numero = W.TextField(name="numero",label=_(u'Nro'), help_text=_(u'Requerido.'), + validator=V.Int(not_empty=True)) + inicio = W.CalendarDateTimePicker(label=_(u"Inicio")) + fin = W.CalendarDateTimePicker(label=_(u"Fin")) + procesada = W.CheckBox(label=_(u"Procesada?")) + activo = W.CheckBox(label=_(u"Activo?")) + observaciones = W.TextArea(rows="5", cols="40") + ejercicio_id= W.HiddenField() + fields = Fields() + javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_nombre');")] + +form = EntregaForm() +#}}} + +#{{{ Controlador +class EntregaController(controllers.Controller, identity.SecureResource): + """Basic model admin interface""" + require = identity.has_permission('admin') + + @expose(template='kid:%s.templates.list' % __name__) + @validate(validators=dict(ejercicio_id=V.Int)) + @paginate('records') + def default(self, ejercicio_id): + e = Ejercicio.get(ejercicio_id) + r = e.instancias + return dict(records=r, name=name, namepl=namepl, parcial=str(ejercicio_id)) + + @expose(template='kid:%s.templates.new' % __name__) + def new(self, ejercicio_id, **kw): + """Create new records in model""" + form.fields[6].attrs['value'] = ejercicio_id + return dict(name=name, namepl=namepl, form=form, values=kw, partial=str(ejercicio_id)) + + @validate(form=form) + @error_handler(new) + @expose() + def create(self, ejercicio_id, **kw): + """Save or create record to model""" + e = Ejercicio.get(ejercicio_id) + e.add_instancia(**kw) + flash(_(u'Se creó un nuevo %s.') % name) + raise redirect('/entrega/'+str(e.id)) + + @expose() + def delete(self, id): + """Destroy record in model""" + r = validate_get(id) + r.destroySelf() + flash(_(u'El %s fue eliminado permanentemente.') % name) + raise redirect('../list') + +#}}} + diff --git a/sercom/subcontrollers/entrega/templates/list.kid b/sercom/subcontrollers/entrega/templates/list.kid new file mode 100644 index 0000000..6ab783b --- /dev/null +++ b/sercom/subcontrollers/entrega/templates/list.kid @@ -0,0 +1,47 @@ + + + + +list + + + +

Administración de Objetos

+ + + + + + + + + + + + + + + + + + + + +
NroInicioFinProcesada?Activa?ObservacionesOperaciones
numeroiniciofinprocesadaactivaobs + Eliminar +
+ +
+Agregar + +
+ ${page} + ${page} +
+ + + + + diff --git a/sercom/subcontrollers/entrega/templates/new.kid b/sercom/subcontrollers/entrega/templates/new.kid new file mode 100644 index 0000000..500ed08 --- /dev/null +++ b/sercom/subcontrollers/entrega/templates/new.kid @@ -0,0 +1,18 @@ + + + + +new + + + +

Crear Nuevo Objeto

+ +

Formulario

+ +
+Cancelar + + + -- 2.43.0