|
|
|
##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 trml2pdf import parseString
|
|
|
|
|
|
|
|
|
|
|
|
def cabecalho(inf_basicas_dic,imagem):
|
|
|
|
"""Gera o codigo rml do cabecalho"""
|
|
|
|
tmp_data=''
|
|
|
|
tmp_data+='\t\t\t\t<image x="2.1cm" y="25.7cm" width="59" height="62" file="' + imagem + '"/>\n'
|
|
|
|
tmp_data+='\t\t\t\t<lines>2cm 25.4cm 19cm 25.4cm</lines>\n'
|
|
|
|
tmp_data+='\t\t\t\t<setFont name="Helvetica-Bold" size="15"/>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawString x="5cm" y="27.2cm">' + dic_cabecalho['nom_casa'] + '</drawString>\n'
|
|
|
|
tmp_data+='\t\t\t\t<setFont name="Helvetica" size="12"/>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawString x="5cm" y="26.6cm">Sistema de Apoio ao Processo Legislativo</drawString>\n'
|
|
|
|
tmp_data+='\t\t\t\t<setFont name="Helvetica-Bold" size="13"/>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawString x="2.2cm" y="24.6cm">Relatório de Normas Jurídicas</drawString>\n'
|
|
|
|
|
|
|
|
return tmp_data
|
|
|
|
|
|
|
|
def rodape(lst_rodape):
|
|
|
|
"""Gera o codigo rml do rodape"""
|
|
|
|
|
|
|
|
tmp_data=''
|
|
|
|
tmp_data+='\t\t\t\t<lines>2cm 3.2cm 19cm 3.2cm</lines>\n'
|
|
|
|
tmp_data+='\t\t\t\t<setFont name="Helvetica" size="8"/>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawString x="2cm" y="3.3cm">' + lst_rodape[2] + '</drawString>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawString x="17.9cm" y="3.3cm">Página <pageNumber/></drawString>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawCentredString x="10.5cm" y="2.7cm">' + lst_rodape[0] + '</drawCentredString>\n'
|
|
|
|
tmp_data+='\t\t\t\t<drawCentredString x="10.5cm" y="2.3cm">' + lst_rodape[1] + '</drawCentredString>\n'
|
|
|
|
|
|
|
|
return tmp_data
|
|
|
|
|
|
|
|
def paraStyle():
|
|
|
|
"""Gera o codigo rml que define o estilo dos paragrafos"""
|
|
|
|
|
|
|
|
tmp_data=''
|
|
|
|
tmp_data+='\t<stylesheet>\n'
|
|
|
|
tmp_data+='\t\t<blockTableStyle id="Standard_Outline">\n'
|
|
|
|
tmp_data+='\t\t\t<blockAlignment value="LEFT"/>\n'
|
|
|
|
tmp_data+='\t\t\t<blockValign value="TOP"/>\n'
|
|
|
|
tmp_data+='\t\t</blockTableStyle>\n'
|
|
|
|
tmp_data+='\t\t<initialize>\n'
|
|
|
|
tmp_data+='\t\t\t<paraStyle name="all" alignment="justify"/>\n'
|
|
|
|
tmp_data+='\t\t</initialize>\n'
|
|
|
|
tmp_data+='\t\t<paraStyle name="P1" fontName="Helvetica-Bold" fontSize="10.0" leading="10" alignment="CENTER"/>\n'
|
|
|
|
tmp_data+='\t\t<paraStyle name="P2" fontName="Helvetica" fontSize="10.0" leading="13" alignment="justify"/>\n'
|
|
|
|
tmp_data+='\t</stylesheet>\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<story>\n'
|
|
|
|
|
|
|
|
for dic in lst_normas:
|
|
|
|
#espaco inicial
|
|
|
|
tmp_data+='\t\t<para style="P2">\n'
|
|
|
|
tmp_data+='\t\t\t<font color="white"> </font>\n'
|
|
|
|
tmp_data+='\t\t</para>\n'
|
|
|
|
tmp_data+='\t\t<para style="P2">\n'
|
|
|
|
tmp_data+='\t\t\t<font color="white"> </font>\n'
|
|
|
|
tmp_data+='\t\t</para>\n'
|
|
|
|
|
|
|
|
#condicao para a quebra de pagina
|
|
|
|
tmp_data+='\t\t<condPageBreak height="4cm"/>\n'
|
|
|
|
|
|
|
|
#normas
|
|
|
|
if dic['titulo']!=None:
|
|
|
|
tmp_data+='\t\t<para style="P1">' + dic['titulo'] + '</para>\n'
|
|
|
|
tmp_data+='\t\t<para style="P1">\n'
|
|
|
|
tmp_data+='\t\t\t<font color="white"> </font>\n'
|
|
|
|
tmp_data+='\t\t</para>\n'
|
|
|
|
if dic['txt_ementa']!=None:
|
|
|
|
txt_ementa = dic['txt_ementa'].replace('&','&')
|
|
|
|
tmp_data+='\t\t<para style="P2">' + txt_ementa + '</para>\n'
|
|
|
|
if dic['materia_vinculada']!=None:
|
|
|
|
tmp_data+='\t\t<para style="P2"><b>Matéria Legislativa:</b> ' + dic['materia_vinculada'] + '</para>\n'
|
|
|
|
|
|
|
|
tmp_data+='\t</story>\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+='<?xml version="1.0" encoding="utf-8" standalone="no" ?>\n'
|
|
|
|
tmp_data+='<!DOCTYPE document SYSTEM "rml_1_0.dtd">\n'
|
|
|
|
tmp_data+='<document filename="relatorio.pdf">\n'
|
|
|
|
tmp_data+='\t<template pageSize="(21cm, 29.7cm)" title="Relatório de Normas Jurídicas" author="Luciano De Fazio" allowSplitting="20">\n'
|
|
|
|
tmp_data+='\t\t<pageTemplate id="first">\n'
|
|
|
|
tmp_data+='\t\t\t<pageGraphics>\n'
|
|
|
|
tmp_data+=cabecalho(dic_cabecalho,imagem)
|
|
|
|
tmp_data+=rodape(lst_rodape)
|
|
|
|
tmp_data+='\t\t\t</pageGraphics>\n'
|
|
|
|
tmp_data+='\t\t\t<frame id="first" x1="2cm" y1="3cm" width="17cm" height="21cm"/>\n'
|
|
|
|
tmp_data+='\t\t</pageTemplate>\n'
|
|
|
|
tmp_data+='\t</template>\n'
|
|
|
|
tmp_data+=paraStyle()
|
|
|
|
tmp_data+=normas(lst_normas)
|
|
|
|
tmp_data+='</document>\n'
|
|
|
|
tmp_pdf=parseString(tmp_data)
|
|
|
|
|
|
|
|
return tmp_pdf
|
|
|
|
|
|
|
|
# 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)
|