Django: удаление полей формы на основе некоторых значений в базе - PullRequest
0 голосов
/ 20 июня 2019

Я хочу удалить некоторые поля из формы на основе некоторых значений в базе данных. Я не использую эту форму для вставки данных в любую базу данных, я собираюсь сделать CSV-файл из этих данных формы. Также эта форма не относится ни к одной модели.

forms.py

class Registration_form(forms.Form):
    Applicant_Name = forms.CharField(label='Your name', max_length=100)
    Applicant_age = forms.IntegerField(label ='Age of Applicant')
    Applicant_email =forms.EmailField(max_length=50)
    Applicant_phone = forms.CharField(max_length=10)

views.py

class Registration_View(FormView):
    template_name = 'EVENTAPP/Application.html'
    form_class = Registration_form
    success_url = '/'

    def form_valid(self, form):

        Applicant_Name = form.cleaned_data['Applicant_Name'],
        Applicant_age=form.cleaned_data['Applicant_age'],
        Applicant_email=form.cleaned_data['Applicant_email']
        Applicant_phone=form.cleaned_data['Applicant_phone']

       # do some operations if form data valid

        return super().form_valid(form)

models.py

class es_event(models.Model):

    ev_name = models.CharField(max_length=100,verbose_name="Event Name")
    ev_date = models.DateField(auto_now=False, verbose_name="Date")
    ev_description = models.TextField(null=True, verbose_name="Description")

    registrant_name = models.BooleanField(default=True )
    registrant_age = models.BooleanField(default=False)
    registrant_phone = models.BooleanField(default=False)
    registrant_email = models.BooleanField(default=False)
    registrant_institution = models.BooleanField(default=False)

    name = models.CharField(max_length=100,null=True)
    reg_open = True
    slug = models.SlugField(max_length=250)


    def save(self, *args, **kwargs):
        self.slug = slugify(self.ev_name)
        return super(es_event, self).save(*args, **kwargs)    
    def get_absolute_url(self):
            return reverse('event_detail', kwargs={'id': self.id, 'slug': self.slug })

urls.py

url(r'^events/register(?P<id>\d+)(?:/(?P<slug>[\w\d-]+))?/$', views.Registration_View.as_view(), name='event_application')

Теперь я хочу найти конкретный экземпляр es_event из базы данных, используя значение "id" в URL.

Тогда, если этот экземпляр имеет атрибуты имя регистранта, регистрант_age и т. Д. Равен True , тогда поля Applicant_Name, Applicant_age и т. Д. Будут доступны в форме

1 Ответ

1 голос
/ 20 июня 2019

Вы можете использовать AJAX для этого.Я думаю, this пример похож на ваш, просто вместо того, чтобы проверять, существует ли пользователь, вы проверяете, есть ли у вашего экземпляра нужные атрибуты (registrant_name, registrant_age).И когда вы получаете ответ JSON, вы показываете / скрываете поля с помощью Javascript.

...