diff --git a/main/inc/ajax/model.ajax.php b/main/inc/ajax/model.ajax.php
index 580d685a71..c6aad9ff50 100755
--- a/main/inc/ajax/model.ajax.php
+++ b/main/inc/ajax/model.ajax.php
@@ -3,11 +3,8 @@
use ChamiloSession as Session;
-//@todo this could be integrated in the inc/lib/model.lib.php + try to clean this file
require_once __DIR__.'/../global.inc.php';
-$libpath = api_get_path(LIBRARY_PATH);
-
// 1. Setting variables needed by jqgrid
$action = $_GET['a'];
$page = (int) $_REQUEST['page']; //page
@@ -61,7 +58,8 @@ if (!in_array(
'get_user_course_report',
'get_sessions_tracking',
'get_sessions',
- 'get_course_announcements'
+ 'get_course_announcements',
+ 'course_log_events'
)
) && !isset($_REQUEST['from_course_session'])) {
api_protect_admin_script(true);
@@ -228,6 +226,18 @@ if (!$sidx) {
//@todo rework this
switch ($action) {
+ case 'course_log_events':
+ $courseId = api_get_course_int_id();
+ if (empty($courseId)) {
+ exit;
+ }
+ $sessionId = api_get_session_id();
+
+ if (!api_is_allowed_to_edit()) {
+ exit;
+ }
+ $count = Statistics::getNumberOfActivities($courseId, $sessionId);
+ break;
case 'get_programmed_announcements':
$object = new ScheduledAnnouncement();
$count = $object->get_count();
@@ -689,12 +699,10 @@ switch ($action) {
$count = $obj->get_count_by_field_id($field_id);
break;
case 'get_timelines':
- require_once $libpath.'timeline.lib.php';
$obj = new Timeline();
$count = $obj->get_count();
break;
case 'get_gradebooks':
- require_once $libpath.'gradebook.lib.php';
$obj = new Gradebook();
$count = $obj->get_count();
break;
@@ -764,6 +772,19 @@ $is_allowedToEdit = api_is_allowed_to_edit(null, true) || api_is_allowed_to_edit
$columns = array();
switch ($action) {
+ case 'course_log_events':
+ $columns = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'];
+
+ $result = Statistics::getActivitiesData(
+ $start,
+ $limit,
+ $column,
+ $direction,
+ $courseId,
+ $sessionId
+ );
+
+ break;
case 'get_programmed_announcements':
$columns = array('subject', 'date', 'sent', 'actions');
$sessionId = isset($_REQUEST['session_id']) ? (int) $_REQUEST['session_id'] : 0;
@@ -2070,7 +2091,8 @@ $allowed_actions = array(
'get_exercise_grade',
'get_group_reporting',
'get_course_announcements',
- 'get_programmed_announcements'
+ 'get_programmed_announcements',
+ 'course_log_events'
);
//5. Creating an obj to return a json
diff --git a/main/inc/lib/statistics.lib.php b/main/inc/lib/statistics.lib.php
index 7d18a4ab9d..7533c2b42a 100644
--- a/main/inc/lib/statistics.lib.php
+++ b/main/inc/lib/statistics.lib.php
@@ -184,7 +184,7 @@ class Statistics
* Count activities from track_e_default_table
* @return int Number of activities counted
*/
- public static function getNumberOfActivities()
+ public static function getNumberOfActivities($courseId = 0, $session = 0)
{
// Database table definitions
$track_e_default = Database::get_main_table(TABLE_STATISTIC_TRACK_E_DEFAULT);
@@ -204,6 +204,12 @@ class Statistics
WHERE default_user_id = user.user_id ";
}
+ if (!empty($courseId)) {
+ $courseId = (int) $courseId;
+ $sql .= " AND c_id = $courseId";
+ $sql .= api_get_session_condition($sessionId);
+ }
+
if (isset($_GET['keyword'])) {
$keyword = Database::escape_string(trim($_GET['keyword']));
$sql .= " AND (
@@ -225,13 +231,18 @@ class Statistics
* @param int $numberOfItems
* @param int $column
* @param string $direction
+ * @param int $courseId
+ * @param int $sessionId
+ *
* @return array
*/
public static function getActivitiesData(
$from,
$numberOfItems,
$column,
- $direction
+ $direction,
+ $courseId = 0,
+ $sessionId = 0
) {
$track_e_default = Database::get_main_table(TABLE_STATISTIC_TRACK_E_DEFAULT);
$table_user = Database::get_main_table(TABLE_MAIN_USER);
@@ -284,6 +295,12 @@ class Statistics
default_value LIKE '%".$keyword."%') ";
}
+ if (!empty($courseId)) {
+ $courseId = (int) $courseId;
+ $sql .= " AND c_id = $courseId";
+ $sql .= api_get_session_condition($sessionId);
+ }
+
if (!empty($column) && !empty($direction)) {
$sql .= " ORDER BY col$column $direction";
} else {
@@ -317,9 +334,13 @@ class Statistics
}
if (!empty($row[5])) {
- //course
+
+ // Course
if (!empty($row[3])) {
- $row[3] = Display::url($row[3], api_get_path(WEB_CODE_PATH).'admin/course_edit.php?id='.$row[3]);
+ $row[3] = Display::url(
+ $row[3],
+ api_get_path(WEB_CODE_PATH).'admin/course_edit.php?id='.$row[3]
+ );
} else {
$row[3] = '-';
}
@@ -337,8 +358,8 @@ class Statistics
// User id.
$row[5] = Display::url(
$row[5],
- api_get_path(WEB_CODE_PATH).'admin/user_information.php?user_id='.$row[6],
- array('title' => get_lang('UserInfo'))
+ api_get_path(WEB_AJAX_PATH).'user_manager.ajax.php?a=get_user_popup&user_id='.$row[6],
+ array('class' => 'ajax')
);
$row[6] = Tracking::get_ip_from_user_event(
@@ -780,9 +801,9 @@ class Statistics
);
$renderer = & $form->defaultRenderer();
$renderer->setCustomElementTemplate('{element} ');
- $form->addElement('hidden', 'report', 'activities');
- $form->addElement('hidden', 'activities_direction', 'DESC');
- $form->addElement('hidden', 'activities_column', '4');
+ $form->addHidden('report', 'activities');
+ $form->addHidden('activities_direction', 'DESC');
+ $form->addHidden('activities_column', '4');
$form->addElement('text', 'keyword', get_lang('Keyword'));
$form->addButtonSearch(get_lang('Search'), 'submit');
echo '
';
diff --git a/main/tracking/course_log_events.php b/main/tracking/course_log_events.php
new file mode 100644
index 0000000000..ce2cfe18b6
--- /dev/null
+++ b/main/tracking/course_log_events.php
@@ -0,0 +1,171 @@
+ 'col0',
+ 'index' => 'col0',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false'
+ ),
+ array(
+ 'name' => 'col1',
+ 'index' => 'col1',
+ 'width' => '60',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ ),
+ array(
+ 'name' => 'col2',
+ 'index' => 'col2',
+ 'width' => '200',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ ),
+ array(
+ 'name' => 'col3',
+ 'index' => 'col3',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ 'hidden' => 'true'
+ ),
+ array(
+ 'name' => 'col4',
+ 'index' => 'col4',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ 'hidden' => 'true'
+ ),
+ array(
+ 'name' => 'col5',
+ 'index' => 'col5',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ ),
+ array(
+ 'name' => 'col6',
+ 'index' => 'col6',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ ),
+ array(
+ 'name' => 'col7',
+ 'index' => 'col7',
+ 'width' => '50',
+ 'align' => 'left',
+ 'sortable' => 'false',
+ )
+);
+
+// Autowidth
+$extra_params['autowidth'] = 'true';
+// height auto
+$extra_params['height'] = 'auto';
+
+$action_links = '
+function action_formatter(cellvalue, options, rowObject) {
+ return \'
'.Display::return_icon('2rightarrow.png', get_lang('Edit'), '', ICON_SIZE_SMALL).''.
+ '\';
+}';
+
+
+// Add the JS needed to use the jqgrid
+$htmlHeadXtra[] = api_get_jqgrid_js();
+$htmlHeadXtra[] = '
+';
+
+Display::display_header();
+
+echo '
';
+echo Display::url(
+ Display::return_icon('user.png', get_lang('StudentsTracking'), array(), ICON_SIZE_MEDIUM),
+ 'courseLog.php?'.api_get_cidreq(true, false)
+);
+echo Display::url(Display::return_icon('group.png', get_lang('GroupReporting'), array(), ICON_SIZE_MEDIUM), '#');
+echo Display::url(
+ Display::return_icon('course.png', get_lang('CourseTracking'), array(), ICON_SIZE_MEDIUM),
+ 'course_log_tools.php?'.api_get_cidreq(true, false)
+);
+echo Display::url(
+ Display::return_icon('tools.png', get_lang('ResourcesTracking'), array(), ICON_SIZE_MEDIUM),
+ 'course_log_resources.php?'.api_get_cidreq(true, false)
+);
+echo '
';
+
+$form = new FormValidator(
+ 'search_simple',
+ 'get',
+ api_get_self().'?'.api_get_cidreq(),
+ '',
+ '',
+ FormValidator::LAYOUT_INLINE
+);
+$form->addHidden('report', 'activities');
+$form->addHidden('activities_direction', 'DESC');
+$form->addElement('text', 'keyword', get_lang('Keyword'));
+$form->addButtonSearch(get_lang('Search'), 'submit');
+echo '
';
+$form->display();
+echo '
';
+
+echo Display::grid_html('course_log_events');
+
+Display::display_footer();
diff --git a/main/tracking/course_log_groups.php b/main/tracking/course_log_groups.php
index 4e73def293..decbef0c20 100644
--- a/main/tracking/course_log_groups.php
+++ b/main/tracking/course_log_groups.php
@@ -109,17 +109,35 @@ $htmlHeadXtra[] = api_get_jqgrid_js();
$htmlHeadXtra[] = '
';
Display::display_header();
echo '
';
-echo Display::url(Display::return_icon('user.png', get_lang('StudentsTracking'), array(), ICON_SIZE_MEDIUM), 'courseLog.php?'.api_get_cidreq(true, false));
+echo Display::url(
+ Display::return_icon('user.png', get_lang('StudentsTracking'), array(), ICON_SIZE_MEDIUM),
+ 'courseLog.php?'.api_get_cidreq(true, false)
+);
echo Display::url(Display::return_icon('group_na.png', get_lang('GroupReporting'), array(), ICON_SIZE_MEDIUM), '#');
-echo Display::url(Display::return_icon('course.png', get_lang('CourseTracking'), array(), ICON_SIZE_MEDIUM), 'course_log_tools.php?'.api_get_cidreq(true, false));
-echo Display::url(Display::return_icon('tools.png', get_lang('ResourcesTracking'), array(), ICON_SIZE_MEDIUM), 'course_log_resources.php?'.api_get_cidreq(true, false));
+echo Display::url(
+ Display::return_icon('course.png', get_lang('CourseTracking'), array(), ICON_SIZE_MEDIUM),
+ 'course_log_tools.php?'.api_get_cidreq(true, false)
+);
+echo Display::url(
+ Display::return_icon('tools.png', get_lang('ResourcesTracking'), array(), ICON_SIZE_MEDIUM),
+ 'course_log_resources.php?'.api_get_cidreq(true, false)
+);
echo '
';
echo Display::grid_html('group_users');
diff --git a/main/tracking/course_log_resources.php b/main/tracking/course_log_resources.php
index 21d6302c96..01a9d85238 100755
--- a/main/tracking/course_log_resources.php
+++ b/main/tracking/course_log_resources.php
@@ -2,14 +2,12 @@
/* For licensing terms, see /license.txt */
/**
- * @package chamilo.tracking
+ * @package chamilo.tracking
*/
-$pathopen = isset($_REQUEST['pathopen']) ? $_REQUEST['pathopen'] : null;
-// Including the global initialization file
require_once __DIR__.'/../inc/global.inc.php';
$current_course_tool = TOOL_TRACKING;
-$course_info = api_get_course_info();
+
$from_myspace = false;
$from = isset($_GET['from']) ? $_GET['from'] : null;
@@ -24,8 +22,7 @@ if ($from == 'myspace') {
$is_allowedToTrack = api_is_platform_admin() || api_is_allowed_to_create_course() || api_is_session_admin() || api_is_drh() || api_is_course_tutor();
if (!$is_allowedToTrack) {
- api_not_allowed();
- exit;
+ api_not_allowed(true);
}
// Starting the output buffering when we are exporting the information.
@@ -83,18 +80,24 @@ if (empty($session_id)) {
// Breadcrumbs.
if (isset($_GET['origin']) && $_GET['origin'] == 'resume_session') {
- $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'admin/index.php', 'name' => get_lang('PlatformAdmin'));
- $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'session/session_list.php', 'name' => get_lang('SessionList'));
- $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'session/resume_session.php?id_session='.api_get_session_id(), 'name' => get_lang('SessionOverview'));
+ $interbreadcrumb[] = array(
+ 'url' => api_get_path(WEB_CODE_PATH).'admin/index.php',
+ 'name' => get_lang('PlatformAdmin'),
+ );
+ $interbreadcrumb[] = array(
+ 'url' => api_get_path(WEB_CODE_PATH).'session/session_list.php',
+ 'name' => get_lang('SessionList'),
+ );
+ $interbreadcrumb[] = array(
+ 'url' => api_get_path(WEB_CODE_PATH).'session/resume_session.php?id_session='.api_get_session_id(),
+ 'name' => get_lang('SessionOverview'),
+ );
}
$nameTools = get_lang('Tracking');
-// Display the header.
Display::display_header($nameTools, 'Tracking');
-/* MAIN CODE */
-
echo '
';
@@ -164,7 +166,6 @@ $table = new SortableTable(
);
$parameters = array(
- //'keyword' => Security::remove_XSS($_GET['keyword']),
'id_session' => $session_id,
'cidReq' => api_get_course_id()
);