Как отобразить условное поле формы, зависящее от атрибута выбранного внешнего ключа, на форме модели django

Я хочу условно отобразить поля frequency_input или duration_input на основе атрибута behavior.recording выбранного поведения.

У меня есть форма Trial, которая в настоящее время отображает 3 поля:

  • имя_поведения (внешний ключ) выпадающий список
  • frequency_input
  • duration_input

Я не уверен, какой метод решения мне лучше выбрать (Javascript или решение в View)?

Модель испытания

class Trial(models.Model):
    behavior_name = models.ForeignKey(Behavior, on_delete=models.CASCADE)
    client_session = models.ForeignKey(Client_Session, on_delete=models.CASCADE)
    frequency_input = models.PositiveIntegerField(default=0, blank=True)
    duration_input = models.DurationField(blank=True, default=timedelta(minutes=0))


    class Meta:
        verbose_name_plural = 'trials'

    def __str__(self):
        return str(self.id)

Модель поведения

RECORDING_CHOICES = (
    ('Rate','RATE'),
    ('Duration','DURATION'),
    ('Frequency','FREQUENCY')
)

class Behavior(models.Model):
    name = models.CharField(max_length=200)
    goal = models.CharField(max_length=200)
    recording = models.CharField(max_length=10, choices=RECORDING_CHOICES, null=False)
    status = models.CharField(max_length=10, choices=STATUS_CHOICES, default='Active')
    
    def __str__(self):
        return self.name

Форма суда

class TrialForm(forms.ModelForm):
    class Meta:
        model = Trial
        fields = ('behavior_name','frequency_input', 'duration_input')

Добавить пробный вид

def add_trial(request, clientsession_id):
    client_session = Client_Session.objects.get(id=clientsession_id)
    if request.method != 'POST':
        form = TrialForm()
    else:
        form = TrialForm(data=request.POST)
        if form.is_valid():
            add_trial = form.save(commit=False)
            add_trial.client_session = client_session
            add_trial.save()
            return HttpResponse(status=204, headers={'HX-Trigger': 'trialupdated'})

    context = {'client_session': client_session, 'form': form}
    return render(request, 'sessions/add_trial.html', context)
Вернуться на верх