mirror of https://github.com/interlegis/sapl.git
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							230 lines
						
					
					
						
							8.6 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							230 lines
						
					
					
						
							8.6 KiB
						
					
					
				| # parameters=sessao,imagem,dat_ordem,lst_splen,lst_pauta,dic_cabecalho,lst_rodape | |
| 
 | |
| """relatorio_ordem.py | |
|    External method para gerar o arquivo rml da ordem do dia | |
|    Autor: Leandro Gasparotto Valladares | |
|    Empresa: Interlegis | |
|    versão: 1.0 | |
| """ | |
| import os | |
| import time | |
| 
 | |
| from trml2pdf import parseString | |
| 
 | |
| 
 | |
| def cabecalho(dic_cabecalho, dat_ordem, imagem): | |
|     """Gera o codigo rml do cabecalho""" | |
| 
 | |
|     tmp = '' | |
|     tmp += '\t\t\t\t<image x="2.1cm" y="25.7cm" width="59" height="62" file="' + \ | |
|         imagem + '"/>\n' | |
|     tmp += '\t\t\t\t<lines>2cm 25cm 19cm 25cm</lines>\n' | |
|     tmp += '\t\t\t\t<setFont name="Helvetica" size="12"/>\n' | |
|     #tmp+='\t\t\t\t<drawString x="4cm" y="27.2cm">' + str(dic_cabecalho['nom_casa']) + '</drawString>\n' | |
|     #tmp+='\t\t\t\t<setFont name="Helvetica" size="14"/>\n' | |
|     tmp += '\t\t\t\t<drawString x="5cm" y="27.2cm">' + \ | |
|         str(dic_cabecalho['nom_estado']) + '</drawString>\n' | |
|     tmp += '\t\t\t\t<setFont name="Helvetica" size="14"/>\n' | |
|     tmp += '\t\t\t\t<drawString x="5cm" y="26.5cm">' + \ | |
|         str(dic_cabecalho['nom_casa']) + '</drawString>\n' | |
|     tmp += '\t\t\t\t<setFont name="Helvetica" size="14"/>\n' | |
|     #tmp+='\t\t\t\t<drawString x="5cm" y="27.9cm">' + "Palacio 11 de Outubro" + '</drawString>\n' | |
|     #tmp+='\t\t\t\t<setFont name="Helvetica" size="10"/>\n' | |
| 
 | |
|     tmp += '\t\t\t\t<drawCentredString x="10.5cm" y="25.2cm">Relatório da Ordem do Dia</drawCentredString>\n' | |
| 
 | |
|     return tmp | |
| 
 | |
| 
 | |
| def rodape(lst_rodape): | |
|     """ Gera o codigo rml do rodape""" | |
| 
 | |
|     tmp = '' | |
|     tmp += '\t\t\t\t<lines>2cm 3.2cm 19cm 3.2cm</lines>\n' | |
|     tmp += '\t\t\t\t<setFont name="Helvetica" size="8"/>\n' | |
|     tmp += '\t\t\t\t<drawString x="2cm" y="3.3cm">' + \ | |
|         lst_rodape[2] + '</drawString>\n' | |
|     tmp += '\t\t\t\t<drawString x="17.9cm" y="3.3cm">Página <pageNumber/></drawString>\n' | |
|     tmp += '\t\t\t\t<drawCentredString x="10.5cm" y="2.7cm">' + \ | |
|         lst_rodape[0] + '</drawCentredString>\n' | |
|     tmp += '\t\t\t\t<drawCentredString x="10.5cm" y="2.3cm">' + \ | |
|         lst_rodape[1] + '</drawCentredString>\n' | |
| 
 | |
|     return tmp | |
| 
 | |
| 
 | |
| def paraStyle(): | |
|     """ Gera o codigo rml que define o estilo dos paragrafos""" | |
| 
 | |
|     tmp = '' | |
|     tmp += '\t<stylesheet>\n' | |
|     tmp += '\t\t<blockTableStyle id="Standard_Outline">\n' | |
|     tmp += '\t\t\t<blockAlignment value="LEFT"/>\n' | |
|     tmp += '\t\t\t<blockValign value="TOP"/>\n' | |
|     tmp += '\t\t</blockTableStyle>\n' | |
|     tmp += '\t\t<initialize>\n' | |
|     tmp += '\t\t\t<paraStyle name="all" alignment="justify"/>\n' | |
|     tmp += '\t\t</initialize>\n' | |
|     tmp += '\t\t<paraStyle name="P1" fontName="Helvetica-Bold" fontSize="12.0" leading="12" alignment="CENTER"/>\n' | |
|     tmp += '\t\t<paraStyle name="P2" fontName="Helvetica" fontSize="9.0" leading="10" alignment="LEFT"/>\n' | |
|     tmp += '\t\t<paraStyle name="P3" fontName="Helvetica" fontSize="10.0" leading="10" alignment="JUSTIFY"/>\n' | |
|     tmp += '\t</stylesheet>\n' | |
| 
 | |
|     return tmp | |
| 
 | |
| # def splen(lst_splen): | |
| 
 | |
| 
 | |
| def pauta(lst_splen, lst_pauta): | |
|     """ Funcao que gera o codigo rml da sessao plenaria """ | |
| 
 | |
|     tmp = '' | |
| 
 | |
|     # inicio do bloco | |
|     tmp += '\t<story>\n' | |
| 
 | |
|     for dicsp in lst_splen: | |
|         # espaço inicial | |
|         tmp += '\t\t<para style="P1">\n' | |
|         tmp += '\t\t\t<font color="white"> </font>\n' | |
|         tmp += '\t\t</para>\n' | |
|         tmp += '\t\t<para style="P1">\n' | |
|         tmp += '\t\t\t<font color="white"> </font>\n' | |
|         tmp += '\t\t</para>\n' | |
| 
 | |
|         # condicao para a quebra de pagina | |
|         tmp += '\t\t<condPageBreak height="4cm"/>\n' | |
| 
 | |
|         # sessao plenaria | |
|         if dicsp['sessao'] != None: | |
|             tmp += '\t\t<para style="P1">' + \ | |
|                 dicsp['sessao'].replace('&', '&') + '</para>\n' | |
|             tmp += '\t\t<para style="P1">\n' | |
|             tmp += '\t\t\t<font color="white"> </font>\n' | |
|             tmp += '\t\t</para>\n' | |
| 
 | |
|         if dicsp['datasessao'] != None: | |
|             tmp += '\t\t<para style="P1">' + \ | |
|                 dicsp['datasessao'].replace('&', '&') + '</para>\n' | |
|             tmp += '\t\t<para style="P1">\n' | |
|             tmp += '\t\t\t<font color="white"> </font>\n' | |
|             tmp += '\t\t</para>\n' | |
| 
 | |
| #    tmp+='\t</story>\n' | |
| #    return tmp | |
| # | |
| # def pauta(lst_pauta): | |
| #    """ Funcao que gera o codigo rml da pauta da ordem do dia""" | |
| 
 | |
| #    tmp='' | |
| 
 | |
|     # inicio do bloco que contem os flowables | |
| #    tmp+='\t<story>\n' | |
| 
 | |
|     for dic in lst_pauta: | |
|         # espaco inicial | |
|         tmp += '\t\t<para style="P2">\n' | |
|         tmp += '\t\t\t<font color="white"> </font>\n' | |
|         tmp += '\t\t</para>\n' | |
|         tmp += '\t\t<para style="P2">\n' | |
|         tmp += '\t\t\t<font color="white"> </font>\n' | |
|         tmp += '\t\t</para>\n' | |
| 
 | |
|         # condicao para a quebra de pagina | |
|         tmp += '\t\t<condPageBreak height="4cm"/>\n' | |
| 
 | |
|         # pauta | |
|         if dic['num_ordem'] != None: | |
|             tmp += '\t\t<para style="P2">Item nº ' + \ | |
|                 str(dic['num_ordem']) + '</para>' | |
|         if dic['id_materia'] != None: | |
|             tmp += '\t\t<para style="P1">' + dic['id_materia'] + '</para>\n' | |
|             tmp += '\t\t<para style="P1">\n' | |
|             tmp += '\t\t\t<font color="white"> </font>\n' | |
|             tmp += '\t\t</para>\n' | |
|         if dic['txt_ementa'] != None: | |
|             tmp += '\t\t<para style="P3">' + \ | |
|                 dic['txt_ementa'].replace('&', '&') + '</para>\n' | |
|             tmp += '\t\t<para style="P3">\n' | |
|             tmp += '\t\t\t<font color="white"> </font>\n' | |
|             tmp += '\t\t</para>\n' | |
|         if dic['des_numeracao'] != None: | |
|             tmp += '\t\t<para style="P2"><b>Processo:</b> ' + \ | |
|                 dic['des_numeracao'] + '</para>\n' | |
|         if dic['des_turno'] != None: | |
|             tmp += '\t\t<para style="P2"><b>Turno:</b> ' + \ | |
|                 dic['des_turno'] + '</para>\n' | |
|         if dic['nom_autor'] != None: | |
|             tmp += '\t\t<para style="P2"><b>Autor:</b> ' + \ | |
|                 dic['nom_autor'] + '</para>\n' | |
|         if dic['des_situacao'] != None: | |
|             tmp += '\t\t<para style="P2"><b>Situação:</b> ' + \ | |
|                 dic['des_situacao'] + '</para>\n' | |
| #       if dic['des_numeracao']!=None: | |
| #           tmp+='\t\t<para style="P2"><b>Processo Nº:</b> ' + dic['des_numeracao'] + '</para>\n' | |
| 
 | |
| 
 | |
| #        indice = 0 | |
| #        for relator in dic['lst_relator']: | |
| #            indice = indice + 1 | |
| #            if (relator != None): | |
| #                if (indice < 2): | |
| #                    tmp+='\t\t<xpre style="P2"><b>Relator</b>: ' + relator + '</xpre>\n' | |
| #                else: | |
| #                    tmp+='\t\t<pre style="P2">              ' + relator + '</pre>\n' | |
| 
 | |
|     tmp += '\t</story>\n' | |
|     return tmp | |
| 
 | |
| 
 | |
| def principal(imagem, lst_splen, lst_pauta, dic_cabecalho, lst_rodape): | |
|     """Funcao principal que gera a estrutura global do arquivo rml contendo o relatorio de uma ordem do dia. | |
|     ordem_dia_[data da ordem do dia do relatório].pdf | |
|     Retorna: | |
|     Parâmetros: | |
|     dat_ordem       => A data da ordem do dia. | |
|         splen       => Uma lista de dicionários contendo as sessões plenárias do dia. | |
|         pauta       => Uma lista de dicionários contendo a pauta da ordem do dia numa sessão plenária. | |
|         cabecalho   => Um dicionário contendo informações para o Cabeçalho do relatório, incluindo a imagem. | |
|         rodapé      => Uma lista contendo informações para o Rodapé do relatório. | |
|     """ | |
| 
 | |
|     arquivoPdf = str(int(time.time() * 100)) + ".pdf" | |
| 
 | |
|     tmp = '' | |
|     tmp += '<?xml version="1.0" encoding="utf-8" standalone="no" ?>\n' | |
|     tmp += '<!DOCTYPE document SYSTEM "rml_1_0.dtd">\n' | |
|     tmp += '<document filename="relatorio.pdf">\n' | |
|     tmp += '\t<template pageSize="(21cm, 29.7cm)" title="Relatorio de Materias" author="Interlegis" allowSplitting="20">\n' | |
|     tmp += '\t\t<pageTemplate id="first">\n' | |
|     tmp += '\t\t\t<pageGraphics>\n' | |
|     tmp += cabecalho(dic_cabecalho, dat_ordem, imagem) | |
|     tmp += rodape(lst_rodape) | |
|     tmp += '\t\t\t</pageGraphics>\n' | |
|     tmp += '\t\t\t<frame id="first" x1="2cm" y1="4cm" width="17cm" height="21cm"/>\n' | |
|     tmp += '\t\t</pageTemplate>\n' | |
|     tmp += '\t</template>\n' | |
|     tmp += paraStyle() | |
| #   tmp+=splen(lst_splen) | |
|     tmp += pauta(lst_splen, lst_pauta) | |
|     tmp += '</document>\n' | |
|     tmp_pdf = parseString(tmp) | |
| 
 | |
|     return tmp_pdf | |
| 
 | |
| # try: | |
| # tmp_pdf=parseString(unicode(tmp, 'utf-8')) | |
| # except: | |
| # tmp_pdf=parseString(unicode(tmp, 'utf-8')) | |
| 
 | |
| #     if hasattr(context.temp_folder, arquivoPdf): | |
| #         context.temp_folder.manage_delObjects(ids=arquivoPdf) | |
| #     context.temp_folder.manage_addFile(arquivoPdf) | |
| #     arq = context.temp_folder[arquivoPdf] | |
| #     arq.manage_edit(title='Arquivo PDF temporário.', | |
| #                     filedata=tmp_pdf, content_type='application/pdf') | |
| 
 | |
| #     return "/temp_folder/" + arquivoPdf | |
| 
 | |
| # return principal(sessao, imagem, dat_ordem, lst_splen, lst_pauta, | |
| # dic_cabecalho, lst_rodape)
 | |
| 
 |