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, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • 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
×

Informação importante

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