Jump to content
Rafael Motta

Manter tamanho da grade no carrinho de compras na $_SESSION

Recommended Posts

Boa tarde, estou tentando entender como faço para manter o valor do "Tamanho" na minha $_SESSION... no carrinho de compras... toda vez que insiro um produto o tamanho muda junto pelo valor do ultimo inserido... seguem os codigos, caso alguem saiba... Obrigado!

 

 

carrinho.php

<?php 
    session_start();
    if(!isset($_SESSION['carrinho'])){
        $_SESSION['carrinho'] = array();
    } 
        
        //adiciona produto
     
    if(isset($_GET['acao'])){
        
        //ADICIONAR CARRINHO
        
        if($_GET['acao'] == 'add'){
            $id = intval($_GET['id']);
            $tam = $_POST['tam'];
                        
            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($_GET['acao'] == '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]);
                        }
                }
            }
        }
   }
           
    ?>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title>Pedidos</title>
		<link href="css/bootstrap.min.css" rel="stylesheet">
                    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <title>Carrinho</title>
                <style>
                    #interna{
                        text-align: center;
                    }
                </style>
    </head>
    <body>
        <div class="col-md-12">
            <table class="table table-striped" border="1px" width=300 height=100 bgcolor="#d9d9d9">
        <caption>Carrinho de Compras</caption>
        <thead>
            <tr>
                <th>Produto</th>
                <th>Quantidade</th>
                <th>Preço</th>
                <th>SubTotal</th>
                <th>Remover</th>
            </tr>
        </thead>
        <form action="?acao=up" method="post">
        <tfoot>
            <tr>
                <td colspan="5"><input type="submit" value="Atualizar Carrinho" /></td>
            </tr>
            <td colspan="5"><a href="index.php">Continuar Comprando</a></td>
        </tfoot>
        <tbody>
     <?php
        if(count($_SESSION['carrinho']) == 0){
          echo '<tr>
                    <td colspan="5">Não há produto no carrinho</td>
                </tr>';
          }else{
                require("conexao.php");
                $total = 0;
                foreach($_SESSION['carrinho'] as $id => $qtd){
                        $pdo= conecta();
                        $resultado = $pdo ->prepare("SELECT max(ID_LISTA)AS ID FROM listas_preco where cod_cliente = 1");
                        $resultado->execute();
                        $lista = $resultado->fetch(PDO::FETCH_ASSOC);
                        $result = $pdo ->prepare("SELECT PRODUTOS.CODIGO, PRODUTOS.DESCRICAO AS DESC, listas_itens.PRECO FROM listas_itens
                            inner join produtos on (listas_itens.cod_produto = produtos.codigo)
                            inner join grupos_produto on (produtos.cod_grupo = grupos_produto.codigo)
                            WHERE PRODUTOS.CODIGO=".$id." and (listas_itens.id_lista = '".$lista['ID']."')");
                        $result->execute();
                        $ln = $result->fetch(PDO::FETCH_ASSOC);
                        $nome  = $ln['DESC'];
                        $preco = number_format($ln['PRECO'], 2, ',', '.');
                        $sub   = number_format($ln['PRECO'] * $qtd, 2, ',', '.');
                        $total += $ln['PRECO'] * $qtd;
                         echo '<tr height=70>'
                        . '<td><p>'. $nome .'</p><br/> Tamanho: '. $tam .'</td></br>
                                <td><input type="text" size="3" name="prod['.$id.']" value="'.$qtd.'" /></td>
                                <td>R$ '.$preco.'</td>
                                <td>R$ '.$sub.'</td>
                                <td><a href="?acao=del&id='.$id.'">Remove</a></td>
                            </tr>';
                }
                $total = number_format($total, 2, ',', '.');
                echo '<tr>
                            <td colspan="4">Total</td>
                            <td>R$ '.$total.'</td>
                    </tr>';
          }
                   ?>
         </tbody>
    </form>
 </table>
        </div>
</body>
</html>

 

Share this post


Link to post
Share on other sites

O que seria o tamanho?

Share this post


Link to post
Share on other sites

Então, desde ontem dei uma mexida no código e obtive algum êxito... Agora recebo o 'ID' da grade do produto e implemento no select mais ao fim do código, porem toda vez que envio ele, ele altera para o novo 'ID' inserido em todos os itens, mas o preço se mantém o correto, queria que este ($tam, que após o select, é extraído e vira $num['NUMERO']), alterasse junto com cada adição nova...

Sabe como eu poderia fazer isto?

 

 

carrinho.php

<?php 
    session_start();
    if(!isset($_SESSION['carrinho'])){
        $_SESSION['carrinho'] = array();
    } 
   
        
        //adiciona produto
     
    if(isset($_GET['acao'])){
        
        //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($_GET['acao'] == 'up'){
            if(is_array($_GET['prod'])){
                foreach($_GET['prod'] as $id => $qtd){
                        $id  = intval($id);
                        $qtd = intval($qtd);
                        if(!empty($qtd) || $qtd <> 0){
                            $_SESSION['carrinho'][$id] = $qtd;
                        }else{
                            unset($_SESSION['carrinho'][$id]);
                        }
                }
            }
        }
   }
    if(empty($_GET['tam'])){
       $tam = 1;
      }else{
        $tam = $_GET['tam'];
    }


    ?>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title>Pedidos</title>
		<link href="css/bootstrap.min.css" rel="stylesheet">
                    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <title>Carrinho</title>
                <style>
                    #interna{
                        text-align: center;
                    }
                </style>
    </head>
    <body>
        <div class="col-md-12">
            <table class="table table-striped" border="1px" width=300 height=100 bgcolor="#d9d9d9">
        <caption>Carrinho de Compras</caption>
        <thead>
            <tr>
                <th>Produto</th>
                <th>Quantidade</th>
                <th>Preço</th>
                <th>SubTotal</th>
                <th>Remover</th>
            </tr>
        </thead>
        <form action="" method="get">
        <tfoot>
            <tr>
                <td colspan="5"><input type="submit" value="Atualizar Carrinho" /></td>
            </tr>
            <td colspan="5"><a href="index.php">Continuar Comprando</a></td>
        </tfoot>
        <tbody>
     <?php
        if(count($_SESSION['carrinho']) == 0){
          echo '<tr>
                    <td colspan="5">Não há produto no carrinho</td>
                </tr>';
          }else{
                require("conexao.php");
                $total = 0;
                
                
                foreach($_SESSION['carrinho'] as $id => $qtd){
                        $pdo= conecta();
                        $resultado = $pdo ->prepare("SELECT max(ID_LISTA)AS ID FROM listas_preco where cod_cliente = 1");
                        $resultado->execute();
                        $lista = $resultado->fetch(PDO::FETCH_ASSOC);
                        
                        
                        $result = $pdo ->prepare("SELECT PRODUTOS.CODIGO,PRODUTOS.DESCRICAO AS DESC,GRADES_NROS.ID_NROGRADE,GRADES_NROS.COD_GRAD, GRADES_NROS.NUMERO, listas_itens.PRECO FROM listas_itens
                            inner join produtos on (listas_itens.cod_produto = produtos.codigo)
                            inner join grupos_produto on (produtos.cod_grupo = grupos_produto.codigo)
                            inner join GRADES_NROS on (produtos.cod_grade = grades_nros.cod_grad)
                            WHERE PRODUTOS.CODIGO=". $id ." and (listas_itens.id_lista = '". $lista['ID'] ."') and ID_NROGRADE=" . $tam);
                        $result->execute();
                        $ln = $result->fetch(PDO::FETCH_ASSOC);
                        
                        
                        $nome  = $ln['DESC'];
                        $preco = number_format($ln['PRECO'], 2, ',', '.');
                        $sub   = number_format($ln['PRECO'] * $qtd, 2, ',', '.');
                        $total += $ln['PRECO'] * $qtd;
                        $num = $ln['NUMERO'];
                         echo '<tr height=70>'
                        . '<td><p>'. $nome .'</p><br/> Tamanho: '. $num .'</td></br>
                                <td><input type="text" size="3" name="prod['.$id.']" value="'.$qtd.'" /></td>
                                <td>R$ '.$preco.'</td>
                                <td>R$ '.$sub.'</td>
                                <td><a href="?acao=del&id='.$id.'&tam='.$tam.'">Remove</a></td>
                            </tr>';
                         
                }
                
                $total = number_format($total, 2, ',', '.');
                echo '<tr>
                            <td colspan="4">Total</td>
                            <td>R$ '.$total.'</td>
                    </tr>';
          }
                   ?>
                </tbody>
                    <input type="hidden" name="acao" value="up"/>
                    <input type="hidden" name="tam" value="<?php echo $tam;?>"/>
           </form>
        </table>
    </div>
</body>
</html>

 

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 TheRonaldoStar
      Oii, fala ae pessoal!!
      Alguém pode me ajudar com uma coisa por favor?;
      Seguinte!, eu anteriormente fiz uma pergunta aqui no fórum recorrente a isso, mas eu conseguir uma solução parcial.
      Que era, fazer uma listagem de todos os cadastros e fazer a junção dos cadastros com uma coluna igual, Ou seja existem duas colunas [DE e Para], que recebem o id de quem está recebendo ou que está enviando a mensagem, eu conseguir fazer a tal listagem por grupo mas o problema que estou tendo é: que so faz o agrupamento de as colunas contiver o id por ex: [De = "1" e Para ="2"].
      Atualmente estou usando a codificação deste Jeito:
       
      $sql_2 = $db -> prepare("SELECT * FROM privado WHERE (Para = '$Meu_id') Or (De = '$Meu_id') GROUP BY Para, De DESC"); $sql_2 -> execute(); Esta consulta como pode ver ele busca todos os cadastros que tenha o meu ID ou seja do usuário online!, Após a consulta ele vei obter em um "while" somente o [ Id_De eo Id_Para ] desta forma:
      while($dados_2 = $sql_2 -> fetch(PDO::FETCH_OBJ)){ $Id_De = ($dados_2 -> De); $Id_Para = ($dados_2 -> Para); } Mas em fim eu gostaria de saber como mostrar somente um resultado ou seja o ultimo resultado que tiver o meu ID em ambas colunas [ Id_De ou Id_Para ].
      Antes de vocês me recomendar a função DESC LIMIT 'valor' saiba eu quero que liste todos os usuários que enviou ou recebeu minha mensagem não somente 1 ou seja se eu mandar um mensagem para o usuário 2 e ele me retornar uma mensagem vai mostrar somente o ultimo registro que tenha o meu ID e o id dele.
       
      Atenciosamente,
      ~Ronaldo
       
    • By TheRonaldoStar
      Oi, mais cedo eu fiz um post aqui no site mas um pouco longo creio eu que e mais fácio eu fazer uma pergunta mais direta.
      A pergunta é:
      Como posso fazer agrupamentos de uma tabela através de dois campos cujo os valores são =, mesmo que esteja invertidos?
      EX: [DE = "1"], [PARA = "2"].
      E fazer o agrupamento ou só mostrar o ultimo cadastro mesmo que eles estejam invertidos desta forma?
      EX: [DE = "2"], [PARA = "1"].
       
      Acho que agora com este post fui mais claro, Alguém pode me ajudar por favor??.
      Atenciosamente,
      ~Ronaldo
    • By HigorCrds
      Bom, o que eu consegui até agora foi fazer com que, ao usuário clicar em algum dos botões de paginação (1, 2, 3...) o PHP guarde uma SESSION com o número da página correspondente.
      Segue o código:
       
      <!-- BOTÃO COM O NÚMERO DA PÁGINA --> <button onclick="mudaVar(<?php echo $i; ?>);"> <?php echo $i; ?> </button> <!-- FUNÇÃO PARA GUARDAR SESSION PG --> function mudaVar(valor) { $.ajax({ url:'sessions.php?valor='+valor }); } // GUARDA SESSION PG if(isset($_GET['valor'])){ $_SESSION['pg'] = $_GET['valor']; } Até aí tudo bem, só que o problema é que a SESSION não é alterada naquele momento, só quando eu atualizo a página.
      Como corrigir isso?
    • By Carcleo
      A ideia:
       
      toda e entrada no site, seja com link direto do tipo:
       
      www.site.com.br/pasta1/pasta2/arquivo.php  
      ou normal url amigável
       
      www.site.com.br/categoria/tipo  
      tudo queria que redirecionasse para o index.php da raiz do site.
       
      E que, caso o arquivo ou pasta NÃO existisse, abrisse normalmente a pagina 404.php
       
       
      Tentei de tres formas mas nenhuma dá certo.
       
      Primeira forma
      RewriteEngine On ErrorDocument 400 http://www.sortecard.com.br/index.php ErrorDocument 401 http://www.sortecard.com.br/401.php ErrorDocument 403 http://www.sortecard.com.br/403.php ErrorDocument 404 http://www.sortecard.com.br/404.php ErrorDocument 500 http://www.sortecard.com.br/500.php php_value allow_url_fopen on php_value allow_url_include on php_flag mail_filter 0 RewriteCond %{HTTP:X-Forwarded-Proto} !https RewriteCond %{HTTPS} off RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301] RewriteCond %{SCRIPT_FILENAME} !-f RewriteCond %{SCRIPT_FILENAME} !-d RewriteRule ^(.*)$ index.php?page=$1 Segunda forma:
      Options +FollowSymLinks DirectorySlash On RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f [OR] RewriteCond %{REQUEST_FILENAME} \.php$ RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?request=$1 [L] Terceira forma:
      RewriteEngine On ErrorDocument 400 http://www.sortecard.com.br/index.php ErrorDocument 401 http://www.sortecard.com.br/401.php ErrorDocument 403 http://www.sortecard.com.br/403.php ErrorDocument 404 http://www.sortecard.com.br/404.php ErrorDocument 500 http://www.sortecard.com.br/500.php php_value allow_url_fopen on php_value allow_url_include on php_flag mail_filter 0 RewriteCond %{HTTP:X-Forwarded-Proto} !https RewriteCond %{HTTPS} off RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301] RewriteRule ^(.*)$ index.php?page=$1 Problemas:
       
      A) Quando acesso a url diretamente não está redirecionando para o index.
      B) Quando falo que é para redirecionar todos os arquivos ele não me dá os parêmetros. 
    • By Pellegrini3834
      Ola galera do IMasters!!!!!!
       
      Estou com uma duvida eu tenho um CRUD em php MVC e queria saber em que camada fica as mensagens depois de uma realização de um evento por exemplo:
      Cadastro de Pessoa, depois de cadastrada quero que ele emita uma mensagem dizendo que a "PESSOA FOI CADASTRADA COM SUCESSO!!!!" e eu queria saber  em que parte ela fica se é no Controle ou na View porque sabemos que no modelo fica a parte referente a manipulação de dados.
      Obrigado.
×

Important Information

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