/** * jspsych-survey-text * a jspsych plugin for free response survey questions * * Josh de Leeuw * * documentation: docs.jspsych.org * */ jsPsych.plugins['survey-text'] = (function() { var plugin = {}; plugin.info = { name: 'survey-text', description: '', parameters: { questions: { type: jsPsych.plugins.parameterType.STRING, array: true, default: undefined, no_function: false, description: '' }, preamble: { type: jsPsych.plugins.parameterType.STRING, default: '', no_function: false, description: '' }, rows: { type: jsPsych.plugins.parameterType.INT, array: true, default: 1, no_function: false, description: '' }, columns: { type: jsPsych.plugins.parameterType.INT, array: true, default: 40, no_function: false, description: '' }, values: { type: jsPsych.plugins.parameterType.STRING, array: true, default: '', no_function: false, description: '' }, button_label: { type: jsPsych.plugins.parameterType.STRING, default: 'Next', no_function: false, description: '' } } } plugin.trial = function(display_element, trial) { trial.preamble = typeof trial.preamble == 'undefined' ? "" : trial.preamble; trial.button_label = typeof trial.button_label === 'undefined' ? 'Next' : trial.button_label; if (typeof trial.rows == 'undefined') { trial.rows = []; for (var i = 0; i < trial.questions.length; i++) { trial.rows.push(1); } } if (typeof trial.columns == 'undefined') { trial.columns = []; for (var i = 0; i < trial.questions.length; i++) { trial.columns.push(40); } } if (typeof trial.values == 'undefined') { trial.values = []; for (var i = 0; i < trial.questions.length; i++) { trial.values.push(""); } } // show preamble text var html = '
'+trial.preamble+'
'; // add questions for (var i = 0; i < trial.questions.length; i++) { html += '
'; html += '

' + trial.questions[i] + '

'; if(trial.rows[i] == 1){ html += ''+trial.values[i]+''; } else { html += ''; } html += '
'; } // add submit button html += ''; display_element.innerHTML = html; display_element.querySelector('#jspsych-survey-text-next').addEventListener('click', function() { // measure response time var endTime = (new Date()).getTime(); var response_time = endTime - startTime; // create object to hold responses var question_data = {}; var matches = display_element.querySelectorAll('div.jspsych-survey-text-question'); for(var index=0; index