jsTree - Mover para cima

TESTE: jQuery não foi carregado! :(


Selecione um nó filho e clique no botão abaixo:

  • Root node 1
    • Root1 Child1
    • Root1 Child2
    • Root1 Child3
  • Root node 2
    • Root2 Child1
    • Root2 Child2
    • Root2 Child3
  • Root node 3
    • Root3 Child1
    • Root3 Child2
    • Root3 Child3
  • Root node 4
    • Root4 Child1
    • Root4 Child2
    • Root4 Child3
      • Root4 Child1 Child1
      • Root4 Child1 Child2


HTML
<div id="divArvore">
  <ul>
    <li id="root_1">Root node 1 
      <ul>
        <li id="root_1_child_1">Root1 Child1</li> 
        <li id="root_1_child_2">Root1 Child2</li> 
        <li id="root_1_child_3">Root1 Child3</li> 
      </ul> 
    </li>
    <li id="root_2">Root node 2 
      <ul>
        <li id="root_2_child_1">Root2 Child1</li>
        <li id="root_2_child_2">Root2 Child2</li>
        <li id="root_2_child_3">Root2 Child3</li> 
      </ul> 
    </li> 
    <li id="root_3">Root node 3 
      <ul> 
        <li id="root_3_child_1">Root3 Child1</li> 
        <li id="root_3_child_2">Root3 Child2</li> 
        <li id="root_3_child_3">Root3 Child3</li> 
      </ul> 
    </li> 
    <li id="root_4">Root node 4 
      <ul> 
        <li id="root_4_child_1">Root4 Child1</li> 
        <li id="root_4_child_2">Root4 Child2</li> 
        <li id="root_4_child_3">Root4 Child3 
          <ul> 
            <li id="root_4_child_1_child_1">Root4 Child1 Child1</li> 
            <li id="root_4_child_1_child_2">Root4 Child1 Child2</li> 
          </ul>
        </li>
      </ul>
    </li>
  </ul>
</div> 
<h2 id="h2Aviso"></h2>


SCRIPT
<script type="text/javascript">            
            $(document).ready(function() {
                
                //Crio instância e passo argumentos para dar permissão para o método move_node.
                $("#divArvore").jstree({
                    'core' : {
                        'check_callback' : function (operation, node, node_parent, node_position) {
                            // operation can be 'create_node', 'rename_node', 'delete_node', 'move_node' or 'copy_node'
                            // in case of 'rename_node' node_position is filled with the new node name
                            
                            switch (operation){
                            case "move_node":
                                permissao = true;
                                break;
                            default:
                                permissao = false;
                            }//end switch                            
                            return permissao;
                        }
                    }
                });
                                
                //Quando clicar no 'botão mover para cima'
                $('#buttonMoverCima').on('click', function(){
                    //limpa qualquer aviso dado anteriormente
                    $('#h2Aviso').html('');
                    
                    arrayIDs = $.jstree.reference('#divArvore').get_selected(false);
                    //arrayIDs = $('#divArvore').get_selected(false);
                    
                    if (arrayIDs.length === 0){
                        $('#h2Aviso').html('Por favor, escolha um nó!');
                    }else if(arrayIDs.length > 1){
                        $('#h2Aviso').html('Por favor, escolha somente um nó!');
                    }else{
                        strId = arrayIDs[0];
                        strSeletor = '#' + strId;
                        nodeSelecionado = $(strSeletor);
                                                
                        mover_cima(nodeSelecionado);
                        
                        $('#h2Aviso').html(strSeletor);
                        
                    }//end if
                });
                
                $("#h4Carregamento").html("TESTE: jQuery foi carregado! :)");
            });
            
            //LIMITAÇÃO: Não funciona com nós raiz.
            function mover_cima(nodeMover){
                nodeAnterior = nodeMover.prev();
                if (nodeAnterior.length) {
                    posicao = posicao_node(nodeMover);
                    if (posicao !== 0){
                        posicao--;
                        
                        nodePaiAnterior =  nodeAnterior.parent();
                        
                        //essa função filha da puta só adiciona como filho, quando passado um número :@
                        //então para poder adicionar no mesmo nó, eu pego o pai do nó anterior                                                                                                                
                        $("#divArvore").jstree(true).move_node(nodeMover, nodePaiAnterior, posicao);
                    }//end if
                }//end if                
            }//end function
            
            //Retorna a posição que o nó está
            //IMPORTANTE: Primeiro elemento índice = 0.
            function posicao_node(node){                                
                posicao = -1;
                while (node.length) {
                    posicao++;
                    node = node.prev();
                }//end while
                return posicao;
            }//end function
            
        </script>

















Comentários

Postagens mais visitadas deste blog

VR Box 2.0 - QR Code

Jogo 60 seconds!