Massimo, Thank you.
As always, if I'm doing something wrong I would be delighted to know it. >From the limited checking I have been able to do, I think the problem is in the SELECT helper, not in the validator. Anyway, here's the code. ## model db.define_table('buckslip_types', Field('name', length=32), ) db.define_table('buckslips', Field('type', db.buckslip_types), Field('status', 'list:string'), Field('date_received', 'datetime'), Field('date_approved', 'datetime'), Field('date_posted', 'datetime'), Field('comments', 'text'), Field('document_filename', length=256), Field('document','upload') ) db.buckslips.type.requires = IS_IN_DB(db, 'buckslip_types.id', '%(name)s', zero=None) db.buckslips.status.requires = IS_IN_SET(['received', 'approved', 'disapproved', 'posted'], multiple=False ) ## controller buckslips.py def edit(): record = db.buckslips(request.args[-1]) or redirect(URL('index')) url = URL('download') db.buckslips.document.writable = False # db.buckslips.status.widget = my_select_widget fields=['date_received', 'status', 'document', 'comments'] form = SQLFORM(db.buckslips, record, deletable=False, upload=url, fields=fields, ) if request.vars.document!=None: form.vars.document_filename= request.vars.document.filename if form.process().accepted: response.flash = 'form accepted' elif form.errors: response.flash = 'form has errors' return dict(form=form) On Mar 1, 11:26 am, Massimo Di Pierro <massimo.dipie...@gmail.com> wrote: > Can you provide an example of IS_IN_SET not working so we can fix it? By > the way, there was a change in IS_IN_SET in trunk and that may have fixed > your problem. > > > > > > > > On Thursday, 1 March 2012 09:05:51 UTC-6, Cliff wrote: > > > Running 1.99.4 > > > I have not been able to get the IS_IN_SET validator to work properly. > > I don't know why this should be. > > > When used with SQLFORM to edit a record, the select field refuses to > > show the current value of the field. Instead it shows the first value > > in the list or the zero value for the field. > > > So I made an alternative widget. The code consists of two functions, > > below. > > > If you are having similar problems, feel free to use it. > > > The _style definition at the end of the call is there to make sure I > > was seeing my widget instead of the default. It is not necessary for > > the widget to work. > > > ############################################################ > > > def is_it_selected(current_value, option, multiple): > > if len(current_value) == 1 or not multiple: > > current_value=current_value[0] > > if current_value==option: > > out = 'selected' > > else: > > out = None > > else: > > if option in current_value: > > out='selected' > > else: > > out=None > > return out > > > def my_select_widget(field,value): > > # diagnostics uncomment to learn > > #print 'value' > > #print value > > #print 'type(value)' > > #print type(value) > > > f = str(field) > > f_name = f.split('.')[-1] > > f_id = f.replace('.', '_') > > f_requires = db[request.controller][f_name].requires > > the_set = f_requires.theset > > the_multiple = f_requires.multiple > > option_set = [] > > for t in the_set: > > is_selected = is_it_selected(value, t, the_multiple) > > option_set.append(OPTION(t, _selected = is_selected)) > > return SELECT(option_set, _name='status', _id='buckslips_status', > > _style='color:red;' > > )