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 ILR master
      Fala galera, tudo bem?
       
      Tenho o seguinte codigo:
       
       class Data {
      public static function ExibirTempoDecorrido($date)
      {
          if(empty($date))
          {
              return "Informe a data";
          }
          $periodos = array("segundo", "minuto", "hora", "dia", "semana", "mês", "ano", "década");
          $duracao = array("60","60","24","7","4.35","12","10");
          $agora = time();
          $unix_data = strtotime($date);
          // check validity of date
          if(empty($unix_data))
          {  
              return "Bad date";
          }
          // is it future date or past date
          if($agora > $unix_data) 
          {  
              $diferenca     = $agora - $unix_data;
              $tempo         = "atrás";
          } 
          else 
          {
              $diferenca     = $unix_data - $agora;
              $tempo         = "agora";
          }
          for($j = 0; $diferenca >= $duracao[$j] && $j < count($duracao)-1; $j++) 
          {
              $diferenca /= $duracao[$j];
          }
          $diferenca = round($diferenca);
          if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
          return "$diferenca $periodos[$j] {$tempo}";
      }
      }
       
      Funciona redondinho se o valor retornado for de algumas horas, mas...
      Quando passa de dois meses, ele retorna a palavra mess. Deve ser por conta dessa linha
      if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
       
      Quero que modre:
       
      2 meses atrás
      e não
      2 mess atrás.
       
      Espero que tenham entendido.
       
      Valeu
    • Por Carlos Web Soluções Web
      Olá...
      Estou tentando fazer o seguinte !!
      Listando dados em tabela !!
      Gostaria que....se na listagem houver 4 linhas...indepedente de seu número de ID, faça a listagem em ID ser em ordem 1 2 3 4 !!
      Exemplo...se tiver uma listagem de dados que está em ID 1 3 3...faça ficar 1 2 3 !!

       
      echo "<table class='tabela_dados' border='1'> <tr> <td>ID</td> <td>Nome Empresa</td> <td>Responsável</td> <td>Telefone 1</td> <td>Telefone 2</td> <td>E-mail 1</td> <td>E-mail 2</td> <td>Endereço</td> <td>CEP</td> <td>Bairro</td> <td>AÇÃO 1</td> <td>AÇÃO 2</td> </tr> "; $sql = "SELECT ID FROM usuarios_dados WHERE Usuario='$usuario'"; $result = $conn->query($sql); $num_rows = $result->num_rows; $Novo_ID = 1; for ($i = 0; $i < $num_rows; $i++) { $registro = $result -> fetch_row(); $sql2 = "UPDATE usuarios_dados SET ID='$Novo_ID' WHERE ID='$Novo_ID'"; $result2 = $conn->query($sql2); $Novo_ID++; } $sql = "SELECT * FROM usuarios_dados"; $result = $conn->query($sql); if ($result->num_rows > 0) { // output data of each row while($row = $result->fetch_assoc()) { echo "<tr> <td>$row[ID]</td> <td>$row[Nome_Empresa]</td> <td>$row[Responsavel]</td> <td>$row[Telefone_1]</td> <td>$row[Telefone_2]</td> <td>$row[Email_1]</td> <td>$row[Email_2]</td> <td>$row[Endereço]</td> <td>$row[CEP]</td> <td>$row[Bairro]</td> <td> <form method='post' action='Editar_Dados.php'> <input type='hidden' name='usuario' value='$usuario'> <input type='hidden' name='senha' value='$senha'> <input type='hidden' name='ID' value='$row[ID]'> <input type='submit' style='padding: 10px;' value='EDITAR'> </form> </td> <td> <form method='post' action='Deletar_Dados.php'> <input type='hidden' name='usuario' value='$usuario'> <input type='hidden' name='senha' value='$senha'> <input type='hidden' name='ID' value='$row[ID]'> <input type='submit' style='padding: 10px;' value='DELETAR'> </form> </td> </tr> "; } } else { echo "0 results"; } $conn->close();  
    • Por ILR master
      Boa tarde pessoal, tudo bem ?
       
      Eu uso o tinymce para cadastro de textos no meu siite, porém, quero fazer um sistema para que os colunistas possam fazer o próprio post.
      O problema do tinymce, é que ele mantém a formatação do texto copiado, como tamanho de fonts, negritos, etc... Quero que o usuário cole o texto e a própria textarea limpe a formatação para que ele formate como quiser.
       
      A pergunta é:
       
      O tinymce tem uma opção para desabilitar a formatação quando um texto é colocado?
      Tem alguma função via java ou php para retirar a formatação assim que o texto é colado?
      Ou é melhor usar um outro editor?
       
      Agradeço deste já.
    • Por Giovanird
      Olá a todos!
      Tenho uma pagina que possui uma DIV onde coloquei uma pagina PHP.
      Uso a função setInterval para atualizar a pagina inclusa dentro da DIV.
      O problema é que ao acessar o site , a DIV só me mostra a pagina inclusa somente quando completo o primeiro minuto.
      Preciso que a pagina inclusa já inicie carregada
       
      Meu código JavaScript e a DIV com a pagina PHP
       
      <script> function atualiza(){ var url = 'direita.php'; $.get(url, function(dataReturn) { $('#direita').html(dataReturn); }); } setInterval("atualiza()",60000); </script> <div> <span id="direita"></span> </div>  
    • Por ILR master
      Fala pessoal.
       
      Seguinte:
       
      Quero selecionar duas tabelas e mostrar com resultados intercalados. Abaixo segue um código explicando para vcs terem uma ideia.
       
      $consulta = "SELECT A.*, B.* FROM tabela1 A, tabela2 B'";
      $resultado = mysqli_query($conexao, $consulta) or die ("erro");
      while($busca = mysqli_fetch_array($resultado)){
       
      print $busca['cod_evento']; --> traz o código da tabela1 
      print $busca['titulo_evento']; -->  traz o titulo da tabela1
      print $busca['cod_noticia']; --> traz o código da tabela2
      print $busca['titulo_noticia']; --> traz o tituloda tabela2
       
      }
       
      Espero que entendam. Grato
       
×

Informação importante

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