Ir para conteúdo

Arquivado

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

dutopfave

Atualizar Carrinho de Compras

Recommended Posts

Boa Noite, tenho um sistema de carrinho de compra, mais ajustei para um sistema de vendas/estoque, pega normal, seleciona o produto, tem como atualizar a qtd e excluir, mais o cliente pediu para adicionar um campo q chama valor adicional, q pode ser usado para coloca um valor de frete por exemplo ou taxa (%), ate blz ta certo, mais quando seleciono dois produto, e coloco um valor adicional em 1 dos produtos, ele acaba atualizando os 2 produto, e ele só funciona se coloca o valor no produto em ordem decrescente, se o produto q adiciono primeiro, coloca um valor adicional, ele não funciona, fica como 0, ai se coloca o valor no 2 produto adicionado, ai ele adiciona só q nos dois 2 produto, certo seria mostra o valor adicional no produto desejável, segue o código:

 

cogido em php que faz todo o funcionamento, foca apenas no  " if(isset($_POST['adicional'])){  "  q é aonde atuliza o valor adicional

<?php
      session_start();
       
      if(!isset($_SESSION['carrinho'])){
         $_SESSION['carrinho'] = array();
      }
       
      //adiciona produto
       

          
         //ADICIONAR CARRINHO
         if($_GET['acao'] == 'add'){
            $id = intval($_GET['id']);
            if(!isset($_SESSION['carrinho'][$id])){
               $_SESSION['carrinho'][$id] = 1;
            }else{
               $_SESSION['carrinho'][$id] += 1;
            }
         }
          
         //REMOVER CARRINHO
         if($_GET['acao'] == 'del'){
            $id = intval($_GET['id']);
            if(isset($_SESSION['carrinho'][$id])){
               unset($_SESSION['carrinho'][$id]);
            }
         }
          
         //ALTERAR QUANTIDADE
         if(isset($_POST['up'])){
            if(is_array($_POST['prod'])){
               foreach($_POST['prod'] as $id => $qtd){
                  $id  = intval($id);
                  $qtd = intval($qtd);
                  if(!empty($qtd) || $qtd <> 0){
                     $_SESSION['carrinho'][$id] = $qtd;
                  }else{
                     unset($_SESSION['carrinho'][$id]);
                  }
               }
            }

            
         }

		//ALTERAR VALOR ADICIONAL
            if(isset($_POST['adicional'])){
         if(is_array($_POST['prods'])){
               foreach($_POST['prods'] as $id => $p_valor_adicional){
                  $id  = intval($id);
                  $p_valor_adicional = intval($p_valor_adicional);
                  if(!empty($p_valor_adicional) || $p_valor_adicional <> 0){
                     $_SESSION['carrinho'][$id] = $p_valor_adicional;
                  }else{
                     unset($_SESSION['carrinho'][$id]);
                  }
               }
            }
        

        
      }
       
       
?>

 

codigo do html e php, com o select listando os produtos:

 

<div class="row">
                    <div class="col-lg-12">
                        <div class="card">
                            <div class="card-block">
                                
                                <h4 class="card-title">Resumo do Pedido</h4>
                                <div class="table-responsive m-t-20">
                                    <table class="table stylish-table color-table muted-table">
                                        <thead>
                                            <tr>
                                                <th>Produto</th>
                                                <th class="text-center">Quantidade</th>
                                                <th class="text-center">Preço</th>
                                                <th class="text-center">Preço Adicional</th>
                                                <th class="text-center">Total</th>
                                                <th> </th>
                                            </tr>
                                        </thead>
                                        <form action="?id_cliente=<?php echo $_GET['id_cliente']; ?>" method="post">
                                        <tbody>

                                        <?php
            
                                            if(count($_SESSION['carrinho']) == 0){
                                                 echo '<tr>
                                                       <td class="center top-20 bottom-40" style="text-align: center; padding: 20px;" colspan="5"><img src="assets/images/icon_cart.fw.png"><br/>Não há produto no carrinho</td>
                                                       </tr>';
                                            }else{

                                            foreach($_SESSION['carrinho'] as $id => $qtd){
                                                
                                            $Seleciona_Produtos = $pdo->prepare("SELECT * FROM tb_sys_produtos WHERE p_id = :id");
                                            $Seleciona_Produtos->bindValue(":id", $id);
                                            $Seleciona_Produtos->execute();
                                            if($Seleciona_Produtos->rowCount() > 0){

                                            foreach($Seleciona_Produtos->fetchAll() as $ResAssoc){
                                             $Total += $ResAssoc['p_valor_venda'] * $qtd + $p_valor_adicional;
                                      
                                            echo '<tr>';
                                            echo '<td class="">'.$ResAssoc['p_nome'].'</td>';
                                            echo '<td class="text-center"><input type="text" size="3" class="text-center" name="prod['.$id.']" value="'.$qtd.'" /></td>';
                                            echo '<td class="text-center">R$ '.number_format($ResAssoc['p_valor_venda'],2,",",".").'</td>';
                                            echo '<td class="text-center"><input type="text" size="10" class="text-center" name="prods['.$id.']" value="'.$p_valor_adicional.'" /></td>';
                                            echo '<td class="text-center">R$ '.number_format($ResAssoc['p_valor_venda'] * $qtd + $p_valor_adicional,2,",",".").'</td>';
                                            echo '<td class="text-center"><a href="?id_cliente='.$_GET['id_cliente'].'&acao=del&id='.$id.'" class="text-inverse btn btn-danger btn-xs" title="" data-toggle="tooltip" data-original-title="Dar Baixa"><i class="ti-trash" style="color:#fff;"></i></a></td>';
                                            echo '</tr>';

                                                
                                            }
                                        }
                                    
                                    }
                                        ?>

                                        <tr>
                                            <td><button type"submit" name="up[]" class="btn btn-primary ladda-button" data-style="zoom-out">
                                                <span class="ladda-label fa fa-refresh"></span> Atualizar Quantidade
                                                </button>
                                            </td>

                                            
                                                <td><button type"submit" name="adicional[]" class="btn btn-success ladda-button" data-style="zoom-out">
                                                <span class="ladda-label fa fa-refresh"></span> Atualizar Adicional
                                                </button>
                                            </td>
                                            

                                            <td></td>
                                            <td></td>
                                            
                                            <td class="text-center"><h5>Subtotal</h5></td>
                                            <td class="text-center"><h5><strong>R$<?php echo number_format($Total,2,",","."); ?></strong></h5></td>
                                        </tr>

                                        <tr>
                                            <td>   </td>
                                            <td>   </td>
                                            <td></td>
                                            <td></td>
                                            
                                            <td class="text-center"><h3>Total</h3></td>
                                            <td class="text-center"><h3><strong>R$<?php echo number_format($Total + $taxa,2,",","."); ?></strong></h3></td>
                                        </tr>

                                        <tr>
                                            <td>   </td>
                                            <td>   </td>
                                            <td></td>
                                            <td></td>
                                            <td class="text-center">
                                            <a href="fatura_novo_busca.php?id_cliente=<?php echo $_GET['id_cliente']; ?>"><button type="button" class="btn btn-default ladda-button" data-style="zoom-out">
                                                <span class="ladda-label fa fa-search"></span> Nova Busca
                                            </button></a></td>
                                            <td class="text-center">
                                            <?php
                                    if(isset($_POST['enviar'])){
                                        $v_data = date('Y-m-d :H:i:s');
                                        $cliente = $_GET['id_cliente'];
                                        $SqlInserirVenda = $pdo->prepare("INSERT INTO tb_sys_vendas (v_codigo, v_cliente, v_valor_total, v_data) VALUES (:v_codigo, :v_cliente, :v_valor_total, :v_data)");
                                        $SqlInserirVenda->bindValue(":v_codigo", $chave_key2);
                                        $SqlInserirVenda->bindValue(":v_cliente", $cliente);
                                        $SqlInserirVenda->bindValue(":v_valor_total", $Total);
                                        $SqlInserirVenda->bindValue(":v_data", $v_data);
                                        $SqlInserirVenda->execute();
                                        
                                        $vi_id_venda = $pdo->lastInsertId();
                                        
                                        
                                        foreach($_SESSION['carrinho'] as $ProdInsert => $qtd):
                                            $SqlInserirItens = $pdo->prepare("INSERT INTO tb_sys_vendas_itens (vi_id_venda, vi_id_produto, vi_id_cliente, vi_qtd) VALUES (:vi_id_venda, :vi_id_produto, :vi_id_cliente, :vi_qtd)");
                                            $SqlInserirItens->bindValue(":vi_id_venda", $vi_id_venda);
                                            $SqlInserirItens->bindValue(":vi_id_produto", $ProdInsert);
                                            $SqlInserirItens->bindValue(":vi_id_cliente", $cliente);
                                            $SqlInserirItens->bindValue(":vi_qtd", $qtd);
                                            $SqlInserirItens->execute();

                                         $calcular = $id;

                                        $UpProduto = $pdo->prepare("UPDATE tb_sys_produtos SET p_disponivel_estoque = p_disponivel_estoque - :qtd WHERE p_id = :ProdInsert");
                                        $UpProduto->bindValue(":qtd", $qtd);
                                        $UpProduto->bindValue(":ProdInsert", $ProdInsert);
                                        $UpProduto->execute();
                                        endforeach;


                                        $pagina = 'visualizar_fatura.php?id_fatura='.$vi_id_venda.'';
                                        echo "<script>parent.location = '$pagina';</script>";
                                        
                                        unset($_SESSION['carrinho']);
                                    }
                                ?>
                                
                                    <form action="" enctype="multipart/form-data" method="post">
                                        <input type="submit" name="enviar" class="btn btn-danger ladda-button" data-style="zoom-out" value="Finalizar Pedido">
                                    </form></td>
                                </tr>
                                <?php } ?>
                                            
                                            
                                        </tbody>

                                    </form>
                                    </table>

                                  
                                </div>
                            </div>
                        </div>
                    </div>
    
                </div>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá.

Se puder grave um vídeo com o problema gravando a tela e narrando o problema, mande para o Youtube e poste aqui o LINK  que fica mais fácil vermos o problema e tentar lhe ajudar.

Abraços!

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
    • Por ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
×

Informação importante

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