4π
β
It is not a built in thing for django and will require a little bit of hacking, but I have done this kind of thing before.
You will want to attach a jQuery AJAX request to an onChange event for company select field. When someone selects a company you query the database and ask for a list of departments that are specific to that company.
EDIT:
Something like the following javascript and django will work:
$('#id_company').change(function(){
$.POST('{% url some_url_name %}',
{
'company_id': $('#id_company').val()
},
function(data){
if(data.valid){
var d = '<select id="id_department" name="department">';
$.each(data.records, function(k,v){
d += '<option value="' + v.id + '">' + v.name +'</option>';
});
d += '</select>';
$('#id_department').html(d);
}
}, 'json'
);
});
def ajax_request(request, company_id):
if request.is_ajax() and request.method == 'POST':
data = simplejson.dumps(Department.objects.filter(company__id=company_id)
return HttpResponse(data, mimetype='application/javascript')
π€Dominic Santos
Source:stackexchange.com