mirror of
https://github.com/ACSPRI/queXS
synced 2024-04-02 12:12:16 +00:00
266 lines
14 KiB
PHP
266 lines
14 KiB
PHP
<?php
|
|
/*
|
|
* LimeSurvey
|
|
* Copyright (C) 2007 The LimeSurvey Project Team / Carsten Schmitz
|
|
* All rights reserved.
|
|
* License: GNU/GPL License v2 or later, see LICENSE.php
|
|
* LimeSurvey is free software. This version may have been modified pursuant
|
|
* to the GNU General Public License, and as distributed it includes or
|
|
* is derivative of works licensed under the GNU General Public License or
|
|
* other free or open source software licenses.
|
|
* See COPYRIGHT.php for copyright notices and details.
|
|
*
|
|
* $Id:
|
|
*
|
|
*/
|
|
|
|
include_once("login_check.php"); //Login Check dies also if the script is started directly
|
|
|
|
|
|
$js_admin_includes[]='scripts/answers.js';
|
|
$js_admin_includes[]='../scripts/jquery/jquery.blockUI.js';
|
|
$js_admin_includes[]='../scripts/jquery/jquery.selectboxes.min.js';
|
|
|
|
$_SESSION['FileManagerContext']="edit:answer:$surveyid";
|
|
// Get languages select on survey.
|
|
$anslangs = GetAdditionalLanguagesFromSurveyID($surveyid);
|
|
$baselang = GetBaseLanguageFromSurveyID($surveyid);
|
|
|
|
$qquery = "SELECT type FROM ".db_table_name('questions')." WHERE qid=$qid AND language='".$baselang."'";
|
|
$qrow = $connect->GetRow($qquery);
|
|
$qtype = $qrow['type'];
|
|
$scalecount=$qtypes[$qtype]['answerscales'];
|
|
//Check if there is at least one answer
|
|
for ($i = 0; $i < $scalecount; $i++)
|
|
{
|
|
$qquery = "SELECT count(*) as num_ans FROM ".db_table_name('answers')." WHERE qid=$qid AND scale_id=$i AND language='".$baselang."'";
|
|
$qresult = $connect->GetOne($qquery); //Checked
|
|
if ($qresult==0)
|
|
{
|
|
$query="INSERT into ".db_table_name('answers')." (qid,code,answer,language,sortorder,scale_id) VALUES ($qid,'A1',".db_quoteall($clang->gT("Some example answer option")).",'$baselang',0,$i)";
|
|
$connect->execute($query);
|
|
}
|
|
}
|
|
|
|
|
|
// check that there are answers for every language supported by the survey
|
|
for ($i = 0; $i < $scalecount; $i++)
|
|
{
|
|
foreach ($anslangs as $language)
|
|
{
|
|
$iAnswerCount = $connect->GetOne("SELECT count(*) as num_ans FROM ".db_table_name('answers')." WHERE qid=$qid AND scale_id=$i AND language='".$language."'");
|
|
if ($iAnswerCount == 0) // means that no record for the language exists in the answers table
|
|
{
|
|
$qquery = "INSERT INTO ".db_table_name('answers')." (qid,code,answer,sortorder,language,scale_id, assessment_value) (SELECT qid,code,answer,sortorder, '".$language."','$i', assessment_value FROM ".db_table_name('answers')." WHERE qid=$qid AND scale_id=$i AND language='".$baselang."')";
|
|
$connect->Execute($qquery); //Checked
|
|
}
|
|
}
|
|
}
|
|
|
|
array_unshift($anslangs,$baselang); // makes an array with ALL the languages supported by the survey -> $anslangs
|
|
|
|
//delete the answers in languages not supported by the survey
|
|
$languagequery = "SELECT DISTINCT language FROM ".db_table_name('answers')." WHERE (qid = $qid) AND (language NOT IN ('".implode("','",$anslangs)."'))";
|
|
$languageresult = db_execute_assoc($languagequery); //Checked
|
|
while ($qrow = $languageresult->FetchRow())
|
|
{
|
|
$deleteanswerquery = "DELETE FROM ".db_table_name('answers')." WHERE (qid = $qid) AND (language = '".$qrow["language"]."')";
|
|
$connect->Execute($deleteanswerquery); //Checked
|
|
}
|
|
|
|
if (!isset($_POST['ansaction']))
|
|
{
|
|
//check if any nulls exist. If they do, redo the sortorders
|
|
$caquery="SELECT * FROM ".db_table_name('answers')." WHERE qid=$qid AND sortorder is null AND language='".$baselang."'";
|
|
$caresult=$connect->Execute($caquery); //Checked
|
|
$cacount=$caresult->RecordCount();
|
|
if ($cacount)
|
|
{
|
|
fixsortorderAnswers($qid);
|
|
}
|
|
}
|
|
|
|
// Print Key Control JavaScript
|
|
$vasummary = PrepareEditorScript();
|
|
|
|
$query = "SELECT sortorder FROM ".db_table_name('answers')." WHERE qid='{$qid}' AND language='".GetBaseLanguageFromSurveyID($surveyid)."' ORDER BY sortorder desc";
|
|
$result = db_execute_assoc($query) or safe_die($connect->ErrorMsg()); //Checked
|
|
$anscount = $result->RecordCount();
|
|
$row=$result->FetchRow();
|
|
$maxsortorder=$row['sortorder']+1;
|
|
$vasummary .= "<div class='header ui-widget-header'>\n"
|
|
.$clang->gT("Edit answer options")
|
|
."</div>\n"
|
|
."<form id='editanswersform' name='editanswersform' method='post' action='$scriptname'>\n"
|
|
. "<input type='hidden' name='sid' value='$surveyid' />\n"
|
|
. "<input type='hidden' name='gid' value='$gid' />\n"
|
|
. "<input type='hidden' name='qid' value='$qid' />\n"
|
|
. "<input type='hidden' name='action' value='updateansweroptions' />\n"
|
|
. "<input type='hidden' name='sortorder' value='' />\n";
|
|
$vasummary .= "<div class='tab-pane' id='tab-pane-answers-$surveyid'>";
|
|
$first=true;
|
|
|
|
$vasummary .= "<div id='xToolbar'></div>\n";
|
|
|
|
// the following line decides if the assessment input fields are visible or not
|
|
$assessmentvisible=($surveyinfo['assessments']=='Y' && $qtypes[$qtype]['assessable']==1);
|
|
|
|
// Insert some Javascript variables
|
|
$surveysummary .= "\n<script type='text/javascript'>
|
|
var languagecount=".count($anslangs).";
|
|
var scalecount=".$scalecount.";
|
|
var assessmentvisible=".($assessmentvisible?'true':'false').";
|
|
var newansweroption_text='".$clang->gT('New answer option','js')."';
|
|
var strcode='".$clang->gT('Code','js')."';
|
|
var strlabel='".$clang->gT('Label','js')."';
|
|
var strCantDeleteLastAnswer='".$clang->gT('You cannot delete the last answer option.','js')."';
|
|
var lsbrowsertitle='".$clang->gT('Label set browser','js')."';
|
|
var quickaddtitle='".$clang->gT('Quick-add answers','js')."';
|
|
var sAssessmentValue='".$clang->gT('Assessment value','js')."';
|
|
var duplicateanswercode='".$clang->gT('Error: You are trying to use duplicate answer codes.','js')."';
|
|
var strNoLabelSet='".$clang->gT('There are no label sets which match the survey default language','js')."';
|
|
var langs='".implode(';',$anslangs)."';</script>\n";
|
|
|
|
foreach ($anslangs as $anslang)
|
|
{
|
|
$vasummary .= "<div class='tab-page' id='tabpage_$anslang'>"
|
|
."<h2 class='tab'>".getLanguageNameFromCode($anslang, false);
|
|
if ($anslang==GetBaseLanguageFromSurveyID($surveyid)) {$vasummary .= '('.$clang->gT("Base language").')';}
|
|
|
|
$vasummary .= "</h2>";
|
|
|
|
for ($scale_id = 0; $scale_id < $scalecount; $scale_id++)
|
|
{
|
|
$position=0;
|
|
if ($scalecount>1)
|
|
{
|
|
$vasummary.="<div class='header ui-widget-header' style='margin-top:5px;'>".sprintf($clang->gT("Answer scale %s"),$scale_id+1)."</div>";
|
|
}
|
|
|
|
|
|
$vasummary .= "<table class='answertable' id='answers_{$anslang}_$scale_id' align='center' >\n"
|
|
."<thead>"
|
|
."<tr>\n"
|
|
."<th align='right'> </th>\n"
|
|
."<th align='center'>".$clang->gT("Code")."</th>\n";
|
|
if ($assessmentvisible)
|
|
{
|
|
$vasummary .="<th align='center'>".$clang->gT("Assessment value");
|
|
}
|
|
else
|
|
{
|
|
$vasummary .="<th style='display:none;'> ";
|
|
}
|
|
|
|
$vasummary .= "</th>\n"
|
|
."<th align='center'>".$clang->gT("Answer option")."</th>\n"
|
|
."<th align='center'>".$clang->gT("Actions")."</th>\n"
|
|
."</tr></thead>"
|
|
."<tbody align='center'>";
|
|
$alternate=true;
|
|
|
|
$query = "SELECT * FROM ".db_table_name('answers')." WHERE qid='{$qid}' AND language='{$anslang}' and scale_id=$scale_id ORDER BY sortorder, code";
|
|
$result = db_execute_assoc($query) or safe_die($connect->ErrorMsg()); //Checked
|
|
$anscount = $result->RecordCount();
|
|
while ($row=$result->FetchRow())
|
|
{
|
|
$row['code'] = htmlspecialchars($row['code']);
|
|
$row['answer']=htmlspecialchars($row['answer']);
|
|
|
|
$vasummary .= "<tr class='row_$position ";
|
|
if ($alternate==true)
|
|
{
|
|
$vasummary.='highlight';
|
|
}
|
|
$alternate=!$alternate;
|
|
|
|
$vasummary .=" '><td align='right'>\n";
|
|
|
|
if ($first)
|
|
{
|
|
$vasummary .= "<img class='handle' src='$imageurl/handle.png' /></td><td><input type='hidden' class='oldcode' id='oldcode_{$position}_{$scale_id}' name='oldcode_{$position}_{$scale_id}' value=\"{$row['code']}\" /><input type='text' class='code' id='code_{$position}_{$scale_id}' name='code_{$position}_{$scale_id}' value=\"{$row['code']}\" maxlength='5' size='5'"
|
|
." onkeypress=\"return goodchars(event,'1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWZYZ_')\""
|
|
." />";
|
|
}
|
|
else
|
|
{
|
|
$vasummary .= " </td><td>{$row['code']}";
|
|
|
|
}
|
|
|
|
$vasummary .= "</td>\n"
|
|
."<td\n";
|
|
|
|
if ($assessmentvisible && $first)
|
|
{
|
|
$vasummary .= "><input type='text' class='assessment' id='assessment_{$position}_{$scale_id}' name='assessment_{$position}_{$scale_id}' value=\"{$row['assessment_value']}\" maxlength='5' size='5'"
|
|
." onkeypress=\"return goodchars(event,'-1234567890')\""
|
|
." />";
|
|
}
|
|
elseif ( $first)
|
|
{
|
|
$vasummary .= " style='display:none;'><input type='hidden' class='assessment' id='assessment_{$position}_{$scale_id}' name='assessment_{$position}_{$scale_id}' value=\"{$row['assessment_value']}\" maxlength='5' size='5'"
|
|
." onkeypress=\"return goodchars(event,'-1234567890')\""
|
|
." />";
|
|
}
|
|
elseif ($assessmentvisible)
|
|
{
|
|
$vasummary .= '>'.$row['assessment_value'];
|
|
}
|
|
else
|
|
{
|
|
$vasummary .= " style='display:none;'>";
|
|
}
|
|
|
|
$vasummary .= "</td><td>\n"
|
|
."<input type='text' class='answer' id='answer_{$row['language']}_{$row['sortorder']}_{$scale_id}' name='answer_{$row['language']}_{$row['sortorder']}_{$scale_id}' size='100' value=\"{$row['answer']}\" />\n"
|
|
. getEditor("editanswer","answer_".$row['language']."_{$row['sortorder']}_{$scale_id}", "[".$clang->gT("Answer:", "js")."](".$row['language'].")",$surveyid,$gid,$qid,'editanswer');
|
|
|
|
// Deactivate delete button for active surveys
|
|
$vasummary.="</td><td><img src='$imageurl/addanswer.png' class='btnaddanswer' />";
|
|
$vasummary.="<img src='$imageurl/deleteanswer.png' class='btndelanswer' />";
|
|
|
|
$vasummary .= "</td></tr>\n";
|
|
$position++;
|
|
}
|
|
$vasummary .='</table><br />';
|
|
if ($first)
|
|
{
|
|
$vasummary .= "<input type='hidden' id='answercount_{$scale_id}' name='answercount_{$scale_id}' value='$anscount' />\n";
|
|
}
|
|
$vasummary .= "<button id='btnlsbrowser_{$anslang}_{$scale_id}' class='btnlsbrowser' type='button'>".$clang->gT('Predefined label sets...')."</button>";
|
|
$vasummary .= "<button id='btnquickadd_{$anslang}_{$scale_id}' class='btnquickadd' type='button'>".$clang->gT('Quick add...')."</button>";
|
|
|
|
}
|
|
|
|
$position=sprintf("%05d", $position);
|
|
|
|
$first=false;
|
|
$vasummary .= "</div>";
|
|
}
|
|
// Label set browser
|
|
// <br/><input type='checkbox' checked='checked' id='languagefilter' /><label for='languagefilter'>".$clang->gT('Match language')."</label>
|
|
$vasummary .= "<div id='labelsetbrowser' class='labelsets-update' style='display:none;'><div class='labelset-list' style='float:left;width:260px;'>
|
|
<label for='labelsets'>".$clang->gT('Available label sets:')."</label>
|
|
<select id='labelsets' size='10' style='width:250px;'><option> </option></select>
|
|
<p class='button-list'><button id='btnlsreplace' type='button'>".$clang->gT('Replace')."</button>
|
|
<button id='btnlsinsert' type='button'>".$clang->gT('Add')."</button>
|
|
<button id='btncancel' type='button'>".$clang->gT('Cancel')."</button></p></div>
|
|
|
|
<div id='labelsetpreview' style='float:right;width:500px;'></div></div> ";
|
|
$vasummary .= "<div id='quickadd' class='labelsets-update' style='display:none;'><div class='labelset-list' style='float:left;'>
|
|
<label for='quickadd'>".$clang->gT('Enter your answers:')."</label>
|
|
<textarea id='quickaddarea' class='tipme' title='".$clang->gT('Enter one answer per line. You can provide a code by separating code and answer text with a semikolon or tab. For multilingual surveys you add the translation(s) on the same line separated with a semikolon/tab.')."' rows='30' style='width:570px;'></textarea>
|
|
<p class='button-list'><button id='btnqareplace' type='button'>".$clang->gT('Replace')."</button>
|
|
<button id='btnqainsert' type='button'>".$clang->gT('Add')."</button>
|
|
<button id='btnqacancel' type='button'>".$clang->gT('Cancel')."</button></p></div>
|
|
</div> ";
|
|
// Save button
|
|
$vasummary .= "<p><input type='submit' id='saveallbtn_$anslang' name='method' value='".$clang->gT("Save changes")."' />\n";
|
|
$vasummary .= "</div></form>";
|
|
|
|
|
|
|
|
|
|
?>
|