Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Rafael Motta

[Resolvido] Datatables PDO

Recommended Posts

Olá pessoal, alguem sabe como envio um parametro que recebo por $_REQUEST na pagina sales.php(abaixo), para a pagina jsonData.php(abaixo), tem alguns codigos comentados de algumas tentativas frustradas minhas...

 

sales.php

<?php
require '../../../functions/conexao.php';
require '../../../functions/crud.php';
require '../../../functions/crud2.php';
//header('Content-Type: text/html; charset=utf-8');
$idCustomer = $_REQUEST['idCustomer'];
?>
<link rel="stylesheet" type="text/css" href="http://ajax.aspnetcdn.com/ajax/jquery.dataTables/1.9.4/css/jquery.dataTables.css">
<script type="text/javascript" src="https://code.jquery.com/jquery-2.2.0.min.js"></script>
<script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>
<script language="javascript">
    $(document).ready(function() {
        $('#example').dataTable({
            "scrollX": true,
            "language": {
                "sUrl": "../plugins/datatables/Portuguese-Brasil.json"
            },
            "bProcessing": true,
            "aLengthMenu": [[5, 10, 20, 50, -1], [5, 10, 20, 50, "Todos"]],
            "sAjaxSource": 'jsonData.php',
            "serverSide": true,
            "aoColumns": [
                {"mData": "NOTA"},
                {"mData": "NRO_NOTA"},
                {"mData": "EMISSAO"},
                {"mData": "QUANTIDADE1",
                    render: $.fn.dataTable.render.number()},
                {"mData": "TOTAL1",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "VALOR_DESCONTO1",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "VALOR_IPI1",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "VALOR_SUBST",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "REPRES_NOME"},
                {"mData": "VENDEDOR_NOME"},
                {"mData": "OP_NOME"},
                {"mData": "FRANQUEADO_NOME"},
                {"mData": "TRANSP_NOME"},
                {"mData": "OP_NOME"},
                {"mData": "FRANQUEADO_NOME"},
                {"mData": "TRANSP_NOME"},
                {"mData": "CARTEIRA"},
                {"mData": "OCORRENCIA"},
                {"mData": "DATA_OCORRENCIA"},
                {"mData": "COD_TRANSPORTADOR"},
                {"mData": "RASTREAMENTO_CORREIO"},
                {"mData": "BRUTO",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "PRECO_MEDIO",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "TOTAL_NF",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "DESCRICAO"},
                {"mData": "CONHECIMENTO"},
                {"mData": "VALOR_FRETE",
                    render: $.fn.dataTable.render.number('.', ',', 2, 'R$')},
                {"mData": "PERCENTUAL",
                    render: $.fn.dataTable.render.number('.', ',', 2, '%')}
            ]
        });
        //$.fn.dataTable.ext.errMode = 'throw';
    }
    );
</script>
<div class="row"><br>
    <div class="col-xs-12">
        <div class="panel panel-default">
            <div class="panel-heading">Vendas</div>
            <div class="panel-body">
                <form action="jsonData.php?idCustomer=<?php echo $idCustomer ?>" method="post">
                    <table id="example" class="display nowrap" width="300%" cellspacing="0">
                        <thead>
                            <tr>
                                <th>TESTE</th>
                                <th>TESTE</th>
                                <th>TESTE</th>
                                <th>TESTE</th>
                                <th>TESTE</th>
                                <th>Empresa</th>
                                <th>NF</th>
                                <th>Emissão</th>
                                <th>Itens</th>
                                <th>Bruto</th>
                                <th>Desconto</th>
                                <th>Líquido</th>
                                <th>IPI</th>
                                <th>Subst. Trib.</th>
                                <th>Total NF</th>
                                <th>Preço Médio</th>
                                <th>Representante</th>
                                <th>Vendedor</th>
                                <th>Operador</th>
                                <th>Franqueado</th>
                                <th>Carteira</th>
                                <th>Transportadora</th>
                                <th>Rastreamento</th>
                                <th>Conhecimento</th>
                                <th>Frete</th>
                                <th>%</th>
                                <th>Ocorrência</th>
                                <th>Data Ocorrência</th>
                            </tr>
                        </thead>
                    </table>
                </form>
            </div>
        </div>
    </div>
</div>
<script>
    chamaScripts();
</script>

 

 

jsonData.php

 

<?php

require '../../../functions/conexao.php';
$idCustomer = $_REQUEST['idCustomer'];
//function notasVendas($idCustomer) {
$pdo = conecta();
$consultar = $pdo->prepare("SELECT NOTAS.NOTA,NOTAS.NRO_NOTA,NOTAS.EMISSAO,Sum(NOTAS_ITEM.QUANTIDADE) AS QUANTIDADE1, Sum(NOTAS_ITEM.TOTAL) AS TOTAL1,"
        . " Sum(NOTAS_ITEM.VALOR_DESCONTO) AS VALOR_DESCONTO1, Sum(NOTAS_ITEM.VALOR_IPI) AS VALOR_IPI1, Sum(COALESCE(NOTAS_ITEM.ICMS_SUBST_VALOR,0)) AS VALOR_SUBST, "
        . "REPRESENTANTES.NOME AS REPRES_NOME, VENDEDORES.NOME AS VENDEDOR_NOME, OP_TELEMARKETING.NOME AS OP_NOME, FRANQUEADOS.NOME AS FRANQUEADO_NOME, "
        . "TRANSPORTADORAS.NOME AS TRANSP_NOME, CARTEIRA.CARTEIRA, NOTAS.OCORRENCIA, COALESCE(NOTAS.DATA_OCORRENCIA,'0') AS DATA_OCORRENCIA, "
        . "NOTAS.COD_TRANSPORTADOR,NULLIF(PEDIDOS.RASTREAMENTO_CORREIO,'') AS RASTREAMENTO_CORREIO,"
        . "Sum(NOTAS_ITEM.VALOR_DESCONTO)+Sum(NOTAS_ITEM.TOTAL) AS BRUTO,"
        . "Sum(NOTAS_ITEM.TOTAL)/Sum(NOTAS_ITEM.QUANTIDADE)AS PRECO_MEDIO,"
        . "Sum(NOTAS_ITEM.TOTAL)+Sum(NOTAS_ITEM.VALOR_IPI)+Sum(COALESCE(NOTAS_ITEM.ICMS_SUBST_VALOR,0))AS TOTAL_NF "
        . "FROM NOTAS left outer join pedidos on (notas.pedido = pedidos.pedido) INNER JOIN CARTEIRA ON (NOTAS.COD_CARTEIRA = CARTEIRA.COD_CARTEIRA) "
        . "INNER JOIN NATUREZAS_OPERACAO ON (NOTAS.COD_NATUREZA = NATUREZAS_OPERACAO.COD_NATUREZA) AND (NOTAS.SEQ = NATUREZAS_OPERACAO.SEQ) INNER JOIN NOTAS_ITEM ON "
        . "(NOTAS.NOTA = NOTAS_ITEM.NOTA) INNER JOIN REPRESENTANTES ON (NOTAS.COD_REPRESENTANTE = REPRESENTANTES.CODIGO) INNER JOIN FRANQUEADOS ON "
        . "(NOTAS.COD_FRANQUEADO = FRANQUEADOS.CODIGO) INNER JOIN VENDEDORES ON (NOTAS.COD_VENDEDOR = VENDEDORES.CODIGO) INNER JOIN OP_TELEMARKETING ON "
        . "(NOTAS.COD_OP_TMK = OP_TELEMARKETING.CODIGO) INNER JOIN TRANSPORTADORAS ON (NOTAS.COD_TRANSPORTADOR = TRANSPORTADORAS.CODIGO) "
        . "Where NOTAS.COD_CLIENTE= :idCustomer AND (NATUREZAS_OPERACAO.TIPO=1) GROUP BY NOTAS.NOTA,NOTAS.NRO_NOTA,NOTAS.EMISSAO, REPRESENTANTES.NOME,"
        . "VENDEDORES.NOME, OP_TELEMARKETING.NOME, FRANQUEADOS.NOME, TRANSPORTADORAS.NOME, CARTEIRA.CARTEIRA, NOTAS.OCORRENCIA, NOTAS.DATA_OCORRENCIA, "
        . "NOTAS.COD_TRANSPORTADOR, PEDIDOS.RASTREAMENTO_CORREIO order by NOTAS.NOTA desc");
$consultar->bindValue(':idCustomer', $idCustomer, PDO::PARAM_INT);
$consultar->execute();
$i = 0;
$resultado = [];
while ($linha = $consultar->fetch(PDO::FETCH_ASSOC)) {

    $consultar2 = $pdo->prepare("SELECT CONHECIMENTO,VALOR_FRETE,"
            . "(VALOR_FRETE /" . $linha['TOTAL1'] . ")*100 AS PERCENTUAL FROM CONHECIMENTOS WHERE COD_ENTREGA=1 AND NF=" . $linha['NOTA']);
    $consultar2->execute();
    $linha2 = $consultar2->fetch(PDO::FETCH_ASSOC);
    if (($linha['COD_TRANSPORTADOR']) == 131) {
        $consultar3 = $pdo->prepare("SELECT DESCRICAO FROM OCORRENCIAS_TRANSP_MERCURIO WHERE ID= " . $linha['OCORRENCIA']);
        $consultar3->execute();
        $linha3 = $consultar3->fetch(PDO::FETCH_ASSOC);
    } else {
        $consultar3 = $pdo->prepare("SELECT DESCRICAO FROM OCORRENCIAS_TRANSP WHERE ID =" . $linha['OCORRENCIA']);
        $consultar3->execute();
        $linha3 = $consultar3->fetch(PDO::FETCH_ASSOC);
    }
    $arr[] = $linha;
    $arr2[] = $linha2;
    $arr3[] = $linha3;
    $resultado2 = $arr[$i];
    if (empty($resultado3)) {
        $resultado3 = array(
            "CONHECIMENTO" => 0,
            "VALOR_FRETE" => 0,
            "PERCENTUAL" => 0);
    } else {
        $resultado3 = $arr2[$i];
    }
    $resultado4 = $arr3[$i];

    $res = array_merge($resultado2, $resultado3, $resultado4);
    if (empty($resultado)) {
        array_unshift($resultado, $res);
    } else {
        array_push($resultado, $res);
    }
    $result = array("aaData" => $resultado);
    $i ++;
}
echo json_encode($result);
//}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Lá do manual: https://datatables.net/reference/option/ajax.data#Examples

$('#example').dataTable( {
  "ajax": {
    "url": "data.json",
    "data": {
        "user_id": 451
    }
  }
} );

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pois é cara, mas eu recebo o parametro ($idCustomer), aqui (na pagina sales.php)

$idCustomer = $_REQUEST['idCustomer'];

e se eu fosse enviar ele para a pagina jsonData.php, seria algo tipo isso?

$('#example').dataTable( {
  "ajax": {
    "url": "jsonData.php",
    "data": {
        "cod_cliente": $idCustomer = $_REQUEST['idCustomer'];
    }
  }
} );

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ai é uma confusão entre linguagens. PHP é um coisa e JavaScript é outra.

 

Como o PHP é processado no servidor e o JavaScript é processado no browser, você deve utilizar o PHP para criar/incluir/imprimir informações ao javascript pré-existente.

$('#example').dataTable( {
  "ajax": {
    "url": "jsonData.php",
    "data": {
        "cod_cliente": <?php echo $idCustomer; ?>
    }
  }
} );

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Valeu cara!! consegui resolver assim na sales.php

$('#example').dataTable( {
  "ajax": {
    "url": "jsonData.php",
    "type": 'POST',
    "data": {
        "idCustomer": <?php echo $idCustomer; ?>
    }
  }
} );

 

e pra receber o parametro na jsonData.php usei 

$idCustomer = $_POST['idCustomer'];

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.