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 manolegal
      Olá amigos(as) do Fórum.
      Tenho um número inteiro no PHP e preciso inseri-lo no Postgresql com 02 casas decimais.
      Defini o campo no Postgresql do tipo numeric(14,2)
      O valor está assim no PHP:
      2961966 Preciso gravar no BD da seguinte maneira:
      29619.66 Porém está gravando da seguinte forma:
      2961966.00 Tentei utilizando number_format, porém não consegui:
      $numero_bd = number_format($numero, '.', ''); $numero_bd = number_format($numero,2,"."); $numero_bd = number_format($numero,2,","numerovalor_ref_15,2,",","."); Caso alguém possa me ajudar, desde já agradeço.
    • By Sapinn
      Opa galera tudo blz? Então, me deparei com um pequeno problema no desenvolvimento de um projeto, eu gostaria que o usuário se mantivesse logado caso ele marcasse um check box com a opção de "Mantenha-me conectado", e até entendo que nessa caso devo usar os cookies do PHP, entretanto, não entendi ainda como usar esse recurso, alguém pode me ajudar??
    • By lezão
      Boa noite!
      Estou tentando fazer um codigo de horario de atendimento, e naun estou tendo resultados.
      Alguem pode me ajudar :
      <?php if ($hoje = 3 & $hoje < 5 & $hora >= 0 & $hora < 08){ echo "<font face='verdana', arial' size=2 color='red'>Fechado</font>";} else if ($hoje > 3 & $hoje < 5 & $hora >= 08 & $hora < 18){ echo "<font face='verdana', arial' size=2 color='red'>Fechado</font>";} else if ($hoje = 3 & $hora >= 18 & $hora < 23){ echo "<font face='verdana', arial' size=2 color='green'>Aberto</font>";} ?>  
    • By AndersonWS
      Meu site está caindo muito nos últimos dias. Basicamente acessa e não aparece nada, uma tela em branco. O pessoal da hospedagem falou que tenho que otimizar o banco de dados e que o problema é esse. Acho estranho pois o mesmo site não caia e agora "do nada" tem esse problema. Fiz um teste de tracert no cmd para ver as rotas e deu a mensagem: Esgotado o tempo limite do pedido. Isso me parece o problema e não o banco de dados.
      Otimização do banco tem alguma coisa a ver com essa mensagem?
      Poderia o site por não estar muito otimizado simplesmente não mostrar nada na tela? Não deveria carregar ao menos o html?
      Se não for o local certo da pergunta me perdoem mas como falaram que o problema era o banco de dados postei aqui.
      Grato.
    • By Felper
      Criei um sistema de login com php e mysql mas não consigo realizar o login mesmo tendo certeza de que os dados foram cadastrados com sucesso. Não sei o que fiz de errado. Vejam o código:
      <?php $login2 = $_POST['loginlogar']; $senha2 = $_POST['senhalogar']; $link = mysqli_connect("localhost", "root", "", "bancolanche") or die("<h1>Não foi possível conectar!!</h1>". mysqli_error()); $banco = mysqli_select_db($link, "bancolanche") or die("<h1>Não foi possível abrir banco de dados!!</h1>". mysqli_error()); $sql = "SELECT login, senha FROM users"; $resulta = mysqli_query($link, $sql); while ($book = $resulta->fetch_object()) { $logindb = $book->login; $senhadb = $book->senha; } if($login2 == "" || $senha2 == ""){ $_SESSION['msg'] = "<h1 style='color:red'>Erro ao logar! Há campos de preenchimento obrigatório em branco.</h1>"; header("Location: logar.php"); } else { if($logindb==$login2 && $senhadb==$senha2){ $_SESSION['msg'] = "<h1 style='color:green'>Logoff realizado com sucesso!</h1>"; header("Location: index.html"); } else { $_SESSION['msg'] = "<h1 style='color:red'>Erro ao logar! Usuário inexistente ou senha incorreta.</h1>"; header("Location: logar.php"); } } mysqli_close($link); ?>  
×

Important Information

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