Welcome to the LimeSurvey Community Forum

Ask the community, share ideas, and connect with other LimeSurvey users!

Array (text) type question with customized drop down in specific columns

More
3 years 5 months ago #226673 by CultureCommunication
Please help us help you and fill where relevant:Your LimeSurvey version: [see right hand bottom of your LimeSurvey admin screen]Own server or LimeSurvey hosting:Survey theme/template:==================(Hello. I'm using LimeSurvey Cloud: version 5.3.6. Bootswatcch theme. I am learning about LimeSurvey nor have experience in programming. I would like to create a dropdown list that I can reuse in specific columns of my subquestions (along the X axis) for 3 question groups. To do this, I created an Array (text) question, with  subquestions. I found a code in this forum that I modified slightly, but I could not apply it to specific columns.  Any guidance will be greatly appreciated.

Please Log in to join the conversation.

More
3 years 5 months ago #226674 by Joffm
Hi,
please only provide lss exports.

What means 

but I could not apply it to specific columns.

Maybe you use the wrong script.

Here the "usual" to insert different dropdowns different columns.
[url] forums.limesurvey.org/forum/can-i-do-thi...menu-in-array#226612 [/url]

If ALL columns use the same dropdown you may use this (maybe the one you used)
[url] forums.limesurvey.org/forum/can-i-do-thi...ultiple-scale#225294 [/url]

And here a solution to have different dropdowns in each cell of the array.
[url] forums.limesurvey.org/forum/design-issue...ions?start=15#215118 [/url]

Again: The best is to provide your lss export.

Joffm
 

Volunteers are not paid.
Not because they are worthless, but because they are priceless

Please Log in to join the conversation.

More
3 years 4 months ago #226850 by CultureCommunication
Hello,
Thank you for the information provided. I use array questions in my survey. Each question has sub-questions (Y axis) and another set of sub-questions (X axis). I need to insert a drop-down list (a, b, c, d...) For example: Column (Column 2, Column 4, column 6, etc) and every Row (Row1, Row2, Row3, Row4, etc.). My problem is understanding how to use the syntax for variables or where to substitute (QID) and identifying sub-questions numbers (for X and Y axis) so I can have the same drop down in every other column and in all of my rows. Attached is my .lss file. I tried different combinations of question codes but I wasn't successful. 

Many thanks

Please Log in to join the conversation.

More
3 years 4 months ago #226852 by tpartner
Please provide a small export (.lss file) containing only the relevant questions so the volunteers providing help here don't have to waste time figuring out a survey with 10s of questions.

Cheers,
Tony Partner

Solutions, code and workarounds presented in these forums are given without any warranty, implied or otherwise.

Please Log in to join the conversation.

More
3 years 4 months ago #226861 by Joffm
1.

where to substitute (QID)

You do not substitute QID. {QID} is a placeholder that is filled automatically with the actual question ID (curly brackets -> ExpressionScript)

2.

and identifying sub-questions numbers (for X and Y axis)

An easy way is to code the
y-axis "Y001", "Y002",...
x-axis "X001", "X002",...

3.

so I can have the same drop down in every other column and in all of my rows


To do this you may use the script I linked in my previous post.
If ALL columns use the same dropdown you may use this
forums.limesurvey.org/forum/can-i-do-thi...ultiple-scale#225294

It is this one
Code:
<script type="text/javascript" charset="utf-8">
    $(document).on('ready pjax:scriptcomplete',function(){
        var thisQuestion = $('#question{QID}');
 
        // Insert selects
        $('.answer-item', thisQuestion).append('<select class="inserted-select form-control list-question-select">\
 <option value="">Please choose...</option>\
<option value="1">very good</option>\
<option value="2">good</option>\
<option value="3">neither / nor</option>\
<option value="4">poor</option>\
<option value="5">very poor</option>\
<option value="6">DK/NA</option>\
  </select>'); 
 
        // Listeners
        $('.inserted-select', thisQuestion).on('change', function(i) {
            if($(this).val() != '') {
                $(this).closest('.answer-item').find('input:text').val($.trim($(this).val())).trigger('change');
            }
            else {
                $(this).closest('.answer-item').find('input:text').val('').trigger('change');
           }
        });
 
        // Returning to page
        $('input:text', thisQuestion).each(function(i) {
            var thisCell = $(this).closest('.answer-item');
            var inputVal = $.trim($(this).val());
            $('select.inserted-select', thisCell).val(inputVal);
        });
 
        // Clean-up styles
        $('select.inserted-select', thisQuestion).css({
            'max-width': '100%'
        });
        $('input:text', thisQuestion).css({
            'position': 'absolute',
            'left': '-9999em'
        });
    });
</script>

As you see in  this line of the script
$('.answer-item', thisQuestion).append
there is no reference neither to column nor to row




If you like to have different dropdowns you have to use the other script that I linked in my previous post
Here the "usual" to insert different dropdowns different columns.
forums.limesurvey.org/forum/can-i-do-thi...menu-in-array#226612
Code:
<script type="text/javascript" charset="utf-8">
  $(document).on('ready pjax:scriptcomplete',function(){
    var thisQuestion = $('#question{QID}');
 
    // Insert selects
    $('.answer-item.answer_cell_X001', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
  <option value="">...</option>\
  <option value="1">Mère</option>\
  <option value="2">Pére</option>\
  <option value="3">Soeur</option>\
  <option value="4">Frère</option>\
</select>');
    $('.answer-item.answer_cell_X002', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
  <option value="">...</option>\
  <option value="1">masculin</option>\
  <option value="2">femelle</option>\
  <option value="3">autre chose </option>\
</select>');
 
    // Listeners
    $('.inserted-select', thisQuestion).on('change', function(i) {
      if($(this).val() != '') {
        $(this).closest('.answer-item').find('input:text').val($('option:selected', this).val()).trigger('change');
      }
      else {
        $(this).closest('.answer-item').find('input:text').val('').trigger('change');
      }
    });
 
  // Returning to page
    $('.with-select input:text', thisQuestion).each(function(i) {
      var thisCell = $(this).closest('.answer-item');
      var inputText = $.trim($(this).val());
      $('select.inserted-select', thisCell).val(inputText);
    });
 
 
    // Clean-up styles
    $('select.inserted-select', thisQuestion).css({
      'max-width': '100%'
    });
    $('.with-select input:text', thisQuestion).css({
      'position': 'absolute',
      'left': '-9999em'
    });
  });
</script>

Here you see the line
$('.answer-item.answer_cell_X001', thisQuestion)
So this refers to column "X002"
You remember what I wrote in #2.

For each of your columns you can enter this block of "selects"
And you get this
 



Well, now you should be able to insert the dropdowns into your array.

And the last script I linked in my previous post shows how to insert different dropdowns into each row and column.

Joffm

 

Volunteers are not paid.
Not because they are worthless, but because they are priceless

Please Log in to join the conversation.

More
3 years 4 months ago #226863 by tpartner
Here is a slightly different version that allows designating the drop-downs according to column number instead of sub-question code. It also handles drop-downs with different values and labels.

Code:
<script type="text/javascript" data-author="Tony Partner">
 
  $(document).on('ready pjax:scriptcomplete',function(){
    var thisQuestion = $('#question{QID}');
 
    // Column specific classes
    $('tr.subquestion-list', thisQuestion).each(function(i) {
      $('th, td', this).each(function(i) {
        $(this).addClass('column-'+i);
      });
    });
 
    // Insert selects into column 2
    if($('.answer-item.column-2 .inserted-select', thisQuestion).length == 0) {
      $('.answer-item.column-2', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
        <option value="">Please choose...</option>\
        <option value="M">M</option>\
        <option value="Q">Q</option>\
        <option value="U">U</option>\
        <option value="W">W</option>\
        <option value="X">X</option>\
        <option value="Z">Z</option>\
      </select>');
    } 
 
    // Insert selects into column 4
    if($('.answer-item.column-4 .inserted-select', thisQuestion).length == 0) {
      $('.answer-item.column-4', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
        <option value="">Please choose...</option>\
        <option value="A">A</option>\
        <option value="B">B</option>\
        <option value="C">C</option>\
        <option value="D">D</option>\
        <option value="E">E</option>\
        <option value="F">F</option>\
      </select>');  
    } 
 
    // Listeners on select elements
    $('.inserted-select', thisQuestion).on('change', function(i) {
      if($(this).val() != '') {
        $(this).closest('.answer-item').find('input:text').val($.trim($('option:selected', this).text())).trigger('keyup');
      }
      else {
        $(this).closest('.answer-item').find('input:text').val('').trigger('keyup');
      }
    });
 
    // Returning to page
    $('.with-select input:text', thisQuestion).each(function(i) {
      var thisCell = $(this).closest('.answer-item');
      var inputText = $.trim($(this).val());
      var selectval = $('select.inserted-select option', thisCell).filter(function () { return $(this).html() == inputText; }).val();
      $('select.inserted-select', thisCell).val(selectval);
    });
 
    // Clean-up styles
    $('select.inserted-select', thisQuestion).css({
      'max-width': '100%'
    });
    $('.with-select input:text', thisQuestion).css({
      'position': 'absolute',
      'left': '-9999em'
    });
  });
</script>

Cheers,
Tony Partner

Solutions, code and workarounds presented in these forums are given without any warranty, implied or otherwise.

Please Log in to join the conversation.

More
3 years 4 months ago #226864 by CultureCommunication
Apologies, attached is the .lss file with relevant question.Thanks

Please Log in to join the conversation.

More
3 years 4 months ago #226865 by CultureCommunication
Thank you for your quick reply. I tried your suggestion but it's not working. I am new at this, so I'm certainly missing something. If I understand well, the script above is independent of the subquestion numbers? So, I do not need to specify subquestion numbers (as indicated below)

Would my issue be related to the following?
var thisQuestion = $('#question{QID}');

1) var thisQuestion = $('#SQ004{3038}'); Is this correct?
Where:
1) #question (this my subquestion (X axis) 
2) {QID} refers to my ID question number?

Thank you

Please Log in to join the conversation.

More
3 years 4 months ago #226866 by Joffm
Hi,
var thisQuestion = $('#question{QID}');

1) var thisQuestion = $('#SQ004{3038}'); Is this correct?
Where:
1) #question (this my subquestion (X axis) 
2) {QID} refers to my ID question number?

Sorry, why do I write
You do not substitute QID. {QID} is a placeholder that is filled automatically with the actual question ID
You leave it as it is.

@tpartner
yes it's an improvement, as we need/use these classes "column-1", "column-2" also for the individual column widths, or individual colors.
 

Volunteers are not paid.
Not because they are worthless, but because they are priceless

Please Log in to join the conversation.

More
3 years 4 months ago #226867 by CultureCommunication
Thank you so much!!! It has been very helpful and educational :)

The script below worked really well after a few tests. My mistake was that I was including the script at the level of my subquestions (along the X axis) but it wasn't working. I modified the script (columns) and include it at the level of my question.

<script type="text/javascript" data-author="J PartnerTest">
 
    $(document).ready(function() {
        var thisQuestion = $('#question{QID}');
 
        // Column specific classes
        $('tr.subquestion-list', thisQuestion).each(function(i) {
            $('th, td', this).each(function(i) {
                $(this).addClass('column-'+i);
            });
        });
 
        // Insert selects into column 2
        if($('.answer-item.column-2 .inserted-select', thisQuestion).length == 0) {
            $('.answer-item.column-2', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
                <option value="">Please choose...</option>\
                <option value="M">M</option>\
                <option value="Q">Q</option>\
                <option value="U">U</option>\
                <option value="W">W</option>\
                <option value="X">X</option>\
                <option value="Z">Z</option>\            </select>');
        } 
 
        // Insert selects into column 4
        if($('.answer-item.column-4 .inserted-select', thisQuestion).length == 0) {
            $('.answer-item.column-4', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
                <option value="">Please choose...</option>\
                <option value="M">M</option>\
                <option value="Q">Q</option>\
                <option value="U">U</option>\
                <option value="W">W</option>\
                <option value="X">X</option>\
                <option value="Z">Z</option>\                </select>');  
        } 
      
      // Insert selects into column 6
        if($('.answer-item.column-6 .inserted-select', thisQuestion).length == 0) {
            $('.answer-item.column-6', thisQuestion).addClass('with-select').append('<select class="inserted-select form-control list-question-select">\
                <option value="">Please choose...</option>\
                <option value="M">M</option>\
                <option value="Q">Q</option>\
                <option value="U">U</option>\
                <option value="W">W</option>\
                <option value="X">X</option>\
                <option value="Z">Z</option>\                </select>');  
        } 
 
        // Listeners on select elements
        $('.inserted-select', thisQuestion).on('change', function(i) {
            if($(this).val() != '') {
                $(this).closest('.answer-item').find('input:text').val($.trim($('option:selected', this).text())).trigger('keyup');
            }
            else {
                $(this).closest('.answer-item').find('input:text').val('').trigger('keyup');
            }
        });
 
        // Returning to page
        $('.with-select input:text', thisQuestion).each(function(i) {
            var thisCell = $(this).closest('.answer-item');
            var inputText = $.trim($(this).val());
            var selectval = $('select.inserted-select option', thisCell).filter(function () { return $(this).html() == inputText; }).val();
            $('select.inserted-select', thisCell).val(selectval);
        });
 
        // Clean-up styles
        $('select.inserted-select', thisQuestion).css({
            'max-width': '100%'
        });
        $('.with-select input:text', thisQuestion).css({
            'position': 'absolute',
            'left': '-9999em'
        });
    });
</script>

[img][/img]
 

Please Log in to join the conversation.

More
3 years 4 months ago #226868 by CultureCommunication
My apologies, attached is a file of the results.

Please Log in to join the conversation.

More
3 years 4 months ago #226873 by tpartner
Again you pasted an image.

It's impolite to change the data-author value unless you have significantly changed the code. This is a credit for the original author.

Cheers,
Tony Partner

Solutions, code and workarounds presented in these forums are given without any warranty, implied or otherwise.

Please Log in to join the conversation.

More
3 years 4 months ago #226887 by CultureCommunication

Please Log in to join the conversation.

More
2 years 1 month ago - 2 years 1 month ago #245216 by MC_EMC
Dear Community of Limesurvey,

I have been struggling with the following code on limesurvey. I am using javascript for a drop-down array that will ask participants what brand the are using and also provide specific features.
I have trouble with the specific features of the brand. I have already manage to implement the code from tpartner for the use of dropdown menu's in a text array.
However I would like to add 3 columns that would have conditional answers.

For example: 
The first dropdown question: Brand A/B/C
Second dropdown question (conditional to which brand has been filled in): Brand A -> Feature 1/2/3; Brand B Feature 4/ 5 / 6; Brand C -> Feature 7-8-9
Third dropdown question (also conditional to the first dropdown question): Brand A -> Feature A1/A2/A3  Brand B -> Feature B1/B2/B3  Brand C -> Feature C1/C2/C3 

The code that I have now:


<script type="text/javascript" charset="utf-8">
  $(document).ready(function() {
 
    var qID = {9997};
 
    // Define the select element (dropdown)
    var select1 = '<select class="insertedSelect">\
          <option value="">-- Please Choose --</option>\
          <option value="A">Brand A</option>\
          <option value="B">Brand B</option>\
          <option value="C">Brand C</option>\
        </select>';
    
    var select2 = '<select class="insertedSelect2">\
          <option value="">-- Please Choose --</option>\
          <option value="AF">Brand A feature 1</option>\
          <option value="AF">Brand A feature 2</option>\
          <option value="AF">Brand A feature 3</option>\
        </select>';
    
    var select3 = '<select class="insertedSelect3">\
          <option value="">-- Please Choose --</option>\
          <option value="BF">Brand B feature 1</option>\
          <option value="BF">Brand B feature 2</option>\
          <option value="BF">Brand B feature 3</option>\
        </select>';
        
    var select4 = '<select class="insertedSelect4">\
          <option value="">-- Please Choose --</option>\
          <option value="CF">Brand C feature 1</option>\
          <option value="CF">Brand C feature 2</option>\
          <option value="CF">Brand C feature 3</option>\
        </select>';
        
 
    // Hide the text inputs
    $('#question'+qID+' .answer_cell_00SQ002 input[type="text"]').hide();
    $('#question'+qID+' .answer_cell_00SQ003 input[type="text"]').hide();
 
    // Insert the select elements
    $('#question'+qID+' .answer_cell_00SQ002').append(select1);
 
    // Initially select an option if the question has already been answered
    $('#question'+qID+' .answer_cell_00SQ002 input[type="text"]').each(function(i){
      if($(this).val()) {
        $(this).closest('td').find('.insertedSelect').val($(this).val());
      }
    });
    
    // Listener on the dropdowns - insert selected values into hidden text input
    $('.insertedSelect').change(function() {
      $(this).closest('td').find('input[type="text"]').val($(this).val());
    });
    
    
    /// If statement for selection of dropdown answers based if brand A is selected
    $('#question'+qID+' .answer_cell_00SQ002 input[type="text"]').each(function(i){
      if($(this).val()!="A") {
    // Insert the select elements
    $('#question'+qID+' .answer_cell_00SQ003').append(select2);
    $('#question'+qID+' .answer_cell_00SQ003 input[type="text"]').each(function(i){
      if($(this).val()) {
        $(this).closest('td').find('.insertedSelect2').val($(this).val());}
    });
    // Listener on the dropdowns - insert selected values into hidden text input
    $('.insertedSelect2').change(function() {
      $(this).closest('td').find('input[type="text"]').val($(this).val());
        });
    }});
    
    /// If statement for selection of dropdown answers based if brand B is selected
    $('#question'+qID+' .answer_cell_00SQ002 input[type="text"]').each(function(i){
      if($(this).val()!="B") {
    // Insert the select elements
    $('#question'+qID+' .answer_cell_00SQ003').append(select3);
    $('#question'+qID+' .answer_cell_00SQ003 input[type="text"]').each(function(i){
      if($(this).val()) {
        $(this).closest('td').find('.insertedSelect3').val($(this).val());}
    });
    // Listener on the dropdowns - insert selected values into hidden text input
    $('.insertedSelect3').change(function() {
      $(this).closest('td').find('input[type="text"]').val($(this).val());
        });
    }});
    
    /// If statement for selection of dropdown answers based if brand C is selected
    $('#question'+qID+' .answer_cell_00SQ002 input[type="text"]').each(function(i){
      if($(this).val()!="C") {
    // Insert the select elements
    $('#question'+qID+' .answer_cell_00SQ003').append(select4);
    $('#question'+qID+' .answer_cell_00SQ003 input[type="text"]').each(function(i){
      if($(this).val()) {
        $(this).closest('td').find('.insertedSelect4').val($(this).val());}
    });
    // Listener on the dropdowns - insert selected values into hidden text input
    $('.insertedSelect4').change(function() {
      $(this).closest('td').find('input[type="text"]').val($(this).val());
        });
    }});
 
 });

  
</script>

   

File Attachment:

File Name: limesurvey...9972.lsq
File Size:18.9 KB
 

File Attachment:

File Name: Limesurveyfile1.txt
File Size:4.21 KB


 


I believe there is something wrong with the IF statement that tries to match the answers of the first dropdown question.
There may be a better way to approach this problem, but I have not been able to figure it out yet.

I am open for any suggestions/feedback for this code or on a different approach to this problem.


 
Last edit: 2 years 1 month ago by MC_EMC.

Please Log in to join the conversation.

More
2 years 1 month ago #245221 by tpartner
Your LimeSurvey version?

Please never attach .lsq or .lsg files - they are too time consuming for the volunteers here to handle. Always provide .lss files containing only the relevant questions.

Cheers,
Tony Partner

Solutions, code and workarounds presented in these forums are given without any warranty, implied or otherwise.

Please Log in to join the conversation.

Moderators: tpartnerholch

Lime-years ahead

Online-surveys for every purse and purpose