##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 cStringIO import StringIO
from trml2pdf import parseString
def cabecalho(dic_cabecalho,dat_ordem,imagem):
"""Gera o codigo rml do cabecalho"""
tmp=''
tmp+='\t\t\t\t\n'
tmp+='\t\t\t\t2cm 25cm 19cm 25cm\n'
tmp+='\t\t\t\t\n'
#tmp+='\t\t\t\t' + str(dic_cabecalho['nom_casa']) + '\n'
#tmp+='\t\t\t\t\n'
tmp+='\t\t\t\t' + str(dic_cabecalho['nom_estado']) + '\n'
tmp+='\t\t\t\t\n'
tmp+='\t\t\t\t' + str(dic_cabecalho['nom_casa']) + '\n'
tmp+='\t\t\t\t\n'
#tmp+='\t\t\t\t' + "Palacio 11 de Outubro" + '\n'
#tmp+='\t\t\t\t\n'
tmp+='\t\t\t\tRelatório da Ordem do Dia\n'
return tmp
def rodape(lst_rodape):
""" Gera o codigo rml do rodape"""
tmp=''
tmp+='\t\t\t\t2cm 3.2cm 19cm 3.2cm\n'
tmp+='\t\t\t\t\n'
tmp+='\t\t\t\t' + lst_rodape[2] + '\n'
tmp+='\t\t\t\tPágina \n'
tmp+='\t\t\t\t' + lst_rodape[0] + '\n'
tmp+='\t\t\t\t' + lst_rodape[1] + '\n'
return tmp
def paraStyle():
""" Gera o codigo rml que define o estilo dos paragrafos"""
tmp=''
tmp+='\t\n'
tmp+='\t\t\n'
tmp+='\t\t\t\n'
tmp+='\t\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\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\n'
for dicsp in lst_splen:
#espaço inicial
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
#condicao para a quebra de pagina
tmp+='\t\t\n'
#sessao plenaria
if dicsp['sessao']!=None:
tmp+='\t\t' + dicsp['sessao'].replace('&','&') + '\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
if dicsp['datasessao']!=None:
tmp+='\t\t' + dicsp['datasessao'].replace('&','&') + '\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
# tmp+='\t\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\n'
for dic in lst_pauta:
#espaco inicial
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
#condicao para a quebra de pagina
tmp+='\t\t\n'
#pauta
if dic['num_ordem']!=None:
tmp+='\t\tItem nº ' + str(dic['num_ordem']) + ''
if dic['id_materia']!=None:
tmp+='\t\t' + dic['id_materia'] + '\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
if dic['txt_ementa']!=None:
tmp+='\t\t' + dic['txt_ementa'].replace('&','&') + '\n'
tmp+='\t\t\n'
tmp+='\t\t\t \n'
tmp+='\t\t\n'
if dic['des_numeracao']!=None:
tmp+='\t\tProcesso: ' + dic['des_numeracao'] + '\n'
if dic['des_turno']!=None:
tmp+='\t\tTurno: ' + dic['des_turno'] + '\n'
if dic['nom_autor']!=None:
tmp+='\t\tAutor: ' + dic['nom_autor'] + '\n'
if dic['des_situacao']!=None:
tmp+='\t\tSituação: ' + dic['des_situacao'] + '\n'
# if dic['des_numeracao']!=None:
# tmp+='\t\tProcesso Nº: ' + dic['des_numeracao'] + '\n'
# indice = 0
# for relator in dic['lst_relator']:
# indice = indice + 1
# if (relator != None):
# if (indice < 2):
# tmp+='\t\tRelator: ' + relator + '\n'
# else:
# tmp+='\t\t ' + relator + '
\n'
tmp+='\t\n'
return tmp
def principal(sessao,imagem,dat_ordem,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+='\n'
tmp+='\n'
tmp+='\n'
tmp+='\t\n'
tmp+='\t\t\n'
tmp+='\t\t\t\n'
tmp+=cabecalho(dic_cabecalho,dat_ordem,imagem)
tmp+=rodape(lst_rodape)
tmp+='\t\t\t\n'
tmp+='\t\t\t\n'
tmp+='\t\t\n'
tmp+='\t\n'
tmp+=paraStyle()
# tmp+=splen(lst_splen)
tmp+=pauta(lst_splen, lst_pauta)
tmp+='\n'
tmp_pdf=parseString(tmp)
# 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)