]> git.llucax.com Git - software/sercom.git/blob - sercom/subcontrollers/caso_de_prueba/__init__.py
vuelvo a poner en el widget el tip
[software/sercom.git] / sercom / subcontrollers / caso_de_prueba / __init__.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
2
3 #{{{ Imports
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 CasoDePrueba, Enunciado
13 from sercom.validators import ParamsValidator
14 #}}}
15
16 #{{{ Configuración
17 cls = CasoDePrueba
18 name = 'caso de prueba'
19 namepl = 'casos de prueba'
20
21 fkcls = Enunciado
22 fkname = 'enunciado'
23 fknamepl = fkname + 's'
24 #}}}
25
26 #{{{ Validación
27 def validate_fk(data):
28     fk = data.get(fkname + 'ID', None)
29     if fk == 0: fk = None
30     if fk is not None:
31         try:
32             fk = fkcls.get(fk)
33         except LookupError:
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)
38     data[fkname] = fk
39     return fk
40
41 def validate_get(id):
42     return val.validate_get(cls, name, id)
43
44 def validate_set(id, data):
45     validate_fk(data)
46     return val.validate_set(cls, name, id, data)
47
48 def validate_new(data):
49     validate_fk(data)
50     return val.validate_new(cls, name, data)
51 #}}}
52
53 #{{{ Formulario
54 def get_options():
55     return [(0, _(u'<<General>>'))] + [(fk.id, fk.shortrepr())
56         for fk in fkcls.select()]
57
58 class CasoDePruebaForm(W.TableForm):
59     class Fields(W.WidgetsList):
60         nombre = W.TextField(label=_(u'Nombre'),
61             help_text=_(u'Requerido y único.'),
62             validator=V.UnicodeString(min=5, max=60, strip=True))
63         fk = W.SingleSelectField(name=fkname+'ID', label=_(fkname.capitalize()),
64             options=get_options, validator=V.Int(not_empty=False))
65         descripcion = W.TextField(label=_(u'Descripción'),
66             validator=V.UnicodeString(not_empty=False, max=255,
67                 strip=True))
68         parametros = W.TextField(label=_(u'Parámetros'),
69             validator=ParamsValidator(not_empty=False, strip=True))
70         retorno = W.TextField(label=_(u'Código de retorno'),
71             validator=V.Int(not_empty=False, strip=True))
72         tiempo_cpu = W.TextField(label=_(u'Tiempo de CPU'),
73             validator=V.Number(not_empty=False, strip=True))
74     fields = Fields()
75     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_nombre');")]
76
77 form = CasoDePruebaForm()
78 #}}}
79
80 #{{{ Controlador
81
82 def params2str(params):
83     return ' '.join([repr(p)[1:] for p in params])
84
85 class CasoDePruebaController(controllers.Controller, identity.SecureResource):
86     """Basic model admin interface"""
87     require = identity.has_permission('admin')
88
89     @expose()
90     def default(self, tg_errors=None):
91         """handle non exist urls"""
92         raise redirect('list')
93
94     @expose()
95     def index(self):
96         raise redirect('list')
97
98     @expose(template='kid:%s.templates.list' % __name__)
99     @validate(validators=dict(enunciado=V.Int))
100     @paginate('records')
101     def list(self, enunciado=None):
102         """List records in model"""
103         if enunciado is None:
104             r = cls.select()
105         else:
106             r = cls.selectBy(enunciadoID=enunciado)
107         return dict(records=r, name=name, namepl=namepl, parcial=enunciado,
108             params2str=params2str)
109
110     @expose(template='kid:%s.templates.new' % __name__)
111     def new(self, **kw):
112         """Create new records in model"""
113         return dict(name=name, namepl=namepl, form=form, values=kw)
114
115     @validate(form=form)
116     @error_handler(new)
117     @expose()
118     def create(self, **kw):
119         """Save or create record to model"""
120         validate_new(kw)
121         flash(_(u'Se creó un nuevo %s.') % name)
122         raise redirect('list')
123
124     @expose(template='kid:%s.templates.edit' % __name__)
125     def edit(self, id, **kw):
126         """Edit record in model"""
127         r = validate_get(id)
128         return dict(name=name, namepl=namepl, record=r, form=form,
129             params2str=params2str)
130
131     @validate(form=form)
132     @error_handler(edit)
133     @expose()
134     def update(self, id, **kw):
135         """Save or create record to model"""
136         r = validate_set(id, kw)
137         flash(_(u'El %s fue actualizado.') % name)
138         raise redirect('../list')
139
140     @expose(template='kid:%s.templates.show' % __name__)
141     def show(self, id, **kw):
142         """Show record in model"""
143         r = validate_get(id)
144         if r.descripcion is None:
145             r.desc = ''
146         else:
147             r.desc = publish_parts(r.descripcion, writer_name='html')['html_body']
148         return dict(name=name, namepl=namepl, record=r, params2str=params2str)
149
150     @expose()
151     def delete(self, id):
152         """Destroy record in model"""
153         r = validate_get(id)
154         r.destroySelf()
155         flash(_(u'El %s fue eliminado permanentemente.') % name)
156         raise redirect('../list')
157 #}}}
158