MetaTables() or safe_die ("Error getting tokens
".$connect->ErrorMsg()); foreach ($tablelist as $tbl) { if (db_quote_id($tbl) == db_table_name('survey_'.$surveyid)) $resultsexist = 1; } if (!isset($resultsexist)) die("Your results table is missing!"); $sumquery5 = "SELECT b.* FROM {$dbprefix}surveys AS a INNER JOIN {$dbprefix}surveys_rights AS b ON a.sid = b.sid WHERE a.sid=$surveyid AND b.uid = ".$_SESSION['loginID']; //Getting rights for this survey and user $sumresult5 = db_execute_assoc($sumquery5); $sumrows5 = $sumresult5->FetchRow(); require_once(dirname(__FILE__).'/sessioncontrol.php'); // Set language for questions and labels to base language of this survey if (isset($browselang) && $browselang!='') { $_SESSION['browselang']=$browselang; $language=$_SESSION['browselang']; } elseif (isset($_SESSION['browselang'])) { $language=$_SESSION['browselang']; } else { $language = GetBaseLanguageFromSurveyID($surveyid); } $surveyoptions = browsemenubar(); $browseoutput = "
\n" ."\n"; if (!$database_exists) //DATABASE DOESN'T EXIST OR CAN'T CONNECT { $browseoutput .= "\t\n" ."\t\n" ."\n"; return; } if (!$surveyid && !$subaction) //NO SID OR ACTION PROVIDED { $browseoutput .= "\t" . $clang->gT("Browse Responses")."\n" ."\t$setfont\n" ."".$clang->gT("Error")."
\n" . $clang->gT("You have not selected a survey to browse.")."

\n" ."
\n" ."\n"; return; } //CHECK IF SURVEY IS ACTIVATED AND EXISTS $actquery = "SELECT * FROM ".db_table_name('surveys')." as a inner join ".db_table_name('surveys_languagesettings')." as b on (b.surveyls_survey_id=a.sid and b.surveyls_language=a.language) WHERE a.sid=$surveyid"; $actresult = db_execute_assoc($actquery); $actcount = $actresult->RecordCount(); if ($actcount > 0) { while ($actrow = $actresult->FetchRow()) { $surveytable = db_table_name("survey_".$actrow['sid']); $surveyname = "{$actrow['surveyls_title']}"; if ($actrow['active'] == "N") //SURVEY IS NOT ACTIVE YET { $browseoutput .= "\t" . $clang->gT("Browse Responses").": $surveyname\n" ."\t\n" ."".$clang->gT("Error")."
\n" . $clang->gT("This survey has not been activated. There are no results to browse.")."

\n" ."
\n" ."\n" ."\n"; return; } } } else //SURVEY MATCHING $surveyid DOESN'T EXIST { $browseoutput .= "\t" . $clang->gT("Browse Responses")."\n" ."\t\n" ."".$clang->gT("Error")."
\n" . $clang->gT("There is no matching survey.")." ($surveyid)

\n" ."
\n" ."\n" ."\n"; return; } //OK. IF WE GOT THIS FAR, THEN THE SURVEY EXISTS AND IT IS ACTIVE, SO LETS GET TO WORK. $qulanguage = GetBaseLanguageFromSurveyID($surveyid); if ($subaction == "id") // Looking at a SINGLE entry { //SHOW HEADER $browseoutput .= "\t".$clang->gT("Browse Responses").": $surveyname\n"; if (!isset($_POST['sql']) || !$_POST['sql']) {$browseoutput .= "$surveyoptions";} // Don't show options if coming from tokens script $browseoutput .= "\n" ."
\n"; //FIRST LETS GET THE NAMES OF THE QUESTIONS AND MATCH THEM TO THE FIELD NAMES FOR THE DATABASE $fnquery = "SELECT * FROM ".db_table_name("questions").", ".db_table_name("groups").", ".db_table_name("surveys")." WHERE ".db_table_name("questions").".gid=".db_table_name("groups").".gid AND ".db_table_name("groups").".sid=".db_table_name("surveys").".sid AND ".db_table_name("questions").".sid='$surveyid' AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("groups").".language='{$language}' ORDER BY ".db_table_name("groups").".group_order, ".db_table_name("questions").".title"; $fnresult = db_execute_assoc($fnquery); $fncount = 0; $fnrows = array(); //Create an empty array in case fetch_array does not return any rows while ($fnrow = $fnresult->FetchRow()) {++$fncount; $fnrows[] = $fnrow; $private = $fnrow['private']; $datestamp=$fnrow['datestamp']; $ipaddr=$fnrow['ipaddr']; $refurl=$fnrow['refurl'];} // Get table output into array // Perform a case insensitive natural sort on group name then question title of a multidimensional array usort($fnrows, 'CompareGroupThenTitle'); $fnames[] = array("id", "id", "id"); if ($private == "N") //add token to top ofl ist is survey is not private { $fnames[] = array("token", "token", $clang->gT("Token ID")); } $fnames[] = array("completed", "Completed", $clang->gT("Completed"), "0"); if ($datestamp == "Y") //add datetime to list if survey is datestamped { // submitdate for not-datestamped surveys is always 1980/01/01 // so only display it when datestamped $fnames[] = array("startdate", "startdate", $clang->gT("Date Started")); $fnames[] = array("datestamp", "datestamp", $clang->gT("Date Last Action")); $fnames[] = array("submitdate", "submitdate", $clang->gT("Date Submitted")); } if ($ipaddr == "Y") //add ipaddr to list if survey should save submitters IP address { $fnames[] = array("ipaddr", "ipaddr", $clang->gT("IP Address")); } if ($refurl == "Y") //add refer_URL to list if survey should save referring URL { $fnames[] = array("refurl", "refurl", $clang->gT("Referring URL")); } foreach ($fnrows as $fnrow) { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}"; $fquestion = $fnrow['question']; if ($fnrow['type'] == "Q" || $fnrow['type'] == "M" || $fnrow['type'] == "A" || $fnrow['type'] == "B" || $fnrow['type'] == "C" || $fnrow['type'] == "E" || $fnrow['type'] == "F" || $fnrow['type'] == "H" || $fnrow['type'] == "J" || $fnrow['type'] == "K" || $fnrow['type'] == "P" || $fnrow['type'] == "^") { $fnrquery = "SELECT * FROM ".db_table_name("answers")." WHERE qid={$fnrow['qid']} AND language='{$language}' ORDER BY sortorder, answer"; $fnrresult = db_execute_assoc($fnrquery); while ($fnrrow = $fnrresult->FetchRow()) { $fnames[] = array("$field{$fnrrow['code']}", "$ftitle ({$fnrrow['code']})", "{$fnrow['question']} ({$fnrrow['answer']})"); if ($fnrow['type'] == "P") {$fnames[] = array("$field{$fnrrow['code']}"."comment", "$ftitle"."comment", "{$fnrow['question']} (".$clang->gT("Comment").")");} } if ($fnrow['other'] == "Y" and ($fnrow['type']=="!" or $fnrow['type']=="L" or $fnrow['type']=="M" or $fnrow['type']=="P" || $fnrow['type'] == "Z" || $fnrow['type'] == "W")) { $fnames[] = array("$field"."other", "$ftitle"."other", "{$fnrow['question']}(".$clang->gT("Other").")"); } } elseif ($fnrow['type'] == "R") { $fnrquery = "SELECT * FROM ".db_table_name("answers")." WHERE qid={$fnrow['qid']} AND language='{$language}' ORDER BY sortorder, answer"; $fnrresult = $connect->Execute($fnrquery); $fnrcount = $fnrresult->RecordCount(); for ($i=1; $i<=$fnrcount; $i++) { $fnames[] = array("$field$i", "$ftitle ($i)", "{$fnrow['question']} ($i)"); } } elseif ($fnrow['type'] == "O") { $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}"); $field2 = $field."comment"; $ftitle2 = $ftitle."[Comment]"; $longtitle = "{$fnrow['question']}
[Comment]"; $fnames[] = array("$field2", "$ftitle2", "$longtitle"); } elseif ($fnrow['type'] == "1") // multi scale { $i2query = "SELECT ".db_table_name("answers").".*, ".db_table_name("questions").".other FROM ".db_table_name("answers").", ".db_table_name("questions")." WHERE ".db_table_name("answers").".qid=".db_table_name("questions").".qid AND ".db_table_name("answers").".language='{$language}' AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("questions").".qid={$fnrow['qid']} AND ".db_table_name("questions").".sid=$surveyid ORDER BY ".db_table_name("answers").".sortorder, ".db_table_name("answers").".answer"; $i2result = db_execute_assoc($i2query); $otherexists = ""; while ($i2row = $i2result->FetchRow()) { // first scale $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}{$i2row['code']}#0"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}Opt{$i2row['code']}"; if ($i2row['other'] == "Y") {$otherexists = "Y";} $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]
[".$clang->gT("1. scale")."]", "{$fnrow['gid']}"); // second scale $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}{$i2row['code']}#1"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}Opt{$i2row['code']}"; if ($i2row['other'] == "Y") {$otherexists = "Y";} $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]
[".$clang->gT("2. scale")."]", "{$fnrow['gid']}"); } if ($otherexists == "Y") { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"."other"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}OptOther"; $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[Other]", "{$fnrow['gid']}"); } } else { $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}"); if (($fnrow['type'] == "L" || $fnrow['type'] == "!" || $fnrow['type'] == "W" || $fnrow['type'] == "Z") && $fnrow['other'] == "Y") { $fnames[] = array("$field"."other", "$ftitle"."other", "{$fnrow['question']}(".$clang->gT("Other").")"); } } } $nfncount = count($fnames)-1; //SHOW INDIVIDUAL RECORD $idquery = "SELECT *, CASE WHEN submitdate IS NULL THEN 'N' ELSE 'Y' END as completed FROM $surveytable WHERE "; if (incompleteAnsFilterstate() === true) {$idquery .= "submitdate >= ".$connect->DBDate('1980-01-01'). " AND ";} if ($id<1) {$id=1;} if (isset($_POST['sql']) && $_POST['sql']) { if (get_magic_quotes_gpc()) {$idquery .= stripslashes($_POST['sql']);} else {$idquery .= "{$_POST['sql']}";} } else {$idquery .= "id=$id";} $idresult = db_execute_assoc($idquery) or safe_die ("Couldn't get entry
\n$idquery
\n".$connect->ErrorMsg()); while ($idrow = $idresult->FetchRow()) {$id=$idrow['id']; $rlangauge=$idrow['startlanguage'];} $next=$id+1; $last=$id-1; $browseoutput .= "\n" ."\t\n" ."\t\t\n" ."\t\n" ."\t\n" ."\t\n"; $idresult = db_execute_assoc($idquery) or safe_die ("Couldn't get entry
$idquery
".$connect->ErrorMsg()); while ($idrow = $idresult->FetchRow()) { $i=0; for ($i; $i<$nfncount+1; $i++) { $browseoutput .= "\t\n" ."\t\t\n" ."\t\t\n" ."\t\n" ."\t\n"; } } $browseoutput .= "
" . $clang->gT("View Response").": $id
\n" ."\t\t\t\n" ."\t\t\t\n"; if (isset($rlangauge)) { $browseoutput .="\t\t\tgT("Edit this entry", "js")."')\">" . "\n"; } if ($sumrows5['delete_survey']) { // $browseoutput .= "\t\t\tgT("Delete this entry", "js")."')\">" // ."gT("Are you sure you want to delete this entry?","js")."')\" />\n"; $browseoutput .= "\t\t\tgT("Delete this entry", "js")."')\">" ."gT("Are you sure you want to delete this entry?","js")."')) {".get2post("$scriptname?action=dataentry&subaction=delete&id=$id&sid=$surveyid&surveytable=$surveytable")."}\" />\n"; } $browseoutput .= "\t\t\tgT("Export this Response", "js")."')\">" . "". $clang->gT("Export this Response")."\n" ."\t\t\t\n" ."\t\t\t\n" ."\t\t\tgT("Show previous...", "js")."')\">". "\n" ."\t\t\t\n" ."\t\t\tgT("Show next...", "js")."')\">" . "\n" ."\t\t
" ."$setfont{$fnames[$i][2]}$setfont" .htmlspecialchars(getextendedanswer($fnames[$i][0], $idrow[$fnames[$i][0]]), ENT_QUOTES) ."
\n" ."\n" ."\t\n" ."\t\t\n" ."\t\n" ."
\n"; // if (isset($_POST['sql']) && $_POST['sql']) {$browseoutput .= "\t\t\t\n";} $browseoutput .= "\t\t
\n"; } elseif ($subaction == "all") { $browseoutput .= ("\t" . $clang->gT("Browse Responses").": $surveyname\n"); if (!isset($_POST['sql'])) {$browseoutput .= "$surveyoptions";} //don't show options when called from another script with a filter on else { $browseoutput .= "\n\n" ."\t\n" ."\t\t\n" ."\t\n" ."
\n" ."\t\t\t".$clang->gT("Showing Filtered Results")."
\n" ."\t\t\t [".$clang->gT("Close")."]" ."\t\t
\n"; } $browseoutput .= "\n"; //FIRST LETS GET THE NAMES OF THE QUESTIONS AND MATCH THEM TO THE FIELD NAMES FOR THE DATABASE $fnquery = "SELECT * FROM ".db_table_name("questions").", ".db_table_name("groups").", ".db_table_name("surveys")." WHERE ".db_table_name("questions").".gid=".db_table_name("groups").".gid AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("groups").".language='{$language}' AND ".db_table_name("groups").".sid=".db_table_name("surveys").".sid AND ".db_table_name("questions").".sid='$surveyid' ORDER BY ".db_table_name("groups").".group_order"; $fnresult = db_execute_assoc($fnquery); $fncount = 0; $fnrows = array(); //Create an empty array in case FetchRow does not return any rows while ($fnrow = $fnresult->FetchRow()) { ++$fncount; $fnrows[] = $fnrow; $private = $fnrow['private']; $datestamp=$fnrow['datestamp']; $ipaddr=$fnrow['ipaddr']; $refurl=$fnrow['refurl']; } // Get table output into array // Perform a case insensitive natural sort on group name then question title of a multidimensional array usort($fnrows, 'CompareGroupThenTitle'); if ($private == "N") //Add token to list { $fnames[] = array("token", $clang->gT("Token"), $clang->gT("Token ID"), "0"); } $fnames[] = array("completed", "Completed", $clang->gT("Completed"), "0"); if ($datestamp == "Y") //Add datestamp { // submitdate for not-datestamped surveys is always 1980/01/01 // so only display it when datestamped $fnames[] = array("startdate", "startdate", $clang->gT("Date Started"), "0"); $fnames[] = array("datestamp", "Datestamp", $clang->gT("Date Last Action"), "0"); $fnames[] = array("submitdate", "submitdate", $clang->gT("Date Submitted"), "0"); } if ($ipaddr == "Y") // Add IP Address { $fnames[] = array("ipaddr", "IPAddress", $clang->gT("IP Address"), "0"); } if ($refurl == "Y") // refurl { $fnames[] = array("refurl", "refurl", $clang->gT("Referring URL"), "0"); } foreach ($fnrows as $fnrow) { if ($fnrow['type'] != "Q" && $fnrow['type'] != "M" && $fnrow['type'] != "A" && $fnrow['type'] != "B" && $fnrow['type'] != "C" && $fnrow['type'] != "E" && $fnrow['type'] != "F" && $fnrow['type'] != "H" && $fnrow['type'] != "P" && $fnrow['type'] != "J" && $fnrow['type'] != "K" && $fnrow['type'] != "1" && $fnrow['type'] != "O" && $fnrow['type'] != "R" && $fnrow['type'] != "^") { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}"; $fquestion = $fnrow['question']; $fnames[] = array("$field", "$ftitle", "$fquestion", "{$fnrow['gid']}"); if (($fnrow['type'] == "L" || $fnrow['type'] == "!" || $fnrow['type'] == "W" || $fnrow['type'] == "Z") && $fnrow['other'] == "Y") { $fnames[] = array("$field"."other", "$ftitle"."other", "{$fnrow['question']}(".$clang->gT("Other").")", "{$fnrow['gid']}"); } } elseif ($fnrow['type'] == "O") { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}"; $fquestion = $fnrow['question']; $fnames[] = array("$field", "$ftitle", "$fquestion", "{$fnrow['gid']}"); $field .= "comment"; $ftitle .= "[comment]"; $fquestion .= " (comment)"; $fnames[] = array("$field", "$ftitle", "$fquestion", "{$fnrow['gid']}"); } elseif ($fnrow['type'] == "1") // multi scale { $i2query = "SELECT ".db_table_name("answers").".*, ".db_table_name("questions").".other FROM ".db_table_name("answers").", ".db_table_name("questions")." WHERE ".db_table_name("answers").".qid=".db_table_name("questions").".qid AND ".db_table_name("answers").".language='{$language}' AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("questions").".qid={$fnrow['qid']} AND ".db_table_name("questions").".sid=$surveyid ORDER BY ".db_table_name("answers").".sortorder, ".db_table_name("answers").".answer"; $i2result = db_execute_assoc($i2query); $otherexists = ""; while ($i2row = $i2result->FetchRow()) { // first scale $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}{$i2row['code']}#0"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}Opt{$i2row['code']}"; if ($i2row['other'] == "Y") {$otherexists = "Y";} $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]
[".$clang->gT("1. scale")."]", "{$fnrow['gid']}"); // second scale $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}{$i2row['code']}#1"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}Opt{$i2row['code']}"; if ($i2row['other'] == "Y") {$otherexists = "Y";} $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]
[".$clang->gT("2. scale")."]", "{$fnrow['gid']}"); } if ($otherexists == "Y") { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"."other"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}OptOther"; $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[Other]", "{$fnrow['gid']}"); if ($fnrow['type'] == "P") { $fnames[] = array("$field"."comment", "$ftitle"."Comment", "{$fnrow['question']}
\n[Other]
\n[Comment]", "{$fnrow['gid']}"); } } } elseif ($fnrow['type'] == "R") { $i2query = "SELECT ".db_table_name("answers").".*, ".db_table_name("questions").".other FROM ".db_table_name("answers").", ".db_table_name("questions")." WHERE ".db_table_name("answers").".qid=".db_table_name("questions").".qid AND ".db_table_name("answers").".language='{$language}' AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("questions").".qid={$fnrow['qid']} AND ".db_table_name("questions").".sid=$surveyid ORDER BY ".db_table_name("answers").".sortorder, ".db_table_name("answers").".answer"; $i2result = $connect->Execute($i2query); $i2count = $i2result->RecordCount(); for ($i=1; $i<=$i2count; $i++) { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}$i"; $ftitle = "Grp{$fnrow['qid']}Qst{$fnrow['title']}Opt$i"; $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[$i]", "{$fnrow['gid']}"); } } else { $i2query = "SELECT ".db_table_name("answers").".*, ".db_table_name("questions").".other FROM ".db_table_name("answers").", ".db_table_name("questions")." WHERE ".db_table_name("answers").".qid=".db_table_name("questions").".qid AND ".db_table_name("answers").".language='{$language}' AND ".db_table_name("questions").".language='{$language}' AND ".db_table_name("questions").".qid={$fnrow['qid']} AND ".db_table_name("questions").".sid=$surveyid ORDER BY ".db_table_name("answers").".sortorder, ".db_table_name("answers").".answer"; $i2result = db_execute_assoc($i2query); $otherexists = ""; while ($i2row = $i2result->FetchRow()) { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}{$i2row['code']}"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}Opt{$i2row['code']}"; if ($i2row['other'] == "Y") {$otherexists = "Y";} $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]", "{$fnrow['gid']}"); if ($fnrow['type'] == "P") {$fnames[] = array("$field"."comment", "$ftitle", "{$fnrow['question']}
\n[{$i2row['answer']}]
\n[Comment]", "{$fnrow['gid']}");} } if ($otherexists == "Y") { $field = "{$fnrow['sid']}X{$fnrow['gid']}X{$fnrow['qid']}"."other"; $ftitle = "Grp{$fnrow['gid']}Qst{$fnrow['title']}OptOther"; $fnames[] = array("$field", "$ftitle", "{$fnrow['question']}
\n[Other]", "{$fnrow['gid']}"); if ($fnrow['type'] == "P") { $fnames[] = array("$field"."comment", "$ftitle"."Comment", "{$fnrow['question']}
\n[Other]
\n[Comment]", "{$fnrow['gid']}"); } } } } $fncount = count($fnames); //NOW LETS CREATE A TABLE WITH THOSE HEADINGS if ($fncount < 10) {$cellwidth = "10%";} else {$cellwidth = "100";} $tableheader = ""; if ($fncount < 10) {$tableheader .= "\n";} else {$fnwidth = (($fncount-1)*180); $tableheader .= "\n";} $tableheader .= "\t\n" . "\t\t\n"; foreach ($fnames as $fn) { if (!isset($currentgroup)) {$currentgroup = $fn[3]; $gbc = "oddrow";} if ($currentgroup != $fn[3]) { $currentgroup = $fn[3]; if ($gbc == "oddrow") {$gbc = "evenrow";} else {$gbc = "oddrow";} } $tableheader .= "\t\t\n"; } $tableheader .= "\t\n\n"; $start=returnglobal('start'); $limit=returnglobal('limit'); if (!isset($limit) || $limit== '') {$limit = 50;} if (!isset($start) || $start =='') {$start = 0;} //LETS COUNT THE DATA $dtquery = "SELECT count(*) FROM $surveytable"; if (incompleteAnsFilterstate() === true) {$dtquery .= " WHERE submitdate is not null ";} $dtresult=db_execute_num($dtquery); while ($dtrow=$dtresult->FetchRow()) {$dtcount=$dtrow[0];} if ($limit > $dtcount) {$limit=$dtcount;} //NOW LETS SHOW THE DATA if (isset($_POST['sql'])) { if ($_POST['sql'] == "NULL") { $dtquery = "SELECT *, CASE WHEN submitdate IS NULL THEN 'N' ELSE 'Y' END as completed FROM $surveytable "; if (incompleteAnsFilterstate() === true) {$dtquery .= " WHERE submitdate is not null ";} $dtquery .= " ORDER BY id"; } else { $dtquery = "SELECT *, CASE WHEN submitdate IS NULL THEN 'N' ELSE 'Y' END as completed FROM $surveytable WHERE "; if (incompleteAnsFilterstate() === true) { $dtquery .= " submitdate is not null "; if (stripcslashes($_POST['sql']) !== "") { $dtquery .= " AND "; } } if (stripcslashes($_POST['sql']) !== "") { $dtquery .= stripcslashes($_POST['sql'])." "; } $dtquery .= " ORDER BY id"; } } else { $dtquery = "SELECT *, CASE WHEN submitdate IS NULL THEN 'N' ELSE 'Y' END as completed FROM $surveytable "; if (incompleteAnsFilterstate() === true) {$dtquery .= " WHERE submitdate is not null ";} $dtquery .= " ORDER BY id"; } if ($order == "desc") {$dtquery .= " DESC";} if (isset($limit)) { if (!isset($start)) {$start = 0;} $dtresult = db_select_limit_assoc($dtquery, $limit, $start) or safe_die("Couldn't get surveys
$dtquery
".$connect->ErrorMsg()); } else { $dtresult = db_execute_assoc($dtquery) or safe_die("Couldn't get surveys
$dtquery
".$connect->ErrorMsg()); } $dtcount2 = $dtresult->RecordCount(); $cells = $fncount+1; //CONTROL MENUBAR $last=$start-$limit; $next=$start+$limit; $end=$dtcount-$limit; if ($end < 0) {$end=0;} if ($last <0) {$last=0;} if ($next >= $dtcount) {$next=$dtcount-$limit;} if ($end < 0) {$end=0;} $browseoutput .= "
id" . strip_tags("$fn[2]") . "
\n" ."\n" ."\t\n"; if (!isset($_POST['sql'])) { $browseoutput .= "\t\n" ."\t\t\n" ."\t\n" ."\n" ."
\n"; $browseoutput .= $tableheader; while ($dtrow = $dtresult->FetchRow()) { if (!isset($bgcc)) {$bgcc="evenrow";} else { if ($bgcc == "evenrow") {$bgcc = "oddrow";} else {$bgcc = "evenrow";} } $browseoutput .= "\t\n" ."\t\t\n" ."\t\t\t" ."{$dtrow['id']}\n"; $i = 0; if ($private == "N") { $SQL = "Select * FROM ".db_table_name('tokens_'.$surveyid)." WHERE token=?"; if ( db_tables_exist(db_table_name_nq('tokens_'.$surveyid)) && $SQLResult = db_execute_assoc($SQL, $dtrow['token'])) { $TokenRow = $SQLResult->FetchRow(); } $browseoutput .= "\t\t\n"; if (isset($TokenRow) && $TokenRow) { $browseoutput .= "\t\t"; } $browseoutput .= "{$dtrow['token']}"; if (isset($TokenRow) && $TokenRow) { $browseoutput .= "\n"; } $i++; } for ($i; $i<$fncount; $i++) { $browseoutput .= "\t\t" . htmlspecialchars($dtrow[$fnames[$i][0]]) ."\n"; } $browseoutput .= "\t\n"; } $browseoutput .= "\n
\n"; } else { $browseoutput .= "\t" . $clang->gT("Browse Responses").": $surveyname\n" . $surveyoptions; $browseoutput .= "\n"; $num_total_answers=0; $num_completed_answers=0; $gnquery = "SELECT count(id) FROM $surveytable"; $gnquery2 = "SELECT count(id) FROM $surveytable WHERE submitdate is not null"; $gnresult = db_execute_num($gnquery); $gnresult2 = db_execute_num($gnquery2); while ($gnrow=$gnresult->FetchRow()) {$num_total_answers=$gnrow[0];} while ($gnrow2=$gnresult2->FetchRow()) {$num_completed_answers=$gnrow2[0];} $browseoutput .= "\n" ."\t\n" ."
".sprintf($clang->gT("%d responses for this survey"), $num_total_answers)." (" .sprintf($clang->gT("%d full responses"), $num_completed_answers).", " .sprintf($clang->gT("%d responses not completely filled out"), $num_total_answers-$num_completed_answers).")" ."\t
\n"; } ?>