0

フォームから別のモデルのインスタンスを外部キーとして取得するモデルのインスタンスを保存しようとして立ち往生しています。

モデル

class Customer(models.Model):
    owner = models.ForeignKey(User)
    custname = models.CharField() 

class Appointment(models.Model):
    user = models.ForeignKey(User)
    start = models.DateTimeField()
    end = models.DateTimeField()
    customer = models.ForeignKey(Customer)

class AppointmentForm(forms.Form):
    basedate = forms.DateField()
    start = forms.TimeField(widget=forms.Select())
    end = forms.IntegerField(widget=forms.Select())
    customer = forms.ModelMultipleChoiceField(queryset=Customer.objects.all())

一般的な FormView で動作できないメソッド:

def form_valid(self, form):
    if form.is_valid():
        appointment = Appointment()
        appointment.user = self.request.user
        basedate = form.cleaned_data['basedate']
        start = form.cleaned_data['start']
        duration = form.cleaned_data['end']
        appointment.start = datetime.datetime.combine(basedate, start)
        appointment.end = appointment.start + datetime.timedelta(minutes=duration)
        appointment.save()
        return super(AppointmentCreate, self).form_valid(form)

フォームから外部キーの顧客を読み取り、それを予定に渡す最後のメソッドに何を追加すればよいでしょうか? request.user に属する顧客のみがフォームに表示されるようにフィルタリングする方法はありますか?

ご協力いただきありがとうございます。

4

2 に答える 2

1

このようなものがうまくいくはずです。いくつかのこと:

1) フォーム フィールドを複数選択ではなく ModelChoiceField に変更しました。リレーションシップを表示するには、ModelChoiceField を使用する必要があります。モデルによれば、1 つの選択肢のみを保存する必要があるため、これを MultipleChoice から変更しました。ModelChoiceFields の詳細については、https ://docs.djangoproject.com/en/dev/ref/forms/fields/ をご覧ください。

2) あなたのフォームで、選択クエリを に変更しましたcustomer = forms.ModelChoiceField(queryset=Customer.objects.filter(owner=request.user)。これにより、特定のユーザーの顧客のみがフィルタリングされます。

フォーム.py

class AppointmentForm(forms.Form):
    def __init__(self, *args, **kwargs):
        self.request = kwargs.pop("request")
        super(AppointmentForm, self).__init__(*args, **kwargs)

    basedate = forms.DateField()
    start = forms.TimeField(widget=forms.Select())
    end = forms.IntegerField(widget=forms.Select())
    customer = forms.ModelChoiceField(queryset=Customer.objects.filter(owner=request.user))

ビュー.py

def form_valid(self, form):
    if request.method=='POST':
        form = AppointmentForm(request.POST, request=request)
        if form.is_valid():
            appointment = Appointment()
            appointment.user = self.request.user
            basedate = form.cleaned_data['basedate']
            start = form.cleaned_data['start']
            duration = form.cleaned_data['end']
            appointment.customer = form.cleaned_data['customer']
            appointment.start = datetime.datetime.combine(basedate, start)
            appointment.end = appointment.start + datetime.timedelta(minutes=duration)       
            appointment.save()
            return super(AppointmentCreate, self).form_valid(form)
    else:
        form = AppointmentForm()
于 2013-01-11T20:34:09.487 に答える
0

最後に私はそれをしました。重要なのは、forms.pyでinitを変更するのではなく、views.py で FormView クラスのgetメソッドをオーバーライドすることでした。

フォーム.py:

class AppointmentForm(forms.Form):
    basedate = forms.DateField()
    start = forms.TimeField(widget=forms.Select())
    end = forms.IntegerField(widget=forms.Select())
    customer = forms.ModelChoiceField(queryset=Customer.objects.all())
    ...

ビュー.py:

    def get(self, request, *args, **kwargs):
        """
        Handles GET requests and instantiates a blank version of the form.
        """
        choices_start, choices_duration = self._get_choices()
        form_class = self.get_form_class()
        form = self.get_form(form_class)
        form.fields['start'].widget=forms.Select(choices=choices_start)
        form.fields['end'].widget=forms.Select(choices=choices_duration)
        form.fields['customer'].queryset=Customer.objects.filter(owner=request.user)
        return self.render_to_response(self.get_context_data(form=form))

@ダン:私を助けてくれてありがとう。

于 2013-01-14T18:47:27.917 に答える