Chamilo is a learning management system focused on ease of use and accessibility
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.
 
 
 
 
 
 
chamilo-lms/main/mySpace/session.php

191 lines
5.1 KiB

<?php
/*
==============================================================================
Dokeos - elearning and course management software
Copyright (c) 2008 Dokeos SPRL
Copyright (c) various contributors
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, rue du Corbeau, 108, B-1030 Brussels, Belgium
Mail: info@dokeos.com
==============================================================================
*/
/*
* Created on 28 juil. 2006 by Elixir Interactive http://www.elixir-interactive.com
* Somes fixes by Julio Montoya
*/
ob_start();
$nameTools= 'Sessions';
// name of the language file that needs to be included
$language_file = array ('registration', 'index','trad4all','tracking');
$cidReset=true;
require ('../inc/global.inc.php');
require_once (api_get_path(LIBRARY_PATH).'tracking.lib.php');
require_once (api_get_path(LIBRARY_PATH).'export.lib.inc.php');
api_block_anonymous_users();
$this_section = "session_my_space";
api_block_anonymous_users();
$interbreadcrumb[] = array ("url" => "index.php", "name" => get_lang('MySpace'));
Display :: display_header($nameTools);
// Database Table Definitions
$tbl_course_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
$tbl_sessions = Database :: get_main_table(TABLE_MAIN_SESSION);
$tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE);
$tbl_course = Database :: get_main_table(TABLE_MAIN_COURSE);
$export_csv = false;
if (isset($_GET['export']) && $_GET['export'] == 'csv')
{
$export_csv=true;
}
/*
===============================================================================
FUNCTION
===============================================================================
*/
function count_sessions_coached()
{
global $nb_sessions;
return $nb_sessions;
}
function sort_sessions($a, $b)
{
global $tracking_column;
if($a[$tracking_column] > $b[$tracking_column])
return 1;
else
return -1;
}
/*
===============================================================================
MAIN CODE
===============================================================================
*/
if(isset($_GET['id_coach']) && $_GET['id_coach']!='')
{
$id_coach=$_GET['id_coach'];
}
else
{
$id_coach=$_user['user_id'];
}
$a_sessions = Tracking :: get_sessions_coached_by_user($id_coach);
$nb_sessions = count($a_sessions);
if($export_csv)
{
$csv_content=array();
}
if($nb_sessions > 0)
{
echo '<div align="right">
<a href="#" onclick="window.print()"><img align="absbottom" src="../img/printmgr.gif">&nbsp;'.get_lang('Print').'</a>
<a href="'.api_get_self().'?export=csv"><img align="absbottom" src="../img/excel.gif">&nbsp;'.get_lang('ExportAsCSV').'</a>
</div>';
$table = new SortableTable('tracking', 'count_sessions_coached');
$table -> set_header(0, get_lang('Title'));
$table -> set_header(1, get_lang('Status'));
$table -> set_header(2, get_lang('Date'));
$table -> set_header(3, get_lang('Details'),false);
$all_datas = array();
foreach ($a_sessions as $session)
{
$row = array();
$row[] = $session['name'];
$row[] = $session['status'];
if($session['date_start']!='0000-00-00' && $session['date_end']!='0000-00-00')
{
$row[] = get_lang('From').' '.format_locale_date(get_lang('DateFormatLongWithoutDay'),strtotime($session['date_start'])).' '.get_lang('To').' '.format_locale_date(get_lang('DateFormatLongWithoutDay'),strtotime($session['date_end']));
}
else
{
$row[] = ' - ';
}
if($export_csv)
{
$csv_content[]=$row;
}
if(isset($_GET['id_coach']) && $_GET['id_coach']!='')
{
$row[] = '<a href="student.php?id_session='.$session['id'].'&id_coach='.$_GET['id_coach'].'"><img src="'.api_get_path(WEB_IMG_PATH).'2rightarrow.gif" border="0" /></a>';
}
else
{
$row[] = '<a href="course.php?id_session='.$session['id'].'"><img src="'.api_get_path(WEB_IMG_PATH).'2rightarrow.gif" border="0" /></a>';
}
$all_datas[] = $row;
}
if(!isset($tracking_column))
{
$tracking_column = 0;
}
usort($all_datas, 'sort_sessions');
if($export_csv)
{
usort($csv_content, 'sort_sessions');
}
if($_GET['tracking_direction'] == 'DESC')
{
rsort($all_datas);
}
foreach($all_datas as $row)
{
$table -> addRow($row);
}
$table -> setColAttributes(3,array('align'=>'center'));
$table -> display();
if($export_csv)
{
ob_end_clean();
Export :: export_table_csv($csv_content, 'reporting_student_list');
}
}
else
{
get_lang('NoSession');
}
/*
==============================================================================
FOOTER
==============================================================================
*/
Display::display_footer();
?>