2012-03-28 15 views
5

Kullanıcı personel değilse, form alanlarını nasıl hariç tutma? Model formu -Django: Kullanıcı personelse form alanını nasıl hariç tutma?

global name 'user' is not defined

class PostForm(ModelForm): 

    class Meta: 
     model = Photo 
     exclude = ['author','featured','published'] 

    def __init__(self, *args, **kwargs): 
     published = kwargs.pop('published', None) 
     super(PostForm, self).__init__(*args, **kwargs) 
     if not user.is_staff: 
      del self.fields['published'] 

view.py

Sen isteğinizden o kullanıcı örneğini geçmesi gerekiyor
def addpost(request): 

    if request.method == 'POST': 
     form = PostForm(request.POST,request.FILES,user=request.user) 
     if form.is_valid(): 

      post = form.save(False) 
      post.author = request.user 
      form.save() 

      return HttpResponseRedirect(reverse('insight.content.views.index',)) 

    else: 
     form = PostForm(user=request.user) 


    ispost = True 
    return render_to_response('form_add_place.html', {'form': form,'ispost':ispost},context_instance=RequestContext(request)) 

cevap

3

: Ben bir hata veriyor, bu çalıştı ama işe yaramadı ona erişim yok. senin __init__ yılında Sonra

my_form = PostForm(user=request.user)

:

formu oluşturulurken Bu şablonda elde edilebilir
def __init__(self, *args, **kwargs): 
    published = kwargs.pop('published', None) 
    user = kwargs.pop('user', None) 
    super(PostForm, self).__init__(*args, **kwargs) 
    if not user.is_staff: 
     del self.fields['published'] 
+0

Maalesef Bunu anlamadım, bunu ekledim "my_form = PostForm (user = request.user)" benim görüşüm ve __init__ işlevi düzeltildi, ancak başka bir hata oluştu, daha fazla veri eklemek için buradaki soruyu düzenleyeceğim! – Hamza

+0

Bu hata geldi: 'NoneType' nesnesinin 'is_superuser' özniteliği yok – Hamza

+0

Bu, etkin bir oturum açmış kullanıcınız olmadığı anlamına gelir. –

11

. Bu boş değerlere izin vermek veya model tanımında varsayılan bir değere sahip veya alternatif olarak doğrulama geçersiz olması gerekir:

<form method="post">{% csrf_token %} 
    {% if request.user.is_staff %} 
    <p>{{ form.published }}</p> 
    {% endif %} 

    <p>{{ form.author }}</p> 

    <!-- ... your other fields --> 
</form> 

Benzer şekilde is_superuser veya çek izinleri kontrol edebilirsiniz, dokümanlar bakınız: https://docs.djangoproject.com/en/dev/topics/auth/default/#permissions

İlgili konular