You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
311 lines
11 KiB
311 lines
11 KiB
<?php
|
|
/*
|
|
==============================================================================
|
|
Dokeos - elearning and course management software
|
|
|
|
Copyright (c) 2004 Dokeos S.A.
|
|
Copyright (c) 2003 Ghent University (UGent)
|
|
Copyright (c) 2001 Universite catholique de Louvain (UCL)
|
|
|
|
For a full list of contributors, see "credits.txt".
|
|
The full license can be read in "license.txt".
|
|
|
|
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 the GNU General Public License for more details.
|
|
|
|
Contact address: Dokeos, 44 rue des palais, B-1030 Brussels, Belgium
|
|
Mail: info@dokeos.com
|
|
==============================================================================
|
|
*/
|
|
/**
|
|
==============================================================================
|
|
* @author Thomas Depraetere
|
|
* @author Hugues Peeters
|
|
* @author Christophe Gesche
|
|
* @author Sebastien Piraux
|
|
*
|
|
* @package dokeos.tracking
|
|
==============================================================================
|
|
*/
|
|
|
|
/*
|
|
==============================================================================
|
|
INIT SECTION
|
|
==============================================================================
|
|
*/
|
|
|
|
// name of the language file that needs to be included
|
|
$language_file = "tracking";
|
|
include('../inc/global.inc.php');
|
|
|
|
$interbreadcrumb[]= array ("url"=>"../auth/profile.php", "name"=> get_lang('ModifyProfile'));
|
|
$nameTools = get_lang('ToolName');
|
|
|
|
$htmlHeadXtra[] = "<style type=\"text/css\">
|
|
/*<![CDATA[*/
|
|
.secLine {background-color : #E6E6E6;}
|
|
.content {padding-left : 15px; padding-right : 15px;}
|
|
.specialLink{color : #0000FF;}
|
|
/*]]>*/
|
|
</style>
|
|
<style media='print' type='text/css'>
|
|
/*<![CDATA[*/
|
|
td {border-bottom: thin dashed gray;}
|
|
/*]]>*/
|
|
</style>";
|
|
|
|
/*
|
|
-----------------------------------------------------------
|
|
Constants and variables
|
|
-----------------------------------------------------------
|
|
*/
|
|
$view = $_REQUEST['view'];
|
|
|
|
$TABLECOURSUSER = Database::get_main_table(TABLE_MAIN_COURSE_USER);
|
|
$TABLETRACK_ACCESS = $_configuration['statistics_database']."`.`track_e_access";
|
|
$TABLETRACK_LINKS = $_configuration['statistics_database']."`.`track_e_links";
|
|
$TABLETRACK_DOWNLOADS = $_configuration['statistics_database']."`.`track_e_downloads";
|
|
$TABLETRACK_LOGIN = $_configuration['statistics_database']."`.`track_e_login";
|
|
$TABLETRACK_EXERCICES = $_configuration['statistics_database']."`.`track_e_exercices";
|
|
|
|
|
|
$limitOfDisplayedLogins = 25; // number of logins to display
|
|
include(api_get_path(LIBRARY_PATH)."statsUtils.lib.inc.php");
|
|
|
|
////////////// OUTPUT //////////////////////
|
|
Display::display_header($nameTools,"Tracking");
|
|
api_display_tool_title($nameTools);
|
|
|
|
/*
|
|
==============================================================================
|
|
MAIN SECTION
|
|
==============================================================================
|
|
*/
|
|
if ( $_configuration['tracking_enabled'] )
|
|
{
|
|
// show all : view must be equal to the sum of all view values (1024+512+...+64)
|
|
// show none : 0
|
|
|
|
echo "
|
|
<table width=\"100%\" cellpadding=\"2\" cellspacing=\"0\" border=\"0\">
|
|
<tr>
|
|
<td class='minilink'>
|
|
[<a href='".$_SERVER['PHP_SELF']."?view=1111111'>".get_lang('ShowAll')."</a>]
|
|
[<a href='".$_SERVER['PHP_SELF']."?view=0000000'>".get_lang('ShowNone')."</a>]
|
|
</td>
|
|
</tr>
|
|
";
|
|
if(!isset($view)) $view ="0000000";
|
|
|
|
/***************************************************************************
|
|
*
|
|
* Logins
|
|
*
|
|
***************************************************************************/
|
|
$tempView = $view;
|
|
if($tempView[0] == '1')
|
|
{
|
|
$tempView[0] = '0';
|
|
echo "
|
|
<tr>
|
|
<td valign='top'>
|
|
<font color='#0000FF'>- </font>
|
|
<b>".get_lang('Logins')."</b>
|
|
|
|
[<a href='".$_SERVER['PHP_SELF']."?view=".$tempView."'>".get_lang('Close')."</a>]
|
|
</td>
|
|
</tr>";
|
|
$sql = "SELECT `login_date`
|
|
FROM `".$TABLETRACK_LOGIN."`
|
|
WHERE `login_user_id` = '".$_user['user_id']."'
|
|
ORDER BY `login_date` DESC
|
|
LIMIT ".$limitOfDisplayedLogins."";
|
|
echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('LoginsExplaination')."<br/>";
|
|
$results = getManyResults1Col($sql);
|
|
echo "
|
|
<table width='100%' cellpadding='2' cellspacing='1' border='0' align='center'>";
|
|
if (is_array($results))
|
|
{
|
|
|
|
while ( list($key,$value) = each($results))
|
|
{
|
|
$timestamp = strtotime($value);
|
|
//$beautifulDate = $langDay_of_weekNames['long'][date("w" , $timestamp)].date(" d " , $timestamp).$langMonthNames['long'][date("n", $timestamp)-1].date(" Y" , $timestamp);
|
|
//$beautifulHour = date("H : i" , $timestamp);
|
|
$beautifulDate = format_locale_date($dateTimeFormatLong,$timestamp);
|
|
echo "
|
|
<tr>
|
|
<td class='secLine'>
|
|
".$beautifulDate."
|
|
</td>
|
|
</tr>";
|
|
|
|
if(!isset($previousDate))
|
|
{
|
|
$sql = "SELECT NOW()";
|
|
$previousDate = getOneResult($sql);
|
|
}
|
|
|
|
|
|
|
|
$sql = "SELECT `access_tool`, count(access_tool), `access_cours_code`
|
|
FROM `".$TABLETRACK_ACCESS."`
|
|
WHERE `access_user_id` = '".$_user['user_id']."'".
|
|
//AND access_tool IS NOT NULL
|
|
"AND access_date > '".$value."'
|
|
AND access_date < '".$previousDate."'
|
|
GROUP BY access_tool, access_cours_code
|
|
ORDER BY access_cours_code ASC";
|
|
|
|
$results2 = getManyResults3Col($sql);
|
|
|
|
if (is_array($results2))
|
|
{
|
|
echo "
|
|
<tr>
|
|
<td colspan='2'>
|
|
<table width='50%' cellpadding='0' cellspacing='0' border='0' >";
|
|
|
|
$previousCourse = "???";
|
|
for($j = 0 ; $j < count($results2) ; $j++)
|
|
{
|
|
// if course is different, write the name of the course
|
|
if($results2[$j][2] != $previousCourse)
|
|
{
|
|
echo "
|
|
<tr>
|
|
<td colspan='2' width='100%' style='padding-left : 40px;'>
|
|
".$results2[$j][2]."
|
|
</td>
|
|
</tr>";
|
|
}
|
|
// if count != de 0 then display toolname et number of visits, else its a course visit
|
|
if( $results2[$j][1] != 0 )
|
|
{
|
|
echo "<tr>";
|
|
echo "<td width='70%' style='padding-left : 60px;'>".get_lang($results2[$j][0])."</td>";
|
|
echo "<td width='30%' align='right'>".$results2[$j][1]." ".get_lang('Visits')."</td>";
|
|
echo "</tr>";
|
|
}
|
|
$previousCourse = $results2[$j][2];
|
|
}
|
|
echo "</table>";
|
|
echo "</td></tr>";
|
|
}
|
|
$previousDate = $value;
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
echo "<tr>";
|
|
echo "<td colspan='2' bgcolor='#eeeeee' align='center' >".get_lang('NoResult')."</td>";
|
|
echo"</tr>";
|
|
}
|
|
echo "</table>";
|
|
echo "</td></tr>";
|
|
}
|
|
else
|
|
{
|
|
$tempView[0] = '1';
|
|
echo "
|
|
<tr>
|
|
<td valign='top'>
|
|
+<font color='#0000FF'> </font><a href='".$_SERVER['PHP_SELF']."?view=".$tempView."' class='specialLink'>".get_lang('Logins')."</a>
|
|
</td>
|
|
</tr>
|
|
";
|
|
}
|
|
|
|
|
|
/***************************************************************************
|
|
*
|
|
* Exercices
|
|
*
|
|
***************************************************************************/
|
|
/*
|
|
$tempView = $view;
|
|
if($view[1] == '1')
|
|
{
|
|
$tempView[1] = '0';
|
|
echo "
|
|
<tr>
|
|
<td valign='top'>
|
|
<font color='#0000FF'>- </font><b>".get_lang('ExercicesResults')."</b> [<a href='".$_SERVER['PHP_SELF']."?view=".$tempView."'>".get_lang('Close')."</a>]
|
|
</td>
|
|
</tr>
|
|
";
|
|
echo " Ceci est amen etre dplac vers la page de garde des exercices ";
|
|
$sql = "SELECT `ce`.`title`, `te`.`exe_result` , `te`.`exe_weighting`, `te`.`exe_date`
|
|
FROM `$TABLECOURSE_EXERCICES` AS ce , `$TABLETRACK_EXERCICES` AS te
|
|
WHERE `te`.`exe_user_id` = '".$_user['user_id']."'
|
|
AND `te`.`exe_exo_id` = `ce`.`id`
|
|
ORDER BY `te`.`exe_cours_id` ASC, `ce`.`title` ASC, `te`.`exe_date`ASC";
|
|
|
|
echo "<tr><td style='padding-left : 40px;padding-right : 40px;'>";
|
|
$results = getManyResultsXCol($sql,4);
|
|
echo "<table cellpadding='2' cellspacing='1' border='0' align='center'>";
|
|
echo "<tr>
|
|
<td class='secLine' width='60%'>
|
|
".get_lang('ExercicesTitleExerciceColumn')."
|
|
</td>
|
|
<td class='secLine' width='20%'>
|
|
".get_lang('Date')."
|
|
</td>
|
|
<td class='secLine' width='20%'>
|
|
".get_lang('ExercicesTitleScoreColumn')."
|
|
</td>
|
|
</tr>";
|
|
if (is_array($results))
|
|
{
|
|
for($i = 0; $i < sizeof($results); $i++)
|
|
{
|
|
if( $results[$i][1] < ($results[$i][2]/2) )
|
|
$scoreColor = "red";
|
|
elseif( $results[$i][1] > ($results[$i][2]/100*60) )
|
|
$scoreColor = "green";
|
|
else
|
|
$scoreColor = "#FF8C00";
|
|
echo "<tr>";
|
|
echo "<td class='content'>".$results[$i][0]."</td>";
|
|
echo "<td class='content'>".$results[$i][3]."</td>";
|
|
echo "<td valign='top' align='right' class='content'><font color=$scoreColor>".$results[$i][1]." / ".$results[$i][2]."</font></td>";
|
|
echo"</tr>";
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
echo "<tr>";
|
|
echo "<td colspan='2' align='center'>".get_lang('NoResult')."</td>";
|
|
echo"</tr>";
|
|
}
|
|
echo "</table>";
|
|
echo "</td></tr>";
|
|
|
|
}
|
|
else
|
|
{
|
|
$tempView[1] = '1';
|
|
echo "
|
|
<tr>
|
|
<td valign='top'>
|
|
<font color='#0000FF'>+ </font><a href='".$_SERVER['PHP_SELF']."?view=".$tempView."' class='specialLink'>".get_lang('ExercicesResults')."</a>
|
|
</td>
|
|
</tr>
|
|
";
|
|
}
|
|
*/
|
|
echo "\n</table>";
|
|
}
|
|
else
|
|
{
|
|
echo get_lang('TrackingDisabled');
|
|
}
|
|
|
|
Display::display_footer();
|
|
?>
|