123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461 |
- <style>
- /* just because */
- body {
- /* fallback */
- background-color: #eee;
- background-image: url(images/radial_bg.png);
- background-position: center center;
- background-repeat: no-repeat;
- /* Safari 4-5, Chrome 1-9 */ /* Can't specify a percentage size? Laaaaaame. */
- background: -webkit-gradient(radial, center center, 0, center center, 460, from(#eee), to(#666));
- /* Safari 5.1+, Chrome 10+ */
- background: -webkit-radial-gradient(circle, #eee, #666);
- /* Firefox 3.6+ */
- background: -moz-radial-gradient(circle, #eee, #666);
- /* IE 10 */
- background: -ms-radial-gradient(circle, #eee, #666);
- }
- </style>
- <script>
- //js settings (see the skills.js for more)
- var url = '{{ url }}';
- //Block settings see the SkillVisualizer Class
- var offset_x = {{ skill_visualizer.offset_x }};
- var offset_y = {{ skill_visualizer.offset_y }};
- var space_between_blocks_x = {{ skill_visualizer.space_between_blocks_x }};
- var space_between_blocks_y = {{ skill_visualizer.space_between_blocks_y }};
- var center_x = {{ skill_visualizer.center_x }};
- var block_size = {{ skill_visualizer.block_size }};
- $(window).resize(function() {
- jsPlumb.repaintEverything();
- /*jsPlumb.repaint(".skill_root");
- // When resize repaint everything + fix the root position
- normal_weight = $('.skill_child :first-child').width();
- sum = $('body').width() / 2 - normal_weight/2;
- $('.skill_root').animate({ left: sum, top:0 }, { duration: 100 });*/
- });
- jsPlumb.ready(function() {
- //Setting the loading dialog
- var loading = $( "#dialog-loading" );
- loading.dialog( "destroy" );
- loading.dialog({
- autoOpen:false,
- height: 120,
- modal: true,
- zIndex: 10000,
- resizable :false,
- closeOnEscape : false,
- disabled: true,
- open: function(event, ui) { $(this).parent().children().children('.ui-dialog-titlebar-close').hide(); }
- });
- jQuery.ajaxSetup({
- beforeSend: function() {
- loading.dialog( "open" );
- //$('#skill_tree').hide();
- console.log('before------------------->>');
- },
- complete: function(){
- loading.dialog( "close" );
- //$('#skill_tree').show();
- console.log('complete------------------->>');
- },
- success: function() {}
- });
- //Return to root button
- $('#return_to_root').click(function(){
- clean_values();
- console.log('Clean values');
- console.log('Reopen the root ');
- });
- //Open dialog
- $("#dialog-form").dialog({
- autoOpen: false,
- modal : true,
- width : 550,
- height : 480
- });
- //Filling skills select
- /*
- $.getJSON("{{url}}&a=get_skills&parent_id="+parents[0], {},
- function(data) {
- $.each(data, function(n, parent) {
- // add a new option with the JSON-specified value and text
- $("<option />").attr("value", parent.id).text(parent.name).appendTo("#parent_id");
- });
- }
- );*/
- //Filling gradebook select
- $.getJSON("{{url}}&a=get_gradebooks", {},
- function(data) {
- $.each(data, function(n, gradebook) {
- // add a new option with the JSON-specified value and text
- $("<option />").attr("value", gradebook.id).text(gradebook.name).appendTo("#gradebook_id");
- });
- }
- );
- //Add button on click
- $("#add_item_link").click(function() {
- $("#name").attr('value', '');
- $("#description").attr('value', '');
- $("#parent_id option:selected").removeAttr('selected');
- $("#gradebook_id option:selected").removeAttr('selected');
- $("#dialog-form").dialog("open");
- //Filling skills select
- var my_id = 1;
- if (parents.length > 1) {
- my_id = parents[1].split('_')[1];
- }
- //Remove all options
- $("#parent_id").find('option').remove();
- $.getJSON("{{url}}&a=get_skills&id="+my_id, {
- },
- function(data) {
- $.each(data, function(n, parent) {
- // add a new option with the JSON-specified value and text
- $("<option />").attr("value", parent.id).text(parent.name).appendTo("#parent_id");
- });
- }
- );
- });
- //Add button process
- var name = $( "#name" ),
- description = $( "#description" ),
- allFields = $( [] ).add( name ).add( description ), tips = $(".validateTips");
- $("#dialog-form").css('z-index', '9001');
- $("#dialog-form").dialog({
- buttons: {
- "{{"Add"|get_lang}}" : function() {
- var bValid = true;
- bValid = bValid && checkLength( name, "name", 1, 255 );
- if (bValid) {
- var params = $("#add_item").serialize();
- $.ajax({
- async: false,
- url: url+'&a=add&'+params,
- success:function(my_id) {
- //Setting the selected id from the form
- parent_id = $("#parent_id option:selected").attr('value');
- //Reseting jsplumb
- jsPlumb.reset();
- //Deletes all windows
- $('.skill_root').remove();
- $('.skill_child').remove();
- //cleaning skills
- skills = [];
- //Setting the first parent
- first_parent = parents[0];
- //Deleting the first parent
- console.log('parents before '+parents);
- parents.splice(0,1);
- console.log('parents now '+parents);
- //Remove parent block
- $('#block_'+parent_id).remove();
- //Open the block
- open_block('block_'+parent_id, 0, 1);
- //Close dialog
- $("#dialog-form").dialog("close");
- }
- });
- }
- }
- },
- close: function() {
- $("#name").attr('value', '');
- $("#description").attr('value', '');
- }
- });
- //Clicking in a box skill (we use live instead of bind because we're creating divs on the fly )
- $(".open_block").click(function() {
- var id = $(this).attr('id');
- console.log('click.open_block id: ' + id);
- console.log('parents: ' + parents);
- //if is root
- if (parents[0] == id) {
- parents = [id];
- }
- if (parents[1] != id) {
- console.log('parents.length ' +parents.length);
- //If there are 2 parents in the skill_tree
- if (parents.length == 2 ) {
- first_parent = parents[0];
- $('#'+parents[1]).css('top', '0px');
- //console.log('deleting: '+parents[0]);
- //removing father
- console.log("first_parent " + first_parent);
- for (var i = 0; i < skills.length; i++) {
- //console.log('looping '+skills[i].element + ' ');
- if (skills[i].element == parents[0] ) {
- console.log('deleting parent:'+ skills[i].element + ' here ');
- jsPlumb.deleteEndpoint(skills[i].element);
- jsPlumb.detachAllConnections(skills[i].element);
- jsPlumb.removeAllEndpoints(skills[i].element);
- $("#"+skills[i].element).remove();
- }
- }
- parents.splice(0,1);
- parents.push(id);
- console.log('parents after slice/push: ' + parents);
- }
- if ($(this).hasClass('first_window')) {
- console.log('im in a first_window (root)');
- $('#'+first_parent).css('top', '0px');
- //show the first_parent
- //if (first_parent != '') {
- parents = [first_parent, id];
- open_parent(first_parent, id);
- //}
- }
- if (jQuery.inArray(id, parents) == -1) {
- parents.push(id);
- console.log('parents push: ' + parents);
- }
- open_block(id, 0, 0);
- }
- //Setting class
- cleanclass($(this));
- $(this).addClass('second_window');
- parent_div = $("#"+parents[0]);
- cleanclass(parent_div);
- parent_div.addClass('first_window');
- parent_div.addClass('skill_root');
- parent_div = $("#"+parents[1]);
- cleanclass(parent_div);
- parent_div.addClass('second_window');
- //console.log(parents);
- // console.log(skills);
- console.log('first_parent : ' + first_parent);
- //redraw
- jsPlumb.repaintEverything();
- jsPlumb.repaint(id);
- });
- //Skill title click
- $(".edit_block").click(function() {
- var my_id = $(this).attr('id');
- my_id = my_id.split('_')[2];
- //Cleaning selected
- $("#parent_id option:selected").removeAttr('selected');
- $("#gradebook_id option:selected").removeAttr('selected');
- $.ajax({
- url: url+'&a=get_skill_info&id='+my_id,
- success: function(json) {
- var skill = jQuery.parseJSON(json);
- $("#name").attr('value', skill.name);
- $("#id").attr('value', skill.id);
- $("#description").attr('value', skill.description);
- //filling parent_id
- $("#parent_id option[value='"+skill.extra.parent_id+"']").attr('selected', 'selected');
- //filling the gradebook_id
- jQuery.each(skill.gradebooks, function(index, data) {
- $("#gradebook_id option[value='"+data.id+"']").attr('selected', 'selected');
- });
- }
- });
- $("#gradebook_id").trigger("liszt:updated");
- $("#parent_id").trigger("liszt:updated");
- $("#dialog-form").dialog("open");
- return false;
- });
- //Clicking in a box
- $(".window").bind('click', function() {
- var id = $(this).attr('id');
- id = id.split('_')[1];
- });
- // chrome fix.
- document.onselectstart = function () { return false; };
- // render mode
- var resetRenderMode = function(desiredMode) {
- var newMode = jsPlumb.setRenderMode(desiredMode);
- jsPlumbDemo.init();
- };
- resetRenderMode(jsPlumb.CANVAS);
- });
- ;(function() {
- prepare = function(div, endpointOptions) {
- console.log('preparing = '+div);
- console.log('endpointOptions = '+endpointOptions);
- //jsPlumbDemo.initHover(elId);
- var endPoint = jsPlumb.addEndpoint(div, endpointOptions);
- skills.push({
- element: div, endp:endPoint
- });
- return endPoint;
- },
- window.jsPlumbDemo = {
- init : function() {
- console.log('Import defaults');
- jsPlumb.Defaults.Anchors = [ "BottomCenter", "TopCenter" ];
- jsPlumb.Defaults.Container = "skill_tree";
- open_block('block_1', 0, 1);
- // listen for clicks on connections, and offer to delete connections on click.
- jsPlumb.bind("click", function(conn, originalEvent) {
- /*if (confirm("Delete connection from " + conn.sourceId + " to " + conn.targetId + "?"))
- jsPlumb.detach(conn); */
- });
- }
- };
- })();
- $(document).ready(function() {
- /*
- //When creating a connection see
- //http://jsplumb.org/apidocs/files/jsPlumb-1-3-2-all-js.html#bind
- jsPlumb.bind("jsPlumbConnection", function(conn) {
- //alert("Connection created " + conn.sourceId + " to " + conn.targetId + " ");
- //jsPlumb.detach(conn);
- });
- //When double clicking a connection
- jsPlumb.bind("click", function(conn) {
- if (confirm("Delete connection from " + conn.sourceId + " to " + conn.targetId + "?"))
- jsPlumb.detach(conn);
- });
- //When double clicking a connection
- jsPlumb.bind("click", function(endpoint) {
- if (confirm("Delete connection from " + conn.sourceId + " to " + conn.targetId + "?"))
- jsPlumb.detach(conn);
- });*/
- $(".chzn-select").chosen();
- $("#menu").draggable();
- });
- ;(function() {
- jsPlumbDemo.getSelector = function(spec) {
- return $(spec);
- };
- jsPlumbDemo.attachBehaviour = function() {
- $(".hide").click(function() {
- jsPlumb.toggle($(this).attr("rel"));
- });
- $(".drag").click(function() {
- var s = jsPlumb.toggleDraggable($(this).attr("rel"));
- $(this).html(s ? 'disable dragging' : 'enable dragging');
- if (!s) $("#" + $(this).attr("rel")).addClass('drag-locked'); else $("#" + $(this).attr("rel")).removeClass('drag-locked');
- $("#" + $(this).attr("rel")).css("cursor", s ? "pointer" : "default");
- });
- $(".detach").click(function() {
- jsPlumb.detachAll($(this).attr("rel"));
- });
- $("#clear").click(function() {
- jsPlumb.detachEverything(); showConnections();
- });
- };
- })();
- </script>
- <div id="dialog-loading">
- <div class="modal-body">
- <p style="text-align:center">
- {{ "Loading"|get_lang }}
- <img src="{{ _p.web_img}}loadingAnimation.gif"/>
- </p>
- </div>
- </div>
- <div id="menu" class="well" style="top:20px; left:20px; width:380px; z-index: 9000; opacity: 0.9;">
- <h3>{{'Skills'|get_lang}}</h3>
- <div class="btn-group">
- <a style="z-index: 1000" class="btn" id="add_item_link" href="#">{{'AddSkill'|get_lang}}</a>
- <a style="z-index: 1000" class="btn btn-default" id="return_to_root" href="#">{{'Root'|get_lang}}</a>
- <a style="z-index: 1000" class="btn btn-default" id="return_to_admin" href="{{_p.web_main}}admin">{{'BackToAdmin'|get_lang}}</a>
- </div>
- </div>
- <div id="skill_tree"></div>
- <div id="dialog-form" style="display:none; z-index:9001;">
- <p class="validateTips"></p>
- <form class="form-horizontal" id="add_item" name="form">
- <fieldset>
- <input type="hidden" name="id" id="id"/>
- <div class="control-group">
- <label class="control-label" for="name">{{'Name'|get_lang}}</label>
- <div class="controls">
- <input type="text" name="name" id="name" size="40" />
- </div>
- </div>
- <div class="control-group">
- <label class="control-label" for="name">{{'Parent'|get_lang}}</label>
- <div class="controls">
- <select id="parent_id" name="parent_id" />
- </select>
- </div>
- </div>
- <div class="control-group">
- <label class="control-label" for="name">{{'Gradebook'|get_lang}}</label>
- <div class="controls">
- <select id="gradebook_id" name="gradebook_id[]" multiple="multiple"/>
- </select>
- <span class="help-block">
- {{'WithCertificate'|get_lang}}
- </span>
- </div>
- </div>
- <div class="control-group">
- <label class="control-label" for="name">{{'Description'|get_lang}}</label>
- <div class="controls">
- <textarea name="description" id="description" rows="7"></textarea>
- </div>
- </div>
- </fieldset>
- </form>
- </div>
|