/** * Gera pdf apartir dos valores retornados do action * * @param $aDados * @return object */ private function gerarPdf($aDados) { $aParametros = $this->getRequest()->getParams(); $sNomeArquivo = 'relatorio_nfse_periodo_' . date('YmdHis') . '.pdf'; $sCaminhoArquivo = TEMP_PATH . "/{$sNomeArquivo}"; $sFiltroPeriodo = $this->translate->_("De {$aParametros['data_nota_inicial']} até {$aParametros['data_nota_final']}"); $oFpdf = new Fiscal_Model_Relatoriopdfmodelo1('L'); $oFpdf->setLinhaFiltro($this->translate->_('Relatório de NFS-e por Período')); $oFpdf->setLinhaFiltro(''); $oFpdf->setLinhaFiltro($this->translate->_("FILTRO : {$sFiltroPeriodo}")); if (!empty($aParametros['natureza_operacao'])) { $sLabelNaturezaOperacao = $aParametros['natureza_operacao'] == 1 ? 'Tributação no Município' : 'Tributação Fora do Município'; $sFiltroNastureza = $this->translate->_("Natureza da operação: {$sLabelNaturezaOperacao}"); $oFpdf->setLinhaFiltro($sFiltroNastureza); } if (!empty($aParametros['s_dados_iss_retido'])) { $sLabelRetido = $aParametros['s_dados_iss_retido'] == 1 ? 'Sim' : 'Não'; $sFiltroRetido = $this->translate->_("Subst. Tributário (Retido): {$sLabelRetido}"); $oFpdf->setLinhaFiltro($sFiltroRetido); } $oFpdf->Open($sCaminhoArquivo); $oFpdf->carregadados(); $oFpdf->Ln(2); $oFpdf->SetFont('Arial', 'B', 8); $oFpdf->Cell(30, 5, utf8_decode($this->translate->_('Inscrição')), 1, 0, 'C', 1); $oFpdf->Cell(127, 5, utf8_decode($this->translate->_('Razão Social')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Qtd. Notas')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Valor Serviço')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Valor ISS')), 1, 1, 'C', 1); $iFundo = 0; $iTotalLiquido = 0; $iTotalISS = 0; $iTotalQtdNotas = 0; foreach ($aDados as $aNota) { $lFundoLinha = $iFundo++ % 2 == 0 ? 0 : 1; $iTotalQtdNotas = $iTotalQtdNotas + $aNota['notas']; $iTotalLiquido = $iTotalLiquido + $aNota['vl_liquido_nfse']; $iTotalISS = $iTotalISS + $aNota['s_vl_iss']; $sValorLiquido = 'R$ ' . number_format($aNota['vl_liquido_nfse'], 2, ',', '.'); $sValorISS = 'R$ ' . number_format($aNota['s_vl_iss'], 2, ',', '.'); $oFpdf->SetFont('Arial', '', 8); $oFpdf->Cell(30, 5, $aNota['p_im'], 1, 0, 'C', $lFundoLinha); $oFpdf->Cell(127, 5, $aNota['p_razao_social'], 1, 0, 'L', $lFundoLinha); $oFpdf->Cell(40, 5, $aNota['notas'], 1, 0, 'R', $lFundoLinha); $oFpdf->Cell(40, 5, $sValorLiquido, 1, 0, 'R', $lFundoLinha); $oFpdf->Cell(40, 5, $sValorISS, 1, 1, 'R', $lFundoLinha); $oFpdf->proximaPagina(1); if ($oFpdf->lQuebrouPagina) { $iFundo = 0; $oFpdf->SetFont('Arial', 'B', 8); $oFpdf->Cell(30, 5, utf8_decode($this->translate->_('Inscrição')), 1, 0, 'C', 1); $oFpdf->Cell(127, 5, utf8_decode($this->translate->_('Razão Social')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Qtd. Notas')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Valor Serviço')), 1, 0, 'C', 1); $oFpdf->Cell(40, 5, utf8_decode($this->translate->_('Valor ISS')), 1, 1, 'C', 1); } } $sTotalLiquido = 'R$ ' . number_format($iTotalLiquido, 2, ',', '.'); $sTotalISS = 'R$ ' . number_format($iTotalISS, 2, ',', '.'); $oFpdf->SetFont('Arial', 'B', 8); $oFpdf->Cell(157, 5, utf8_decode($this->translate->_('Totais')), 1, 0, 'R', 0); $oFpdf->Cell(40, 5, $iTotalQtdNotas, 1, 0, 'R', 0); $oFpdf->Cell(40, 5, $sTotalLiquido, 1, 0, 'R', 0); $oFpdf->Cell(40, 5, $sTotalISS, 1, 1, 'R', 0); $oFpdf->Output(); /** * Opções de retorno */ $aRetorno = array('location' => $sCaminhoArquivo, 'filename' => $sNomeArquivo, 'type' => 'application/pdf'); return (object) $aRetorno; }
/** * Geração do relatório de valores por atividade / serviço */ public function valoresAtividadeServicoGerarAction() { parent::noLayout(); try { $aValidacaoFormulario = self::validarFormulario(Fiscal_Form_Relatorio1::TIPO5); if (is_array($aValidacaoFormulario)) { exit($this->getHelper('json')->sendJson($aValidacaoFormulario)); } $sNomeArquivo = 'evolucao_arrecadacao_ ' . date('YmdHis') . '.pdf'; $sCaminhoArquivo = APPLICATION_PATH . "/../public/tmp/{$sNomeArquivo}"; $aParametros = $this->getRequest()->getParams(); $aFiltros = array('atividade_servico' => 'Atividade / Serviço'); $sOrdenacao = 'Crescente'; if (strtoupper($aParametros['ordem']) == 'DESC') { $sOrdenacao = 'Decrescente'; } $sFiltro = "Competência {$aParametros['data_competencia_inicial']} até {$aParametros['data_competencia_final']}"; $sOrdem = $aFiltros[$aParametros['ordenacao']] . " ({$sOrdenacao})"; $oFpdf = new Fiscal_Model_Relatoriopdfmodelo1('L'); $oFpdf->setLinhaFiltro('Relatório Evolução de Arrecadação por Atividade/Serviço'); $oFpdf->setLinhaFiltro(''); $oFpdf->setLinhaFiltro("FILTRO : {$sFiltro}"); $oFpdf->setLinhaFiltro("ORDEM : {$sOrdem}"); $oFpdf->Open($sCaminhoArquivo); $oFpdf->carregadados(); $aDataCompetenciaInicial = explode('/', $aParametros['data_competencia_inicial']); $aDataCompetenciaFinal = explode('/', $aParametros['data_competencia_final']); $sSql = "SELECT SUM(servico_valor_iss) AS valor_imposto,\n servico_codigo_cnae,\n documento_competencia_ano,\n documento_competencia_mes\n FROM view_nota_mais_dms\n WHERE documento_emite_guia = TRUE\n AND (dms_operacao = 's' OR dms_operacao IS NULL)\n AND documento_situacao NOT IN ('c', 'e')\n AND documento_status_cancelamento = FALSE\n AND (documento_competencia_ano || LPAD(CAST(documento_competencia_mes AS VARCHAR), 2, '0'))\n BETWEEN ? AND ?\n GROUP BY servico_codigo_cnae,\n documento_competencia_ano,\n documento_competencia_mes "; $aDadosRelatorio = array(); $oEntityManager = Zend_Registry::get('em'); $oConexao = $oEntityManager->getConnection(); $oStatement = $oConexao->prepare($sSql); $oStatement->execute(array("{$aDataCompetenciaInicial[1]}{$aDataCompetenciaInicial[0]}", "{$aDataCompetenciaFinal[1]}{$aDataCompetenciaFinal[0]}")); if ($oStatement->rowCount() < 1) { throw new Exception('Nenhum Registro encontrado.'); } while ($aNota = $oStatement->fetch()) { $oServicos = Contribuinte_Model_Servico::getServicoPorCnae($aNota['servico_codigo_cnae']); if (!$oServicos) { throw new Exception("Erro: {$aNota['servico_codigo_cnae']}"); } $sIndice = md5($aNota['servico_codigo_cnae'] . $oServicos->attr('atividade')); $aDadosRelatorio[$sIndice]['estrutural'] = $oServicos->attr('estrutural'); $aDadosRelatorio[$sIndice]['descricao'] = DBSeller_Helper_String_Format::wordsCap($oServicos->attr('atividade')); if (!isset($aDadosRelatorio[$sIndice]['totalAnoMes'][$aNota['documento_competencia_ano']][$aNota['documento_competencia_mes']])) { $aDadosRelatorio[$sIndice]['totalAnoMes'][$aNota['documento_competencia_ano']][$aNota['documento_competencia_mes']] = 0; } $aDadosRelatorio[$sIndice]['totalAnoMes'][$aNota['documento_competencia_ano']][$aNota['documento_competencia_mes']] += $aNota['valor_imposto']; if (!isset($aDadosRelatorio[$sIndice]['totalAcumulado'])) { $aDadosRelatorio[$sIndice]['totalAcumulado'] = 0; } $aDadosRelatorio[$sIndice]['totalAcumulado'] += $aNota['valor_imposto']; } switch ($aParametros['ordenacao']) { case 'atividade_servico': $sOrdenacao = 'estrutural'; break; case 'valor_total': $sOrdenacao = 'totalAcumulado'; break; } $iComprimentoPagina = $oFpdf->w - $oFpdf->rMargin - $oFpdf->lMargin; $aDadosRelatorio = DBSeller_Helper_Array_Abstract::ordenarPorIndice($aDadosRelatorio, $sOrdenacao, $aParametros['ordem'], TRUE); // Percorre os registros do relatório foreach ($aDadosRelatorio as $aRegistro) { $sAtividadeServico = "Atividade / Serviço: {$aRegistro['estrutural']} - {$aRegistro['descricao']}"; $oFpdf->SetFont('Arial', 'B', 8); $oFpdf->Cell($iComprimentoPagina, 5, utf8_decode($sAtividadeServico), 0, 1, 'J'); $oFpdf->SetFont('Arial', '', 8); $aMeses = DBSeller_Helper_Date_Date::getMesesArray(); $iTamanhoMes = $iComprimentoPagina / count($aMeses); // Ordena a lista pelo índice ksort($aRegistro['totalAnoMes']); // Percorre a lista pelo total por ano/mes foreach ($aRegistro['totalAnoMes'] as $iAno => $aAnos) { // Percorre os meses para gerar o cabeçalho de meses foreach ($aMeses as $iMes => $sDescricaoMes) { $oFpdf->SetFont('Arial', 'B', 8); $oFpdf->Cell($iTamanhoMes, 5, utf8_decode(substr($aMeses[$iMes], 0, 3)) . '/' . $iAno . '(R$)', 1, 0, 'C'); } $oFpdf->ln(); // Percorre os meses para gerar os dados por mês foreach ($aMeses as $iMes => $sMes) { $oFpdf->SetFont('Arial', '', 8); if (!empty($aAnos[$iMes])) { $oFpdf->Cell($iTamanhoMes, 5, DBSeller_Helper_Number_Format::toMoney($aAnos[$iMes], 2), 1, 0, 'R'); } else { $oFpdf->Cell($iTamanhoMes, 5, 'S / M', 1, 0, 'C'); } } $oFpdf->proximaPagina(1); if (!$oFpdf->lQuebrouPagina) { $oFpdf->Ln(6); } } if (!$oFpdf->lQuebrouPagina) { $oFpdf->Ln(2); } } $oFpdf->Output(); $aRetornoJson['status'] = TRUE; $aRetornoJson['url'] = $this->view->baseUrl('tmp/' . $sNomeArquivo); $aRetornoJson['success'] = $this->translate->_('Relatório gerado com sucesso.'); } catch (Exception $oErro) { $aRetornoJson['status'] = FALSE; $aRetornoJson['error'][] = $this->translate->_($oErro->getMessage()); } echo $this->getHelper('json')->sendJson($aRetornoJson); }