function BuildRows($valuesOnly)
{
    global $dataConnector;
    global $itemArray;
    global $calculoFaturamento;
    global $totalContadores;
    // Cria os objetos de mapeamento objeto-relacional
    $subContractDAO = new SubContractDAO($dataConnector->mysqlConnection);
    $subContractDAO->showErrors = 1;
    $businessPartnerDAO = new BusinessPartnerDAO($dataConnector->sqlserverConnection);
    $businessPartnerDAO->showErrors = 1;
    $equipmentDAO = new EquipmentDAO($dataConnector->sqlserverConnection);
    $equipmentDAO->showErrors = 1;
    $inventoryItemDAO = new InventoryItemDAO($dataConnector->sqlserverConnection);
    $inventoryItemDAO->showErrors = 1;
    // Para cada equipamento monta os dados de faturamento
    foreach ($itemArray as $contractItem) {
        $equipmentId = $contractItem->codigoCartaoEquipamento;
        $subContract = $subContractDAO->RetrieveRecord($contractItem->codigoSubContrato);
        $contractType = $subContract->codigoTipoContrato;
        $contractDTO = $calculoFaturamento->GetContract($dataConnector->mysqlConnection, $subContract->id);
        $divisor = $calculoFaturamento->GetDivisor($dataConnector->mysqlConnection, $contractDTO, $subContract);
        // divisor para calculo da média (no caso de contrato global)
        // Caso o status do contrato seja finalizado ou cancelado não fatura, passa para o proximo equipamento
        if ($contractDTO->status == 3 || $contractDTO->status == 4) {
            continue;
        }
        $equipmentDTO = $equipmentDAO->RetrieveRecord($equipmentId);
        $inventoryItem = $inventoryItemDAO->RetrieveRecord($equipmentDTO->itemCode);
        $contractTypeInfo = $calculoFaturamento->GetTipoContratoAsText($contractType);
        $equipmentInfo = GetEquipmentInfo($equipmentDTO, $contractTypeInfo);
        echo '<tr bgcolor="LIGHTGRAY" ><td colspan="11" >' . $equipmentInfo . '</td></tr>';
        $counterIdArray = array_keys($calculoFaturamento->GetContadores());
        foreach ($counterIdArray as $counterId) {
            $billingSummary = $totalContadores[$counterId];
            $formaCobranca = $calculoFaturamento->GetFormaCobranca($subContract->id, $counterId);
            $consumo = $calculoFaturamento->GetConsumo($equipmentId, $counterId);
            $consumoGlobal = 0;
            $excedenteGlobal = 0;
            if ($contractDTO->global) {
                $consumoGlobal = $calculoFaturamento->GetConsumoGlobal($dataConnector->mysqlConnection, $contractDTO->id, $counterId);
                $franquiaGlobal = $calculoFaturamento->GetFranquiaGlobal($dataConnector->mysqlConnection, $counterId);
                $excedenteGlobal = $consumoGlobal > $franquiaGlobal ? $consumoGlobal - $franquiaGlobal : 0;
                if ($franquiaGlobal == 0) {
                    $excedenteGlobal = 0;
                }
            }
            $modalidadeMedicao = 0;
            $fixo = 0.0;
            $variavelDefault = 0.0;
            $franquia = 0;
            $individualPorCapacidade = 0;
            if ($formaCobranca != null) {
                $modalidadeMedicao = $formaCobranca->modalidadeMedicao;
                $fixo = $formaCobranca->fixo / $divisor;
                $variavelDefault = $formaCobranca->variavel;
                $franquia = $formaCobranca->franquia / $divisor;
                $individualPorCapacidade = $formaCobranca->individual;
                if ($individualPorCapacidade) {
                    $franquia = $equipmentDTO->capacity;
                }
            }
            if ($modalidadeMedicao == 1) {
                // Sem leituras
                $rowData = '<td>' . $calculoFaturamento->GetContadorAsText($counterId) . '</td><td>Sem leitura</td><td>Sem leitura</td><td>Sem leitura</td><td>0</td><td>0</td><td>0</td><td>0</td><td>' . formatBrCurrency($fixo, 2) . '</td><td>0</td><td>' . formatBrCurrency($fixo, 2) . '</td>';
                if ($valuesOnly) {
                    $rowData = '<td>' . $equipmentId . '</td><td>' . $contractTypeInfo . '</td><td>' . $counterId . '</td><td>Sem leitura</td><td>Sem leitura</td><td>Sem leitura</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>' . $fixo . '</td><td>0</td><td>' . $fixo . '</td>';
                }
                echo '<tr bgcolor="WHITE" >' . $rowData . '</tr>';
                $billingSummary->valorFixo += $fixo;
                $billingSummary->excedente += 0;
                $billingSummary->valorTotal += $fixo;
            }
            if ($consumo != null && $modalidadeMedicao != 1) {
                $dataLeitura = $consumo->dataLeitura;
                $medicaoInicial = $consumo->medicaoInicial;
                $medicaoFinal = $consumo->medicaoFinal;
                $consumoMedido = $consumo->total;
                $ajuste = $consumo->ajusteTotal;
                $excedente = $consumoMedido > $franquia ? $consumoMedido - $franquia : 0;
                if ($contractDTO->global && !$individualPorCapacidade) {
                    $excedente = $excedenteGlobal / sizeof($itemArray);
                }
                if ($franquia == 0) {
                    $excedente = 0;
                }
                $tarifaExcedente = $calculoFaturamento->GetCustoVariavel($subContract->id, $counterId, $consumoMedido, $variavelDefault);
                if ($contractDTO->global && !$individualPorCapacidade) {
                    $tarifaExcedente = $calculoFaturamento->GetCustoVariavel($subContract->id, $counterId, $consumoGlobal, $variavelDefault);
                }
                $valorFixo = $fixo;
                $valorVariavel = $franquia != 0 ? $excedente * $tarifaExcedente : $consumoMedido * $tarifaExcedente;
                $valorTotal = $valorFixo + $valorVariavel;
                $rowData = '<td>' . $calculoFaturamento->GetContadorAsText($counterId) . '</td><td>' . date("d/m/Y", $dataLeitura) . '</td><td>' . $medicaoFinal . '</td><td>' . $medicaoInicial . '</td><td>' . $consumoMedido . '<br/>(Acrésc/Desc = ' . $ajuste . ')' . '</td><td>' . formatDecimal($franquia, 2) . '</td><td>' . round($excedente) . '</td><td>' . formatDecimal($tarifaExcedente, null) . '</td><td>' . formatBrCurrency($valorFixo, 2) . '</td><td>' . formatBrCurrency($valorVariavel, 2) . '</td><td>' . formatBrCurrency($valorTotal, 2) . '</td>';
                if ($valuesOnly) {
                    $rowData = '<td>' . $equipmentId . '</td><td>' . $contractTypeInfo . '</td><td>' . $counterId . '</td><td>' . date("Y-m-d", $dataLeitura) . '</td><td>' . $medicaoFinal . '</td><td>' . $medicaoInicial . '</td><td>' . $consumoMedido . '</td><td>' . $ajuste . '</td><td>' . $franquia . '</td><td>' . $excedente . '</td><td>' . $tarifaExcedente . '</td><td>' . $valorFixo . '</td><td>' . $valorVariavel . '</td><td>' . $valorTotal . '</td>';
                }
                echo '<tr bgcolor="WHITE" >' . $rowData . '</tr>';
                $billingSummary->consumo += $consumoMedido;
                $billingSummary->franquia += $franquia;
                $billingSummary->excedente += $excedente;
                $billingSummary->valorFixo += $valorFixo;
                $billingSummary->valorVariavel += $valorVariavel;
                $billingSummary->valorTotal += $valorTotal;
            }
        }
        // foreach de tipos de contador
    }
    // foreach de itens de faturamento (equipamentos)
}
Example #2
0
            </div>
            <div style="clear:both;"><br/><br/></div>
            &nbsp;&nbsp;
            <?php 
echo $filter;
?>
<br/>
            <div style="clear:both;">&nbsp;</div>
            <hr/>
            <div style="clear:both;"><br/></div>
            <table>
            <tr bgcolor="YELLOW" style="height:30px;" ><td>Tipo do Contador</td><td>Data de Leitura</td><td>Medição Final</td><td>Medição Inicial</td><td>Consumo</td><td>Franquia</td><td>Excedente (Págs.)</td><td>Tarifa sobre exced.</td><td>Valor Fixo (R$)</td><td>Valor Variável (R$)</td><td>Valor Total (R$)</td></tr>
            <?php 
foreach ($billingItemArray as $billingItem) {
    $equipment = $equipmentDAO->RetrieveRecord($billingItem->codigoCartaoEquipamento);
    $equipmentInfo = GetEquipmentInfo($equipment, $billingItem->tipoLocacao);
    echo '<tr bgcolor="LIGHTGRAY" ><td colspan="11" >' . $equipmentInfo . '</td></tr>';
    $counterName = CounterDAO::GetCounterName($dataConnector->mysqlConnection, $billingItem->counterId);
    $dataLeitura = $billingItem->dataLeitura;
    $medicaoInicial = $billingItem->medicaoInicial;
    $medicaoFinal = $billingItem->medicaoFinal;
    if ($billingItem->medicaoInicial == 0 && $billingItem->medicaoFinal == 0) {
        $dataLeitura = "Sem Leitura";
        $medicaoInicial = "Sem Leitura";
        $medicaoFinal = "Sem Leitura";
    }
    $rowData = '<td>' . $counterName . '</td><td>' . $dataLeitura . '</td><td>' . $medicaoFinal . '</td><td>' . $medicaoInicial . '</td><td>' . $billingItem->consumo . '<br/>(Acrésc/Desc = ' . $billingItem->ajuste . ')' . '</td><td>' . number_format($billingItem->franquia, 0, '', '') . '</td><td>' . $billingItem->excedente . '</td><td>' . formatDecimal($billingItem->tarifaSobreExcedente, null) . '</td><td>' . formatBrCurrency($billingItem->fixo, 2) . '</td><td>' . formatBrCurrency($billingItem->variavel, 2) . '</td><td>' . formatBrCurrency($billingItem->total, 2) . '</td>';
    echo '<tr bgcolor="WHITE" >' . $rowData . '</tr>';
    $billingSummary = $totalContadores[$billingItem->counterId];
    $billingSummary->consumo += $billingItem->consumo;
    $billingSummary->franquia += $billingItem->franquia;