On Thu, Jun 4, 2009 at 9:38 AM, justind <justin.don...@gmail.com> wrote:

>
> Thanks Alex. That works great.
>
> Just wondering: It seems like this causes the form to be bound, which
> causes it to render all its errors.
> I can set .is_bound to False manually to get around this, is this what
> I should be doing?
>
> On Jun 3, 5:15 pm, Alex Gaynor <alex.gay...@gmail.com> wrote:
> > On Wed, Jun 3, 2009 at 5:12 PM, justind <justin.don...@gmail.com> wrote:
> >
> > > Hello,
> >
> > > I'm using the following to provide a select box with filtered choices:
> >
> > > class AssetForm(ModelForm):
> > >    """Asset form takes a project id. It only allows workstreams
> > > attached to
> > >    this project name."""
> > >    workstreams = forms.ModelChoiceField(Workstream, None)
> > >    def __init__(self, *args, **kwargs):
> > >        super(AssetForm, self).__init__(*args, **kwargs)
> > >        if self.instance:
> > >            self.fields['workstreams'].queryset =
> > > Workstream.objects.filter(project__id=args[0])
> > >            self.fields['workstreams'].widget.choices =
> > > self.base_fields['workstreams'].choices
> >
> > > I instantiate it
> >
> > > f = AssetForm(1) # 1 is the number of a project, which I filter with.
> >
> > > It seems to work, and I can poke around at the fields and choices.
> >
> > > but when I try to render it:
> >
> > > f.as_p()
> >
> > > I get:
> >
> > > Traceback (most recent call last):
> > >  File "<console>", line 1, in <module>
> > >  File "django\django\forms\forms.py", line 191, in as_p
> > >    return self._html_output(u'<p>%(label)s %(field)s%(help_text)s</
> > > p>', u'%s',
> > > '</p>', u' %s', True)
> > >  File "django\django\forms\forms.py", line 139, in _html_output
> > >    top_errors = self.non_field_errors() # Errors that should be
> > > displayed above
> > >  all fields.
> > >  File "django\django\forms\forms.py", line 199, in non_field_errors
> > >    return self.errors.get(NON_FIELD_ERRORS, self.error_class())
> > >  File "django\djang
> > > o\forms\forms.py", line 111, in _get_errors
> > >    self.full_clean()
> > >  File "django\django\forms\forms.py", line 218, in full_clean
> > >    value = field.widget.value_from_datadict(self.data, self.files,
> > > self.add_pre
> > > fix(name))
> > >  File "django\django\forms\widgets.py", line 170, in
> > > value_from_datadict
> > >    return data.get(name, None)
> > > AttributeError: 'int' object has no attribute 'get'
> >
> > > Any ideas?
> >
> > > Thanks,
> > > Justin
> >
> > You need to remove the 1 from args before instantiating the Form, so
> > something like:
> >
> > def __init__(self, *args, **kwargs):
> >    id = args[0]
> >    args = args[1:]
> >    etc...
> >
> > Otherwise django thinks 1 is the first argument which is supposed to be
> the
> > data dictionary..
> >
> > Alex
> > --
> > "I disapprove of what you say, but I will defend to the death your right
> to
> > say it." --Voltaire
> > "The people's good is the highest law."--Cicero
> >
>
No, you should be doing more or less exactly what I specified in my earlier
post to ensure tha tyou don't actaully pass the integer to the parent
constructor.

Alex

-- 
"I disapprove of what you say, but I will defend to the death your right to
say it." --Voltaire
"The people's good is the highest law."--Cicero

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to