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

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month 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.

  • Joffm
  • Joffm's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month 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.

  • tpartner
  • tpartner's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

  • Joffm
  • Joffm's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

  • tpartner
  • tpartner's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month ago #226864 by CultureCommunication
Apologies, attached is the .lss file with relevant question.Thanks

Please Log in to join the conversation.

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month 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.

  • Joffm
  • Joffm's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month 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.

  • CultureCommunication
  • CultureCommunication's Avatar Topic Author
  • Offline
  • New Member
  • New Member
More
2 years 1 month ago #226868 by CultureCommunication
My apologies, attached is a file of the results.

Please Log in to join the conversation.

  • tpartner
  • tpartner's Avatar
  • Offline
  • LimeSurvey Community Team
  • LimeSurvey Community Team
More
2 years 1 month 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.

Lime-years ahead

Online-surveys for every purse and purpose