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.

Foi útil?

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>'
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top