简体   繁体   English

Django:如何使用ModelFormSet通过request.user过滤ForeignKey选择

[英]Django: How to filter ForeignKey choices by request.user with ModelFormSet

I just want to filter select field in a form, regarding a currently logged user. 我只想过滤表单中与当前登录用户有关的选择字段。 Every user has own categories and budgets - I want to display only a models related with a currently logged user. 每个用户都有自己的类别和预算-我只想显示与当前登录用户相关的模型。 I've tried stuff with filtering before is_valid field, but with no result. 我尝试过在is_valid字段之前进行过滤的东西,但是没有结果。 Please, find my code below: 请在下面找到我的代码:

views.py views.py

@login_required
def day_data_multiadd(request, no_of_lines=0):
  no_of_lines = int(no_of_lines)
  CostFormSet = modelformset_factory(Cost, form=DataAddForm, extra=no_of_lines)
  if request.method == 'POST' and 'form' in request.POST:
      formset = CostFormSet(request.POST, request.FILES)
      if formset.is_valid():
          for form in formset.forms:
              f = form.save(commit=False)
              f.user = request.user
              f.save()
  else:
  formset = CostFormSet(queryset=Cost.objects.none())

  if request.method == 'POST' and 'no_line' in request.POST:
  generate_form = MultiaddGenerateForm(request.POST)
  if generate_form.is_valid():
      cd = generate_form.cleaned_data
  return HttpResponseRedirect(reverse('core_sm:day_data_multiadd', args=(cd['formy'], )))
  else:
  generate_form = MultiaddGenerateForm()

  return render(request, 'core_sm/costs/multi_add.html', {'formset': formset,
   'no_of_lines': no_of_lines,
  'generate_form': generate_form})

forms.py 表格

class DataAddForm(forms.ModelForm):
    class Meta:
    model = Cost
    fields = ['title', 'value', 'publish', 'category', 'budget']
    exclude = ['user']
    labels = {
        'title': _('Tytuł'),
        'value': _('Wartość'),
        'publish': _('Data'),
        'category': _('Kategoria'),
        'budget': _('Budżet')
    }

models.py models.py

class Category(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL)
    title = models.CharField(max_length=200)
    publish = models.DateField(auto_now_add=True)
    updated = models.DateField(auto_now=True)

    class Meta:
        ordering = ('-publish',)

    def __str__(self):
        return self.title

    def get_absolute_ur(self):
        return reverse('core_sm:category_detail', args=[self.id])


class Budget(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL)
    title = models.CharField(max_length=200, db_index=True)
    value = models.DecimalField(decimal_places=2, max_digits=10)
    publish = models.DateField(auto_now_add=True)
    updated = models.DateField(auto_now=True)

    class Meta:
        ordering = ('-publish',)

    def __str__(self):
        return self.title

    def get_absolute_url(self):
        return reverse('core_sm:budget_detail', args=[self.id])


class Cost(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL)
    budget = models.ForeignKey(Budget, related_name='cost')
    category = models.ForeignKey(Category, related_name='cost')
    title = models.CharField(max_length=200, db_index=True)
    publish = models.DateField(default=timezone.now)
    created = models.DateField(auto_now_add=True)
    updated = models.DateField(auto_now=True)
    value = models.DecimalField(max_digits=10, decimal_places=2)

    class Meta:
        ordering = ('-publish',)

    def get_absolute_url(self):
        return reverse('core_sm:stats_detail', args=[self.publish.year,
                                        self.publish.strftime('%y'),
                                        self.publish.strftime('%m'),
                                        self.publish.strftime('%d')])

    def __str__(self):
        return self.title

According to the docs you can pass custom parameters to formsets forms. 根据文档,您可以将自定义参数传递给formset表单。

class DataAddForm(forms.ModelForm):
    class Meta:
    model = Cost
    fields = ['title', 'value', 'publish', 'category', 'budget']
    exclude = ['user']
    labels = {
        'title': _('Tytuł'),
        'value': _('Wartość'),
        'publish': _('Data'),
        'category': _('Kategoria'),
        'budget': _('Budżet')
    }

    def __init__(self, *args, **kwargs):
        user = kwargs.pop('user')
        self.fields['category'].queryset = Category.objects.filter(user=user)
        self.fields['budget'].queryset = Budget.objects.filter(user=user)
        super(DataAddForm, self).__init__(*args, **kwargs)

views.py views.py

formset = CostFormSet(queryset=Cost.objects.none(), form_kwargs={'user': request.user})

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 如何基于request.user覆盖django管理表单Foreignkey - how to override django admin form Foreignkey based on request.user Django:保存表单不起作用(ModelForm 通过 request.user 过滤 ForeignKey 选择) - Django: saving the Form does not work (The ModelForm Filters the ForeignKey choices by request.user) 将request.user传递给Django中的modelformset_factory() - Pass request.user to modelformset_factory() in Django 如何通过request.user过滤django-tastypie的ToManyField? - How to filter ToManyField of django-tastypie by request.user? Django-Rest-Framework:如何使用request.user为登录用户发布到foreignkey字段 - Django-Rest-Framework: How to post to foreignkey field using request.user for logged in user 将 request.user 参数传递给 modelformset_factory 表单 - Pass request.user parameter to modelformset_factory form 如何在Django模板中使用objects.filter(user = request.user)? - How to use objects.filter(user=request.user) in Django templates? Django-filter:具有基于 request.user 的查询集的 ModelChoiceFilter - Django-filter: ModelChoiceFilter with request.user based queryset Django管理员:如何根据对象(而非request.user)的数据过滤ForeignKeyField小部件? - Django admin: how do I filter a ForeignKeyField widget based on the object's (not request.user's) data? Django request.user是空的 - Django request.user is empty
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM