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.
160 lines
4.9 KiB
160 lines
4.9 KiB
<?php
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
/**
|
|
* @package chamilo.admin
|
|
*/
|
|
|
|
// Language files that need to be included.
|
|
$language_file = array('admin');
|
|
|
|
$cidReset = true;
|
|
require_once '../inc/global.inc.php';
|
|
require_once api_get_path(LIBRARY_PATH).'skill.lib.php';
|
|
$this_section = SECTION_PLATFORM_ADMIN;
|
|
|
|
api_protect_admin_script();
|
|
|
|
if (api_get_setting('allow_skills_tool') != 'true') {
|
|
api_not_allowed();
|
|
}
|
|
|
|
$htmlHeadXtra[] = '<script src="'.api_get_path(WEB_LIBRARY_PATH).'javascript/tag/jquery.fcbkcomplete.js" type="text/javascript" language="javascript"></script>';
|
|
$htmlHeadXtra[] = '<link href="'.api_get_path(WEB_LIBRARY_PATH).'javascript/tag/style.css" rel="stylesheet" type="text/css" />';
|
|
|
|
$interbreadcrumb[] = array('url' => 'index.php',"name" => get_lang('PlatformAdmin'));
|
|
|
|
$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('SearchSkills'));
|
|
$form->addElement('select', 'skills', null, null, array('id'=>'skills'));
|
|
$form->addElement('style_submit_button', 'submit', get_lang('Search'), 'class="btn"');
|
|
|
|
$profiles = $skill_profile->get_all();
|
|
|
|
$tpl->assign('profiles', $profiles);
|
|
|
|
$total_skills_to_search = array();
|
|
|
|
if ($form->validate()) {
|
|
$values = $form->getSubmitValues();
|
|
|
|
$skills = $values['skills'];
|
|
if (!empty($skills)) {
|
|
|
|
$hidden_skills = isset($values['hidden_skills']) ? $values['hidden_skills'] : array();
|
|
$skills = array_merge($skills, $hidden_skills);
|
|
|
|
$skills = array_filter($skills);
|
|
$skills = array_unique($skills);
|
|
|
|
$_SESSION['skills'] = $skills;
|
|
|
|
} else {
|
|
$skills = isset($_SESSION['skills']) ? $_SESSION['skills']: array();
|
|
}
|
|
} else {
|
|
$skills = isset($_SESSION['skills']) ? $_SESSION['skills']: array();
|
|
}
|
|
|
|
$user_list = array();
|
|
$count_skills = count($skills);
|
|
|
|
$users = $skill_rel_user->get_user_by_skills($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->get_user_skills($user['user_id']);
|
|
$user_skills = array();
|
|
$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[] = array('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 = array();
|
|
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('user_list', $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->get_skills_info($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 = array();
|
|
foreach ($skills as $skill_id) {
|
|
if ($id != $skill_id) {
|
|
$new_skill[] = $skill_id;
|
|
}
|
|
}
|
|
$skills = $_SESSION['skills'] = $new_skill;
|
|
break;
|
|
case 'load_profile':
|
|
$skill_profile = new SkillRelProfile();
|
|
$skills = $skill_profile->get_skills_by_profile($id);
|
|
$total_skills_to_search = $skill->get_skills_info($skills);
|
|
break;
|
|
}
|
|
|
|
$skill_list = array();
|
|
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->return_form();
|
|
|
|
//var_dump($total_skills_to_search);
|
|
|
|
$tpl->assign('form', $form_to_html);
|
|
$tpl->assign('url', $url);
|
|
|
|
$content = $tpl->fetch('default/skill/profile.tpl');
|
|
$tpl->assign('content', $content);
|
|
$tpl->display_one_col_template();
|