parent
f6cb80e25b
commit
d92c10b64a
@ -0,0 +1,648 @@ |
||||
{% 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">×</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">×</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 %} |
Loading…
Reference in new issue