1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
4 from turbogears import controllers, expose, redirect
5 from turbogears import validate, flash, error_handler
6 from turbogears import validators as V
7 from turbogears import widgets as W
8 from turbogears import identity
9 from turbogears import paginate
10 from docutils.core import publish_parts
11 from sercom.subcontrollers import validate as val
12 from sercom.model import Enunciado, Docente
13 from cherrypy import request, response
23 fknamepl = fkname + 'es'
27 def validate_fk(data):
28 fk = data.get(fkname + 'ID', None)
34 flash(_(u'No se pudo crear el nuevo %s porque el %s con '
35 'identificador %d no existe.' % (name, fkname, fk)))
36 raise redirect('new', **data)
37 data.pop(fkname + 'ID', None)
42 return val.validate_get(cls, name, id)
44 def validate_set(id, data):
46 return val.validate_set(cls, name, id, data)
48 def validate_new(data):
50 return val.validate_new(cls, name, data)
55 return [(0, _(u'--'))] + [(fk.id, fk.shortrepr()) for fk in fkcls.select()]
57 class EnunciadoForm(W.TableForm):
58 class Fields(W.WidgetsList):
59 nombre = W.TextField(label=_(u'Nombre'),
60 help_text=_(u'Requerido y único.'),
61 validator=V.UnicodeString(min=5, max=60, strip=True))
62 fk = W.SingleSelectField(name=fkname+'ID', label=_(fkname.capitalize()),
63 options=get_options, validator=V.Int(not_empty=False))
64 descripcion = W.TextField(label=_(u'Descripción'),
65 validator=V.UnicodeString(not_empty=False, max=255, strip=True))
66 archivo = W.FileField(label=_(u'Archivo'))
68 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_nombre');")]
70 form = EnunciadoForm()
74 class EnunciadoController(controllers.Controller, identity.SecureResource):
75 """Basic model admin interface"""
76 require = identity.has_permission('admin')
79 def default(self, tg_errors=None):
80 """handle non exist urls"""
81 raise redirect('list')
85 raise redirect('list')
87 @expose(template='kid:%s.templates.list' % __name__)
88 @validate(validators=dict(autor=V.Int))
90 def list(self, autor=None):
91 """List records in model"""
95 r = cls.selectBy(autorID=autor)
96 return dict(records=r, name=name, namepl=namepl, parcial=autor)
98 @expose(template='kid:%s.templates.new' % __name__)
100 """Create new records in model"""
101 return dict(name=name, namepl=namepl, form=form, values=kw)
106 def create(self, archivo, **kw):
107 """Save or create record to model"""
108 kw['archivo'] = archivo.file.read()
109 kw['archivo_name'] = archivo.filename
110 kw['archivo_type'] = archivo.type
112 flash(_(u'Se creó un nuevo %s.') % name)
113 raise redirect('list')
115 @expose(template='kid:%s.templates.edit' % __name__)
116 def edit(self, id, **kw):
117 """Edit record in model"""
119 return dict(name=name, namepl=namepl, record=r, form=form)
124 def update(self, id, **kw):
125 """Save or create record to model"""
126 r = validate_set(id, kw)
127 flash(_(u'El %s fue actualizado.') % name)
128 raise redirect('../list')
130 @expose(template='kid:%s.templates.show' % __name__)
131 def show(self,id, **kw):
132 """Show record in model"""
134 if r.descripcion is None:
137 r.desc = publish_parts(r.descripcion, writer_name='html')['html_body']
138 return dict(name=name, namepl=namepl, record=r)
141 def delete(self, id):
142 """Destroy record in model"""
145 flash(_(u'El %s fue eliminado permanentemente.') % name)
146 raise redirect('../list')
151 response.headers["Content-Type"] = r.archivo_type
152 response.headers["Content-disposition"] = "attachment;filename=%s" % (r.archivo_name)
153 flash(_(u'El %s fue eliminado permanentemente.') % name)