I like to create a text search field based on dropdown options from a model. I chose django-select2 but it isn't working. This is the output HTML
<form class="add_new container" method="post">
<h3 class="text-center">Issue Book</h3><hr><br>
{% csrf_token %}
<h4> Choose the student to issue book to</h4><br>
{% for field in form %}
{{ field }}
{% endfor %}<hr><br>
<input type="submit" value="Issue" class="btn btn-dark text-right" style="float:right">
</form>
This is the form
class NewIssueForm(forms.ModelForm):
def __init__(self,*args, pk,school,issuer, **kwargs):
super(NewIssueForm, self).__init__(*args, **kwargs)
self.fields['issuer'].initial = issuer
self.fields['borrower_id'].queryset = Student.objects.filter(school=school)
self.fields['book_id'].initial = pk #Sets the field with the pk and it's hidden again
class Meta:
model = Issue
fields = ['issuer','book_id','borrower_id']
widgets = { }
widgets = {
'book_id':forms.TextInput(attrs={"class":'form-control','type':'hidden'}),
'issuer':forms.TextInput(attrs={"class":'form-control','type':'hidden'}),
'borrower_id': Select2Widget,
}
Settings.py hs the following
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/1",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
},
'select2': {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/2",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
There are multiple parts that need to be set up to make django-select2
work:
django-select2
, so you need to provide your own. If this is missing, you will get an error in your browser's developer tools.{{ form.media.css }}
in the header, you won't get any of the custom styling, and without {{ form.media.js }}
somewhere (for example at the bottom of the <body>
), you won't get any of the custom behavior.django_select2.urls
needs to be included in your URL config. Without it, you will probably get an error when select2 tries to resolve URLs, so you probably got that one right.