# parameters=sessao,imagem,data,lst_materias,dic_cabecalho,lst_rodape,dic_filtro
"""relatorio_materia.py
External method para gerar o arquivo rml do resultado de uma pesquisa de matérias
Autor: Leandro Gasparotto Valladares
Empresa: Interlegis
versão: 1.0
"""
import time
from trml2pdf import parseString
def cabecalho(dic_cabecalho, imagem):
"""Gera o codigo rml do cabecalho"""
tmp_data = ''
tmp_data += '\t\t\t\t\n'
tmp_data += '\t\t\t\t2cm 25cm 19cm 25cm\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\t' + \
dic_cabecalho['nom_estado'] + '\n'
tmp_data += '\t\t\t\t\n'
tmp_data += '\t\t\t\tSECRETARIA\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\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 materias(lst_materias):
"""Gera o codigo rml do conteudo da pesquisa de materias"""
tmp_data = ''
# inicio do bloco que contem os flowables
tmp_data += '\t\n'
for dic in lst_materias:
# 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'
# materias
# 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['materia'] != None:
tmp_data += '\t\t\n'
tmp_data += '\t\t\t \n'
tmp_data += '\t\t\n'
tmp_data += '\t\tINDICAÇÃO: ' + \
dic['materia'] + '\n'
tmp_data += '\t\t\n'
tmp_data += '\t\t\t \n'
tmp_data += '\t\t\n'
if dic['dat_apresentacao'] != None:
tmp_data += '\t\tDATA DE ENTRADA: ' + \
dic['dat_apresentacao'] + '\n'
tmp_data += '\t\t\n'
tmp_data += '\t\t\t \n'
tmp_data += '\t\t\n'
if dic['nom_autor'] != None:
tmp_data += '\t\tAUTOR: ' + \
dic['nom_autor'] + '\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\tEMENTA: ' + \
dic['txt_ementa'] + '\n'
tmp_data += '\t\t\n'
tmp_data += '\t\t\t \n'
tmp_data += '\t\t\n'
tmp_data += '\t\n'
return tmp_data
def principal(imagem, lst_materias, dic_cabecalho, lst_rodape):
"""Funcao pricipal que gera a estrutura global do arquivo rml"""
# if sessao:
# arquivoPdf=sessao+".pdf"
# else:
# arquivoPdf=str(int(time.time()*100))+".pdf"
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 += materias(lst_materias)
tmp_data += '\n'
tmp_pdf = parseString(tmp_data)
return tmp_pdf
# try:
# tmp_pdf=parseString(unicode(tmp_data, 'utf-8'))
# except:
# tmp_pdf=parseString(unicode(tmp_data, '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,data,lst_materias,dic_cabecalho,lst_rodape,dic_filtro)