/** * jspsych-survey-multi-picture * a jspsych plugin for multiple choice survey questions * * documentation: docs.jspsych.org * */ jsPsych.plugins['survey-multi-picture'] = (function() { var plugin = {}; plugin.info = { name: 'survey-multi-picture', description: '', parameters: { questions: { type: [jsPsych.plugins.parameterType.STRING], array: true, default: undefined, no_function: false, description: '' }, options: { type: [jsPsych.plugins.parameterType.STRING], array: true, default: undefined, no_function: false, description: '' }, required: { type: [jsPsych.plugins.parameterType.BOOL], array: true, default: false, no_function: false, description: '' }, horitzontal: { type: [jsPsych.plugins.parameterType.BOOL], default: false, no_function: false, description: '' }, preamble: { type: [jsPsych.plugins.parameterType.STRING], default: '', no_function: false, description: '' } } } plugin.trial = function(display_element, trial) { var plugin_id_name = "jspsych-survey-multi-picture"; var plugin_id_selector = '#' + plugin_id_name; var _join = function( /*args*/ ) { var arr = Array.prototype.slice.call(arguments, _join.length); return arr.join(separator = '-'); } // trial defaults trial.preamble = typeof trial.preamble == 'undefined' ? "" : trial.preamble; trial.required = typeof trial.required == 'undefined' ? null : trial.required; trial.horizontal = typeof trial.required == 'undefined' ? false : trial.horizontal; // if any trial variables are functions // this evaluates the function and replaces // it with the output of the function trial = jsPsych.pluginAPI.evaluateFunctionParameters(trial); // inject CSS for trial display_element.innerHTML = ''; var cssstr = ".jspsych-survey-multi-picture-question { margin-top: 2em; margin-bottom: 2em; text-align: center; }"+ ".jspsych-survey-multi-picture-text span.required {color: darkred;}"+ ".jspsych-survey-multi-picture-option { line-height: 2; margin-bottom: 10px; }"+ ".jspsych-survey-multi-picture-horizontal .jspsych-survey-multi-picture-option { display: inline-block; margin-left: 1em; margin-right: 1em; vertical-align: top;}" display_element.querySelector('#jspsych-survey-multi-picture-css').innerHTML = cssstr; // form element var trial_form_id = _join(plugin_id_name, "form"); display_element.innerHTML += '
'; var trial_form = display_element.querySelector("#" + trial_form_id); // show preamble text var preamble_id_name = _join(plugin_id_name, 'preamble'); trial_form.innerHTML += '' + trial.questions[i] + '
'; // create option clickble images for (var j = 0; j < trial.options[i].length; j++) { var option_id_name = _join(plugin_id_name, "option", i, j), option_id_selector = '#' + option_id_name; // add image container display_element.querySelector(question_selector).innerHTML += ''; // add label if(trial.options[i][j].label){ var label = trial.options[i][j].label; var option_label = ''; display_element.querySelector(option_id_selector).innerHTML += option_label; } else { var option_label = ''; display_element.querySelector(option_id_selector).innerHTML += option_label; } display_element.querySelector(option_id_selector + " label").innerHTML = '