How do I set initial data on a Django class based generic createview with request data
Asked Answered
E

2

10

I used Django's generic createview for my model

from myproject.app.forms import PersonForm
class PersonMixin(object):
    model = Person
    form_class = PersontForm

class PersonCreateView(PersonMixin, CreateView):
    pass

This works perfectly for displaying a create view of Person with my custom form. However, I have a field in the form that I want to pre-populate with a value. I found this answer: Set initial value to modelform in class based generic views

However, my pre-populated value comes from the profile for request.user. How do I access the request in PersonCreateView and pass that to the form?

Eliezer answered 1/11, 2012 at 15:17 Comment(0)
A
40

In any of the class methods you can access the request using self.request. So your user profile will be accessible with self.request.user.

Building on the link you provided you will be able to use self.request.user in your get_initial method to set the value.

ie.

def get_initial(self):
    return { 'value1': self.request.user }
Agha answered 1/11, 2012 at 15:22 Comment(2)
Where do you add this code?Misquote
I added it under my form_valid, nothing happened.Misquote
C
4

First off, you don't need to use a mixin there. Just specify the form_class in PersonCreateView; model is not needed either, since you are already specifying it in the form_class (assuming is a subclass of ModelForm).

About where to get the request from, class based views save it in the object, so you can do self.request.user inside get_initial or get_form_kwargs.

Christan answered 1/11, 2012 at 15:28 Comment(4)
I actually use this PersonMixin in other generic views which is why its separated, but I appreciate the advice and I didn't know i could forgo model since i'm specifying form_class.Eliezer
Yes, I figured that out after posting, but still I'd advice against using Mixins like that unless totally necessary (with class based views is not uncommon to need them, but if it's just to reuse a couple of attribute definitions then it's not worth it).Christan
why do you say that? i never gave much though to the downside but maybe i'm missing something?Eliezer
Multiple inheritance is generally not a good idea (although very useful in particular cases): it adds complexity to the code, making it less readable, and sometimes producing non intuitive behavior. So as rule of thumb, I prefer not to use it unless I have a good reason to do so.Christan

© 2022 - 2024 — McMap. All rights reserved.