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/public/main/admin/skills_profile.php

140 lines
4.1 KiB

<?php
/* For licensing terms, see /license.txt */
use ChamiloSession as Session;
$cidReset = true;
require_once __DIR__.'/../inc/global.inc.php';
$this_section = SECTION_PLATFORM_ADMIN;
api_protect_admin_script();
Skill::isAllowed();
$interbreadcrumb[] = [
'url' => 'index.php',
"name" => get_lang('Administration'),
];
$skill = new Skill();
$skill_profile = new SkillProfile();
$skill_rel_user = new SkillRelUser();
$url = api_get_path(WEB_AJAX_PATH).'skill.ajax.php';
$tpl = new Template(get_lang('Skills'));
$form = new FormValidator('profile_search');
$form->addElement('header', get_lang('Search skills'));
$form->addElement('select', 'skills', null, null, ['id' => 'skills']);
$form->addButtonSearch(get_lang('Search'));
$profiles = $skill_profile->get_all();
$tpl->assign('profiles', $profiles);
$total_skills_to_search = [];
if ($form->validate()) {
$values = $form->getSubmitValues();
$skills = $values['skills'];
if (!empty($skills)) {
$hidden_skills = isset($values['hidden_skills']) ? $values['hidden_skills'] : [];
$skills = array_merge($skills, $hidden_skills);
$skills = array_filter($skills);
$skills = array_unique($skills);
Session::write('skills', $skills);
} else {
$skills = Session::read('skills', []);
}
} else {
$skills = Session::read('skills', []);
}
$user_list = [];
$count_skills = count($skills);
$users = $skill_rel_user->getUserBySkills($skills);
if (!empty($users)) {
foreach ($users as $user) {
$user_info = api_get_user_info($user['user_id']);
$user_list[$user['user_id']]['user'] = $user_info;
$my_user_skills = $skill_rel_user->getUserSkills($user['user_id']);
$user_skills = [];
$found_counts = 0;
foreach ($my_user_skills as $my_skill) {
$found = false;
if (in_array($my_skill['skill_id'], $skills)) {
$found = true;
$found_counts++;
}
$user_skills[] = [
'skill_id' => $my_skill['skill_id'],
'found' => $found,
];
$total_skills_to_search[$my_skill['skill_id']] = $my_skill['skill_id'];
}
$user_list[$user['user_id']]['skills'] = $user_skills;
$user_list[$user['user_id']]['total_found_skills'] = $found_counts;
}
$ordered_user_list = [];
foreach ($user_list as $user_id => $user_data) {
$ordered_user_list[$user_data['total_found_skills']][] = $user_data;
}
if (!empty($ordered_user_list)) {
asort($ordered_user_list);
}
}
$tpl->assign('order_user_list', $ordered_user_list);
$tpl->assign('total_search_skills', $count_skills);
if (!empty($skills)) {
$counter = 0;
foreach ($skills as $hidden_skill_id) {
$form->addElement('hidden', 'hidden_skills[]', $hidden_skill_id);
$counter++;
}
}
if (!empty($skills)) {
foreach ($skills as $my_skill) {
$total_skills_to_search[$my_skill] = $my_skill;
}
}
$total_skills_to_search = $skill->getSkillsInfo($total_skills_to_search);
$action = isset($_REQUEST['a']) ? $_REQUEST['a'] : null;
$id = isset($_REQUEST['id']) ? intval($_REQUEST['id']) : null;
switch ($action) {
case 'remove_skill':
$new_skill = [];
foreach ($skills as $skill_id) {
if ($id != $skill_id) {
$new_skill[] = $skill_id;
}
}
$skills = $new_skill;
Session::write('skills', $skills);
break;
case 'load_profile':
$skill_profile = new SkillRelProfile();
$skills = $skill_profile->getSkillsByProfile($id);
$total_skills_to_search = $skill->getSkillsInfo($skills);
break;
}
$skill_list = [];
foreach ($total_skills_to_search as $skill_info) {
$skill_list[$skill_info['id']] = $skill_info;
}
$tpl->assign('skill_list', $skill_list);
$tpl->assign('search_skill_list', $skills);
$form_to_html = $form->returnForm();
$tpl->assign('form', $form_to_html);
$tpl->assign('url', $url);
$templateName = $tpl->get_template('skill/profile.tpl');
$content = $tpl->fetch($templateName);
$tpl->assign('content', $content);
$tpl->display_one_col_template();