Jump to content
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>

 

Share this post


Link to post
Share on other 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!

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By neto_celino
      Estou usando o seguinte código para somar um SELECT, mas cheguei em um determinado ponto que travei.
       
      Tenho 400 registros na DB e tenho que somar alguns registros somente. Ou seja, somar o (valortotal) de alguns ID's somente. 
      É possivel e por onde vou ? rs.
      <?php $subtotal = "SELECT SUM(valortotal) from tbl_compras WHERE id = VariosIdAqui"; $resultado = mysql_query($subtotal); $registro = mysql_fetch_row($resultado); echo number_format($registro[0], 2, ',', ' ') ;  ?>      
    • By Camilavip
      Oi, como consigo fazer uma página de erro ou redirecionamento ou aviso, caso alguém clique em um cadastro que já não existe ou não tenha?
      localhost/clientes/12/ricardo No exemplo acima eu clico no cliente com esse id 12 e abre os dados dele, mas se eu o excluir mas estiver com o link e colocar no navegador, ele abre a página, sem os dados dele, mas abre. Eu queria se caso não tivesse mais o id cadastrado, abrisse algo como nenhum cadastro encontrado ou existente.
    • By mamotinho
      Olá, gostaria de sabe como posso fazer uma contagem regressiva apartir de um registro em meu banco de dados eu tentei montar um código da seguinte forma:

       
      <? $DateGET = date('m/d/Y H:i A', strtotime($result->DateDiscount)); ?> <script> var valueDate = <?=$DateGET?>; var end = new Date(valueDate); var _second = 1000; var _minute = _second * 60; var _hour = _minute * 60; var _day = _hour * 24; var timer; function showRemaining() { var now = new Date(); var distance = end - now; if (distance < 0) { clearInterval(timer); document.getElementById("countdown").innerHTML = "EXPIRED!"; return; } var days = Math.floor(distance / _day); var hours = Math.floor((distance % _day) / _hour); var minutes = Math.floor((distance % _hour) / _minute); var seconds = Math.floor((distance % _minute) / _second); document.getElementById("countdown").innerHTML = "<span class='n_date day' id='days'>" + days + "</span><span class='date'>일</span>"; document.getElementById("countdown").innerHTML += "<span class='n_time hour' id='hrs'>" + hours + "</span>"; document.getElementById("countdown").innerHTML += "<span class='n_time minute' id='minus'>" + minutes + "</span>"; document.getElementById("countdown").innerHTML += "<span class='n_time second' id='secs'>" + seconds + "</span>"; } timer = setInterval(showRemaining, 1000); </script> Mais infelizmente não passou a data registrada no banco de dados, alguém teria ideia de como posso ta fazendo.
    • By emmanuelsiqueira30
      Pessoal preciso de uma ajudinha aqui se alguém puder me ajudar fico muito agradecido.
      O problema é o seguinte gostaria de editar dados de um formulário com checkbox usando html e php.
      Desde já agradeço por toda ajuda.
    • By liniker.o
      Boa tarde pessoal!
      Estou com um problema em meu código quando coloco uma referencia de fonte a mesma não carrega, quando faça o mesmo procedimento local colocando os caminhos de pasta funciona normalmente.
      Será que alguém poderia me ajudar?
      Segue o código.
      <html> <head> <title>Minha pagina</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <!-- Se não declarar charset por meta, envie um header de igual valor --> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <?php //Carregar imagem tamanho da imagen = 515x76 $img = ImageCreateFromJPEG("base.jpg"); //Definir cor $cor1 = imagecolorallocate($img, 0, 0, 0); $cor2 = imagecolorallocate($img, 0, 0, 0); // carregar fonte... $fonte1 = 'https://ff.static.1001fonts.net/r/o/roboto-condensed.light.ttf'; $fonte2 = 'https://ff.static.1001fonts.net/r/o/roboto-condensed.light.ttf'; //Escrever nome $txtNome = $_POST['nome']; $txtFuncao = $_POST['func']; $txtEmail = $_POST['email']; $txtDDD = "+55 ".$_POST['telefone']; // IMAGEM, TAMANHO_FONTE, 0, POSICAO X, posicao Y, TEXTO_COR, ARQ_FONTE, TEXTO imagettftext($img, 32, 0, 250, 100, $cor1, $fonte1, $txtNome); imagettftext($img, 18, 0, 250, 125, $cor1, $fonte2, $txtFuncao); imagettftext($img, 18, 0, 250, 150, $cor1, $fonte2, $txtEmail); imagettftext($img, 18, 0, 250, 180, $cor1, $fonte2, $txtDDD); //Header e output header('Content-type: image/jpeg'); imagejpeg($img,"Assinatura - ".$txtNome.".jpg"); imagedestroy($img); header('Location: Assinatura - '.$txtNome.'.jpg'); ?>  
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.