123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639 |
- {% include template ~ '/skill/skill_wheel.js.tpl' %}
- <script>
- /* Skill search input in the left menu */
- function check_skills_sidebar() {
- //Selecting only selected skills
- $("#skill_id option:selected").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("{{ 'SkillDoesNotExist'|get_lang }}");
- //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.name);
- $("#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-default ' + activeCondition + '" aria-label="{{ 'Select'|get_lang }}" title="{{ 'SelectToSearch'|get_lang }}">\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-default load_wheel" aria-label="{{ 'Search'|get_lang }}" title="{{ 'PlaceOnTheWheel'|get_lang }}" 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'|get_lang }}");
- //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.name + '</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'|get_lang }}");
- //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.name +
- ' <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();
- }
- }
- $(document).ready(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.name);
- $("#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.name, 1);
- $("#skill_holder").append(li);
- add_skill_in_profile_list(skill_id, skill_info.name);
- });
- 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").fcbkcomplete({
- json_url: "{{ url }}&a=find_skills",
- cache: false,
- filter_case: false,
- filter_hide: true,
- complete_text: "{{ 'EnterTheSkillNameToSearch' | get_lang }}",
- firstselected: true,
- //onremove: "testme",
- onselect: "check_skills_sidebar",
- filter_selected: true,
- newel: true
- });
- 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 = "{{ _p.web_main }}admin/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 = "{{ _p.web_main }}admin/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.name);
- });
- $('#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" | get_lang }}");
- } else {
- alert("{{ "Error" | get_lang }}");
- }
- $('#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="{{ _p.web }}user_portal.php">
- <em class="fa fa-home"></em> {{ "ReturnToCourseList"|get_lang }}
- </a>
- </div>
- <div class="panel panel-default">
- <div class="panel-body">
- <div id="saved_profiles"></div>
- <h4 class="page-header">{{ 'WhatSkillsAreYouLookingFor'|get_lang }}</h4>
- <div class="search-skill">
- <form id="skill_search" class="form-search">
- <select id="skill_id" name="skill_id" /></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-default btn-block" type="submit">
- <em class="fa fa-search"></em> {{ "SearchProfileMatches"|get_lang }}
- </button>
- </form>
- <h4 class="page-header">{{ 'IsThisWhatYouWereLookingFor'|get_lang }}</h4>
- <form id="save_profile_form_button" class="form-search">
- <button class="btn btn-default btn-block" type="submit">
- <em class="fa fa-floppy-o"></em> {{ "SaveThisSearch"|get_lang }}
- </button>
- </form>
- </div>
- <hr>
- <p>
- <a class="btn btn-block btn-default load_root" rel="0" href="#">
- <em class="fa fa-eye"></em> {{ "ViewSkillsWheel"|get_lang }}
- </a>
- </p>
- </div>
- </div>
- <div class="panel-group" id="wheel-second-accordion" role="tablist" aria-multiselectable="true">
- <div class="panel panel-default">
- <div class="panel-heading" role="tab" id="wheel-legend-heading">
- <h4 class="panel-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"|get_lang }}
- </a>
- </h4>
- </div>
- <div id="wheel-legend-collapse" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="wheel-legend-heading">
- <div class="panel-body">
- <ul class="fa-ul">
- <li>
- <em class="fa fa-li fa-square skill-legend-basic"></em> {{ "BasicSkills"|get_lang }}
- </li>
- <li>
- <em class="fa fa-li fa-square skill-legend-add"></em> {{ "SkillsYouCanLearn"|get_lang }}
- </li>
- <li>
- <em class="fa fa-li fa-square skill-legend-search"></em> {{ "SkillsSearchedFor"|get_lang }}
- </li>
- </ul>
- </div>
- </div>
- </div>
- <div class="panel panel-default">
- <div class="panel-heading" role="tab" id="wheel-display-heading">
- <h4 class="panel-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">
- {{ 'DisplayOptions' | get_lang }}
- </a>
- </h4>
- </div>
- <div id="wheel-display-collapse" class="panel-collapse collapse" role="tabpanel" aria-labelledby="wheel-display-heading">
- <div class="panel-body">
- <p>{{ 'ChooseABackgroundColor' | get_lang }}</p>
- <ul class="list-unstyled" id="skill-change-background-options">
- <li><a href="#" data-color="#FFFFFF">{{ 'White' | get_lang }}</a></li>
- <li><a href="#" data-color="#000000">{{ 'Black' | get_lang }}</a></li>
- <li><a href="#" data-color="#A9E2F3">{{ 'LightBlue' }}</a></li>
- <li><a href="#" data-color="#848484">{{ 'Gray' | get_lang }}</a></li>
- <li><a href="#" data-color="#F7F8E0">{{ 'Corn' | get_lang }}</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" | get_lang }}">
- <span aria-hidden="true">×</span>
- </button>
- <h4 class="modal-title" id="form-skill-title">{{ "Skill" | get_lang }}</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" | get_lang }}
- </button>
- <button id="form-button-create-child" class="btn btn-primary">
- <em class="fa fa-plus"></em> {{ "CreateChildSkill" | get_lang }}
- </button>
- <button id="form-button-add-to-profile" class="btn btn-primary">
- <em class="fa fa-check"></em> {{ "AddSkillToProfileSearch" | get_lang }}
- </button>
- <button type="button" class="btn btn-primary" data-dismiss="modal">
- <em class="fa fa-close"></em> {{ "Close" | get_lang }}
- </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" | get_lang }}">
- <span aria-hidden="true">×</span>
- </button>
- <h4 class="modal-title" id="form-save-profile-title">{{ "SkillProfile" | get_lang }}</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" | get_lang }}
- </button>
- <button type="button" class="btn btn-primary" data-dismiss="modal">
- <em class="fa fa-close"></em> {{ "Close" | get_lang }}
- </button>
- </div>
- </div>
- </div>
- </div>
|