'index.php', 'name' => get_lang('Administration')]; $interbreadcrumb[] = ["url" => 'user_list.php', 'name' => get_lang('User list')]; $userId = $user['user_id']; $currentUrl = api_get_self().'?user_id='.$userId; $tool_name = UserManager::formatUserFullName($userEntity); $table_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER); $table_course = Database::get_main_table(TABLE_MAIN_COURSE); $csvContent = []; // only allow platform admins to login_as, or session admins only for students (not teachers nor other admins) $actions = [ Display::url( Display::return_icon( 'statistics.png', get_lang('Reporting'), [], ICON_SIZE_MEDIUM ), api_get_path(WEB_CODE_PATH).'mySpace/myStudents.php?'.http_build_query([ 'student' => $userId, ]), ['title' => get_lang('Reporting')] ), ]; if (api_can_login_as($userId)) { $actions[] = Display::url( Display::return_icon( 'login_as.png', get_lang('Login as'), [], ICON_SIZE_MEDIUM ), api_get_path(WEB_CODE_PATH).'admin/user_list.php?action=login_as&user_id='.$userId.'&sec_token='.Security::getTokenFromSession() ); } if (api_is_platform_admin()) { $actions[] = Display::url( Display::return_icon( 'edit.png', get_lang('Edit'), [], ICON_SIZE_MEDIUM ), api_get_path(WEB_CODE_PATH).'admin/user_edit.php?user_id='.$userId ); $actions[] = Display::url( Display::return_icon( 'export_csv.png', get_lang('CSV export'), [], ICON_SIZE_MEDIUM ), api_get_self().'?user_id='.$userId.'&action=export' ); $actions[] = Display::url( Display::return_icon( 'vcard.png', get_lang('user information'), [], ICON_SIZE_MEDIUM ), api_get_path(WEB_PATH).'main/social/vcard_export.php?userId='.$userId ); $actions[] = Display::url( Display::return_icon('new_group.png', get_lang('Add Human Resources Manager to user'), [], ICON_SIZE_MEDIUM), api_get_path(WEB_CODE_PATH).'admin/add_drh_to_user.php?u='.$userId ); if (Skill::isAllowed($userId, false)) { $actions[] = Display::url( Display::return_icon( 'skill-badges.png', get_lang('Add skill'), [], ICON_SIZE_MEDIUM, false ), api_get_path(WEB_CODE_PATH).'badge/assign.php?user='.$userId ); } } $userInfo = null; $studentBossList = UserManager::getStudentBossList($userId); $studentBossListToString = ''; if (!empty($studentBossList)) { $table = new HTML_Table(['class' => 'data_table']); $table->setHeaderContents(0, 0, get_lang('User')); $csvContent[] = [get_lang('Superior (n+1)')]; $row = 1; foreach ($studentBossList as $studentBossId) { $studentBoss = api_get_user_info($studentBossId['boss_id']); $table->setCellContents($row, 0, $studentBoss['complete_name_with_message_link']); $csvContent[] = [$studentBoss['complete_name_with_username']]; $row++; } $studentBossListToString = $table->toHtml(); } $registrationDate = $user['registration_date']; $table = new HTML_Table(['class' => 'data_table']); $table->setHeaderContents(0, 0, get_lang('Information')); $csvContent[] = [get_lang('Information')]; $data = [ get_lang('Name') => $user['complete_name'], get_lang('e-mail') => $user['email'], get_lang('Phone') => $user['phone'], get_lang('Course code') => $user['official_code'], get_lang('Online') => !empty($user['user_is_online']) ? Display::return_icon('online.png') : Display::return_icon('offline.png'), get_lang('Status') => $user['status'] == 1 ? get_lang('Trainer') : get_lang('Learner'), ]; $userInfo = [ 'complete_name' => $user['complete_name'], 'email' => $user['email'], 'phone' => $user['phone'], 'official_code' => $user['official_code'], 'user_is_online' => !empty($user['user_is_online']) ? Display::return_icon('online.png') : Display::return_icon('offline.png'), 'status' => $user['status'] == 1 ? get_lang('Trainer') : get_lang('Learner'), 'avatar' => $user['avatar'], ]; // Show info about who created this user and when $creatorId = $user['creator_id']; $creatorInfo = api_get_user_info($creatorId); if (!empty($creatorId) && !empty($creatorInfo)) { $userInfo['created'] = sprintf( get_lang('Create by %s on %s'), 'user_information.php?user_id='.$creatorId, $creatorInfo['username'], api_get_utc_datetime($registrationDate) ); } $row = 1; foreach ($data as $label => $item) { if (!empty($label)) { $label = $label.': '; } $table->setCellContents($row, 0, $label.$item); $csvContent[] = [$label, strip_tags($item)]; $row++; } //$userInformation = $table->toHtml(); $table = new HTML_Table(['class' => 'data_table']); $table->setHeaderContents(0, 0, get_lang('Reporting')); $csvContent[] = [get_lang('Reporting')]; $userInfo['first_connection'] = Tracking::get_first_connection_date($userId); $userInfo['last_connection'] = Tracking::get_last_connection_date($userId, true); $data = [ get_lang('First connection') => $userInfo['first_connection'], get_lang('Latest login') => $userInfo['last_connection'], ]; if (api_get_setting('allow_terms_conditions') === 'true') { $extraFieldValue = new ExtraFieldValue('user'); $value = $extraFieldValue->get_values_by_handler_and_field_variable( $userId, 'legal_accept' ); $icon = Display::return_icon('accept_na.png'); if (!empty($value['value'])) { list($legalId, $legalLanguageId, $legalTime) = explode(':', $value['value']); $icon = Display::return_icon('accept.png'); $timeLegalAccept = api_get_local_time($legalTime); $btn = Display::url( get_lang('Delete legal agreement'), api_get_self().'?action=delete_legal&user_id='.$userId, ['class' => 'btn btn-danger btn-xs'] ); } else { $btn = Display::url( get_lang('Send legal agreement'), api_get_self().'?action=send_legal&user_id='.$userId, ['class' => 'btn btn-primary btn-xs'] ); $timeLegalAccept = get_lang('Not Registered'); } $data[get_lang('Legal accepted')] = $icon; $userInfo['legal'] = [ 'icon' => $icon, 'datetime' => $timeLegalAccept, 'url_send' => $btn, ]; } $row = 1; foreach ($data as $label => $item) { if (!empty($label)) { $label = $label.': '; } $table->setCellContents($row, 0, $label.$item); $csvContent[] = [$label, strip_tags($item)]; $row++; } /** * Show social activity. */ if (api_get_setting('allow_social_tool') === 'true') { $userObject = api_get_user_entity($userId); $data = []; // Calculate values if (api_get_setting('allow_message_tool') === 'true') { $messagesSent = SocialManager::getCountMessagesSent($userId); $data[] = [get_lang('Number of messages sent'), $messagesSent]; $messagesReceived = SocialManager::getCountMessagesReceived($userId); $data[] = [get_lang('Number of messages received'), $messagesReceived]; } $wallMessagesPosted = SocialManager::getCountWallPostedMessages($userId); $data[] = [get_lang('Wall messages posted by him/herself'), $wallMessagesPosted]; $friends = SocialManager::getCountFriends($userId); $data[] = [get_lang('Friends'), $friends]; $countSent = SocialManager::getCountInvitationSent($userId); $data[] = [get_lang('Invitation sent'), $countSent]; $countReceived = SocialManager::get_message_number_invitation_by_user_id($userId); $data[] = [get_lang('Invitation received'), $countReceived]; $userInfo['social'] = [ 'friends' => $friends, 'invitation_sent' => $countSent, 'invitation_received' => $countReceived, 'messages_posted' => $wallMessagesPosted, 'message_sent' => $messagesSent, 'message_received' => $messagesReceived, ]; } /** * Show the sessions in which this user is subscribed. */ $sessions = SessionManager::get_sessions_by_user($userId, true); $personal_course_list = []; $courseToolInformationTotal = null; $sessionInformation = ''; if (count($sessions) > 0) { $header = [ [get_lang('Course code'), true], [get_lang('Title'), true], [get_lang('Status'), true], [get_lang('Time spent in the course'), true], [get_lang('Total posts in all forums.'), true], ['', false], ]; $headerList = []; foreach ($header as $item) { $headerList[] = $item[0]; } $csvContent[] = []; $csvContent[] = [get_lang('Course sessions')]; foreach ($sessions as $session_item) { $data = []; $personal_course_list = []; $id_session = $session_item['session_id']; $csvContent[] = [$session_item['session_name']]; $csvContent[] = $headerList; foreach ($session_item['courses'] as $my_course) { $courseInfo = api_get_course_info_by_id($my_course['real_id']); $sessionStatus = SessionManager::get_user_status_in_course_session( $userId, $courseInfo['real_id'], $id_session ); $status = null; switch ($sessionStatus) { case 0: case STUDENT: $status = get_lang('Learner'); break; case 2: $status = get_lang('Course coach'); break; } $tools = Display::url( Display::return_icon('statistics.png', get_lang('Statistics')), api_get_path(WEB_CODE_PATH).'mySpace/myStudents.php?details=true&student='.$userId.'&id_session='.$id_session.'&course='.$courseInfo['code'] ); $tools .= ' '. Display::return_icon('info2.png', get_lang('Overview')).''. ''. Display::return_icon('course_home.png', get_lang('Course home')).''; if (!empty($my_course['status']) && $my_course['status'] == STUDENT) { $tools .= ''. Display::return_icon('delete.png', get_lang('Delete')).''; } $timeSpent = api_time_to_hms( Tracking::get_time_spent_on_the_course( $userId, $courseInfo['real_id'], $id_session ) ); $totalForumMessages = CourseManager::getCountPostInForumPerUser( $userId, $courseInfo['real_id'], $id_session ); $row = [ Display::url( $courseInfo['code'], $courseInfo['course_public_url'].'?id_session='.$id_session ), $courseInfo['title'], $status, $timeSpent, $totalForumMessages, $tools, ]; $csvContent[] = array_map('strip_tags', $row); $data[] = $row; $result = Tracking::getToolInformation( $userId, $courseInfo, $id_session ); if (!empty($result['html'])) { $courseToolInformationTotal .= $result['html']; $csvContent = array_merge($csvContent, $result['array']); } } $dates = array_filter( [$session_item['access_start_date'], $session_item['access_end_date']] ); $sessionInformation .= Display::page_subheader( ''. $session_item['session_name'].'', ' '.implode(' - ', $dates) ); $sessionInformation .= Display::return_sortable_table( $header, $data, [], [], ['user_id' => $userId] ); $sessionInformation .= $courseToolInformationTotal; } } else { $sessionInformation = '

'.get_lang('NoCourse sessionsForThisUser').'

'; } $courseToolInformationTotal = ''; /** * Show the courses in which this user is subscribed. */ $sql = 'SELECT * FROM '.$table_course_user.' cu, '.$table_course.' c WHERE cu.user_id = '.$userId.' AND cu.c_id = c.id AND cu.relation_type <> '.COURSE_RELATION_TYPE_RRHH.' '; $res = Database::query($sql); if (Database::num_rows($res) > 0) { $header = [ [get_lang('Course code')], [get_lang('Title')], [get_lang('Status')], [get_lang('Time spent in the course')], [get_lang('Total posts in all forums.')], [''], ]; $headerList = []; foreach ($header as $item) { $headerList[] = $item[0]; } $csvContent[] = []; $csvContent[] = [get_lang('Courses')]; $csvContent[] = $headerList; $data = []; $courseToolInformationTotal = null; while ($course = Database::fetch_object($res)) { $courseInfo = api_get_course_info_by_id($course->c_id); $courseCode = $courseInfo['code']; $courseToolInformation = null; $tools = Display::url( Display::return_icon('statistics.png', get_lang('Statistics')), api_get_path(WEB_CODE_PATH).'mySpace/myStudents.php?details=true&student='.$userId.'&id_session=0&course='.$courseCode ); $tools .= ' '. Display::return_icon('info2.png', get_lang('Overview')).''. ''. Display::return_icon('course_home.png', get_lang('Course home')).''. ''. Display::return_icon('edit.png', get_lang('Edit')).''; if ($course->status == STUDENT) { $tools .= ''. Display::return_icon('delete.png', get_lang('Delete')).''; } $timeSpent = api_time_to_hms( Tracking::get_time_spent_on_the_course( $userId, $courseInfo['real_id'] ) ); $totalForumMessages = CourseManager::getCountPostInForumPerUser( $userId, $course->id, 0 ); $row = [ Display::url($courseCode, $courseInfo['course_public_url']), $course->title, $course->status == STUDENT ? get_lang('Learner') : get_lang('Trainer'), $timeSpent, $totalForumMessages, $tools, ]; $csvContent[] = array_map('strip_tags', $row); $data[] = $row; $result = Tracking::getToolInformation( $userId, $courseInfo, 0 ); $courseToolInformationTotal .= $result['html']; $csvContent = array_merge($csvContent, $result['array']); } $courseInformation = Display::return_sortable_table( $header, $data, [], [], ['user_id' => $userId] ); $courseInformation .= $courseToolInformationTotal; } else { $courseInformation = '

'.get_lang('This user isn\'t subscribed in a course').'

'; } /** * Show the URL in which this user is subscribed. */ $urlInformation = ''; if (api_is_multiple_url_enabled()) { $urlList = UrlManager::get_access_url_from_user($userId); if (count($urlList) > 0) { $header = []; $header[] = ['URL', true]; $data = []; $csvContent[] = []; $csvContent[] = ['Url']; foreach ($urlList as $url) { $row = []; $row[] = Display::url($url['url'], $url['url']); $csvContent[] = array_map('strip_tags', $row); $data[] = $row; } $urlInformation = Display::page_subheader(get_lang('URL list')); $urlInformation .= Display::return_sortable_table( $header, $data, [], [], ['user_id' => $userId] ); } else { $urlInformation = '

'.get_lang('This user doesn\'t have a related URL.').'

'; } } if (isset($_GET['action'])) { switch ($_GET['action']) { case 'send_legal': $subject = get_lang('Send legal agreementSubject'); $content = sprintf( get_lang('Send legal agreementDescriptionToUrlX'), api_get_path(WEB_PATH) ); MessageManager::send_message_simple($userId, $subject, $content); Display::addFlash(Display::return_message(get_lang('Sent'))); break; case 'delete_legal': $extraFieldValue = new ExtraFieldValue('user'); $value = $extraFieldValue->get_values_by_handler_and_field_variable( $userId, 'legal_accept' ); $result = $extraFieldValue->delete($value['id']); if ($result) { Display::addFlash(Display::return_message(get_lang('Deleted'))); } break; case 'unsubscribe': $courseId = !empty($_GET['course_id']) ? (int) $_GET['course_id'] : 0; $sessionId = !empty($_GET['id_session']) ? (int) $_GET['id_session'] : 0; $courseInfo = api_get_course_info_by_id($courseId); if (empty($courseInfo)) { break; } if (CourseManager::getUserInCourseStatus($userId, $courseInfo['real_id']) == STUDENT) { CourseManager::unsubscribe_user($userId, $courseInfo['code'], $sessionId); Display::addFlash(Display::return_message(get_lang('User is now unsubscribed'))); } else { Display::addFlash(Display::return_message( get_lang('User can not be unsubscribed because he is one of the teachers.'), 'error', false )); } header('Location: '.$currentUrl); exit; break; case 'unsubscribe_session_course': $courseId = !empty($_GET['course_id']) ? (int) $_GET['course_id'] : 0; $sessionId = !empty($_GET['id_session']) ? (int) $_GET['id_session'] : 0; SessionManager::removeUsersFromCourseSession( [$userId], $sessionId, api_get_course_info_by_id($courseId) ); Display::addFlash(Display::return_message(get_lang('User is now unsubscribed'))); header('Location: '.$currentUrl); exit; break; case 'export': Export::arrayToCsv( $csvContent, 'user_information_'.$userId ); exit; break; } } Display::display_header($tool_name); echo Display::toolbarAction('toolbar-user-information', [implode(PHP_EOL, $actions)]); $fullUrlBig = UserManager::getUserPicture( $userId, USER_IMAGE_SIZE_BIG ); $fullUrl = UserManager::getUserPicture( $userId, USER_IMAGE_SIZE_ORIGINAL ); if ($studentBossList) { echo Display::page_subheader(get_lang('Superior (n+1)List')); echo $studentBossListToString; } $em = Database::getManager(); $userRepository = UserManager::getRepository(); $hrmList = $userRepository->getAssignedHrmUserList( $userEntity->getId(), api_get_current_access_url_id() ); if ($hrmList) { echo Display::page_subheader(get_lang('Human Resource Managers list')); echo '
'; /** @var UserRelUser $hrm */ foreach ($hrmList as $hrm) { $hrmInfo = api_get_user_info($hrm->getFriendUserId()); $userPicture = isset($hrmInfo['avatar_medium']) ? $hrmInfo['avatar_medium'] : $hrmInfo['avatar']; echo '
'; echo '
'; echo '
'; echo Display::img($userPicture, $hrmInfo['complete_name'], ['class' => 'media-object'], false); echo '
'; echo '
'; echo '

'.$hrmInfo['complete_name_with_message_link'].'

'; echo $hrmInfo['username']; echo '
'; echo '
'; echo '
'; } echo '
'; } if ($user['status'] == DRH) { $usersAssigned = UserManager::get_users_followed_by_drh($userId); if ($usersAssigned) { echo Display::page_subheader(get_lang('List of users assigned to Human Resources manager')); echo '
'; foreach ($usersAssigned as $userAssigned) { $userAssigned = api_get_user_info($userAssigned['user_id']); $userPicture = isset($userAssigned['avatar_medium']) ? $userAssigned['avatar_medium'] : $userAssigned['avatar']; echo '
'; echo '
'; echo '
'; echo Display::img($userPicture, $userAssigned['complete_name'], ['class' => 'media-object'], false); echo '
'; echo '
'; echo '

'.$userAssigned['complete_name_with_message_link'].'

'; echo $userAssigned['official_code']; echo '
'; echo '
'; echo '
'; } echo '
'; } } $socialTool = api_get_setting('allow_social_tool'); $tpl->assign('social_tool', $socialTool); $tpl->assign('user', $userInfo); $layoutTemplate = $tpl->get_template('admin/user_information.tpl'); $content = $tpl->fetch($layoutTemplate); echo $content; echo Display::page_subheader(get_lang('Session list'), null, 'h3', ['class' => 'section-title']); echo $sessionInformation; echo Display::page_subheader(get_lang('Course list'), null, 'h3', ['class' => 'section-title']); echo $courseInformation; echo $urlInformation; echo Tracking::displayUserSkills( $userId, 0, 0 ); if (api_get_configuration_value('allow_career_users')) { $careers = UserManager::getUserCareers($userId); if (!empty($careers)) { echo Display::page_subheader(get_lang('Careers'), null, 'h3', ['class' => 'section-title']); $table = new HTML_Table(['class' => 'data_table']); $table->setHeaderContents(0, 0, get_lang('Career')); $row = 1; foreach ($careers as $carerData) { $table->setCellContents($row, 0, $carerData['name']); $row++; } echo $table->toHtml(); } } Display::display_footer();