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/template/default/skill/skill_wheel.html.twig

648 lines
26 KiB

{% import '@ChamiloCore/Macros/box.html.twig' as display %}
{% autoescape false %}
<script>
/* Skill search input in the left menu */
function check_skills_sidebar() {
//Selecting only selected skills
$("#skill_id option").each(function () {
var skill_id = $(this).val();
if (skill_id != "") {
$.ajax({
url: "{{ url }}&a=skill_exists",
data: "skill_id=" + skill_id,
async: false,
success: function (return_value) {
if (return_value == 0) {
alert("{{ 'There is no such skill'|trans }}");
//Deleting select option tag
//$("#skill_id option[value="+skill_id+"]").remove();
$("#skill_id").empty();
//Deleting holder
$("#skill_search .holder li").each(function () {
if ($(this).attr("rel") == skill_id) {
$(this).remove();
}
});
} else {
$("#skill_id option[value=" + skill_id + "]").remove();
//Deleting holder
$("#skill_search .holder li").each(function () {
if ($(this).attr("rel") == skill_id) {
$(this).remove();
}
});
if ($('#skill_to_select_id_' + skill_id).length == 0) {
skill_info = get_skill_info(skill_id);
li = fill_skill_search_li(skill_id, skill_info.title);
$("#skill_holder").append(li);
}
}
}
});
}
});
}
function fill_skill_search_li(skill_id, skill_name, checked) {
var checked_condition = '',
activeCondition = '',
iconClassCondition = 'fa fa-square-o fa-fw';
if (checked) {
checked_condition = 'checked=checked';
activeCondition = 'active';
iconClassCondition = 'fa fa-check-square-o fa-fw';
}
return '\
<tr>\n\
<td>' + skill_name + '</td>\n\
<td class="text-right">\n\
<div class="btn-group btn-group-sm" data-toggle="buttons">\n\
<label class="btn btn--plain ' + activeCondition + '" aria-label="{{ 'Select'|trans }}" title="{{ 'Select to search'|trans }}">\n\
<input id="skill_to_select_id_' + skill_id + '" data-id="' + skill_id + '" name="' + skill_name + '" class="skill_to_select" type="checkbox" autocomplete="off" ' + checked_condition + '>\n\
<span class="' + iconClassCondition + '" aria-hidden="true"></span>\n\
</label>\n\
<button class="btn btn--plain load_wheel" aria-label="{{ 'Search'|trans }}" title="{{ 'Place on the wheel'|trans }}" data-id="' + skill_id + '">\n\
<span class="fa fa-crosshairs fa-fw" aria-hidden="true"></span>\n\
</button>\n\
</div>\n\
</td>\n\
</tr>';
}
function check_skills_edit_form() {
//selecting only selected parents
$("#parent_id option:selected").each(function () {
var skill_id = $(this).val();
if (skill_id != "") {
$.ajax({
async: false,
url: "{{ url }}&a=skill_exists",
data: "skill_id=" + skill_id,
success: function (return_value) {
if (return_value == 0) {
alert("{{ 'SkillDoesNotExist'|trans }}");
//Deleting select option tag
$("#parent_id").find('option').remove();
//Deleting holder
$("#skill_row .holder li").each(function () {
if ($(this).attr("rel") == skill_id) {
$(this).remove();
}
});
} else {
$("#parent_id").empty();
$("#skill_edit_holder").find('li').remove();
//Deleting holder
$("#skill_row .holder li").each(function () {
if ($(this).attr("rel") == skill_id) {
$(this).remove();
}
});
skill = get_skill_info(skill_id);
$("#skill_edit_holder").append('<li class="bit-box" id="skill_option_' + skill_id + '"> ' + skill.title + '</li>');
$("#parent_id").append('<option class="selected" selected="selected" value="' + skill_id + '"></option>');
}
}
});
}
});
}
function check_gradebook() {
//selecting only selected users
$("#gradebook_id option:selected").each(function () {
var gradebook_id = $(this).val();
if (gradebook_id != "") {
$.ajax({
url: "{{ url }}&a=gradebook_exists",
data: "gradebook_id=" + gradebook_id,
success: function (return_value) {
if (return_value == 0) {
alert("{{ 'GradebookDoesNotExist'|trans }}");
//Deleting select option tag
$("#gradebook_id option[value=" + gradebook_id + "]").remove();
//Deleting holder
$("#gradebook_row .holder li").each(function () {
if ($(this).attr("rel") == gradebook_id) {
$(this).remove();
}
});
} else {
//Deleting holder
$("#gradebook_row .holder li").each(function () {
if ($(this).attr("rel") == gradebook_id) {
$(this).remove();
}
});
if ($('#gradebook_item_' + gradebook_id).length == 0) {
gradebook = get_gradebook_info(gradebook_id);
if (gradebook) {
$("#gradebook_holder").append('<li id="gradebook_item_' + gradebook_id + '" class="bit-box"> ' + gradebook.title +
' <a rel="' + gradebook_id + '" class="closebutton" href="#"></a></li>');
}
}
}
}
});
}
});
}
function delete_gradebook_from_skill(skill_id, gradebook_id) {
$.ajax({
url: url + '&a=delete_gradebook_from_skill&skill_id=' + skill_id + '&gradebook_id=' + gradebook_id,
async: false,
success: function (result) {
//if (result == 1) {
$('#gradebook_item_' + gradebook_id).remove();
$("#gradebook_id option").each(function () {
if ($(this).attr("value") == gradebook_id) {
$(this).remove();
}
});
//}
}
});
}
function return_skill_list_from_profile_search() {
var skill_list = {};
if ($("#profile_search li").length != 0) {
$("#profile_search li").each(function (index) {
id = $(this).attr("id").split('_')[3];
if (id) {
skill_list[index] = id;
}
});
}
return skill_list;
}
function submit_profile_search_form() {
$("#skill_wheel").remove();
var skill_list = return_skill_list_from_profile_search();
if (skill_list.length != 0) {
skill_list = {'skill_id': skill_list};
skill_params = $.param(skill_list);
$.ajax({
url: url + '&a=profile_matches&' + skill_params,
async: false,
success: function (html) {
//users = jQuery.parseJSON(users);
$('#wheel_container').html(html);
}
});
}
//return skill;
}
function add_skill_in_profile_list(skill_id, skill_name) {
if ($('#profile_match_item_' + skill_id).length == 0) {
$('#profile_search').append('<li class="bit-box" id="profile_match_item_' + skill_id + '">' + skill_name +
' <a rel="' + skill_id + '" class="closebutton" href="#"></a> </li>');
} else {
$('#profile_match_item_' + skill_id).remove();
}
toogle_save_profile_form();
}
function toogle_save_profile_form() {
//Hiding showing the save this search
if ($('#profile_search li').length == 0) {
$('#profile-options-container').hide();
} else {
$('#profile-options-container').show();
}
}
$(function() {
/* Skill search */
// Tool tip (in exercises)
var tip_options = {
placement: 'right'
}
$('.tooltip_skill').tooltip(tip_options);
/* Skill item list onclick */
$("#skill_holder").on("change", "input.skill_to_select", function () {
var self = $(this);
skill_id = self.data('id') || 0;
skill_name = self.attr('name');
add_skill_in_profile_list(skill_id, skill_name);
if (this.checked) {
self.next('.fa').replaceWith('<span class="fa fa-check-square-o fa-fw" aria-hidden="true"></span>');
} else {
self.next('.fa').replaceWith('<span class="fa fa-square-o fa-fw" aria-hidden="true"></span>');
}
});
/* URL link when searching skills */
$("#skill_holder").on("click", "button.load_wheel", function (e) {
e.preventDefault();
skill_id = $(this).data('id') || 0;
skill_to_load_from_get = 0;
load_nodes(skill_id, main_depth);
});
/* URL link when searching skills */
$("a.load_root").on("click", function (e) {
e.preventDefault();
skill_id = $(this).attr('rel');
skill_to_load_from_get = 0;
load_nodes(skill_id, main_depth);
});
/* Profile matcher */
/* Submit button */
$("#search_profile_form").submit(function () {
submit_profile_search_form();
return false;
});
$("form#save_profile_form_button").on('submit', function (e) {
e.preventDefault();
var profileId = parseInt($('input[name="profile_id"]').val());
var getProfileInfo = $.getJSON(
'{{ url }}',
{
a: 'get_profile',
profile_id: profileId
}
);
$.when(getProfileInfo).done(function (profileInfo) {
$("#name_profile").val(profileInfo.title);
$("#description_profile").val(profileInfo.description);
$('#frm-save-profile').modal('show');
});
});
/* Close button in profile matcher items */
$("#profile_search").on("click", "a.closebutton", function () {
skill_id = $(this).attr('rel');
$('input[id=skill_to_select_id_' + skill_id + ']').attr('checked', false);
$('#profile_match_item_' + skill_id).remove();
submit_profile_search_form();
toogle_save_profile_form();
});
// Fill saved profiles list
update_my_saved_profiles();
/* Click in profile */
$("#saved_profiles").on("click", "button.skill-wheel-load-profile", function (e) {
e.preventDefault();
profile_id = $(this).data('id') || 0;
$('input[name="profile_id"]').val(profile_id);
$.ajax({
url: '{{ url }}&a=get_skills_by_profile&profile_id=' + profile_id,
success: function (json) {
$('#profile_search').empty();
$('#skill_holder').empty();
skill_list = $.parseJSON(json);
$.each(skill_list, function (index, skill_id) {
skill_info = get_skill_info(skill_id);
li = fill_skill_search_li(skill_id, skill_info.title, 1);
$("#skill_holder").append(li);
add_skill_in_profile_list(skill_id, skill_info.title);
});
submit_profile_search_form();
}
});
});
$("#saved_profiles").on('click', 'button.skill-wheel-delete-profile', function (e) {
e.preventDefault();
var self = $(this),
profileId = self.data('id') || 0;
$.getJSON('{{ url }}&a=delete_profile', {
profile: profileId
}, function (response) {
if (response.status) {
update_my_saved_profiles();
}
});
});
/* Wheel skill popup form */
/* Close button in gradebook select */
$("#gradebook_holder").on("click", "a.closebutton", function () {
gradebook_id = $(this).attr('rel');
skill_id = $('input[name="id"]').attr('value');
delete_gradebook_from_skill(skill_id, gradebook_id);
});
$("#skill_id").select2({
ajax: {
url: '{{ url }}&a=find_skills',
processResults: function (data) {
return {
results: data.items
};
}
},
cache: false,
placeholder: '{{ 'Enter the skill name to search'|trans }}'
}).on('change', function () {
check_skills_sidebar();
});
load_nodes(0, main_depth);
function update_my_saved_profiles() {
$.ajax({
url: '{{ url }}&a=get_saved_profiles',
success: function (data) {
$("#saved_profiles").html(data);
}
});
}
/* change background color */
$('#skill-change-background-options li a').on('click', function (e) {
e.preventDefault();
var newBackgroundColor = $(this).data('color') || '#FFF';
$("#page-back").css("background", newBackgroundColor);
});
/* Generated random colour */
/*
function colour(d) {
if (d.children) {
// There is a maximum of two children!
var colours = d.children.map(colour),
a = d3.hsl(colours[0]),
b = d3.hsl(colours[1]);
// L*a*b* might be better here...
return d3.hsl((a.h + b.h) / 2, a.s * 1.2, a.levels_to_show / 1.2);
}
return d.colour || "#fff";
}*/
$('#form-button-edit').on('click', function (e) {
e.preventDefault();
if (SkillWheel.currentSkill === null) {
return;
}
window.location.href = "{{ url('legacy_main', {'name': 'skills/skill_edit.php?id=' }) }}" + SkillWheel.currentSkill.id;
});
$('#form-button-create-child').on('click', function (e) {
e.preventDefault();
if (SkillWheel.currentSkill === null) {
return;
}
window.location.href = "{{ url('legacy_main', {'name': 'skills/skill_create.php?parent=' }) }}" + SkillWheel.currentSkill.id;
});
$('#form-button-add-to-profile').on('click', function (e) {
e.preventDefault();
if (SkillWheel.currentSkill === null) {
return;
}
add_skill_in_profile_list(SkillWheel.currentSkill.id, SkillWheel.currentSkill.title);
});
$('#frm-save-profile').on('hidden.bs.modal', function () {
$("#name_profile").val('');
$("#description_profile").val('');
$('input[name="profile_id"]').val(0);
});
$('#form-button-save-profile').on('click', function (e) {
e.preventDefault();
var saveProfile = $.ajax(
'{{ url }}',
{
data: {
a: 'save_profile',
name: $("#name_profile").val(),
description: $("#description_profile").val(),
skill_id: return_skill_list_from_profile_search(),
profile: $('input[name="profile_id"]').val()
}
}
);
$.when(saveProfile).done(function (response) {
if (parseInt(response) === 1) {
update_my_saved_profiles();
alert("{{ "Saved" | trans }}");
} else {
alert("{{ "Error" | trans }}");
}
$('#frm-save-profile').modal('hide');
});
});
$(".facebook-auto").css("width","100%");
$(".facebook-auto ul").css("width","100%");
$("ul.holder").css("width","100%");
});
</script>
<div id="page-back" class="page-skill">
<div class="container-fluid">
<div class="row">
<div class="col-md-3 skill-options">
<div class="skill-home">
<a class="btn btn-large btn-block btn--primary" href="{{ url('courses') }}">
<em class="fa fa-home"></em> {{ "Return to the course list"|trans }}
</a>
</div>
<div class="card">
<div class="card-body">
<div id="saved_profiles"></div>
<h4 class="page-header">{{ 'What skills are you looking for?'|trans }}</h4>
<div class="search-skill">
<form id="skill_search" class="form-search">
<select id="skill_id" name="skill_id" style="width: 100%;" multiple></select>
<table id="skill_holder" class="table table-condensed"></table>
</form>
</div>
<div class="search-profile-skill">
<ul id="profile_search" class="holder holder_simple hide"></ul>
<form id="search_profile_form" class="form-search">
<button class="btn btn--plain btn-block" type="submit">
<em class="fa fa-search"></em> {{ "Search profile matches"|trans }}
</button>
</form>
<h4 class="page-header">{{ 'Is this what you were looking for?'|trans }}</h4>
<form id="save_profile_form_button" class="form-search">
<button class="btn btn--plain btn-block" type="submit">
<em class="fa fa-floppy-o"></em> {{ "Save this search"|trans }}
</button>
</form>
</div>
<hr>
<p>
<a class="btn btn-block btn--primary load_root" rel="0" href="#">
<em class="fa fa-eye"></em> {{ "View skills wheel"|trans }}
</a>
</p>
</div>
</div>
<div class="accordion" id="wheel-second-accordion" role="tablist" aria-multiselectable="true">
<div class="card">
<div class="card-header" role="tab" id="wheel-legend-heading">
<h4 class="card-title">
<a role="button" data-toggle="collapse" data-parent="#wheel-second-accordion"
href="#wheel-legend-collapse" aria-expanded="true" aria-controls="wheel-legend-collapse">
{{ "Legend"|trans }}
</a>
</h4>
</div>
<div id="wheel-legend-collapse" class="collapse in" role="tabpanel" aria-labelledby="wheel-legend-heading">
<div class="card-body">
<ul class="fa-ul">
<li>
<em class="fa fa-li fa-square skill-legend-basic"></em> {{ "Basic skills"|trans }}
</li>
<li>
<em class="fa fa-li fa-square skill-legend-add"></em> {{ "Skills you can learn"|trans }}
</li>
<li>
<em class="fa fa-li fa-square skill-legend-search"></em> {{ "Skills searched for"|trans }}
</li>
</ul>
</div>
</div>
</div>
<div class="card">
<div class="card-header" role="tab" id="wheel-display-heading">
<h4 class="card-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#wheel-second-accordion"
href="#wheel-display-collapse" aria-expanded="false" aria-controls="wheel-display-collapse">
{{ 'Display options' | trans }}
</a>
</h4>
</div>
<div id="wheel-display-collapse" class="collapse" role="tabpanel" aria-labelledby="wheel-display-heading">
<div class="card-body">
<p>{{ 'Choose a background color' | trans }}</p>
<ul class="list-unstyled" id="skill-change-background-options">
<li><a href="#" data-color="#FFFFFF">{{ 'White' | trans }}</a></li>
<li><a href="#" data-color="#000000">{{ 'Black' | trans }}</a></li>
<li><a href="#" data-color="#A9E2F3">{{ 'Light blue' }}</a></li>
<li><a href="#" data-color="#848484">{{ 'Gray' | trans }}</a></li>
<li><a href="#" data-color="#F7F8E0">{{ 'Corn' | trans }}</a></li>
</ul>
</div>
</div>
</div>
</div>
</div>
<div id="wheel_container" class="col-md-9">
<div id="skill_wheel">
<img src="">
</div>
</div>
</div>
</div>
</div>
<div class="modal fade" id="frm-skill" tabindex="-1" role="dialog" aria-labelledby="form-skill-title" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="{{ "Close" | trans }}">
<span aria-hidden="true">&times;</span>
</button>
<h4 class="modal-title" id="form-skill-title">{{ "Skill" | trans }}</h4>
</div>
<div class="modal-body">
{{ dialogForm }}
</div>
<div class="modal-footer">
<button id="form-button-edit" class="btn btn--primary">
<em class="fa fa-edit"></em> {{ "Edit" | trans }}
</button>
<button id="form-button-create-child" class="btn btn--primary">
<em class="fa fa-plus"></em> {{ "Create child skill" | trans }}
</button>
<button id="form-button-add-to-profile" class="btn btn--primary">
<em class="fa fa-check"></em> {{ "Add skill to profile search" | trans }}
</button>
<button type="button" class="btn btn--primary" data-dismiss="modal">
<em class="fa fa-close"></em> {{ "Close" | trans }}
</button>
</div>
</div>
</div>
</div>
<div class="modal fade" id="frm-save-profile" tabindex="-1" role="dialog" aria-labelledby="form-save-profile-title" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="{{ "Close" | trans }}">
<span aria-hidden="true">&times;</span>
</button>
<h4 class="modal-title" id="form-save-profile-title">
{{ "Skill profile" | trans }}
</h4>
</div>
<div class="modal-body">
{{ save_profile_form }}
</div>
<div class="modal-footer">
<button id="form-button-save-profile" class="btn btn--primary">
<em class="fa fa-save"></em> {{ "Save" | trans }}
</button>
<button type="button" class="btn btn--primary" data-dismiss="modal">
<em class="fa fa-close"></em> {{ "Close" | trans }}
</button>
</div>
</div>
</div>
</div>
{% endautoescape %}