Ir para conteúdo
uoston.bs

Sistema de Contagem de Refeições

Recommended Posts

Galera, bom dia! 

Estou com um problema que acredito ser "simples", mas ainda não conseguir resolver.

Desenvolvi uma aplicação simples em PHP que faz a contagem de refeições através de dados registrados em um txt, pego os dados do txt usando o substring para determinar o valor de cada coluna, o programa funciona até que bem, porém quando tenho alteração de DATA, mas com mesma faixa de horário ele não imprime a quantidade de refeição (seja ceia, café, almoço ou jantar).

logo o que queria é que o programa além de fazer as impressões que já faz, imprimir também a quantidade de refeições quando a data for alterada, pois a contagem é feita por dia.

Segue meu código completo abaixo:

<?php set_time_limit(60); ?>
<?php require_once('conexao/conectar.php'); ?>
<?php date_default_timezone_set('America/Sao_Paulo'); ?>

<?php header("Content-Type: text/html; charset=ISO-8859-1",true) ; ?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="shortcut icon" href="icone/icone.ico" type="image/x-icon" />
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
<title>Index</title>
<style>


</head>
<style>
.titulo{

    background: linear-gradient(#3555a2, #3555a2);
      background: -moz-linear-gradient(#3555a2, #3555a2);
      background: -ms-linear-gradient(#3555a2, #3555a2);
      background: -o-linear-gradient(#3555a2, #3555a2);
      background: -webkit-linear-gradient(#3555a2, #3555a2);
      background-color: #57944d;
    color: #FFF;
      box-shadow: #57944d 0 0 15px;
      border-top: 2px solid #3555a2;
      border-bottom: 2px solid #3555a2;
      -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border-radius:4px;
    font-family:Tahoma, Geneva, sans-serif;
}
.lista{

    background: linear-gradient(#3555a2, #3555a2);
      background: -moz-linear-gradient(#3555a2, #3555a2);
      background: -ms-linear-gradient(#3555a2, #3555a2);
      background: -o-linear-gradient(#3555a2, #3555a2);
      background: -webkit-linear-gradient(#3555a2, #3555a2);
      background-color: #57944d;
    color: #FFF;
      box-shadow: #57944d 0 0 15px;
      border-top: 2px solid #3555a2;
      border-bottom: 2px solid #3555a2;
      -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border-radius:4px;
    font-family:Tahoma, Geneva, sans-serif;
}
</style>
<style>
.a{
    text-decoretion: underline;
    color: #FFF;
}
.a:hover{
    color: #CD2626;
}

#preloader {
    position: absolute;
    left: 0px;
    right: 0px;
    bottom: 0px;
    top: 0px;
    background: #ccc;
}

</style>

<body>

<?php


$count = 0;


if (!function_exists("GetSQLValueString")) {
function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 
{
  if (PHP_VERSION < 6) {
    $theValue = get_magic_quotes_gpc() ? stripslashes($theValue) : $theValue;
  }

  $theValue = function_exists("mysql_real_escape_string") ? mysql_real_escape_string($theValue) : mysql_escape_string($theValue);

  switch ($theType) {
    case "text":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;    
    case "long":
    case "int":
      $theValue = ($theValue != "") ? intval($theValue) : "NULL";
      break;
    case "double":
      $theValue = ($theValue != "") ? doubleval($theValue) : "NULL";
      break;
    case "date":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;
    case "defined":
      $theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
      break;
  }
  return $theValue;
}


$contador = 0;
$data_inicial = $_POST['inicial'];
$data_final = $_POST['final'];
$empresa = $_POST['tipo'];
//$data_teste = date("d/m/Y");
$data_arquivoin = $_POST['inicial'];
$data_arquivofi = $_POST['final'];

$quebra =  chr(13).chr(10);


$escrever = "Empresa INDU. REUN. * RAYMUNDO DA FONTE *".PHP_EOL;
$area = "Relatorio: $empresa".PHP_EOL;
$cabecalho = "Relatorio $empresa de $data_arquivoin a $data_arquivofi $quebra";

$titulos = "$quebra Data          Hora       Cartao            Colaborador           $quebra ";
$formatacao = "----------------------------------------------------------------- $quebra $quebra";

$normal = fopen("Relatorios/Relatorio $empresa de $data_inicial a $data_final.txt", "w");
$texto1 = fwrite($normal, $escrever);
$texto2 = fwrite($normal, $area);
$texto3 = fwrite($normal, $cabecalho);
$texto4 = fwrite($normal, $titulos);
$texto5 = fwrite($normal, $formatacao);

//Variaveis para determinar qual o tipo da refeição que foi realizada.
$cafe_inicial = '05';
$cafe_final = '08';
$almoco_inicial = '11';
$almoco_final = '14';
$jantar_inicial = '18';
$jantar_final = '20';
$ceia_inicial = '00';
$ceia_final = '02';

//Variaveis para calculo de refeição diaria
$cont_cafe = 0;
$cont_almoco = 0;
$cont_jantar = 0;
$cont_ceia = 0;

$cont_cresauto = 0;
$cont_asa = 0;
$cont_ws = 0;
$cont_nbs = 0;
$cont_total = 0;
$cont_pm = 0;
$cont_only = 0;
$cont_helna = 0;
$cont_wjm = 0;

$arquivo = "Relatorios/Relatorio $empresa de $data_inicial a $data_final.txt";
    $ponteiro = '//192.168.4.39//Portaria//bilhetes-p.txt';
    $abrir = fopen($ponteiro, 'r');
    $total_linhas = 0;    
        if(file_exists($ponteiro)){
                
            do{
                    
                $conteudo = fgets($abrir, 3500);
                $cartao = substr($conteudo, 27, -5);
                $data = substr($conteudo, 4, 10);
                $hora = substr($conteudo, 15, -25);
                $hora_cont = substr($conteudo, 15, -22);
                
                            
                            
            $query_row = mysql_query("SELECT nome, cartao, empresa FROM catracas WHERE cartao = '$cartao'");
            $row = ($query_row)or die(mysql_error());
            $row_row = mysql_fetch_assoc($row);
            $totalRows_row = mysql_num_rows($row);
                        
            $colaborador = $row_row['nome'];
            
            $data_mod = str_replace("/", "-", $data);
                //echo "<br>$empresa<br>";
                
            
            if($empresa == 'Brilux'){
            
            
            
            if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
            
            if($cartao == $row_row['cartao']){                
                $cont_total = $cont_total + 1;
                    if($hora > $ceia_final and $cont_ceia > 1){
                        $dados = fwrite($normal, "$quebra Total Ceia ----------->>>>> $cont_ceia $quebra $quebra");
                        $cont_ceia = 0;
                    }
                    
                            if($hora > $cafe_final and $cont_cafe > 1){
                        $dados = fwrite($normal, "$quebra Total Cafe ----------->>>>> $cont_cafe $quebra $quebra");
                        $cont_cafe = 0;
                    }
                    
                        if($hora > $almoco_final and $cont_almoco> 1){
                        $dados = fwrite($normal, "$quebra Total Almoco ----------->>>>> $cont_almoco $quebra $quebra");
                        $cont_almoco = 0;
                    }
                    
                        if($hora == $ceia_inicial and $cont_jantar > 1){
                        $dados = fwrite($normal, "$quebra Total Jantar ----------->>>>> $cont_jantar $quebra $quebra");
                        $cont_jantar = 0;
                    }
                                        
                    
                    
                    if($hora >= $ceia_inicial and $hora <= $ceia_final){
                        $cont_ceia = $cont_ceia +1;
                    }
                    
                    if($hora >= $cafe_inicial and $hora <= $cafe_final){
                        $cont_cafe = $cont_cafe +1;
                    }
                    
                    if($hora >= $almoco_inicial and $hora <= $almoco_final){
                        $cont_almoco = $cont_almoco+1;
                    }
                    
                    if($hora >= $jantar_inicial and $hora <= $jantar_final){
                        $cont_jantar = $cont_jantar +1;
                    }
                    
                    
                    $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                
                    
                    
                    }    
                    
                }

            }
            
            if($empresa == 'cresauto'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='Cresauto'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_cresauto = $cont_cresauto +1;    
                    }
                }
            }
            
            if($empresa == 'asa'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='Asa de Prata'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_asa = $cont_asa +1;    
                    }
                }
            }
            
            if($empresa == 'ws'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='WS'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_ws = $cont_ws +1;    
                    }
                }
            }
            
            if($empresa == 'nbs'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='NBS'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_nbs = $cont_nbs +1;    
                    }
                }
            }
            
            if($empresa == 'pm'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='PM'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_pm = $cont_pm +1;    
                    }
                }
            }
            
            if($empresa == 'only'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='ONLY'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_only = $cont_only +1;    
                    }
                }
            }
            
            if($empresa == 'helena'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='MARIA HELENA'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_helena = $cont_helena +1;    
                    }
                }
            }
            
            if($empresa == 'wjm'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='WJM'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_wjm = $cont_wjm +1;    
                    }
                }
            }
            
        
        }while(!feof($abrir));
}
            if($empresa == 'cresauto'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeições ----> $cont_cresauto");
            }
            
                if($empresa == 'asa'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeições ----> $cont_asa");
            }
            
            if($empresa == 'Brilux'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_total");
                
            }
            
            if($empresa == 'ws'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_ws");
                
            }
            
            if($empresa == 'nbs'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_nbs");
                
            }
            
            if($empresa == 'pm'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_pm");
                
            }
            
            //$apaga_frequencia = mysql_query ("DELETE FROM frequencia");
            //$pega = ($apaga_frequencia)or die(mysql_error());
                    

            }else{
                echo "arquivo não encontrado";
        }
            
        //echo $data;
        fclose($abrir);
        fclose($normal);
        
        
        

?>
<br><br>
<p align="center">Relatório Gerado com Sucesso</p>
<p align="center"><a href="<?php echo $arquivo ?>" download>Baixar Arquivo.</a></p>


</script>
</body>
</html>

 

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 Claudia França
      Pessoal estou com um problema para homologar um pagamento service.
       o resultado do Status deve ser sucessfull.
      Parte do codido do index.
      "

          $('#payButton').one('click', function(){
              var amount = $('input[name=amount]').val();
              var currency = $('[name=currency]').val();
              console.log(amount, currency);
              V.init( {
                  apikey: '<?php echo $visaApiKey ?>',
                  settings: {
                      //logoUrl: 'https://www.novachance.org.br/wp-content/uploads/2018/06/xLogo_INC.jpg.pagespeed.ic.QrM-Azm3n5.jpg',
                      locale: 'en_US',
                      displayName: 'Viva a Musica',
                      websiteUrl: 'https://www.vivaamusica.org.br',
                      customerSupportUrl: 'https://www.vivaamusica.org.br/contato',
                      dataLevel: 'FULL'
                  },
                  paymentRequest: {
                      currencyCode: currency,
                      total: amount,
                      merchantRequestId: 'you can send any value to API ang get it in callback',
                      orderId: 'you can send any value to API ang get it in callback',
                      description: 'any order description if needs'
                  }
              });
                V.on('payment.success', function(payment) {
                  console.log('Visa success:', JSON.stringify(payment));
                  $('#succesOverlay').show();
                  $.ajax({
                      type: 'POST',
                      url: 'mailer.php',
                      data: {json: JSON.stringify(payment)},
                      dataType: 'json',
                      success: function(data){
                        console.log('Ajax success');
                        console.log(data);
                        location = 'thanks.php';
                      },
                      error: function(jqXHR, textStatus, errorThrown) {
                        console.log('Ajax error:');
                        console.log(textStatus, errorThrown);
                      }
                  });
              });
              V.on('payment.cancel', function(payment){
                  console.log('Canceled:', payment);
              });
              V.on('payment.error', function(payment, error){
                  console.log('Visa error:', payment, error);
              });
              $('.v-button').click();
          })
       
      "
       Chamada Json
       
      "
      "Customer": {
              "Name": "[$userFullName]"
          },
          "Payment": {
              "ServiceTaxAmount": 0,
              "Installments": 1,
              "Interest": 0,
              "Capture": false,
              "Authenticate": false,
              "Recurrent": false,
              "CreditCard": {
                  "CardNumber": "453211******1521",
                  "Holder": "Gama Gama",
                  "ExpirationDate": "08/2020",
                  "SaveCard": false,
                  "Brand": "Visa"
              },
              "Tid": "0319040817883",
              "ProofOfSale": "817883",
              "AuthorizationCode": "027795",
              "Wallet": {
                  "Type": "VisaCheckout",
                  "WalletKey": "1140814777695873901",
                  "Eci": 0
                  },
              
              "SoftDescriptor": "123456789ABCD",
              "Amount": 100,
              "ReceivedDate": "2018-03-19 16:08:16",
              "Status": "eventStatus",
              "IsSplitted": false,
              "ReturnMessage": "Operation Successful",
              "ReturnCode": "4",
              "PaymentId": "e57b09eb-475b-44b6-ac71-01b9b82f2491",
              "Type": "CreditCard",
              "Currency": "BRL","en_US",
              "Country": "BRA","USA",
              
              
          
      "updateInfo":  {
               "payInfo": {
               "reason": "Pagamento","Payment",
               "avsResponseCode": "Y",
               "Amount": 91.00,
               "currencyCode": "USD",
               "eventStatus": "Success",
               "eventType": "Authorize",
               "PaymentId": "e57b09eb-475b-44b6-ac71-01b9b82f2491",
              
               }
      }
           
            }
      }
      {
       
       
      "
       
       
      O pessoal da empresa me fala que tenho que enviar o CallID gerado ( não sei como faço isso) e fazer a chamado do alteração de evento quando a transação for sucesso.
       
      Pensei em criar um aquivo payment.php mas pelo que li no manual necessariamente, não eh necessário.
       
    • Por edison.silva
      Pessoal, alguem tem algum exemplo em php de geração do arquivo .TXT2 da NFe ou MDFe e o envio para API de rotas dele?
    • Por eduuh1524
      Olá.
      Boa noite a todos,eu preciso de uma ajuda.
      Eu tenho um projeto em PHP e MySQL
      Tem uma database chamada easy e a uma tabela chamada usuários
      E dentro da tabela tem usuário,senha, saldo
       
      Bem.
      Eu tenho um random resultados em duas form na (resultados.php)eu queria fazer que quando a pessoa clicasse no botão Gerar usasse o saldo e gerasse o resultado.
      Exemplo,a pessoa já começa com 1000 de saldo e o botão diminui esse saldo em 100 e quando esse saldo chegasse em 0 se tentasse usar dá um erro de saldo insuficiente.
      Como posso fazer isso?
      Dei uma olhada em uns artigos aqui mas estou meio confuso,sou iniciante em PHP mas tenho uma noçãozinha .
      Boa noite a todos.
       
    • Por rd111072
      Olá, moçada!

      Tenho esse gráfico aqui: http://riocir.com.br/renan/chart_barg_g2.php 
      Mas ele exibe só os dias da semana do mês 1. Queria que ele exibisse todos os dias de todos os meses (como é o resultado do echo).

      Segue o código. Alguém pode me ajudar?
       
       
×

Informação importante

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