##parameters=sessao,imagem,data,lst_normas,dic_cabecalho,lst_rodape,dic_filtro
"""relatorio_norma.py
External method para gerar o arquivo rml do resultado de uma pesquisa de normas
Autor: Luciano De Fazio
Empresa: OpenLegis Consultoria
versão: 1.0
"""
import time
from cStringIO import StringIO
from trml2pdf import parseString
def cabecalho(inf_basicas_dic,imagem):
"""Gera o codigo rml do cabecalho"""
tmp_data=''
tmp_data+='\t\t\t\t\n'
tmp_data+='\t\t\t\t2cm 25.4cm 19cm 25.4cm\n'
tmp_data+='\t\t\t\t\n'
tmp_data+='\t\t\t\t' + dic_cabecalho['nom_casa'] + '\n'
tmp_data+='\t\t\t\t\n'
tmp_data+='\t\t\t\tSistema de Apoio ao Processo Legislativo\n'
tmp_data+='\t\t\t\t\n'
tmp_data+='\t\t\t\tRelatório de Normas Jurídicas\n'
return tmp_data
def rodape(lst_rodape):
"""Gera o codigo rml do rodape"""
tmp_data=''
tmp_data+='\t\t\t\t2cm 3.2cm 19cm 3.2cm\n'
tmp_data+='\t\t\t\t\n'
tmp_data+='\t\t\t\t' + lst_rodape[2] + '\n'
tmp_data+='\t\t\t\tPágina \n'
tmp_data+='\t\t\t\t' + lst_rodape[0] + '\n'
tmp_data+='\t\t\t\t' + lst_rodape[1] + '\n'
return tmp_data
def paraStyle():
"""Gera o codigo rml que define o estilo dos paragrafos"""
tmp_data=''
tmp_data+='\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\t\n'
tmp_data+='\t\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\n'
return tmp_data
def normas(lst_normas):
"""Gera o codigo rml do conteudo da pesquisa de normas"""
tmp_data=''
#inicio do bloco que contem os flowables
tmp_data+='\t\n'
for dic in lst_normas:
#espaco inicial
tmp_data+='\t\t\n'
tmp_data+='\t\t\t \n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\t \n'
tmp_data+='\t\t\n'
#condicao para a quebra de pagina
tmp_data+='\t\t\n'
#normas
if dic['titulo']!=None:
tmp_data+='\t\t' + dic['titulo'] + '\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\t \n'
tmp_data+='\t\t\n'
if dic['txt_ementa']!=None:
txt_ementa = dic['txt_ementa'].replace('&','&')
tmp_data+='\t\t' + txt_ementa + '\n'
if dic['materia_vinculada']!=None:
tmp_data+='\t\tMatéria Legislativa: ' + dic['materia_vinculada'] + '\n'
tmp_data+='\t\n'
return tmp_data
def principal(sessao,imagem,data,lst_normas,dic_cabecalho,lst_rodape,dic_filtro={}):
"""Funcao pricipal que gera a estrutura global do arquivo rml"""
arquivoPdf=str(int(time.time()*100))+".pdf"
tmp_data=''
tmp_data+='\n'
tmp_data+='\n'
tmp_data+='\n'
tmp_data+='\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\t\t\n'
tmp_data+=cabecalho(dic_cabecalho,imagem)
tmp_data+=rodape(lst_rodape)
tmp_data+='\t\t\t\n'
tmp_data+='\t\t\t\n'
tmp_data+='\t\t\n'
tmp_data+='\t\n'
tmp_data+=paraStyle()
tmp_data+=normas(lst_normas)
tmp_data+='\n'
tmp_pdf=parseString(tmp_data)
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,data,lst_normas,dic_cabecalho,lst_rodape,dic_filtro)