chamilo/chamilo-lms

View on GitHub
public/main/social/my_skills_report.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

/* For licensing terms, see /license.txt */

use Chamilo\CoreBundle\Entity\Skill;
use Chamilo\CoreBundle\Framework\Container;

/**
 * Show the skills report.
 *
 * @author Angel Fernando Quiroz Campos <angel.quiroz@beeznest.com>
 */
require_once __DIR__.'/../inc/global.inc.php';

$userId = api_get_user_id();
SkillModel::isAllowed($userId);

$isStudent = api_is_student();
$isStudentBoss = api_is_student_boss();
$isDRH = api_is_drh();

$em = Database::getManager();

if (!$isStudent && !$isStudentBoss && !$isDRH) {
    header('Location: '.api_get_path(WEB_CODE_PATH).'social/skills_wheel.php');
    exit;
}

$action = isset($_GET['a']) ? $_GET['a'] : '';
switch ($action) {
    case 'generate_custom_skill':
        $certificate = new Certificate(0, api_get_user_id(), false, false);
        $certificate->generatePdfFromCustomCertificate();
        break;
    case 'generate':
        $certificate = Certificate::generateUserSkills(api_get_user_id());
        Display::addFlash(Display::return_message(get_lang('Update successful')));
        header('Location: '.api_get_self());
        exit;
        break;
}

$skillTable = Database::get_main_table(TABLE_MAIN_SKILL);
$skillRelUserTable = Database::get_main_table(TABLE_MAIN_SKILL_REL_USER);
$courseTable = Database::get_main_table(TABLE_MAIN_COURSE);
$tableRows = [];
$objSkill = new SkillModel();
$tpl = new Template(get_lang('Skills'));
$tplPath = null;

$tpl->assign('allow_skill_tool', 'true' === api_get_setting('allow_skills_tool'));
$tpl->assign('allow_drh_skills_management', 'true' === api_get_setting('allow_hr_skills_management'));

if ($isStudent) {
    $result = $objSkill->getUserSkillsTable($userId);
    $tableRows = $result['skills'];
    $tpl->assign('skill_table', $result['table']);
    $tplPath = 'skill/student_report.html.twig';
} elseif ($isStudentBoss) {
    $tableRows = [];
    $followedStudents = UserManager::getUsersFollowedByStudentBoss($userId);

    $frmStudents = new FormValidator('students', 'get');
    $slcStudent = $frmStudents->addSelect(
        'student',
        get_lang('Learner'),
        ['0' => get_lang('Select')]
    );
    $frmStudents->addButtonSearch(get_lang('Search'));

    foreach ($followedStudents as &$student) {
        $student['completeName'] = api_get_person_name($student['firstname'], $student['lastname']);

        $slcStudent->addOption($student['completeName'], $student['user_id']);
    }

    if ($frmStudents->validate()) {
        $selectedStudent = (int) $frmStudents->exportValue('student');

        $sql = "SELECT s.id AS skill_id9i, sru.acquired_skill_at, c.title, c.directory, c.id as course_id
                FROM $skillTable s
                INNER JOIN $skillRelUserTable sru
                ON s.id = sru.skill_id
                LEFT JOIN $courseTable c
                ON sru.course_id = c.id
                WHERE sru.user_id = $selectedStudent
                ";

        $result = Database::query($sql);

        while ($resultData = Database::fetch_assoc($result)) {
            $skill = $em->find(Skill::class, $resultData['skill_id']);

            $tableRow = [
                'complete_name' => $followedStudents[$selectedStudent]['completeName'],
                'skill_name' => $skill->getTitle(),
                'achieved_at' => api_format_date($resultData['acquired_skill_at'], DATE_FORMAT_NUMBER),
                'course_image' => Display::return_icon(
                    'course.png',
                    null,
                    null,
                    ICON_SIZE_MEDIUM,
                    null,
                    true
                ),
                'course_name' => $resultData['title'],
            ];

            $courseEntity = api_get_course_entity($resultData['course_id']);
            $illustrationUrl = Container::getIllustrationRepository()->getIllustrationUrl($courseEntity);
            if ($illustrationUrl) {
                $tableRow['course_image'] = $illustrationUrl;
            }
            $tableRows[] = $tableRow;
        }
    }

    $tplPath = 'skill/student_boss_report.tpl';
    $tpl->assign('form', $frmStudents->returnForm());
} elseif ($isDRH) {
    $selectedCourse = isset($_REQUEST['course']) ? intval($_REQUEST['course']) : null;
    $selectedSkill = isset($_REQUEST['skill']) ? intval($_REQUEST['skill']) : 0;
    $action = null;
    if (!empty($selectedCourse)) {
        $action = 'filterByCourse';
    } elseif (!empty($selectedSkill)) {
        $action = 'filterBySkill';
    }

    $courses = CourseManager::getCoursesFollowedByUser($userId, DRH);

    $tableRows = [];
    $reportTitle = null;
    $skills = $objSkill->getAllSkills();

    switch ($action) {
        case 'filterByCourse':
            $course = api_get_course_info_by_id($selectedCourse);
            $reportTitle = sprintf(get_lang('Skills acquired in course %s'), $course['name']);
            $tableRows = $objSkill->listAchievedByCourse($selectedCourse);
            break;
        case 'filterBySkill':
            $skill = $objSkill->get($selectedSkill);
            $reportTitle = sprintf(get_lang('LearnersWhoAchievedTheSkillX'), $skill['name']);
            $students = UserManager::getUsersFollowedByUser(
                $userId,
                STUDENT,
                false,
                false,
                false,
                null,
                null,
                null,
                null,
                null,
                null,
                DRH
            );

            $coursesFilter = [];
            foreach ($courses as $course) {
                $coursesFilter[] = $course['id'];
            }

            $tableRows = $objSkill->listUsersWhoAchieved($selectedSkill, $coursesFilter);
            break;
    }

    foreach ($tableRows as &$row) {
        $row['complete_name'] = api_get_person_name($row['firstname'], $row['lastname']);
        $row['achieved_at'] = api_format_date($row['acquired_skill_at'], DATE_FORMAT_NUMBER);
        $row['course_image'] = Display::return_icon(
            'course.png',
            null,
            null,
            ICON_SIZE_MEDIUM,
            null,
            true
        );

        $courseEntity = api_get_course_entity($row['real_id']);
        $illustrationUrl = Container::getIllustrationRepository()->getIllustrationUrl($courseEntity);
        if ($illustrationUrl) {
            $row['course_image'] = $illustrationUrl;
        }
    }

    $tplPath = 'skill/drh_report.tpl';
    $tpl->assign('action', $action);
    $tpl->assign('courses', $courses);
    $tpl->assign('skills', $skills);
    $tpl->assign('selected_course', $selectedCourse);
    $tpl->assign('selected_skill', $selectedSkill);
    $tpl->assign('report_title', $reportTitle);
}

if (empty($tableRows)) {
    Display::addFlash(Display::return_message(get_lang('No results found')));
}
$tpl->assign('rows', $tableRows);
$templateName = $tpl->get_template($tplPath);
$contentTemplate = $tpl->fetch($templateName);
$tpl->assign('content', $contentTemplate);
$tpl->display_one_col_template();