0

わかりました、私は立ち往生しています。

私が抱えている問題は次のとおりです。私は2つのモデルを持っていRelenvaceCodingRecordますEventRecord
ユーザーは、記事が関連するかどうかを選択できる必要があります。そうである場合は、フォームの他のフィールドが必要です。そうでない場合は、必須フィールドはありません。これは、JS を使用せずに、同じページの 1 つの形式で行う必要があります。

これまでに行ったことは、2 つのモデルの多くのフィールドを持つフォーム (forms.Form) を作成することです。この記事に続いて、条件付きrequiredロジックを実装しようとしました。

class CodingForm(forms.Form):
    relevance = forms.BooleanField(required=False)
    event_date = forms.DateField('Event Date',required=False)
    location = forms.ModelChoiceField(queryset=Location.objects.all(), empty_label=None, required=False)
    actors = forms.CharField(max_length=100, required=False)
    party = forms.NullBooleanField('Party')
    labor_org = forms.NullBooleanField('Labor Organization')
    property_dmg = forms.NullBooleanField('Property Damage')
    violence = forms.NullBooleanField('Violence')
    injured = forms.IntegerField(required=False)
    deaths = forms.IntegerField(required=False)
    participants_num = forms.IntegerField(required=False)
    participants_str = forms.IntegerField(required=False)
    anti_gov = forms.NullBooleanField('Anti Government')
    presence = forms.NullBooleanField('Presence')
    intervene = forms.NullBooleanField('Intervention')
    brutality = forms.NullBooleanField('Brutality')
    arrests = forms.NullBooleanField('Arrests')
    issue = forms.CharField(max_length=100,required=False)
    url = forms.CharField(max_length=100,required=False)

    def __init__(self, data=None, *args, **kwargs):
        super(CodingForm, self).__init__(data, *args, **kwargs)

        if data and data.get('relevance', None) == True:
            self.fields['event_date'].required = True
            self.fields['location'].required = True
            self.fields['anti_gov'].required = True

私の見解では、フォームを取得し、その値を と の 2 つの ModelForms に渡して、RelevanceCodingRecordすべてEventRecord保存しようとしました。

if request.method == 'POST':
    if 'coding' in request.POST:
    event_form = EventRecordForm(request.POST, prefix='event')
    relevance_form = RelevanceCodingRecordForm(request.POST, prefix='event')
    coding_form = CodingForm(request.POST, prefix='coding')

    if coding_form.is_valid():
        obj = coding_form.save(commit=False)
        event = event_form.save(commit=False)
        relevance = relevance_form.save(commit=False)

        # Relevance Data
        relevance.relevance = obj.relevance
        relevance.screened = True
        relevance.classified = True
        relevance.coder = request.user.coder
        relevance.article = paginator.page(page).object_list[0]
        relevance.last_updated = datetime.datetime.today
        relevance.save()

        if relenvace.relevance == True:
        # Event Data
            event.article = paginator.page(page).object_list[0]
            event.event_date = obj.event_date
            event.country = paginator.page(page).object_list[0].country
            event.location = obj.event_location
            event.actors = obj.actors
            event.party = obj.party
            event.labor_org = obj.labor_org
            event.property_dmg = obj.property_dmg
            event.violence = obj.violence
            event.injured = obj.injured
            event.deaths = obj.deaths
            event.participants_num = obj.participants_num
            event.participants_str = obj.participants_str
            event.anti_gov = obj.anti_gov
            event.presence = obj.presence
            event.intervene = obj.intervene
            event.brutality = obj.brutality
            event.arrests = obj.arrests
            event.issue = obj.issue
            event.url = paginator.page(page).object_list[0].source
            event.coder = request.user.coder
            event.last_updated = datetime.datetime.today
            event.save()

            redirect_to = "?page=%s" % page
            return HttpResponseRedirect(redirect_to)
        else:
            redirect_to = "?page=%s" % page
            return HttpResponseRedirect(redirect_to)

else:
    coding_form = CodingForm(prefix='coding')
    coding_form.fields["location"].queryset = Location.objects.filter(ccode=country).order_by('name')

ただし、これは機能しません。データベースにレコードが作成されず、リダイレクトされるだけです。
これを機能させる方法はありますか?それとも私はここで愚かな用事をしていますか?
あるフォームから別のフォームに渡されるデータのほとんども DRY ではありませんが、より良い方法を知りません。

ここで何か助けていただければ幸いです。

4

1 に答える 1