123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605 |
- var counter_new_functions = 0;
- var counter_new_parameters = 0;
- var counter_new_variables = 0;
- function addFunctionHandler() {
- new_function = new Funcao(i18n("new_function") + "_" + counter_new_functions);
- adicionarFuncao(new_function);
- counter_new_functions ++;
- renderAlgorithm();
- }
- function updateSequenceFunctionHandler(index_from, index_to) {
- programa.funcoes.splice(index_to, 0, programa.funcoes.splice(index_from, 1)[0]);
- renderAlgorithm();
- }
- function removeFunctionHandler(div_function, sequence) {
- programa.funcoes.splice(sequence, 1);
- $(div_function).slideUp(400, function(){
- renderAlgorithm();
- });
-
- }
- function minimizeFunctionHandler(div_function, sequence) {
- $(div_function).find(".function_area").toggle();
- programa.funcoes[sequence].esta_oculta = !programa.funcoes[sequence].esta_oculta;
- }
- function renderAlgorithm() {
- $('.all_functions').empty();
- for (i = 0; i < programa.funcoes.length; i++) {
- appendFunction(programa.funcoes[i], i);
- }
- $('.data_types_dropdown').dropdown();
-
- $('.parameter_data_types_dropdown').dropdown();
- addHandlers();
- }
- function addHandlers() {
- $('.ui.dropdown.function_return')
- .dropdown({
- onChange: function(value, text, $selectedItem) {
- classList = $selectedItem.attr('class').split(/\s+/);
- $.each(classList, function(index, item) {
- if (item.indexOf("seq_") > -1) {
- seq = item.split("seq_")[1];
- for (tm in tiposDados) {
- if ($selectedItem.hasClass(tm)) {
- programa.funcoes[seq].tipo_retorno = tm;
- }
- }
- updateFunctionReturn(seq, value);
- }
- });
- }
- })
- ;
- $('.ui.dropdown.parameter_type').dropdown({
- onChange: function(value, text, $selectedItem) {
- classList = $selectedItem.attr('class').split(/\s+/);
- var fun;
- var seq;
- $.each(classList, function(index, item) {
- if (item.indexOf("fun_") > -1) {
- fun = item.split("fun_")[1];
- }
- if (item.indexOf("seq_") > -1) {
- seq = item.split("seq_")[1];
- }
- });
- var dim = 0;
- if (value.indexOf(i18n(tiposDados.vector)) > -1) {
- dim = 1;
- }
- for (tm in tiposDados) {
- if ($selectedItem.hasClass(tm)) {
- updateParameterType(fun, seq, tm, dim);
- break;
- }
- }
- }
- });
- $('.ui.dropdown.variable_type').dropdown({
- onChange: function(value, text, $selectedItem) {
- classList = $selectedItem.attr('class').split(/\s+/);
- var fun;
- var seq;
- $.each(classList, function(index, item) {
- if (item.indexOf("fun_") > -1) {
- fun = item.split("fun_")[1];
- }
- if (item.indexOf("seq_") > -1) {
- seq = item.split("seq_")[1];
- }
- });
- var dim = 0;
- if (value.indexOf(i18n(tiposDados.vector)) > -1) {
- dim = value.split('[').length - 1;
- }
- for (tm in tiposDados) {
- if ($selectedItem.hasClass(tm)) {
- console.log("possui: " + tm);
- updateVariableType(fun, seq, tm, dim);
- break;
- }
- }
- }
- });
- }
- function updateVariableType(wich_function, wich_variable, new_value, new_dimensions) {
- programa.funcoes[wich_function].variaveis[wich_variable].tipo = new_value;
- programa.funcoes[wich_function].variaveis[wich_variable].dimensoes = new_dimensions;
- }
- function addVariable(sequence) {//tipo, nome, valor
- var v = new Variavel(tiposDados.integer, i18n('new_variable') + '_' + counter_new_variables, 1);
- adicionarVariavel(sequence, v);
- counter_new_variables ++;
- renderAlgorithm();
- }
- function deleteVariable(which_function, which_variable) {
- programa.funcoes[which_function].variaveis.splice(which_variable, 1);
- renderAlgorithm();
- }
- function addParameter(sequence) {
- if (programa.funcoes[sequence].lista_parametros == null) {
- programa.funcoes[sequence].lista_parametros = new Array();
- }
- programa.funcoes[sequence].lista_parametros.push(new Variavel(tiposDados.integer, i18n("new_parameter") + "_" + counter_new_parameters));
- counter_new_parameters ++;
- renderAlgorithm();
- }
- function updateFunctionReturn(sequence, new_value) {
- if (new_value.indexOf(i18n(tiposDados.vector)) > -1) {
- programa.funcoes[sequence].dimensoes_retorno = 1;
- } else {
- programa.funcoes[sequence].dimensoes_retorno = 0;
- }
-
- }
- function updateParameterType(wich_function, wich_parameter, new_value, new_dimensions) {
- programa.funcoes[wich_function].lista_parametros[wich_parameter].tipo = new_value;
- programa.funcoes[wich_function].lista_parametros[wich_parameter].dimensoes = new_dimensions;
- }
- var opened_name_function = false;
- var opened_input = null;
- var sequence_name_opened;
- function enableNameFunctionUpdate(div_el, sequence) {
- if (opened_name_function) {
- $(opened_input).focus();
- return;
- }
- opened_name_function = true;
- sequence_name_opened = sequence;
- $(div_el).find('.span_name_function').text('');
- $( "<input type='text' class='width-dynamic input_name_function' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' value='"+programa.funcoes[sequence].nome+"' />" ).insertBefore($(div_el).find('.span_name_function'));
- $('.width-dynamic').on('input', function() {
- var inputWidth = $(this).textWidth()+10;
- opened_input = this;
- $(this).focus();
- var tmpStr = $(this).val();
- $(this).val('');
- $(this).val(tmpStr);
- $(this).css({
- width: inputWidth
- })
- }).trigger('input');
- $('.width-dynamic').focusout(function() {
- /// update array:
- if ($(this).val().trim()) {
- programa.funcoes[sequence_name_opened].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_function = false;
- opened_input = false;
- renderAlgorithm();
- });
- $('.width-dynamic').on('keydown', function(e) {
- var code = e.keyCode || e.which;
- if(code == 13) {
- if ($(this).val().trim()) {
- programa.funcoes[sequence_name_opened].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_function = false;
- opened_input = false;
- renderAlgorithm();
- }
- if(code == 27) {
- $(div_el).find('.span_name_function').text(programa.funcoes[sequence_name_opened].nome);
- $(this).remove();
- /// update elements:
- opened_name_function = false;
- opened_input = false;
- }
- });
-
- }
- var opened_name_variable = false;
- var opened_input_variable = null;
- var sequence_name_opened_variable;
- var sequence_function_opened_variable;
- function enableNameVariableUpdate(parent_node, which_function, which_parameter) {
- if (opened_name_variable) {
- $(opened_input_variable).focus();
- return;
- }
- opened_name_variable = true;
- sequence_name_opened_variable = which_parameter;
- sequence_function_opened_variable = which_function;
- $(parent_node).find('.span_name_variable').text('');
- $( "<input type='text' class='width-dynamic input_name_function' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' value='"
- + programa.funcoes[which_function].variaveis[which_parameter].nome + "' />" ).insertBefore($(parent_node).find('.span_name_variable'));
- $('.width-dynamic').on('input', function() {
- var inputWidth = $(this).textWidth()+10;
- opened_input_variable = this;
- $(this).focus();
- var tmpStr = $(this).val();
- $(this).val('');
- $(this).val(tmpStr);
- $(this).css({
- width: inputWidth
- })
- }).trigger('input');
- $('.width-dynamic').focusout(function() {
- /// update array:
- if ($(this).val().trim()) {
- programa.funcoes[which_function].variaveis[which_parameter].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_variable = false;
- opened_input_variable = false;
- renderAlgorithm();
- });
- $('.width-dynamic').on('keydown', function(e) {
- var code = e.keyCode || e.which;
- if(code == 13) {
- if ($(this).val().trim()) {
- programa.funcoes[which_function].variaveis[which_parameter].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_variable = false;
- opened_input_variable = false;
- renderAlgorithm();
- }
- if(code == 27) {
- $(parent_node).find('.span_name_variable').text(programa.funcoes[which_function].variaveis[which_parameter].nome);
- $(this).remove();
- /// update elements:
- opened_name_variable = false;
- opened_input_variable = false;
- }
- });
- }
- var opened_name_parameter = false;
- var opened_input_parameter = null;
- var sequence_name_opened_parameter;
- var sequence_function_opened_parameter;
- function enableNameParameterUpdate(parent_node, which_function, which_parameter) {
- if (opened_name_parameter) {
- $(opened_input_parameter).focus();
- return;
- }
- opened_name_parameter = true;
- sequence_name_opened_parameter = which_parameter;
- sequence_function_opened_parameter = which_function;
- $(parent_node).find('.span_name_parameter').text('');
- $( "<input type='text' class='width-dynamic input_name_function' autocomplete='off' autocorrect='off' autocapitalize='off' spellcheck='false' value='"+programa.funcoes[which_function].lista_parametros[which_parameter].nome+"' />" ).insertBefore($(parent_node).find('.span_name_parameter'));
- $('.width-dynamic').on('input', function() {
- var inputWidth = $(this).textWidth()+10;
- opened_input_parameter = this;
- $(this).focus();
- var tmpStr = $(this).val();
- $(this).val('');
- $(this).val(tmpStr);
- $(this).css({
- width: inputWidth
- })
- }).trigger('input');
- $('.width-dynamic').focusout(function() {
- /// update array:
- if ($(this).val().trim()) {
- programa.funcoes[which_function].lista_parametros[which_parameter].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_parameter = false;
- opened_input_parameter = false;
- renderAlgorithm();
- });
- $('.width-dynamic').on('keydown', function(e) {
- var code = e.keyCode || e.which;
- if(code == 13) {
- if ($(this).val().trim()) {
- programa.funcoes[which_function].lista_parametros[which_parameter].nome = $(this).val().trim();
- }
- $(this).remove();
- /// update elements:
- opened_name_parameter = false;
- opened_input_parameter = false;
- renderAlgorithm();
- }
- if(code == 27) {
- $(parent_node).find('.span_name_parameter').text(programa.funcoes[which_function].lista_parametros[which_parameter].nome);
- $(this).remove();
- /// update elements:
- opened_name_parameter = false;
- opened_input_parameter = false;
- }
- });
- }
- function removeParameter(parent_node, which_function, which_parameter) {
- programa.funcoes[which_function].lista_parametros.splice(which_parameter, 1);
- renderAlgorithm();
- }
- function appendFunction(function_obj, sequence) {
- var appender = '<div class="ui secondary segment function_div list-group-item">'
- + '<span class="glyphicon glyphicon-move" aria-hidden="true"><i class="icon sort alternate vertical"></i></span>'
-
- + (!function_obj.eh_principal ? '<button class="ui icon button large remove_function_button" onclick="removeFunctionHandler(this.parentNode, '+sequence+')"><i class="red icon times"></i></button>' : '')
- + '<button class="ui icon button tiny minimize_function_button" onclick="minimizeFunctionHandler(this.parentNode, '+sequence+')"><i class="icon window minimize"></i></button>'
- + '<div class="function_signature_div">'+i18n('function')+' ';
- if (function_obj.eh_principal) {
- appender += '<div class="function_name_div"> ' + i18n('void') + ' <span class="span_name_function" >'+function_obj.nome+'</span> </div> '
- + '( <div class="ui large labels parameters_list">';
- } else {
- appender += renderFunctionReturn(function_obj, sequence);
- appender += '<div class="function_name_div"><span class="span_name_function" ondblclick="enableNameFunctionUpdate(this.parentNode, '+sequence+')" >'+function_obj.nome+'</span> <i class="icon small pencil alternate enable_edit_name_function" onclick="enableNameFunctionUpdate(this.parentNode, '+sequence+')"></i></div> '
- + '( <i class="ui icon plus square outline add_parameter" onclick="addParameter('+sequence+')"></i> <div class="ui large labels parameters_list">';
- }
- appender += renderFunctionParameters(function_obj, sequence);
-
- appender += '</div> ) {</div>'
- + (function_obj.esta_oculta ? ' <div class="function_area" style="display: none;"> ' : ' <div class="function_area"> ')
- + '<div class="ui top attached segment variables_list_div"><div class="ui teal small labeled icon button add_variable_button" onclick="addVariable('+sequence+')">'+i18n('Variable')+'<i class="add icon"></i></div>'
- + renderVariables(function_obj, sequence)
- + '</div>'
- + '<div class="ui bottom attached segment commands_list_div"><div class="ui teal small labeled icon button add_command_button seq_'+sequence+'">'+i18n('Command')+'<i class="add icon"></i></div></div>'
- + '<div class="function_close_div">}</div>'
- + '</div>'
- + '</div>';
- $('.all_functions').append(appender);
- }
- // Essa função imprime os parâmetros e cria os elementos para a sua manipulação
- function renderFunctionParameters(function_obj, sequence) {
- var ret = "";
- if (function_obj.lista_parametros != null) {
- for (var j = 0; j < function_obj.lista_parametros.length; j++) {
- var par_temp = function_obj.lista_parametros[j];
- ret += '<div class="ui label function_name_parameter"><span class="span_name_parameter" ondblclick="enableNameParameterUpdate(this.parentNode, '+sequence+', '+j+')">'+par_temp.nome+'</span> <i class="icon small pencil alternate enable_edit_name_parameter" onclick="enableNameParameterUpdate(this.parentNode, '+sequence+', '+j+')"></i>';
- ret += '<div class="ui dropdown parameter_type seq_'+j+' fun_'+sequence+'">';
-
- if (par_temp.dimensoes > 0) {
- ret += '<div class="text seq_'+j+' fun_'+sequence+'">'+ i18n(tiposDados.vector)+':'+i18n(par_temp.tipo);
- ret += '</div>';
- } else {
- ret += '<div class="text seq_'+j+' fun_'+sequence+'">'+i18n(par_temp.tipo)+'</div>';
- }
- ret += '<i class="dropdown icon"></i>'
- + '<div class="menu seq_'+j+' fun_'+sequence+'">';
- var i = 0;
- for (tm in tiposDados) {
- i ++;
- if (i == 1) { continue; }
- if (i == (Object.keys(tiposDados).length - 1)) { break; }
- ret += '<div class="item ' + ((par_temp.tipo == tm && par_temp.dimensoes < 1) ? ' selected ' : '') + ' seq_'+j+' fun_'+sequence+' '+tm+'" >'+i18n(tm)+'</div>';
- }
- i = 0;
- for (tm in tiposDados) {
- i ++;
- if (i == 1) { continue; }
- if (i == (Object.keys(tiposDados).length)) { break; }
- ret += '<div class="item seq_'+j+' '+tm+' fun_'+sequence+' ' + ((par_temp.tipo == tm && par_temp.dimensoes > 0) ? ' selected ' : '') + ' ">'
- + i18n(tiposDados.vector)+':'+i18n(tm)
- + '</div>';
- }
- ret += '</div></div>';
- ret += ' <i class="red icon times remove_parameter" onclick="removeParameter(this.parentNode, '+sequence+', '+j+')"></i></div>';
- }
- }
- return ret;
- }
- // Essa função imprime as variáveis e os recursos para sua manipulação
- function renderVariables(function_obj, sequence) {
- var ret = "";
- if (function_obj.variaveis != null) {
- for (var j = 0; j < function_obj.variaveis.length; j++) {
- var par_temp = function_obj.variaveis[j];
- ret += '<div class="ui label name_variable"><span class="span_name_variable" ondblclick="enableNameVariableUpdate(this.parentNode, '+sequence+', '+j+')">'+par_temp.nome+'</span> <i class="icon small pencil alternate enable_edit_name_parameter" onclick="enableNameVariableUpdate(this.parentNode, '+sequence+', '+j+')"></i>';
- ret += '<div class="ui dropdown variable_type seq_'+j+' fun_'+sequence+'">';
-
- if (par_temp.dimensoes > 0) {
- ret += '<div class="text seq_'+j+' fun_'+sequence+'">'+ i18n(tiposDados.vector)+':'+i18n(par_temp.tipo);
- for (i = 0; i < par_temp.dimensoes; i ++) {
- ret += ' [ ] ';
- }
- ret += '</div>';
- } else {
- ret += '<div class="text seq_'+j+' fun_'+sequence+'">'+i18n(par_temp.tipo)+'</div>';
- }
- ret += '<i class="dropdown icon"></i>'
- + '<div class="menu seq_'+j+' fun_'+sequence+'">';
- var i = 0;
- for (tm in tiposDados) {
- i ++;
- if (i == 1) { continue; }
- if (i == (Object.keys(tiposDados).length - 1)) { break; }
- ret += '<div class="item ' + (par_temp.tipo == tm ? ' selected ' : '') + ' seq_'+j+' fun_'+sequence+' '+tm+'" >'+i18n(tm)+'</div>';
- }
- i = 0;
- for (tm in tiposDados) {
- i ++;
- if (i == 1) { continue; }
- if (i == (Object.keys(tiposDados).length)) { break; }
- ret += '<div class="item seq_'+j+' fun_'+sequence+'">'
- + '<i class="dropdown icon"></i>'
- + i18n(tiposDados.vector)+':'+i18n(tm)
- + '<div class="menu seq_'+j+' fun_'+sequence+'">'
- + '<div class="item seq_'+j+' fun_'+sequence+' '+tm+'" data-text="'+ i18n(tiposDados.vector)+':'+i18n(tm)+' [ ] ">[ ]</div>'
- + '<div class="item seq_'+j+' fun_'+sequence+' '+tm+'" data-text="'+ i18n(tiposDados.vector)+':'+i18n(tm)+' [ ] [ ] ">[ ] [ ] </div>'
- + '</div>'
- + '</div>';
- }
- ret += '</div></div>';
- ret += ' = ' + par_temp.valor + ' <i class="red icon times remove_parameter" onclick="deleteVariable('+sequence+', '+j+')"></i></div>';
- }
- }
- return ret;
- }
- // Essa função imprime o tipo de retorno da função e cria o menu do tipo 'select' para alteração
- function renderFunctionReturn(function_obj, sequence) {
- var ret = '<div class="ui dropdown function_return seq_'+sequence+'">';
-
- if (function_obj.dimensoes_retorno > 0) {
- ret += '<div class="text seq_'+sequence+'"">'+ i18n(tiposDados.vector)+':'+i18n(function_obj.tipo_retorno);
- ret += '</div>';
- } else {
- ret += '<div class="text seq_'+sequence+'"">'+i18n(function_obj.tipo_retorno)+'</div>';
- }
- ret += '<i class="dropdown icon"></i>'
- + '<div class="menu seq_'+sequence+'"">';
- var i = 0;
- for (tm in tiposDados) {
- if (i == (Object.keys(tiposDados).length - 1)) { break; }
- ret += '<div class="item ' + ((function_obj.tipo_retorno == tm && function_obj.dimensoes_retorno < 1) ? ' selected ' : '') + ' seq_'+sequence+' '+tm+'" >'+i18n(tm)+'</div>';
- i ++;
- }
- i = 0;
- for (tm in tiposDados) {
- i ++;
- if (i == 1) { continue; }
- if (i == (Object.keys(tiposDados).length)) { break; }
- ret += '<div class="item seq_'+sequence+' '+tm+' '+ ((function_obj.tipo_retorno == tm && function_obj.dimensoes_retorno > 0) ? ' selected ' : '') +'" data-text="'+i18n(tiposDados.vector)+':'+i18n(tm)+' ">'
- + i18n(tiposDados.vector)+':'+i18n(tm)
- + '</div>';
- }
- ret += '</div></div>';
- return ret;
- }
- $.fn.textWidth = function(text, font) {
-
- if (!$.fn.textWidth.fakeEl) $.fn.textWidth.fakeEl = $('<span>').hide().appendTo(document.body);
-
- $.fn.textWidth.fakeEl.text(text || this.val() || this.text() || this.attr('placeholder')).css('font', font || this.css('font'));
-
- return $.fn.textWidth.fakeEl.width();
- };
|