Django autocomplete based on drop down selection











up vote
0
down vote

favorite












I am storing the autocompletion data in SomeObject objects and successfully use the following to autocomplete with a filter based on current user:



views.py



def get_autocompletion_list(request):

if request.is_ajax():
q = request.GET.get('term', '')

results =
if len(q) > 0:
my_words = SomeObject.objects.filter(owner=request.user.id)
words = my_words.filter(word__startswith=q)
for w in words:
results.append(w.word)

data = json.dumps(results)
else:
data = ''

mimetype = 'application/json'
return HttpResponse(data, mimetype)


template:



<form action="/" method="post" id="">
{% csrf_token %}

{{form.category}}
</form>

<input id="searching">


scripts:



  $("#category_id").change(function () {

console.log("selected category")
console.log($(category_id).val())

});


$(function() {

$("#searching").autocomplete({
source: "/api/get_autocompletion_list/",
select: function (event, ui) {
AutoCompleteSelectHandler(event, ui)
},
minLength: 1,
});
});


Now I want to filter the autocompletion based on the selection of form.category drop down, I am able to get the current selection in the form, but how would I send it to the view where I can do the filtering?










share|improve this question
























  • Do you know django-select2? May be is useful for you. I
    – dani herrera
    yesterday















up vote
0
down vote

favorite












I am storing the autocompletion data in SomeObject objects and successfully use the following to autocomplete with a filter based on current user:



views.py



def get_autocompletion_list(request):

if request.is_ajax():
q = request.GET.get('term', '')

results =
if len(q) > 0:
my_words = SomeObject.objects.filter(owner=request.user.id)
words = my_words.filter(word__startswith=q)
for w in words:
results.append(w.word)

data = json.dumps(results)
else:
data = ''

mimetype = 'application/json'
return HttpResponse(data, mimetype)


template:



<form action="/" method="post" id="">
{% csrf_token %}

{{form.category}}
</form>

<input id="searching">


scripts:



  $("#category_id").change(function () {

console.log("selected category")
console.log($(category_id).val())

});


$(function() {

$("#searching").autocomplete({
source: "/api/get_autocompletion_list/",
select: function (event, ui) {
AutoCompleteSelectHandler(event, ui)
},
minLength: 1,
});
});


Now I want to filter the autocompletion based on the selection of form.category drop down, I am able to get the current selection in the form, but how would I send it to the view where I can do the filtering?










share|improve this question
























  • Do you know django-select2? May be is useful for you. I
    – dani herrera
    yesterday













up vote
0
down vote

favorite









up vote
0
down vote

favorite











I am storing the autocompletion data in SomeObject objects and successfully use the following to autocomplete with a filter based on current user:



views.py



def get_autocompletion_list(request):

if request.is_ajax():
q = request.GET.get('term', '')

results =
if len(q) > 0:
my_words = SomeObject.objects.filter(owner=request.user.id)
words = my_words.filter(word__startswith=q)
for w in words:
results.append(w.word)

data = json.dumps(results)
else:
data = ''

mimetype = 'application/json'
return HttpResponse(data, mimetype)


template:



<form action="/" method="post" id="">
{% csrf_token %}

{{form.category}}
</form>

<input id="searching">


scripts:



  $("#category_id").change(function () {

console.log("selected category")
console.log($(category_id).val())

});


$(function() {

$("#searching").autocomplete({
source: "/api/get_autocompletion_list/",
select: function (event, ui) {
AutoCompleteSelectHandler(event, ui)
},
minLength: 1,
});
});


Now I want to filter the autocompletion based on the selection of form.category drop down, I am able to get the current selection in the form, but how would I send it to the view where I can do the filtering?










share|improve this question















I am storing the autocompletion data in SomeObject objects and successfully use the following to autocomplete with a filter based on current user:



views.py



def get_autocompletion_list(request):

if request.is_ajax():
q = request.GET.get('term', '')

results =
if len(q) > 0:
my_words = SomeObject.objects.filter(owner=request.user.id)
words = my_words.filter(word__startswith=q)
for w in words:
results.append(w.word)

data = json.dumps(results)
else:
data = ''

mimetype = 'application/json'
return HttpResponse(data, mimetype)


template:



<form action="/" method="post" id="">
{% csrf_token %}

{{form.category}}
</form>

<input id="searching">


scripts:



  $("#category_id").change(function () {

console.log("selected category")
console.log($(category_id).val())

});


$(function() {

$("#searching").autocomplete({
source: "/api/get_autocompletion_list/",
select: function (event, ui) {
AutoCompleteSelectHandler(event, ui)
},
minLength: 1,
});
});


Now I want to filter the autocompletion based on the selection of form.category drop down, I am able to get the current selection in the form, but how would I send it to the view where I can do the filtering?







jquery django forms






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited yesterday

























asked yesterday









DevB2F

1,67421030




1,67421030












  • Do you know django-select2? May be is useful for you. I
    – dani herrera
    yesterday


















  • Do you know django-select2? May be is useful for you. I
    – dani herrera
    yesterday
















Do you know django-select2? May be is useful for you. I
– dani herrera
yesterday




Do you know django-select2? May be is useful for you. I
– dani herrera
yesterday












1 Answer
1






active

oldest

votes

















up vote
0
down vote













I was able to send the data over to django by adding the id for the currently selected category to the url used for the autocompletion.



//when value is changed in the dropdown
$("#category_id").change(function () {
setAutocompletion()
});

//change the url based on the selected drop down value
function setAutocompletion(){
$("#searching").autocomplete({
source: "/api/get_autocompletion_list/" + getSelectedValue(),
select: function (event, ui) {
AutoCompleteSelectHandler(event, ui)
},
minLength: 1,
});
}

function getSelectedValue() {
var s = $(id_kategori).val()
return String(s)
}

function AutoCompleteSelectHandler(event, ui) {
var selectedObj = ui.item;
}





share|improve this answer





















    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














     

    draft saved


    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53401696%2fdjango-autocomplete-based-on-drop-down-selection%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    0
    down vote













    I was able to send the data over to django by adding the id for the currently selected category to the url used for the autocompletion.



    //when value is changed in the dropdown
    $("#category_id").change(function () {
    setAutocompletion()
    });

    //change the url based on the selected drop down value
    function setAutocompletion(){
    $("#searching").autocomplete({
    source: "/api/get_autocompletion_list/" + getSelectedValue(),
    select: function (event, ui) {
    AutoCompleteSelectHandler(event, ui)
    },
    minLength: 1,
    });
    }

    function getSelectedValue() {
    var s = $(id_kategori).val()
    return String(s)
    }

    function AutoCompleteSelectHandler(event, ui) {
    var selectedObj = ui.item;
    }





    share|improve this answer

























      up vote
      0
      down vote













      I was able to send the data over to django by adding the id for the currently selected category to the url used for the autocompletion.



      //when value is changed in the dropdown
      $("#category_id").change(function () {
      setAutocompletion()
      });

      //change the url based on the selected drop down value
      function setAutocompletion(){
      $("#searching").autocomplete({
      source: "/api/get_autocompletion_list/" + getSelectedValue(),
      select: function (event, ui) {
      AutoCompleteSelectHandler(event, ui)
      },
      minLength: 1,
      });
      }

      function getSelectedValue() {
      var s = $(id_kategori).val()
      return String(s)
      }

      function AutoCompleteSelectHandler(event, ui) {
      var selectedObj = ui.item;
      }





      share|improve this answer























        up vote
        0
        down vote










        up vote
        0
        down vote









        I was able to send the data over to django by adding the id for the currently selected category to the url used for the autocompletion.



        //when value is changed in the dropdown
        $("#category_id").change(function () {
        setAutocompletion()
        });

        //change the url based on the selected drop down value
        function setAutocompletion(){
        $("#searching").autocomplete({
        source: "/api/get_autocompletion_list/" + getSelectedValue(),
        select: function (event, ui) {
        AutoCompleteSelectHandler(event, ui)
        },
        minLength: 1,
        });
        }

        function getSelectedValue() {
        var s = $(id_kategori).val()
        return String(s)
        }

        function AutoCompleteSelectHandler(event, ui) {
        var selectedObj = ui.item;
        }





        share|improve this answer












        I was able to send the data over to django by adding the id for the currently selected category to the url used for the autocompletion.



        //when value is changed in the dropdown
        $("#category_id").change(function () {
        setAutocompletion()
        });

        //change the url based on the selected drop down value
        function setAutocompletion(){
        $("#searching").autocomplete({
        source: "/api/get_autocompletion_list/" + getSelectedValue(),
        select: function (event, ui) {
        AutoCompleteSelectHandler(event, ui)
        },
        minLength: 1,
        });
        }

        function getSelectedValue() {
        var s = $(id_kategori).val()
        return String(s)
        }

        function AutoCompleteSelectHandler(event, ui) {
        var selectedObj = ui.item;
        }






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered yesterday









        DevB2F

        1,67421030




        1,67421030






























             

            draft saved


            draft discarded



















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53401696%2fdjango-autocomplete-based-on-drop-down-selection%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Berounka

            Sphinx de Gizeh

            Different font size/position of beamer's navigation symbols template's content depending on regular/plain...