Formulário de Inicialização com ToscaWidgets
-
21-08-2019 - |
Pergunta
Pergunta:
Como faço para preencher previamente um CheckBoxTable de ToscaWidgets com valores.
Fundo:
Eu olhei em todos os lugares e eu não consigo descobrir como inicializar um campo de forma particular com ToscaWidgets. A maioria dos campos do formulário parecem responder bem a inicialização, como se eu criar um formulário com um único TextField nele quando eu tornar o formulário no modelo e passar fieldValue = x, onde fieldValue é o nome do TextField e x é uma string TextField será preenchido com x. Meu problema é com todo o campo de seleção múltipla, em particular CheckBoxTable. Não importa o que eu passar em que não irá inicializar o múltipla escolha. Aqui está um exemplo do que estou falando, é uma página de usuário editar com um CheckBoxTable para grupos para que você pode selecionar vários ou nenhum grupo de fora de uma lista de vários grupos obtido a partir da databse:
O que eu tenho:
Meu widget é:
from tw import forms
class UserForm(forms.TableForm):
show_errors = True
submit_text = "Create User"
clientOptions = [(-1, "Select a Client")]
groupOptions = [(-1, "Select a Group")]
fields = [forms.TextField('name', label_text='User Name', validator=String(not_empty=True), size=40),
forms.Spacer(),
forms.SingleSelectField('clientID', label_text='Client Name', validator=Int(min=0), options=clientOptions),
forms.Spacer(),
forms.CheckBoxTable('groups', lable_text='Groups', validator=Set(), options=groupOptions, num_cols=3),
forms.Spacer(),
forms.PasswordField('password', label_text="Password", validator=String(not_empty=True, min=6), size=40),
forms.PasswordField('passwordAgain', label_text="Repeat Password", validator=String(not_empty=True, min=6), size=40),
forms.HiddenField('id')]
editUserForm = UserForm("createUserForm", action='alterUser', submit_text="Edit User")
No meu controlador eu tenho:
result = model.DBSession.query(model.User).filter_by(id=kw['id']).first()
tmpl_context.form = editUserForm
clientOptions=model.DBSession.query(model.Client.id, model.Client.name)
groupOptions=model.DBSession.query(model.Group.id, model.Group.name)
formChildArgs = dict(clientID=dict(options=clientOptions), groups=dict(options=groupOptions))
userAttributes=dict(id=result.id, name=result.name, groups=[g.id for g in result.groups], clientID=result.clientID, password=result.password, passwordAgain=result.password)
return dict(verb="Edit", modelName = "User", modelAttributes=userAttributes, formChildArgs=formChildArgs, page='editUser')
e no meu modelo (Mako) tenho:
${tmpl_context.form(modelAttributes, child_args=formChildArgs) | n}
O que eu tentei:
Em meus userAttributs Dicionário eu tentei:
groups=[g.id for g in result.groups]
groups=[g.name for g in result.groups]
groups=[(g.id, g.name) for g in result.groups]
groups=[[g.id, g.name) for g in result.groups]
groups=result.groups
O que eu recebo:
O resultado de tudo isso código é um formulário de edição do usuário com dados pré-preenchidos com os dados do usuário, exceto para o CheckBoxTable. O CheckBoxTable tem todos os grupos no meu banco de dados exibir e esvaziar, o que eu preciso para que eles sejam visualizadas, mas têm os grupos o usuário é além de marcada. Eu pensei que o código nos atributos modelo iria fazer isso, já que é o que ele faz para todos os outros campos, mas deve haver alguma coisa fundamentais que estou perdendo cerca CheckBoxTable instanciação.
especificações:
Eu estou usando Turbogears 2 com ToscaWidgets 0.9.7 formas e Mako para templates.
Solução
configurá-los via o valor param.
import tw.forms
f = tw.forms.TableForm(fields=[tw.forms.CheckBoxTable("name",options=(("foo"),("bar")))])
f(value={"name":{"foo":True,"bar":False}})
>>> u'<form xmlns="http://www.w3.org/1999/xhtml" action="" method="post" class="tableform">\n <table border="0" cellspacing="0" cellpadding="2">\n<tr id="name.container" class="even" title="">\n <td class="labelcol">\n <label id="name.label" for="name" class="fieldlabel">Name</label>\n </td>\n <td class="fieldcol">\n <table id="name" class="checkboxtable">\n <tbody>\n <tr>\n <td>\n
<input id="name_0" value="foo" name="name" type="checkbox" checked="checked" />\n <label for="name_0">foo</label>\n </td>\n </tr><tr>\n <td>\n <input id="name_1" value="bar" name="name" type="checkbox" />\n <label for="name_1">bar</label>\n </td>\n </tr>\n
</tbody>\n</table>\n </td>\n </tr><tr id="submit.container" class="odd" title="">\n <td class="labelcol">\n </td>\n
<td class="fieldcol">\n <input type="submit" class="submitbutton" value="Submit" />\n </td>\n </tr>\n </table>\n</form>'