##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+=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)