Fórum OpenCart Brasil

Por um e-commerce livre, confiável e profissional

#729
Atualização de 22/07/2013
- Mudança no funcionamento: se o preço do produto for inferior a 2x o valor da parcela mínima, nada é exibido (nem mesmo o título "Parcelamento no cartão de crédito"). Modificação feita a pedido de Antonio Fragueiro, que queria um meio de esconder o parcelamento nos produtos com preço a consultar (que ele deixava com preço de R$ 0,01).

Atualização de 16/06/2011
- Acrescentadas instruções sobre a configuração da moeda da loja, caso o parcelamento não apareça

Atualização de 22/05/2011
- Corrigido problema causado por alguns templates que faziam com que o cálculo não funcionasse (obrigado andersonnarciso!). Veja a explicação aqui.

Atualização de 25/10/2010
- Adicionada opção de parcela mínima a pedido de NathanMuniz
- Adicionado cálculo de parcelas seguindo a Tabela Price usada pelo PagSeguro
- A moeda para exibição dos valores agora pode ser configurada
- A fórmula de cálculo das parcelas agora pode ser configurada
- As parcelas sem juros são exibidas na cor verde

Leia o post completo para conhecer todas as novidades. E antes de postar uma dúvida, leia todo o tópico: ela já pode ter sido respondida.
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Olá a todos!
Comecei a usar o OpenCart para montar a minha loja virtual e já estou nessa há alguns meses. Hoje andando pelo fórum vi o tópico do usuário thiiix7 onde ele explica como inserir as opções de parcelamento através de um sistema fornecido pelo Pagamento Digital. Inspirado por esse tópico, resolvi colaborar com a comunidade e criar outra função que faz o cálculo diretamente através do PHP, sem depender de um sistema externo.

Características
- Facilmente configurável no código
- Roda diretamente no sistema da loja sem depender de servidores externos
- Permite definir a quantidade máxima de parcelas
- Permite definir o valor mínimo para parcelamento
- Permite definir quantas parcelas não terão juros (para lojas que utilizam, p.ex., até 3x sem juros ou até 12x com juros de 1,99% ao mês)
- Duas fórmulas para cálculo do parcelamento: juros simples e tabela Price

Imagem

Antes de começar
Acesse a configuração de moeda da sua loja e certifique-se de que o símbolo de moeda seja igual a "R$ " (sem aspas e com um espaço no final). Devido a uma limitação do OpenCart, a função de cálculo de parcelamento precisa remover o símbolo manualmente antes de fazer os cálculos, e ela está programada para remover o R$ com espaço no final. Se você não fizer esta alteração, o cálculo de parcelamento não funcionará.

Se sua loja usa outra moeda ou se você quiser usar o R$ sem o espaço no final, basta alterar a variável $moeda_da_loja abaixo (repare que nesta variável um espaço depois do R$).

Para inserir
1. Abra o arquivo /catalog/view/theme/<seu tema>/template/product/product.tpl.
2. Escolha onde você quer inserir as opções de parcelamento. Eu inseri depois do seguinte bloco de código (que exibe a classificação do produto):
Código: Selecionar todos
                  <?php echo $text_no_rating; ?>
                  <?php } ?></td>
              </tr>
			  <?php } ?>
            </table>
            <br />
3. Insira o seguinte código:
Código: Selecionar todos
            <!-- Exibicao de parcelas -->
              <?php
                /*
                  Configuracoes do sistema de parcelamento
                  ----------------------------------------
                  $maximo_parcelas = Define a quantidade maxima de parcelas aceita pela loja
                  $parcela_minima = Valor minimo da parcela aceito pela loja
                  $parcelas_sem_juros = Define quantas parcelas nao terao juros
                  $juros = Taxa de juros mensal
                  $moeda_da_loja = Permite especificar a moeda utilizada na loja

                  $tipo_de_calculo = Permite escolher o tipo de calculo a ser utilizado
                  0 = Juros simples (Pagamento Digital)
                  1 = Tabela Price (PagSeguro e outros)
                */

                $maximo_parcelas = 12;
                $parcela_minima = 5;
                $parcelas_sem_juros = 1;
                $juros = 1.99;
                $moeda_da_loja = 'R$ ';
                $tipo_de_calculo = 0;

                if (!$special) {
                  $preco_numero = str_replace(',','.',str_replace('.','', str_replace($moeda_da_loja,"",strip_tags($price))));
                } else {
                  $preco_numero = str_replace(',','.',str_replace('.','', str_replace($moeda_da_loja,"",strip_tags($special))));
                }

                if ($preco_numero >= $parcela_minima*2) {

                // Titulo
                echo '<b>Parcelamento no cart&atilde;o de cr&eacute;dito</b><br />';
                echo '<table width="100%">';

                // Inicia a primeira coluna
                echo '<div style="width: 50%; float:left;">';

                // Exibicao das parcelas
                for ($p = 2; $p <= $maximo_parcelas; $p++) {

                  // Se a parcela nao tiver juros
                  if ($p <= $parcelas_sem_juros) {
                    $valor_parcela = $preco_numero / $p;
                  }

                  // Se a parcela tiver juros
                  if ($p > $parcelas_sem_juros) {
                    if ($tipo_de_calculo == 0) {
                      $valor_parcela = ($preco_numero * pow(1+($juros/100), $p))/$p;
                    }
                    if ($tipo_de_calculo == 1) {
                      $valor_parcela = ($preco_numero * ($juros/100))/(1-(1/(pow(1+($juros/100), $p))));
                    }
                  }

                  // Escreve a parcela se ela for maior do que a parcela minima
                  if ($valor_parcela >= $parcela_minima) {
                    $valor_parcela = number_format($valor_parcela, 2, ',', '.');
                    if ($p <= $parcelas_sem_juros) {
                      echo '<span style="color: darkgreen;">' . $p . 'x de ' . $moeda_da_loja . $valor_parcela . ' sem juros</span><br />';
                    } else {
                      echo $p . 'x de ' . $moeda_da_loja . $valor_parcela . ' com juros<br />';
                    }
                  }

                  // Fecha a primeira coluna e inicia a segunda
                  if ($p == intval($maximo_parcelas/2)+1) { echo '</div><div style="width: 50%; float:right;">'; }
                }

                // Exibe os juros utilizados e o valor minimo da parcela se esta for maior que zero
                if ($parcelas_sem_juros < $maximo_parcelas) {
                  $juros = number_format($juros, 2, ',', '.');
                  echo '<span style="font-size: smaller;">Juros de ' . $juros . '% ao m&ecirc;s</span>';
                }
                if ($parcela_minima > 0) {
                  $parcela_minima = number_format($parcela_minima, 2, ',', '.');
                  echo '<br /><span style="font-size: smaller;">Parcela m&iacute;nima de ' . $moeda_da_loja . $parcela_minima . '</span>';
                }

                // Fecha a segunda coluna e finaliza
                echo '</div>';
                echo '</table><br />';
                }
              ?>
            <!-- Exibicao de parcelas -->
4. É só isso!

Configurando
O código é auto-explicativo e bem comentado. Basta fazer as alterações desejadas:

$maximo_parcelas = Define a quantidade máxima de parcelas aceita pela loja.
$parcela_minima = Valor minimo da parcela aceito pela loja. Escreva apenas os números e utilize ponto para separar as casas decimais (p.ex. 10.00)
$parcelas_sem_juros = Define quantas parcelas não terão juros.
$juros = Taxa de juros mensal. Escreva apenas os números e utilize ponto para separar as casas decimais (p.ex. 1.99)
$moeda_da_loja = Permite especificar a moeda utilizada na loja. Se a sua loja usa outra moeda além de R$, escreva aqui a moeda.
$tipo_de_calculo = Permite escolher o tipo de cálculo a ser utilizado no parcelamento: 0 = Juros simples (Pagamento Digital), 1 = Tabela Price (PagSeguro).

Observações
- Se houverem parcelas com juros, a função irá exibir a taxa de juros depois da última parcela. Se nenhuma das parcelas tiver juros, essa linha não será exibida.
- O OpenCart só disponibiliza o preço já formatado (R$ 130,00) e não como um número (130,00). Para fazer os cálculos das parcelas foi necessário fazer uma conversão para número usando a função str_replace. Você deve alterar a opção $moeda_da_loja e especificar o símbolo de moeda utilizado em sua loja caso ele seja diferente de "R$".
- O parcelamento é exibido em duas colunas através de <div>. Se você quiser colocar todas as parcelas em uma única coluna basta remover os blocos marcados como "inicia a primeira coluna", "fecha a primeira coluna e inicia a segunda", e "fecha a segunda coluna".
- Se o valor mínimo para a parcela for superior a zero, a função irá exibir a frase "Parcela mínima de " e o valor correspondente.
- Para alterar a cor das parcelas sem juros basta modificar a linha que começa com echo '<span style="color: darkgreen;">'

Dúvidas?
No que eu puder ajudar, é só perguntar. Tenho certeza de que ainda farei inúmeras adaptações ao OpenCart ;)

Assim que minha loja estiver pronta postarei o link para que possam avaliar.
Editado pela última vez por denisgomes em 22 Jul 2013, 13:04, em um total de 7 vezes.
#730
olá
falta só uma coisa ai

quando o produto ta em promoção, ele vai calcular o valor sem a promoção

coloque na string para reconhecer quando ta em promoção
Código: Selecionar todos
                  <?php if (!$special) { ?>
                  <?php $preco_numero = str_replace(',','.',str_replace('.','', str_replace("R$","",$price))); ?>
                  <?php } else { ?>
                  <?php $preco_numero = str_replace(',','.',str_replace('.','', str_replace("R$","",$price))); ?>
                  <?php } ?>
flws
#752
denisgomes escreveu:Obrigado pelo incentivo, Manoel. Próximo passo: boleto direto com todos os bancos via phpBoleto.
Bacana amigo, também peguei o phpBoleto para implementar mas não consegui tempo para fazer a implantação. :(
Que bom que todos podem contar com você também. :D

Qualquer coisa estou a disposição.
#753
Manoel,
A minha estratégia é pegar um módulo do Pagamento Digital já funcionando (com os devidos créditos é claro) e alterar apenas o necessário para implementar o phpBoleto. Numa análise rápida, preliminar, vi que é bem viável.

Qualquer novidade posto aqui.
#860
Estou com um 2 problemas...

1. Esse juros não está calculando corretamente, os juros não estão batendo com o pagseguro!

2. No pagseguro a parcela mínima é de R$ 5,00, e com o código como está ele mostra todas as parcelas, se for 12 mostra as 12 mesmo o valor da parcela sendo menor que R$ 5,00.

Alguém sabe como é feita a conta de juros do pagseguro?
#862
@NathanMuniz não é que ta errado

é que existe 2 tipo de juros, o simples e composto

ele dicerto usa o pagamento digital, que é baseado no calculo de juros simples,


pra calcular o composto, tem q tirar o fator de cada parcela, tem meu tuto do pagseguro no https://forum.opencartbrasil.com.br/ ... f=18&t=135
#865
@NathanMuniz,
De fato não está batendo com o PagSeguro e eu não sei porque, mas a diferença é pequena. A fórmula utilizada bate com o Pagamento Digital, no entanto.

@Maxno,
Vou revisar a fórmula. Acessei outro site que faz simulações usando a tabela Price e a mesma pequena diferença apareceu.
  • 1
  • 2
  • 3
  • 4
  • 5
  • 27

Gente preciso de ajuda urgente. Na migraç&a[…]

Caro @reds , muito obrigado pela resposta.

PHP 8+ incompatibilidade

Toda tradução para a versão 3[…]

Ola @alex3257 Se você precisa apenas ver […]