Ir para conteúdo

POWERED BY:

violin101

PHP - Cadastro de Faturamento

Recommended Posts

Caros amigos, saudações.

 

Estou com uma dúvida de como devo fazer.

 

Preciso criar uma Rotina para Cadastrar Faturamento, por exemplo:

1) 28/42/56 dias -> de 28 p/ 42 a dif. é de 14 dias...

2) 30/60/90 dias -> de 30 p/ 60 a dif. é de 30 dias...

3) 0/15/30/45 dias  -> de 0 p/ 15 a dif. é de 15 dias...

 

Como devo fazer para  cadastrar os prazo de vencimento, onde o sistema possa contar as diferenças entre os dias ?

 

Grato,

 

Cesar

Compartilhar este post


Link para o post
Compartilhar em outros sites
  Em 28/06/2024 at 19:17, violin101 disse:

Como devo fazer para  cadastrar os prazo de vencimento, onde o sistema possa contar as diferenças entre os dias ?

Crie uma tabela no seu database e vincule ao que quer que seja

Compartilhar este post


Link para o post
Compartilhar em outros sites

Caros amigos, saudações.

 

Estou tentando fazer uma Rotina em PHP onde eu possa gerar datas de Vencimentos, o meu problema é que não consigo entender como faço para contar DIFERENÇA entre as data de vencimentos.


Exemplo:
qtde de dias para vencer: 28/42/56.
a 1ª parcela conta 28 dias da Data Atual.

a 2ª parcela conta 14 dias da A PARTIR da 1ª. parcela.

a 3ª parcela conta 14 dias da A PARTIR da 2ª. parcela.

 

ficaria assim: Data Atual: 03/07/2024

1 vcto p/ 31/07/2024

2 vcto p/ 11/09/2024

3 vcto p/ 25/09/2024

 

Abaixo fiz uma Rotina Simples, para fazer os PARCELMENTO, VALORES e VECIMENTOS.

 

<?php
// Definir um fuso horario padrao
date_default_timezone_set('America/Sao_Paulo');
?>
<!DOCTYPE html>
<html lang="pt-br">

<head>
    <meta charset="UTF-8">
    <title>Calcula Vencimento</title>
</head>

<body>

    <?php
    // Valor da compra
    $valor_total = 700;

    // Quantidade de parcelas
    $quantidade_parc = 3;

	//Intervalo de Dias para Vencer
    $intervalo=28;	
	
    // Converter o valor para o formato Real separado pela virgula
    echo "Valor da compra: " . number_format($valor_total, 2, ',', '.') . "<br><br>";

    // Imprimir a quantidade de parcelas
    echo "Quantidade de parcelas: $quantidade_parc <br><br>";
	
    // Imprimir a quantidade de parcelas
    echo "Intervalo de Dias p/ Vencer: $intervalo <br><br>";	

    // Calcula o valor de cada parcela
    $valor_parc = $valor_total / $quantidade_parc;

    // Variável do Controle do WHILE
    $controle = 1;

    // Realiza a Sotal das parcelas
    $soma_valor_parc = 0;

    // Data atual
    $data_atual = new DateTime();

    // Laço de repetição
    while ($controle <= $quantidade_parc) {

        // Somar Intervalo de Tempo na Data		
        $data_atual->add(new DateInterval('P' . $intervalo . 'D'));
		
        // Acessa o IF quando é última parcela para corrigir o valor da compra
        if ($controle == $quantidade_parc) {

            // Utilizar a soma das parcelas e subtrair do valor total da 
            // para obter o valor a última parcela e corrigir a diferença
            $valor_ultima_parc = $valor_total - $soma_valor_parc;

            // Converter o valor da parcela para o formato Real separado pela virgula
            echo "Valor da parcela " . number_format($valor_ultima_parc, 2, ',', '.') . "<br>";

            // Somar o valor das parcelas
            $soma_valor_parc += number_format($valor_ultima_parc, 2, '.', '');
        } else {
            // Converter o valor da parcela para o formato Real separado pela virgula
            echo "Valor da parcela " . number_format($valor_parc, 2, ',', '.') . "<br>";

            // Somar o valor das parcelas
            $soma_valor_parc += number_format($valor_parc, 2, '.', '');
        }

        // Converter a data
        echo "Data de Vencimento: " . $data_atual->format('d/m/Y') . "<br><br>";     

        // Incrementar a variável após imprimir a parcela
        $controle++;
    } 

    // Imprimir o valor total da soma das parcelas e converter para o formato Real separado pela virgula
    echo "<br>Valor total Parcelado: " . number_format($soma_valor_parc, 2, ',', '.') . "<br>";
			

    ?>

</body>

</html>

 

Grato,

 

Cesar

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Seu  codigo esta certo, mas você precisa fazer algumas correções,  precisa fazer uns ajustes  para que ele funcione conforme você esta  esperado. Código para calcular corretamente as datas de vencimento e os valores das parcelas de acordo com as regras que você especificou. 

 

Intervalos das Parcelas: O intervalo entre as parcelas não está correto. O intervalo para a 2ª parcela e subsequentes é de 14 dias, e não de 28 dias como está definido na variável $intervalo.

 

Soma dos Valores das Parcelas: Ao formatar o valor das parcelas, você está convertendo o valor para uma string e depois somando isso, o que pode levar a erros. A soma deve ser feita usando números, e a formatação para a exibição deve ser feita separadamente.

 

Correção da Última Parcela: A última parcela não está sendo calculada corretamente. O valor da última parcela deve ser ajustado para garantir que a soma total seja igual ao valor total da compra.

 

Vou mostra 3 abordagem que pode ser feita

 

Abordagem 1: Usando Funções Simples e Arrays casi desejar

 

Nesta abordagem, você pode usar arrays para armazenar as datas de vencimento e valores das parcelas. A lógica para calcular as datas e valores é separada em funções para melhorar a organização e a legibilidade.

<?php
// Definir um fuso horário padrão
date_default_timezone_set('America/Sao_Paulo');

// Valor da compra
$valor_total = 700;

// Quantidade de parcelas
$quantidade_parc = 3;

// Intervalo de Dias para Vencer
$intervalo_inicial = 28; 
$intervalo_subsequente = 14; 

// Calcula o valor de cada parcela
$valor_parc = $valor_total / $quantidade_parc;

// Função para calcular a data de vencimento
function calcular_vencimento($data_inicial, $dias) {
    $data = clone $data_inicial;
    $data->add(new DateInterval('P' . $dias . 'D'));
    return $data;
}

// Data atual
$data_atual = new DateTime();

$valores_parcelas = [];
$datas_vencimento = [];
$intervalo = $intervalo_inicial;

for ($i = 1; $i <= $quantidade_parc; $i++) {
    $datas_vencimento[$i] = calcular_vencimento($data_atual, $intervalo);
    if ($i == $quantidade_parc) {
        $valor_parcela_atual = $valor_total - array_sum($valores_parcelas);
    } else {
        $valor_parcela_atual = $valor_parc;
    }
    $valores_parcelas[$i] = $valor_parcela_atual;
    $intervalo = $intervalo_subsequente;
}

?>

<!DOCTYPE html>
<html lang="pt-br">

<head>
    <meta charset="UTF-8">
    <title>Calcula Vencimento</title>
</head>

<body>

    <?php
    // Converter o valor para o formato Real separado pela vírgula
    echo "Valor da compra: " . number_format($valor_total, 2, ',', '.') . "<br><br>";

    // Imprimir a quantidade de parcelas
    echo "Quantidade de parcelas: $quantidade_parc <br><br>";

    // Imprimir a quantidade de parcelas
    echo "Intervalo de Dias p/ Vencer: $intervalo_inicial para 1ª parcela e $intervalo_subsequente para as demais<br><br>";    

    for ($i = 1; $i <= $quantidade_parc; $i++) {
        echo "Valor da parcela " . $i . ": " . number_format($valores_parcelas[$i], 2, ',', '.') . "<br>";
        echo "Data de Vencimento: " . $datas_vencimento[$i]->format('d/m/Y') . "<br><br>";     
    }

    // Imprimir o valor total da soma das parcelas e converter para o formato Real separado pela vírgula
    echo "<br>Valor total Parcelado: " . number_format(array_sum($valores_parcelas), 2, ',', '.') . "<br>";
    ?>

</body>

</html>

 

Abordagem 2: Usando uma Classe para Encapsular a Lógica caso desejar também

Nesta abordagem, encapsulamos a lógica em uma classe para melhorar a organização e a reusabilidade do código.

 

<?php
// Definir um fuso horário padrão
date_default_timezone_set('America/Sao_Paulo');

class CalculadorParcelas {
    private $valor_total;
    private $quantidade_parc;
    private $intervalo_inicial;
    private $intervalo_subsequente;

    public function __construct($valor_total, $quantidade_parc, $intervalo_inicial, $intervalo_subsequente) {
        $this->valor_total = $valor_total;
        $this->quantidade_parc = $quantidade_parc;
        $this->intervalo_inicial = $intervalo_inicial;
        $this->intervalo_subsequente = $intervalo_subsequente;
    }

    public function calcularParcelas() {
        $valor_parc = $this->valor_total / $this->quantidade_parc;
        $data_atual = new DateTime();
        $valores_parcelas = [];
        $datas_vencimento = [];
        $intervalo = $this->intervalo_inicial;

        for ($i = 1; $i <= $this->quantidade_parc; $i++) {
            $data_vencimento = clone $data_atual;
            $data_vencimento->add(new DateInterval('P' . $intervalo . 'D'));
            $datas_vencimento[$i] = $data_vencimento;

            if ($i == $this->quantidade_parc) {
                $valor_parcela_atual = $this->valor_total - array_sum($valores_parcelas);
            } else {
                $valor_parcela_atual = $valor_parc;
            }
            $valores_parcelas[$i] = $valor_parcela_atual;
            $intervalo = $this->intervalo_subsequente;
        }

        return [$valores_parcelas, $datas_vencimento];
    }
}

// Inicializando a classe
$calculador = new CalculadorParcelas(700, 3, 28, 14);
list($valores_parcelas, $datas_vencimento) = $calculador->calcularParcelas();

?>

<!DOCTYPE html>
<html lang="pt-br">

<head>
    <meta charset="UTF-8">
    <title>Calcula Vencimento</title>
</head>

<body>

    <?php
    // Converter o valor para o formato Real separado pela vírgula
    echo "Valor da compra: " . number_format(700, 2, ',', '.') . "<br><br>";

    // Imprimir a quantidade de parcelas
    echo "Quantidade de parcelas: 3 <br><br>";

    // Imprimir a quantidade de parcelas
    echo "Intervalo de Dias p/ Vencer: 28 para 1ª parcela e 14 para as demais<br><br>";    

    for ($i = 1; $i <= 3; $i++) {
        echo "Valor da parcela " . $i . ": " . number_format($valores_parcelas[$i], 2, ',', '.') . "<br>";
        echo "Data de Vencimento: " . $datas_vencimento[$i]->format('d/m/Y') . "<br><br>";     
    }

    // Imprimir o valor total da soma das parcelas e converter para o formato Real separado pela vírgula
    echo "<br>Valor total Parcelado: " . number_format(array_sum($valores_parcelas), 2, ',', '.') . "<br>";
    ?>

</body>

</html>

 

Abordagem 3: Usando uma Função de Agregação se assim você também desejar rsrs

Abordagem é criar uma função que retorna todas as informações necessárias para o cálculo das parcelas e exibição dos resultados.

 

<?php
// Definir um fuso horário padrão
date_default_timezone_set('America/Sao_Paulo');

function calcularParcelas($valor_total, $quantidade_parc, $intervalo_inicial, $intervalo_subsequente) {
    $valor_parc = $valor_total / $quantidade_parc;
    $data_atual = new DateTime();
    $parcelas = [];

    for ($i = 1; $i <= $quantidade_parc; $i++) {
        $data_vencimento = clone $data_atual;
        $intervalo = ($i == 1) ? $intervalo_inicial : $intervalo_subsequente;
        $data_vencimento->add(new DateInterval('P' . $intervalo . 'D'));

        $valor_parcela_atual = ($i == $quantidade_parc) ? $valor_total - array_sum(array_column($parcelas, 'valor')) : $valor_parc;

        $parcelas[] = [
            'data' => $data_vencimento,
            'valor' => $valor_parcela_atual
        ];
    }

    return $parcelas;
}

$parcelas = calcularParcelas(700, 3, 28, 14);

?>

<!DOCTYPE html>
<html lang="pt-br">

<head>
    <meta charset="UTF-8">
    <title>Calcula Vencimento</title>
</head>

<body>

    <?php
    // Converter o valor para o formato Real separado pela vírgula
    echo "Valor da compra: " . number_format(700, 2, ',', '.') . "<br><br>";

    // Imprimir a quantidade de parcelas
    echo "Quantidade de parcelas: 3 <br><br>";

    // Imprimir a quantidade de parcelas
    echo "Intervalo de Dias p/ Vencer: 28 para 1ª parcela e 14 para as demais<br><br>";    

    foreach ($parcelas as $index => $parcela) {
        echo "Valor da parcela " . ($index + 1) . ": " . number_format($parcela['valor'], 2, ',', '.') . "<br>";
        echo "Data de Vencimento: " . $parcela['data']->format('d/m/Y') . "<br><br>";
    }

    // Imprimir o valor total da soma das parcelas e converter para o formato Real separado pela vírgula
    echo "<br>Valor total Parcelado: " . number_format(array_sum(array_column($parcelas, 'valor')), 2, ',', '.') . "<br>";
    ?>

</body>

</html>

Espero que seja o que deseja

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
×

Informação importante

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