Source for file exercice.php
Documentation is available at exercice.php
DOKEOS - elearning and course management software
For a full list of contributors, see documentation/credits.html
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
See "documentation/licence.html" more details.
B-1030 Brussels - Belgium
* Exercise list: This script shows the list of exercises for administrators and students.
* @package dokeos.exercise
* @author Olivier Brouckaert, original author
* @author Denes Nagy, HotPotatoes integration
* @author Wolfgang Schneider, code/html cleanup
* @version $Id:exercice.php 12269 2007-05-03 14:17:37Z elixir_julian $
// name of the language file that needs to be included
$language_file= 'exercice';
require_once('../inc/global.inc.php');
$show= (isset ($_GET['show']) && $_GET['show'] == 'result')? 'result': 'test'; // moved down to fix bug: http://www.dokeos.com/forum/viewtopic.php?p=18609#18609
-----------------------------------------------------------
-----------------------------------------------------------
require_once('exercise.class.php');
require_once('question.class.php');
require_once('answer.class.php');
require_once(api_get_path(LIBRARY_PATH). 'fileManage.lib.php');
require_once(api_get_path(LIBRARY_PATH). 'fileUpload.lib.php');
require_once('hotpotatoes.lib.php');
require_once(api_get_path(LIBRARY_PATH). 'document.lib.php');
include(api_get_path(LIBRARY_PATH). 'mail.lib.inc.php');
include(api_get_path(LIBRARY_PATH). 'usermanager.lib.php');
-----------------------------------------------------------
-----------------------------------------------------------
$picturePath= $documentPath. '/images';
$audioPath= $documentPath. '/audio';
$exfile = explode('/',$exercicePath);
$exercicePath = substr($exercicePath,0,strpos($exercicePath,$exfile));
$exercicePath = $exercicePath. "exercice.php";
// maximum number of exercises on a same page
// Clear the exercise session
//general POST/GET/SESSION/COOKIES parameters recovery
if ( empty ( $origin ) ) {
$origin = $_REQUEST['origin'];
if ( empty ($choice ) ) {
$choice = $_REQUEST['choice'];
if ( empty ( $hpchoice ) ) {
$hpchoice = $_REQUEST['hpchoice'];
if ( empty ($exerciseId ) ) {
if($origin == 'learnpath'){
$htmlHeadXtra[]= '<style type="text/css">
if ($show== 'result' && $_REQUEST['comments']== 'update' && ($is_allowedToEdit || $is_tutor))
$emailid = $_GET['emailid'];
$from = $_SESSION['_user']['mail'];
$from_name = $_SESSION['_user']['firstName']. " ". $_SESSION['_user']['lastName'];
foreach ($_POST as $key=> $v)
if ($keyexp[0] == "marks")
$sql = "select question from $TBL_QUESTIONS where id = '$keyexp[1]'";
$query = "update $TBL_TRACK_ATTEMPT set marks = '$v' where question_id = $keyexp[1] and exe_id=$id";
$qry = 'SELECT sum(marks) as tot
FROM '. $TBL_TRACK_ATTEMPT. ' where exe_id = '. intval($id). '
$totquery = "update $TBL_TRACK_EXERCICES set exe_result = $tot where exe_Id=$id";
$query = "update $TBL_TRACK_ATTEMPT set teacher_comment = '$v' where question_id = $keyexp[1] and exe_id = $id ";
$qry = 'SELECT DISTINCT question_id, marks
FROM '. $TBL_TRACK_ATTEMPT. ' where exe_id = '. intval($id). '
$totquery = "update $TBL_TRACK_EXERCICES set exe_result = $tot where exe_Id=$id";
'<style type="text/css">' .
'font-family: Verdana, Arial, Helvetica, sans-serif;' .
'.style8 {font-family: Verdana, Arial, Helvetica, sans-serif; font-weight: bold; color: #006699; }' .
' font-family: Verdana, Arial, Helvetica, sans-serif;' .
'.style16 {font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 12px; }' .
' <p>'. get_lang('DearStudentEmailIntroduction'). '</p>' .
' <p class="style10"> '. get_lang('AttemptVCC'). ' </p>' .
' <td width="229" valign="top" bgcolor="E5EDF8"> <span class="style10">'. get_lang('Question'). '</span></td>' .
' <td width="469" valign="top" bgcolor="#F3F3F3"><span class="style16">#ques_name#</span></td>' .
' <td width="229" valign="top" bgcolor="E5EDF8"> <span class="style10">'. get_lang('Exercice'). '</span></td>' .
' <td width="469" valign="top" bgcolor="#F3F3F3"><span class="style16">#test#</span></td>' .
' <p>'. get_lang('ClickLinkToViewComment'). ' <a href="#url#">#url#</a><br />' .
$message = '<p>'. sprintf(get_lang('AttemptVCCLong'),$test). ' <A href="#url#">#url#</A></p><br />';
//$message= str_replace("#ques_name#",$ques_name,$mess);
$headers = " MIME-Version: 1.0 \r\n";
$headers .= "User-Agent: Dokeos/1.6";
$headers .= "Content-Transfer-Encoding: 7bit";
$headers .= 'From: '. $from_name. ' <'. $from. '>' . "\r\n";
$headers= "From:$from_name\r\nReply-to: $to\r\nContent-type: text/html; charset=". ($charset? $charset: 'ISO-8859-15');
//mail($emailid, $subject, $mess,$headers);
api_mail_html($emailid, $emailid, $subject, $mess, $from_name, $from);
if(in_array($origin, array('tracking_course','user_course'))){
//Redirect to the reporting
header('location: ../mySpace/myStudents.php?origin='. $origin. '&student='. $_GET['student']. '&details=true&course='. $_GET['course']);
if($is_allowedToEdit || $is_tutor)
$interbreadcrumb[]= array("url" => "exercice.php","name" => get_lang('Exercices'));
$interbreadcrumb[]= array("url" => "exercice.php","name" => get_lang('Exercices'));
// need functions of statsutils lib to display previous exercices scores
include_once(api_get_path(LIBRARY_PATH). 'statsUtils.lib.inc.php');
if($is_allowedToEdit && !empty($choice) && $choice == 'exportqti2')
require_once('export/qti2/qti2_export.php');
require_once(api_get_path(LIBRARY_PATH). 'pclzip/pclzip.lib.php');
$temp_zip_dir = $garbage_path. "/". $temp_dir_short;
$temp_zip_file = $temp_zip_dir. "/". md5(time()). ".zip";
$temp_xml_file = $temp_zip_dir. "/qti2export_". $exerciseId. '.xml';
$zip_folder= new PclZip($temp_zip_file);
$name = 'qti2_export_'. $exerciseId. '.zip';
//DocumentManager::string_send_for_download($export,true,'qti2export_'.$exerciseId.'.xml');
exit(); //otherwise following clicks may become buggy
if(!empty($_POST['export_user_fields']))
switch($_POST['export_user_fields'])
case 'export_user_fields':
$_SESSION['export_user_fields'] = true;
case 'do_not_export_user_fields':
$_SESSION['export_user_fields'] = false;
if(!empty($_POST['export_report']) && $_POST['export_report'] == 'export_report')
if(empty($_SESSION['export_user_fields'])) $_SESSION['export_user_fields'] = false;
if(!$is_allowedToEdit and !$is_tutor)
require_once('exercise_result.class.php');
switch($_POST['export_format'])
$export->exportCompleteReportXLS($documentPath, $user_id, $_SESSION['export_user_fields']);
$export->exportCompleteReportCSV($documentPath, $user_id, $_SESSION['export_user_fields']);
if ($origin != 'learnpath')
//so we are not in learnpath tool
if(isset ($_GET['message']))
if (in_array($_GET['message'], array('ExerciseEdited')))
include_once(api_get_path(LIBRARY_PATH). 'events.lib.inc.php');
// selects $limitExPage exercises at the same time
$from= $page* $limitExPage;
$sql= "SELECT count(id) FROM $TBL_EXERCICES";
HotPotGCt($documentPath,1,$_user['user_id']);
// only for administrator
// construction of Exercise
if($objExerciseTmp->read($exerciseId))
case 'delete': // deletes an exercise
$objExerciseTmp->delete();
case 'enable': // enables an exercise
$objExerciseTmp->enable();
// "WHAT'S NEW" notification: update table item_property (previously last_tooledit)
case 'disable': // disables an exercise
$objExerciseTmp->disable();
case 'disable_results' : //disable the results for the learners
$objExerciseTmp->disable_results();
case 'enable_results' : //disable the results for the learners
$objExerciseTmp->enable_results();
// destruction of Exercise
//$sql="SELECT id,title,type,active FROM $TBL_EXERCICES ORDER BY title LIMIT $from,".($limitExPage+1);
//$result=api_sql_query($sql,__FILE__,__LINE__);
case 'delete': // deletes an exercise
for($i= 0;$i < $imgcount;$i++ )
my_delete($documentPath. $uploadPath. "/". $fld. "/". $imgparams[$i]);
my_delete($documentPath. $uploadPath. "/". $fld. "/");
case 'enable': // enables an exercise
$newVisibilityStatus = "1"; //"visible"
$query = "SELECT id FROM $TBL_DOCUMENT WHERE path='$file'";
//$dialogBox = get_lang('ViMod');
case 'disable': // disables an exercise
$newVisibilityStatus = "0"; //"invisible"
$query = "SELECT id FROM $TBL_DOCUMENT WHERE path='$file'";
#$query = "UPDATE $TBL_DOCUMENT SET visibility='$newVisibilityStatus' WHERE path=\"".$file."\""; //added by Toon
#api_sql_query($query,__FILE__,__LINE__);
//$dialogBox = get_lang('ViMod');
$sql= "SELECT id,title,type,active,description, results_disabled FROM $TBL_EXERCICES WHERE active<>'-1' ORDER BY title LIMIT $from,". ($limitExPage+ 1);
$sql= "SELECT id,title,type,description, results_disabled FROM $TBL_EXERCICES WHERE active='1' ORDER BY title LIMIT $from,". ($limitExPage+ 1);
echo '<table border="0" align="center" cellpadding="2" cellspacing="2" width="100%">'.
if (($is_allowedToEdit) and ($origin != 'learnpath'))
echo '<td width="50%" nowrap="nowrap">'.
'<img src="../img/new_test.gif" alt="new test" align="absbottom"> <a href="exercise_admin.php?'. api_get_cidreq(). '">'. get_lang('NewEx'). '</a>'.
' | <img src="../img/jqz.jpg" alt="HotPotatoes" valign="ABSMIDDLE"> <a href="hotpotatoes.php">'. get_lang('ImportHotPotatoesQuiz'). '</a>'.
'<td width="50%" align="right">';
echo '<td align="right">';
//get HotPotatoes files (active and inactive)
path LIKE '". $uploadPath. "/%/%'",__FILE__ ,__LINE__ );
FROM $TBL_DOCUMENT d, $TBL_ITEM_PROPERTY ip
AND d.path LIKE '". $uploadPath. "/%/%'
AND ip.visibility='1'", __FILE__ ,__LINE__ );
{//if user is allowed to edit, also show hidden HP tests
$nbrHpTests = $nbrActiveTests;
$nbrNextTests = $nbrexerc- $nbrHpTests- (($page* $limitExPage));
//show pages navigation link for previous page
elseif($nbrExercises+ $nbrNextTests > $limitExPage)
echo "<< ",get_lang("PreviousPage"). " | ";
//show pages navigation link for previous page
if($nbrExercises+ $nbrNextTests > $limitExPage)
echo get_lang("NextPage") . " >>";
<table class="data_table">
if (($is_allowedToEdit) and ($origin != 'learnpath'))
<th colspan="2"> <?php echo get_lang("ExerciseName");?></th>
<th> <?php echo get_lang("Description");?></th>
<th> <?php echo get_lang('Export');?></th>
<th> <?php echo get_lang("Modify");?></th>
?> <tr bgcolor="#e6e6e6">
<th> <?php echo get_lang("ExerciseName");?></th>
<th> <?php echo get_lang("Description");?></th>
<th> <?php echo get_lang("State");?></th>
// show message if no HP test to show
if(!($nbrExercises+ $nbrHpTests) )
<td <?php echo ($is_allowedToEdit? 'colspan="5"': 'colspan="3"'); ?>> <?php echo get_lang("NoEx"); ?></td>
if ($origin != 'learnpath')
//avoid sending empty parameters
$myorigin = (empty($origin)? '': '&origin='. $origin);
$mylpid = (empty($learnpath_id)? '': '&learnpath_id='. $learnpath_id);
$mylpitemid = (empty($learnpath_item_id)? '': '&learnpath_item_id='. $learnpath_item_id);
if($i% 2== 0) $s_class= "row_odd"; else $s_class= "row_even";
echo '<tr class="'. $s_class. '">'. "\n";
<td width="27%" colspan="2">
<table border="0" cellpadding="0" cellspacing="0" width="100%">
<td width="30" align="left"><img src="../img/quiz.gif"></td>
<td width="15" valign="left" align="center"> <?php echo ($i+ ($page* $limitExPage)). '.'; ?></td>
<a href="exercice_submit.php? <?php echo api_get_cidreq(). $myorigin. $mylpid. $mylpitemid; ?>&exerciseId= <?php echo $row['id']; ?>" <?php if(!$row['active']) echo 'class="invisible"'; ?>> <?php echo $row['title']; ?></a>
<td width="8%" align="center"> <?php
$sqlquery = "SELECT count(*) FROM $TBL_EXERCICE_QUESTION WHERE exercice_id = '$exid'";
echo '<td width="5%" align="center"><a href="exercice.php?choice=exportqti2&exerciseId='. $row['id']. '"><img src="../img/export.png" border="0" title="IMS/QTI" /></a></td>';
<td width="12%" align="center">
<a href="exercise_admin.php?modifyExercise=yes&exerciseId= <?php echo $row['id']; ?>"> <img src="../img/edit.gif" border="0" title=" <?php echo htmlentities(get_lang('Modify'),ENT_QUOTES,$charset); ?>" alt=" <?php echo htmlentities(get_lang('Modify'),ENT_QUOTES,$charset); ?>" /></a>
<a href="admin.php?exerciseId= <?php echo $row['id']; ?>"><img src="../img/wizard_small.gif" border="0" title=" <?php echo htmlentities(get_lang('Build'),ENT_QUOTES,$charset); ?>" alt=" <?php echo htmlentities(get_lang('Build'),ENT_QUOTES,$charset); ?>" /></a>
<a href="exercice.php?choice=delete&exerciseId= <?php echo $row['id']; ?>" onclick="javascript:if(!confirm(' <?php echo addslashes(htmlentities(get_lang('AreYouSureToDelete'),ENT_QUOTES,$charset)); echo " ". $row['title']; echo "?"; ?>')) return false;"> <img src="../img/delete.gif" border="0" alt=" <?php echo htmlentities(get_lang('Delete'),ENT_QUOTES,$charset); ?>" /></a>
<a href="exercice.php?choice=disable&page= <?php echo $page; ?>&exerciseId= <?php echo $row['id']; ?>"> <img src="../img/visible.gif" border="0" alt=" <?php echo htmlentities(get_lang('Deactivate'),ENT_QUOTES,$charset); ?>" /></a>
<a href="exercice.php?choice=enable&page= <?php echo $page; ?>&exerciseId= <?php echo $row['id']; ?>"> <img src="../img/invisible.gif" border="0" alt=" <?php echo htmlentities(get_lang('Activate'),ENT_QUOTES,$charset); ?>" /></a>
if($row['results_disabled'])
echo '<a href="exercice.php?choice=enable_results&page='. $page. '&exerciseId='. $row['id']. '" title="'. get_lang('EnableResults'). '" alt="'. get_lang('EnableResults'). '"><img src="../img/lp_quiz_na.gif" border="0" alt="'. htmlentities(get_lang('EnableResults'),ENT_QUOTES,$charset). '" /></a>';
echo '<a href="exercice.php?choice=disable_results&page='. $page. '&exerciseId='. $row['id']. '" title="'. get_lang('DisableResults'). '" alt="'. get_lang('DisableResults'). '"><img src="../img/lp_quiz.gif" border="0" alt="'. htmlentities(get_lang('DisableResults'),ENT_QUOTES,$charset). '" /></a>';
<td width="40%"><table border="0" cellpadding="0" cellspacing="0" width="100%">
<td width="20" valign="top" align="right"> <?php echo ($i+ ($page* $limitExPage)). '.'; ?></td>
<td width="1"> </td>
<td><a href="exercice_submit.php? <?php echo api_get_cidreq(). $myorigin. $mylpid. $myllpitemid; ?>&exerciseId= <?php echo $row['id']; ?>"> <?php echo $row['title']; ?></a></td>
<td align="center"> <?php
$sqlquery = "SELECT count(*) FROM $TBL_EXERCICE_QUESTION WHERE exercice_id = '$exid'";
//this query might be improved later on by ordering by the new "tms" field rather than by exe_id
$qry = "select * from $TBL_TRACK_EXERCICES where exe_exo_id = $eid and exe_user_id = $uid and exe_cours_id = '". api_get_course_id(). "' ORDER BY exe_id DESC";
if($row['exe_weighting'] != 0)
$percentage = ($row['exe_result']/ $row['exe_weighting'])* 100;
printf("%1.2f\n",$percentage);
// skips the last exercise, that is only used to know if we have or not to create a link "Next page"
if (($from+ $limitExPage- 1)> $nbrexerc)
$from = $from - $nbrexerc;
$to = $limitExPage- ($nbrexerc- $from);
$sql = "SELECT d.path as path, d.comment as comment, ip.visibility as visibility
FROM $TBL_DOCUMENT d, $TBL_ITEM_PROPERTY ip
AND d.path LIKE '". $uploadPath. "/%/%' LIMIT $from,$to"; // only .htm or .html files listed
$sql = "SELECT d.path as path, d.comment as comment, ip.visibility as visibility
FROM $TBL_DOCUMENT d, $TBL_ITEM_PROPERTY ip
AND d.path LIKE '". $uploadPath. "/%/%' AND ip.visibility='1' LIMIT $from,$to";
$attribute['path' ][] = $row['path' ];
$attribute['visibility'][] = $row['visibility'];
$attribute['comment' ][] = $row['comment' ];
while(list ($key,$path) = each($attribute['path']))
list ($a,$vis)= each($attribute['visibility']);
<td width="27%" colspan="2">
<table border="0" cellpadding="0" cellspacing="0" width="100%">
<td width="30" align="left"><img src="../img/jqz.jpg" alt="HotPotatoes" /></td>
<td width="15" align="center"> <?php echo ($ind+ ($page* $limitExPage)). '.'; ?></td>
<td><a href="showinframes.php?file= <?php echo $path?>&cid= <?php echo $_course['official_code'];?>&uid= <?php echo $_user['user_id'];?>" <?php if(!$active) echo 'class="invisible"'; ?>> <?php echo $title?></a></td>
<td width="12%" align="center"><a href="adminhp.php?hotpotatoesName= <?php echo $path; ?>"> <img src="../img/edit.gif" border="0" alt=" <?php echo htmlentities(get_lang('Modify'),ENT_QUOTES,$charset); ?>" /></a>
<img src="../img/wizard_gray_small.gif" border="0" title=" <?php echo htmlentities(get_lang('Build'),ENT_QUOTES,$charset); ?>" alt=" <?php echo htmlentities(get_lang('Build'),ENT_QUOTES,$charset); ?>" />
<a href=" <?php echo $exercicePath; ?>?hpchoice=delete&file= <?php echo $path; ?>" onclick="javascript:if(!confirm(' <?php echo addslashes(htmlentities(get_lang('AreYouSure'),ENT_QUOTES,$charset). $title. "?"); ?>')) return false;"><img src="../img/delete.gif" border="0" alt=" <?php echo htmlentities(get_lang('Delete'),ENT_QUOTES,$charset); ?>" /></a>
$nbrActiveTests = $nbrActiveTests + 1;
<a href=" <?php echo $exercicePath; ?>?hpchoice=disable&page= <?php echo $page; ?>&file= <?php echo $path; ?>"><img src="../img/visible.gif" border="0" alt=" <?php echo htmlentities(get_lang('Deactivate'),ENT_QUOTES,$charset); ?>" /></a>
<a href=" <?php echo $exercicePath; ?>?hpchoice=enable&page= <?php echo $page; ?>&file= <?php echo $path; ?>"><img src="../img/invisible.gif" border="0" alt=" <?php echo htmlentities(get_lang('Activate'),ENT_QUOTES,$charset); ?>" /></a>
echo '<img src="../img/lp_quiz_na.gif" border="0" alt="" />';
$nbrActiveTests = $nbrActiveTests + 1;
<td width="40%"><table border="0" cellpadding="0" cellspacing="0" width="100%">
<td width="20" align="right"> <?php echo ($ind+ ($page* $limitExPage)). '.'; ?><!--<img src="../img/jqz.jpg" alt="HotPotatoes" />--></td>
<td width="1"> </td>
<td><a href="showinframes.php? <?php echo api_get_cidreq(). "&file=". $path. "&cid=". $_course['official_code']. "&uid=". $_user['user_id']. '"'; if(!$active) echo 'class="invisible"'; ?>"> <?php echo $title;?></a></td>
} //end if ($origin != 'learnpath') {
if($origin != 'learnpath'){
}// end if($show == 'test')
/*****************************************/
/* Exercise Results (uses tracking tool) */
/*****************************************/
// if tracking is enabled
if($_configuration['tracking_enabled'])
echo '<input type="hidden" name="export_report" value="export_report">';
echo '<input type="hidden" name="export_format" value="csv">';
echo '<input type="hidden" name="export_report" value="export_report">';
echo '<input type="hidden" name="export_format" value="xls">';
if($_SESSION['export_user_fields']== false)
$alt = get_lang('ExportWithUserFields');
echo '<input type="hidden" name="export_user_fields" value="export_user_fields">';
$alt = get_lang('ExportWithoutUserFields');
echo '<input type="hidden" name="export_user_fields" value="do_not_export_user_fields">';
echo '<a class="quiz_export_link" href="#" onclick="document.form1a.submit();"><img align="absbottom" src="'. api_get_path(WEB_IMG_PATH). 'excel.gif" alt="'. get_lang('ExportAsCSV'). '"> '. get_lang('ExportAsCSV'). '</a>';
echo '<a class="quiz_export_link" href="#" onclick="document.form1b.submit();"><img align="absbottom" src="'. api_get_path(WEB_IMG_PATH). 'excel.gif" alt="'. get_lang('ExportAsXLS'). '"> '. get_lang('ExportAsXLS'). '</a>';
echo '<a class="quiz_export_link" href="#" onclick="document.form1c.submit();"><img align="absbottom" src="'. api_get_path(WEB_IMG_PATH). 'synthese_view.gif" alt="'. $alt. '"> '. $alt. '</a>';
<table class="data_table">
<?php if($is_allowedToEdit || $is_tutor): ?>
<th> <?php echo get_lang("User"); ?></th> <?php endif; ?>
<th> <?php echo get_lang("Exercice"); ?></th>
<th> <?php echo get_lang("Date"); ?></th>
<th> <?php echo get_lang("Result"); ?></th>
<th> <?php echo (($is_allowedToEdit|| $is_tutor)? get_lang("CorrectTest"): get_lang("ViewTest")); ?></th>
if($is_allowedToEdit || $is_tutor)
//get all results (ourself and the others) as an admin should see them
//AND exe_user_id <> $_user['user_id'] clause has been removed
$sql= "SELECT CONCAT(lastname,' ',firstname),ce.title, te.exe_result ,
te.exe_weighting, UNIX_TIMESTAMP(te.exe_date),te.exe_id,email
FROM $TBL_EXERCICES AS ce , $TBL_TRACK_EXERCICES AS te, $TBL_USER AS user
WHERE te.exe_exo_id = ce.id AND user_id=te.exe_user_id AND te.exe_cours_id='$_cid'
ORDER BY te.exe_cours_id ASC, ce.title ASC, te.exe_date ASC";
$hpsql= "SELECT CONCAT(tu.lastname,' ',tu.firstname), tth.exe_name,
tth.exe_result , tth.exe_weighting, UNIX_TIMESTAMP(tth.exe_date)
FROM $TBL_TRACK_HOTPOTATOES tth, $TBL_USER tu
WHERE tu.user_id=tth.exe_user_id AND tth.exe_cours_id = '". $_cid. "'
ORDER BY tth.exe_cours_id ASC, tth.exe_date ASC";
{ // get only this user's results
$sql= "SELECT '',ce.title, te.exe_result , te.exe_weighting, UNIX_TIMESTAMP(te.exe_date),te.exe_id
FROM $TBL_EXERCICES AS ce , $TBL_TRACK_EXERCICES AS te
WHERE te.exe_exo_id = ce.id AND te.exe_user_id='". $_user['user_id']. "' AND te.exe_cours_id='$_cid' AND results_disabled=0
ORDER BY te.exe_cours_id ASC, ce.title ASC, te.exe_date ASC";
$hpsql= "SELECT '',exe_name, exe_result , exe_weighting, UNIX_TIMESTAMP(exe_date)
FROM $TBL_TRACK_HOTPOTATOES
WHERE exe_user_id = '". $_user['user_id']. "' AND exe_cours_id = '". $_cid. "'
ORDER BY exe_cours_id ASC, exe_date ASC";
//Print the results of tests
for($i = 0; $i < sizeof($results); $i++ )
$mailid = $results[$i][6];
$dt = strftime($dateTimeFormatLong,$results[$i][4]);
if($i% 2== 0) echo 'class="row_odd"'; else echo 'class="row_even"';
if($is_allowedToEdit || $is_tutor)
echo '<td>'. $user. '</td>';
echo '<td>'. $test. '</td>';
echo '<td>'. round(($res/ ($results[$i][3]!= 0? $results[$i][3]: 1))* 100). '% ('. $res. ' / '. $results[$i][3]. ')</td>';
echo '<td>'. (($is_allowedToEdit|| $is_tutor)? "<a href='exercise_show.php?user=$user&dt=$dt&res=$res&id=$id&email=$mailid'>". get_lang("Edit"). "</a>": "<a href='exercise_show.php?dt=$dt&res=$res&id=$id'>". get_lang('Show'). "</a>"). '</td>';
// Print the Result of Hotpotatoes Tests
for($i = 0; $i < sizeof($hpresults); $i++ )
echo '<td class="content">'. $hpresults[$i][0]. '</td>';
echo '<td class="content">'. $title. '</td>';
echo '<td class="content">'. strftime($dateTimeFormatLong,$hpresults[$i][4]). '</td>';
echo '<td class="content">'. round(($hpresults[$i][2]/ ($hpresults[$i][3]!= 0? $hpresults[$i][3]: 1))* 100). '% ('. $hpresults[$i][2]. ' / '. $hpresults[$i][3]. ')</td>';
echo '<td></td>'; //there is no possibility to edit the results of a Hotpotatoes test
if ($NoTestRes== 1 && $NoHPTestRes== 1)
<td colspan="5"> <?php echo get_lang("NoResult"); ?></td>
}// end if($show == 'result')
}// end if tracking is enabled
if ($origin != 'learnpath') { //so we are not in learnpath tool
<link rel="stylesheet" type="text/css" href=" <?php echo $clarolineRepositoryWeb ?>css/default.css" />
|