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